/*- * ============LICENSE_START========================================== * ONAP Portal * =================================================================== * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved. * =================================================================== * * Unless otherwise specified, all software contained herein is licensed * under the Apache License, Version 2.0 (the "License"); * you may not use this software 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. * * Unless otherwise specified, all documentation contained herein is licensed * under the Creative Commons License, Attribution 4.0 Intl. (the "License"); * you may not use this documentation except in compliance with the License. * You may obtain a copy of the License at * * https://creativecommons.org/licenses/by/4.0/ * * Unless required by applicable law or agreed to in writing, documentation * 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============================================ * * */ package org.onap.portalapp.portal.service; import org.apache.cxf.transport.http.HTTPException; import org.onap.portalapp.util.SystemType; public interface ApplicationsRestClientService { public T get(Class clazz, long app, String restPath) throws HTTPException; public String getIncomingJsonString(long appId, String restPath) throws HTTPException; public T post(Class clazz, long appId, Object payload, String restPath) throws HTTPException; public T post(Class clazz, long appId, Object payload, String restPath, SystemType type) throws HTTPException; public T put(Class clazz, long appId, Object payload, String restPath) throws HTTPException; /** * Sends a GET request to the specified application at the specified path. * This is a workaround for a problem triggered by a superclass/subclass * with identical field names. * * @param clazz * Expected response type * @param appId * Application ID * @param restPath * Path at the remote application * @param useJacksonMapper * If true, uses a com.fasterxml.jackson.databind.ObjectMapper to * translate the remote application response from JSON to an * object. Otherwise, uses a com.google.gson.Gson. * @return Instance of the specified class * @throws HTTPException */ public T get(Class clazz, long appId, String restPath, boolean useJacksonMapper) throws HTTPException; }