aboutsummaryrefslogtreecommitdiffstats
path: root/config-provisioning/src/main/java/com
diff options
context:
space:
mode:
authorjonmv <venstad@gmail.com>2022-04-08 22:26:37 +0200
committerjonmv <venstad@gmail.com>2022-04-08 22:26:37 +0200
commit1c27950698237c7ebe0f8ea7ed5848889d6b4759 (patch)
tree6748bfa41fac16ad9b22d0afba4d150b44414542 /config-provisioning/src/main/java/com
parentc5c330f63efb47dad355860db70bf3a89a737970 (diff)
Revert "Merge pull request #22068 from vespa-engine/jonmv/unify-hostname-classes"
This reverts commit 8aa4c83df5ce7843c040afa41706fcc7c3afd030, reversing changes made to f95ad44fae879da9db19f73eabe62c53baeb0c36.
Diffstat (limited to 'config-provisioning/src/main/java/com')
-rw-r--r--config-provisioning/src/main/java/com/yahoo/config/provision/HostName.java44
1 files changed, 34 insertions, 10 deletions
diff --git a/config-provisioning/src/main/java/com/yahoo/config/provision/HostName.java b/config-provisioning/src/main/java/com/yahoo/config/provision/HostName.java
index e55737da18d..04b15af51f2 100644
--- a/config-provisioning/src/main/java/com/yahoo/config/provision/HostName.java
+++ b/config-provisioning/src/main/java/com/yahoo/config/provision/HostName.java
@@ -1,23 +1,47 @@
// Copyright Yahoo. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
package com.yahoo.config.provision;
-import ai.vespa.http.DomainName;
-
-import static ai.vespa.validation.Validation.requireLength;
+import java.util.Objects;
/**
- * Hostnames match {@link #domainNamePattern}, and are restricted to 64 characters in length.
+ * A host name
*
- * @author jonmv
+ * @author mortent
*/
-public class HostName extends DomainName {
+public class HostName implements Comparable<HostName> {
+
+ private final String name;
+
+ private HostName(String name) {
+ this.name = name;
+ }
+
+ public String value() { return name; }
+
+ /** Create a {@link HostName} with a given name */
+ public static HostName from(String name) {
+ return new HostName(name);
+ }
+
+ @Override
+ public int hashCode() {
+ return name.hashCode();
+ }
+
+ @Override
+ public boolean equals(Object obj) {
+ if (!(obj instanceof HostName)) return false;
+ return Objects.equals(((HostName)obj).value(), value());
+ }
- private HostName(String value) {
- super(requireLength(value, "hostname length", 1, 64));
+ @Override
+ public String toString() {
+ return name;
}
- public static HostName of(String value) {
- return new HostName(value);
+ @Override
+ public int compareTo(HostName that) {
+ return this.name.compareTo(that.name);
}
}