2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright (C) 2017 - 2018 AT&T Intellectual Property. All rights reserved.
6 * ================================================================================
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 * ============LICENSE_END=========================================================
21 package org.onap.so.client.graphinventory.entities.uri;
25 import org.onap.so.client.graphinventory.entities.uri.Depth;
26 import org.onap.so.client.graphinventory.GraphInventoryObjectType;
28 public interface GraphInventoryUri {
33 * By default GraphInventory enforces a depth of 1. Some objects can be told to retrieve objects nested beneath them
34 * by increasing this number.
36 * You can use 0 to restrict the returned information to only the object you requested You can use all to retrieve
37 * all nested objects (this should only be used if you really need a massive amount of information and are caching
43 public GraphInventoryUri depth(Depth depth);
46 * Makes client only return object fields, no relationships
50 public GraphInventoryUri nodesOnly(boolean nodesOnly);
52 public GraphInventoryUri queryParam(String name, String... values);
54 public GraphInventoryUri replaceQueryParam(String name, String... values);
56 public GraphInventoryUri resultIndex(int index);
58 public GraphInventoryUri resultSize(int size);
60 public GraphInventoryUri limit(int size);
62 public GraphInventoryUri clone();
65 * returns all key values of the URI as a map. Key names can be found in {@link GraphInventoryObjectType}
69 public Map<String, String> getURIKeys();
71 public GraphInventoryObjectType getObjectType();
73 public boolean equals(Object o);
75 public int hashCode();