diff options
author | Bjørn Christian Seime <bjorncs@yahooinc.com> | 2022-07-19 14:45:41 +0200 |
---|---|---|
committer | Bjørn Christian Seime <bjorncs@yahooinc.com> | 2022-07-20 13:56:33 +0200 |
commit | 91b46555d137dcdf73a534ba5fa10e07510eb0f9 (patch) | |
tree | b5d84e0d32f784512ec5fd70c889639828ad8e58 /security-utils/src/main/java/com/yahoo/security/tls/UriGlobPattern.java | |
parent | ff025feea342cabb764b8e9cc1bba34cafe09409 (diff) |
Merge Java package 'c.y.s.tls.{auth,json,policy}' into 'c.y.s.tls'
Facilitate improved encapsulation of Vespa mTLS related classes
Diffstat (limited to 'security-utils/src/main/java/com/yahoo/security/tls/UriGlobPattern.java')
-rw-r--r-- | security-utils/src/main/java/com/yahoo/security/tls/UriGlobPattern.java | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/security-utils/src/main/java/com/yahoo/security/tls/UriGlobPattern.java b/security-utils/src/main/java/com/yahoo/security/tls/UriGlobPattern.java new file mode 100644 index 00000000000..18d18a5ab3c --- /dev/null +++ b/security-utils/src/main/java/com/yahoo/security/tls/UriGlobPattern.java @@ -0,0 +1,42 @@ +// Copyright Yahoo. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root. +package com.yahoo.security.tls; + +import java.util.Objects; + +/** + * Pattern used for matching URIs in X.509 certificate subject alternative names. + * + * @author bjorncs + */ +class UriGlobPattern implements RequiredPeerCredential.Pattern { + + private final GlobPattern globPattern; + + UriGlobPattern(String globPattern) { + this.globPattern = new GlobPattern(globPattern, new char[] {'/'}, false); + } + + @Override public String asString() { return globPattern.asString(); } + + @Override public boolean matches(String fieldValue) { return globPattern.matches(fieldValue); } + + @Override + public String toString() { + return "UriPattern{" + + "pattern='" + globPattern + '\'' + + '}'; + } + + @Override + public boolean equals(Object o) { + if (this == o) return true; + if (o == null || getClass() != o.getClass()) return false; + UriGlobPattern that = (UriGlobPattern) o; + return Objects.equals(globPattern, that.globPattern); + } + + @Override + public int hashCode() { + return Objects.hash(globPattern); + } +} |