aboutsummaryrefslogtreecommitdiffstats
path: root/security-utils/src/main/java/com/yahoo/security/tls/Capability.java
diff options
context:
space:
mode:
authorBjørn Christian Seime <bjorncs@yahooinc.com>2022-07-19 14:45:41 +0200
committerBjørn Christian Seime <bjorncs@yahooinc.com>2022-07-20 13:56:33 +0200
commit91b46555d137dcdf73a534ba5fa10e07510eb0f9 (patch)
treeb5d84e0d32f784512ec5fd70c889639828ad8e58 /security-utils/src/main/java/com/yahoo/security/tls/Capability.java
parentff025feea342cabb764b8e9cc1bba34cafe09409 (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/Capability.java')
-rw-r--r--security-utils/src/main/java/com/yahoo/security/tls/Capability.java32
1 files changed, 32 insertions, 0 deletions
diff --git a/security-utils/src/main/java/com/yahoo/security/tls/Capability.java b/security-utils/src/main/java/com/yahoo/security/tls/Capability.java
new file mode 100644
index 00000000000..0ae253985a6
--- /dev/null
+++ b/security-utils/src/main/java/com/yahoo/security/tls/Capability.java
@@ -0,0 +1,32 @@
+// 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.Arrays;
+
+/**
+ * @author bjorncs
+ */
+public enum Capability {
+ CONTENT__CLUSTER_CONTROLLER__INTERNAL_STATE_API("vespa.content.cluster_controller.internal_state_api"),
+ CONTENT__DOCUMENT_API("vespa.content.document_api"),
+ CONTENT__METRICS_API("vespa.content.metrics_api"),
+ CONTENT__SEARCH_API("vespa.content.search_api"),
+ CONTENT__STATUS_PAGES("vespa.content.status_pages"),
+ CONTENT__STORAGE_API("vespa.content.storage_api"),
+ SLOBROK__API("vespa.slobrok.api"),
+ ;
+
+ private final String name;
+
+ Capability(String name) { this.name = name; }
+
+ public String asString() { return name; }
+
+ public static Capability fromName(String name) {
+ return Arrays.stream(values())
+ .filter(c -> c.name.equals(name))
+ .findAny().orElseThrow(() ->
+ new IllegalArgumentException("Cannot find predefined capability set with name '" + name + "'"));
+ }
+
+}