Browse Source
Remove caching variant of MongoClientEncryption. Rename types for consistent key alt name scheme. Rename annotation to ExplicitEncrypted. Add package-info. Improve documentation wording. Reduce visibility of KeyId and KeyAltName to package-private. Original pull request: #4302 See: #4284pull/4309/merge
21 changed files with 427 additions and 368 deletions
@ -0,0 +1,7 @@
@@ -0,0 +1,7 @@
|
||||
/** |
||||
* Converters integrating with |
||||
* <a href="https://www.mongodb.com/docs/manual/core/csfle/fundamentals/manual-encryption/">explicit encryption |
||||
* mechanism of Client-Side Field Level Encryption</a>. |
||||
*/ |
||||
@org.springframework.lang.NonNullApi |
||||
package org.springframework.data.mongodb.core.convert.encryption; |
||||
@ -0,0 +1,54 @@
@@ -0,0 +1,54 @@
|
||||
/* |
||||
* Copyright 2023 the original author or authors. |
||||
* |
||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||
* you may not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* https://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
package org.springframework.data.mongodb.core.encryption; |
||||
|
||||
import org.springframework.util.ObjectUtils; |
||||
|
||||
record KeyAltName(String value) implements EncryptionKey { |
||||
|
||||
@Override |
||||
public Type type() { |
||||
return Type.ALT; |
||||
} |
||||
|
||||
@Override |
||||
public String toString() { |
||||
|
||||
if (value().length() <= 3) { |
||||
return "KeyAltName('***')"; |
||||
} |
||||
return String.format("KeyAltName('%s***')", value.substring(0, 3)); |
||||
} |
||||
|
||||
@Override |
||||
public boolean equals(Object o) { |
||||
|
||||
if (this == o) { |
||||
return true; |
||||
} |
||||
if (o == null || getClass() != o.getClass()) { |
||||
return false; |
||||
} |
||||
|
||||
KeyAltName that = (KeyAltName) o; |
||||
return ObjectUtils.nullSafeEquals(value, that.value); |
||||
} |
||||
|
||||
@Override |
||||
public int hashCode() { |
||||
return ObjectUtils.nullSafeHashCode(value); |
||||
} |
||||
} |
||||
@ -0,0 +1,59 @@
@@ -0,0 +1,59 @@
|
||||
/* |
||||
* Copyright 2023 the original author or authors. |
||||
* |
||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||
* you may not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* https://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
package org.springframework.data.mongodb.core.encryption; |
||||
|
||||
import org.bson.BsonBinary; |
||||
import org.bson.BsonBinarySubType; |
||||
import org.springframework.util.ObjectUtils; |
||||
|
||||
record KeyId(BsonBinary value) implements EncryptionKey { |
||||
|
||||
@Override |
||||
public Type type() { |
||||
return Type.ID; |
||||
} |
||||
|
||||
@Override |
||||
public String toString() { |
||||
|
||||
if (BsonBinarySubType.isUuid(value.getType())) { |
||||
String representation = value.asUuid().toString(); |
||||
if (representation.length() > 6) { |
||||
return String.format("KeyId('%s***')", representation.substring(0, 6)); |
||||
} |
||||
} |
||||
return "KeyId('***')"; |
||||
} |
||||
|
||||
@Override |
||||
public boolean equals(Object o) { |
||||
|
||||
if (this == o) { |
||||
return true; |
||||
} |
||||
if (o == null || getClass() != o.getClass()) { |
||||
return false; |
||||
} |
||||
|
||||
org.springframework.data.mongodb.core.encryption.KeyId that = (org.springframework.data.mongodb.core.encryption.KeyId) o; |
||||
return ObjectUtils.nullSafeEquals(value, that.value); |
||||
} |
||||
|
||||
@Override |
||||
public int hashCode() { |
||||
return ObjectUtils.nullSafeHashCode(value); |
||||
} |
||||
} |
||||
@ -0,0 +1,6 @@
@@ -0,0 +1,6 @@
|
||||
/** |
||||
* Infrastructure for <a href="https://www.mongodb.com/docs/manual/core/csfle/fundamentals/manual-encryption/">explicit |
||||
* encryption mechanism of Client-Side Field Level Encryption</a>. |
||||
*/ |
||||
@org.springframework.lang.NonNullApi |
||||
package org.springframework.data.mongodb.core.encryption; |
||||
Loading…
Reference in new issue