All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.hpe.adm.nga.sdk.entities.get.GetEntities Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2016-2023 Open Text.
 *
 * The only warranties for products and services of Open Text and
 * its affiliates and licensors (“Open Text”) are as may be set forth
 * in the express warranty statements accompanying such products and services.
 * Nothing herein should be construed as constituting an additional warranty.
 * Open Text shall not be liable for technical or editorial errors or
 * omissions contained herein. The information contained herein is subject
 * to change without notice.
 *
 * Except as specifically indicated otherwise, this document contains
 * confidential information and a valid license is required for possession,
 * use or copying. If this work is provided to the U.S. Government,
 * consistent with FAR 12.211 and 12.212, Commercial Computer Software,
 * Computer Software Documentation, and Technical Data for Commercial Items are
 * licensed to the U.S. Government under vendor's standard commercial license.
 *
 * 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.
 */
package com.hpe.adm.nga.sdk.entities.get;

import com.hpe.adm.nga.sdk.APIMode;
import com.hpe.adm.nga.sdk.entities.OctaneCollection;
import com.hpe.adm.nga.sdk.model.EntityModel;
import com.hpe.adm.nga.sdk.network.OctaneHttpClient;
import com.hpe.adm.nga.sdk.network.OctaneRequest;
import com.hpe.adm.nga.sdk.query.Query;

/**
 * This class hold the GetEntities objects and serve all functions concern to REST
 * GetEntities.
 * 
* As of Octane version 12.60.60 only a limited number of fields are returned by default. Therefore the {@link #addFields(String...)} * method should be used. @see here for more information */ public class GetEntities { protected final OctaneRequest octaneRequest; public GetEntities(OctaneHttpClient octaneHttpClient, String urlDomain) { octaneRequest = new OctaneRequest(octaneHttpClient, urlDomain); } /** * 1. Request GetEntities Execution
* 2. Parse response to a new Collection object * @return a collection of entities models that have been retrieved */ public OctaneCollection execute() { return GetHelper.getInstance().getEntityModels(octaneRequest); } /** * 1. Request GetEntities Execution
using a custom api mode value * 2. Parse response to a new Collection object * @return a collection of entities models that have been retrieved */ public OctaneCollection execute(APIMode apiMode) { octaneRequest.addHeader(apiMode); OctaneCollection result = execute(); octaneRequest.removeHeader(apiMode); return result; } /** * Add Fields parameters * * @param fields An array of fields that will be part of the HTTP Request * @return GetEntities Object with new Fields parameters */ public GetEntities addFields(String... fields) { octaneRequest.getOctaneUrl().addFieldsParam(fields); return this; } /** * Add Limit parameter * * @param limit The entity limit * @return GetEntities Object with new limit parameter */ public GetEntities limit(int limit) { octaneRequest.getOctaneUrl().setLimitParam(limit); return this; } /** * Add offset parameter * * @param offset The entity limit offset * @return GetEntities Object with new offset parameter */ public GetEntities offset(int offset) { octaneRequest.getOctaneUrl().setOffsetParam(offset); return this; } /** * Add OrderBy parameters * * @param orderBy The string which determines how the entities should be ordered * @param asc - true=ascending/false=descending * @return GetEntities Object with new OrderBy parameters */ public GetEntities addOrderBy(String orderBy, boolean asc) { octaneRequest.getOctaneUrl().setOrderByParam(orderBy, asc); return this; } /** * @param query The query to use * @return The object */ public GetEntities query(Query query) { octaneRequest.getOctaneUrl().setDqlQueryParam(query); return this; } /** * Append a new path element, for special cases * @param path The new path section to be added * @return this */ public GetEntities addPath(String path) { octaneRequest.getOctaneUrl().getPaths().add(path); return this; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy