From bfaa9c16b35545e36e98c3ed67199177040e999c Mon Sep 17 00:00:00 2001 From: Valerij Fredriksen Date: Mon, 11 Feb 2019 13:20:57 +0100 Subject: Move CloudName to config-provisioning --- .../java/com/yahoo/config/provision/CloudName.java | 60 ++++++++++++++++++++++ 1 file changed, 60 insertions(+) create mode 100644 config-provisioning/src/main/java/com/yahoo/config/provision/CloudName.java (limited to 'config-provisioning/src') diff --git a/config-provisioning/src/main/java/com/yahoo/config/provision/CloudName.java b/config-provisioning/src/main/java/com/yahoo/config/provision/CloudName.java new file mode 100644 index 00000000000..53e00373713 --- /dev/null +++ b/config-provisioning/src/main/java/com/yahoo/config/provision/CloudName.java @@ -0,0 +1,60 @@ +// 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; + +import java.util.Objects; + +/** + * Represents a cloud provider used in a hosted Vespa system. + * + * @author mpolden + */ +public class CloudName implements Comparable { + + private final static CloudName defaultCloud = from("default"); + + private final String cloud; + + private CloudName(String cloud) { + this.cloud = cloud; + } + + public String value() { + return cloud; + } + + public boolean isDefault() { + return defaultName().equals(this); + } + + public static CloudName defaultName() { + return defaultCloud; + } + + public static CloudName from(String cloud) { + return new CloudName(cloud); + } + + @Override + public boolean equals(Object o) { + if (this == o) return true; + if (o == null || getClass() != o.getClass()) return false; + CloudName cloudName = (CloudName) o; + return Objects.equals(cloud, cloudName.cloud); + } + + @Override + public int hashCode() { + return Objects.hash(cloud); + } + + @Override + public String toString() { + return cloud; + } + + @Override + public int compareTo(CloudName o) { + return cloud.compareTo(o.cloud); + } + +} -- cgit v1.2.3