com.adobe.acs.commons.adobeio.service.EndpointService Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of acs-aem-commons-bundle Show documentation
Show all versions of acs-aem-commons-bundle Show documentation
Main ACS AEM Commons OSGi Bundle. Includes commons utilities.
The newest version!
/* * ACS AEM Commons * * Copyright (C) 2013 - 2023 Adobe * * 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.adobe.acs.commons.adobeio.service; import java.util.Map; import com.google.gson.JsonObject; import org.osgi.annotation.versioning.ProviderType; /** * This is the interface for the EndpointService.
*/ @ProviderType public interface EndpointService { /** * The id of the endpoint that is defined via the configuration * * @return The ID of the endpoint */ String getId(); /** * The method of the endpoint that is defined via the configuration * * @return The method of the endpoint */ String getMethod(); /** * The url of the endpoint that is defined via the configuration * * @return The url of this endpoint */ String getUrl(); /** * Performs the action connected to the endpoint. * * @return JsonObject containing the result of the action */ JsonObject performIO_Action(); /** * Performs the action connected to the endpoint. * With the parameters you can influence all the aspects of the api-call. * * @param url the url of the api call, the url can include queryparameter * @param method the method of the api call, like GET or POST * @param headers headers that need to passed to the api, on top of the authentication headers * @param payload an optional payload for the api-call * * @return JsonObject containing the result of the action */ JsonObject performIO_Action(String url, String method, String[] headers, JsonObject payload ); /** * Performs the action connected to the endpoint, with the specified queryParameters. * * @param queryParameters query parameters to pass to the endpoint * @return JsonObject containing the result of the action */ JsonObject performIO_Action(Map
* Using this service, the calling component can post to and retrieve from the endpoint.
* All the plumbing around authentication will be taken care of.
* * Example how to use the service in your custom code:
* {@code @Reference(target="(id=yourEndpointId)")}
* {@code private EndpointService endpointService;} *queryParameters); /** * Performs the action connected to the endpoint with the specified payload. * @param payload JsonObject containing the data that is used in the action * @return JsonObject containing the result of the action */ JsonObject performIO_Action(JsonObject payload); /** * This is a test for the connection to the endpoint. * The test will be performed using the URL and the GET-method. * @return TRUE if connection is successful */ boolean isConnected(); /** * Gets the headers that are set via the configuration. * * @return an array with the headers, in the format <name:value> */ String[] getConfigServiceSpecificHeaders(); }
© 2015 - 2025 Weber Informatics LLC | Privacy Policy