aboutsummaryrefslogtreecommitdiffstats
path: root/config-provisioning
diff options
context:
space:
mode:
authorHÃ¥kon Hallingstad <hakon.hallingstad@gmail.com>2022-12-06 13:53:50 +0100
committerGitHub <noreply@github.com>2022-12-06 13:53:50 +0100
commitc415b8fdb0974f04c489d46f4c82c2bd001296d9 (patch)
treef04d23d19998909d239ea59522dd284a4674530d /config-provisioning
parentb01ebe82c392cd08c2cfe736049ad3d61d91e2b5 (diff)
parent268b74729c9c3ff74806875e05f52585000b4b9d (diff)
Merge pull request #25120 from vespa-engine/hakonhall/limit-fields-allowed-to-be-patched-from-tenant-host
Limit fields allowed to be patched from tenant host
Diffstat (limited to 'config-provisioning')
-rw-r--r--config-provisioning/src/main/java/com/yahoo/config/provision/security/NodePrincipal.java51
1 files changed, 51 insertions, 0 deletions
diff --git a/config-provisioning/src/main/java/com/yahoo/config/provision/security/NodePrincipal.java b/config-provisioning/src/main/java/com/yahoo/config/provision/security/NodePrincipal.java
new file mode 100644
index 00000000000..7e58c9c15ac
--- /dev/null
+++ b/config-provisioning/src/main/java/com/yahoo/config/provision/security/NodePrincipal.java
@@ -0,0 +1,51 @@
+// Copyright 2018 Yahoo Holdings. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
+package com.yahoo.config.provision.security;
+
+import java.security.Principal;
+import java.util.Objects;
+
+/**
+ * Represents the identity of a hosted Vespa node
+ *
+ * @author bjorncs
+ */
+public class NodePrincipal implements Principal {
+
+ private final NodeIdentity identity;
+
+ public NodePrincipal(NodeIdentity identity) {
+ this.identity = identity;
+ }
+
+ public NodeIdentity getIdentity() {
+ return identity;
+ }
+
+ @Override
+ public String getName() {
+ StringBuilder builder = new StringBuilder(identity.nodeType().name());
+ identity.hostname().ifPresent(hostname -> builder.append('/').append(hostname.value()));
+ identity.applicationId().ifPresent(applicationId -> builder.append('/').append(applicationId.toShortString()));
+ return builder.toString();
+ }
+
+ @Override
+ public String toString() {
+ return "NodePrincipal{" +
+ "identity=" + identity +
+ '}';
+ }
+
+ @Override
+ public boolean equals(Object o) {
+ if (this == o) return true;
+ if (o == null || getClass() != o.getClass()) return false;
+ NodePrincipal that = (NodePrincipal) o;
+ return Objects.equals(identity, that.identity);
+ }
+
+ @Override
+ public int hashCode() {
+ return Objects.hash(identity);
+ }
+}