[AAI-80 Amsterdam] checking in source code
[aai/champ.git] / src / main / java / org / openecomp / aai / champ / model / ChampObjectIndex.java
diff --git a/src/main/java/org/openecomp/aai/champ/model/ChampObjectIndex.java b/src/main/java/org/openecomp/aai/champ/model/ChampObjectIndex.java
new file mode 100644 (file)
index 0000000..9b588c7
--- /dev/null
@@ -0,0 +1,87 @@
+/**
+ * ============LICENSE_START==========================================
+ * org.onap.aai
+ * ===================================================================
+ * Copyright © 2017 AT&T Intellectual Property. All rights reserved.
+ * Copyright © 2017 Amdocs
+ * ===================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *        http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END============================================
+ * ECOMP is a trademark and service mark of AT&T Intellectual Property.
+ */
+package org.openecomp.aai.champ.model;
+
+import org.openecomp.aai.champ.model.fluent.index.CreateObjectIndexable;
+import org.openecomp.aai.champ.model.fluent.index.impl.CreateObjectIndexableImpl;
+
+public final class ChampObjectIndex {
+
+       private final String name;
+       private final String type;
+       private final ChampField field;
+
+       public static CreateObjectIndexable create() {
+               return new CreateObjectIndexableImpl();
+       }
+
+       private ChampObjectIndex() {
+               throw new RuntimeException("Cannot call ChampObjectIndex() constructor");
+       }
+
+       private ChampObjectIndex(Builder builder) {
+               this.name = builder.name;
+               this.type = builder.type;
+               this.field = builder.field;
+       }
+
+       public String getName() { return name; }
+       public String getType() { return type; }
+       public ChampField getField() { return field; }
+
+       public static class Builder {
+               private final String name;
+               private final String type;
+               private final ChampField field;
+
+               public Builder(String name, String type, ChampField field) {
+                       this.name = name;
+                       this.type = type;
+                       this.field = field;
+               }
+
+               public ChampObjectIndex build() {
+                       return new ChampObjectIndex(this);
+               }
+       }
+
+       @Override
+       public String toString() {
+               return "{name: " + getName()
+                       + ", type: " + getType()
+                       + ", field: " + getField() + "}";
+       }
+
+       @Override
+       public boolean equals(Object object) {
+               if (this == object) return true;
+               
+               if (object instanceof ChampObjectIndex) {
+                       final ChampObjectIndex objectIndex = (ChampObjectIndex) object;
+                       
+                       if (getName().equals(objectIndex.getName()) &&
+                               getField().getName().equals(objectIndex.getField().getName())) return true;
+               }
+               
+               return false;
+       }
+}