diff options
author | HÃ¥kon Hallingstad <hakon.hallingstad@gmail.com> | 2022-12-06 13:53:50 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-12-06 13:53:50 +0100 |
commit | c415b8fdb0974f04c489d46f4c82c2bd001296d9 (patch) | |
tree | f04d23d19998909d239ea59522dd284a4674530d /config-provisioning | |
parent | b01ebe82c392cd08c2cfe736049ad3d61d91e2b5 (diff) | |
parent | 268b74729c9c3ff74806875e05f52585000b4b9d (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.java | 51 |
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); + } +} |