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

com.identityx.clientSDK.repositories.BaseRepository Maven / Gradle / Ivy

There is a newer version: 5.6.0.2
Show newest version
/*
* Copyright Daon.
*
* 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.identityx.clientSDK.repositories;

import org.apache.http.conn.ssl.SSLConnectionSocketFactory;

import com.daon.identityx.rest.model.def.IRestResource;
import com.daon.identityx.rest.model.pojo.RestCollection;
import com.identityx.auth.def.IApiKey;
import com.identityx.auth.impl.QueryString;
import com.identityx.clientSDK.base.RestClient;
import com.identityx.clientSDK.exceptions.IdxRestException;
import com.identityx.clientSDK.queryHolders.QueryHolder;


/**
 * Base class for creating a repository for a particular entity type.
 * A repository is a client abstraction used to access a set of Rest services related to an entity type.
 *
 * @param  type of an entity. Entities implement {@link IRestResource} 
 * @param  type of an entity collection. Entity collections implement {@link com.daon.identityx.rest.model.pojo.RestCollection} 
 */
public class BaseRepository, V extends QueryHolder> {

	private String baseUrl;
	private Class type;
	private Class collectionClass;
	private String resourcePath;
	private RestClient restClient = new RestClient(); 
	
	
	/**
	 * 
	 * @param type entity type
	 * @param collectionClass entity collection type
	 */
	public BaseRepository(Class type, Class collectionClass) {
		this.type = type;
		this.collectionClass = collectionClass;
	}

	public void init(RestClient restClient, String baseUrl) {
		this.restClient = restClient;
		this.baseUrl = baseUrl;
	}

	public void init(RestClient restClient, String baseUrl, String resourcePath) {
		this.restClient = restClient;
		this.baseUrl = baseUrl;
		this.resourcePath = resourcePath;
	}
	
	/**
	 * Initialises the repository.
	 * 
	 * @param apiKey key used to access the Rest resources
	 * @param baseUrl the url of the Rest service, resourcePath is appended to this to create the resource url
	 */
	public void init(IApiKey apiKey, String baseUrl, SSLConnectionSocketFactory sslCSF) {
		getRestClient().init(apiKey, sslCSF);
		this.baseUrl = baseUrl;
	}

	/**
	 * Initialises the repository.
	 * 
	 * @param apiKey used to access the Rest resources
	 * @param baseUrl the url of the Rest service, resourcePath is appended to this to create the resource url 
	 * @param cookie required when the token used is a session token; cookie is obtained at the same time with the session token
	 * @param resourcePath path of the resource, to be appended to the baseUrl
	 */
	public void init(IApiKey apiKey, String baseUrl, String cookie, String resourcePath, SSLConnectionSocketFactory sslCSF) {
		this.resourcePath = resourcePath;
		init(apiKey, baseUrl, sslCSF);
		getRestClient().setCookie(cookie);
	}	
	
	/**
	 * Initialises the repository.
	 * 
	 * @param apiKey used to access the Rest resources
	 * @param baseUrl url of the Rest service, resourcePath is appended to this to create the resource url
	 * @param cookie required when the token used is a session token; cookie is obtained at the same time with the session token
	 */
	public void init(IApiKey apiKey, String baseUrl, String cookie, SSLConnectionSocketFactory sslCSF) {
		init(apiKey, baseUrl, sslCSF);
		getRestClient().setCookie(cookie);
	}
	
	/**
	 * 
	 * @return url of the Rest service, resourcePath is appended to this to create the resource url
	 */
	public String getBaseUrl() {
		return baseUrl;
	}
			
	/**
	 * 
	 * @param baseUrl url of the Rest service, resourcePath is appended to this to create the resource url
	 */
	public void setBaseUrl(String baseUrl) {
		this.baseUrl = baseUrl;
	}
				
	/**
	 * Creates a new entity
	 * 
	 * @param entity to create
	 * @return the created entity
	 */
	public T create(T entity) throws IdxRestException {
		T result = getRestClient().post(entity, getBaseUrl() + "/" + getResourcePath(), type);
		return result;
	}
	
	/**
	 * updates an entity
	 * 
	 * @param entity to update
	 * @return the updated entity
	 */
	public T update(T entity) throws IdxRestException {
		T result = getRestClient().post(entity, entity.getHref(), type);
		return result;
	}

	/**
	 * Gets a resource from a specified location
	 * 
	 * @param href an absolute url of the resource
	 * @return a resource of type T
	 */ 	
	public T get(String href) throws IdxRestException {
		T result = getRestClient().get(new QueryString(), href, type);
		return result;		
	}

	/**
	 * Gets a resource for the specified unique id
	 * 
	 * @param id of the resource
	 * @return a resource of type T
	 */ 	
	public T getById(String id) throws IdxRestException {
		String href = getBaseUrl() + "/" + getResourcePath() + "/" + id;
		T result = getRestClient().get(new QueryString(), href, type);
		return result;		
	}

	
	
	
	/**
	 * Gets a resource from a specified location
	 * 
	 * @param href an absolute url of the resource
	 * @param queryString an object containing various name-value pairs to be included in the http query string. Can be null null. See {@link QueryString}
	 * @return a resource of type T
	 */ 
	public T get(String href, QueryString queryString) throws IdxRestException {
		T result = getRestClient().get(queryString, href, type);
		return result;		
	}	
		
	/**
	 * Lists resources from a specified location
	 * 
	 * @param href an absolute url of the resource list
	 * @param queryHolder an object specifying various options for the list operation. See {@link QueryHolder}
	 * @return a collection of resources of type U, extends {@link RestCollection}
	 */
	public U list(String href, V queryHolder) throws IdxRestException {
		U result = getRestClient().list(queryHolder, href, collectionClass);
		return result;		
	}	

	/**
	 * Lists resources from the default location
	 * 
	 * @param queryHolder an object specifying various options for the list operation. See {@link QueryHolder}
	 * @return a collection of resources of type U, extends {@link RestCollection}
	 */ 	
	public U list(V queryHolder) throws IdxRestException {
		U result = getRestClient().list(queryHolder, getBaseUrl() + "/" + getResourcePath(), collectionClass);
		return result;		
	}

	/**
	 * Blocks an entity. Blocked entities cannot be updated but can be unblocked.
	 * Also, entities that have one or more blocked parents cannot be updated either. 
	 * 
	 * @param entity to block
	 * @return the blocked entity
	 * @throws IdxRestException
	 */
	public T block(T entity) throws IdxRestException {
		T result = getRestClient().post(null, entity.getHref() + "/blocked", type);
		return result;
	}

	/**
	 * Unblocks an entity. Will raise an exception if already blocked.
	 * 
	 * @param entity to be unblocked
	 * @return the unblocked entity
	 * @throws IdxRestException
	 */
	public T unblock(T entity) throws IdxRestException {
		T result = getRestClient().delete(entity.getHref() + "/blocked", type);
		return result;
	}
	
	/**
	 * Archives an entity. Archived entities become permanently read-only.
	 * 
	 * @param entity to be archived.
	 * @return the archived entity.
	 * @throws IdxRestException
	 */
	public T archive(T entity) throws IdxRestException {
		T result = getRestClient().post(null, entity.getHref() + "/archived", type);
		return result;
	}

	/**
	 * 
	 * @return path of the resource, to be appended to the baseUrl
	 */
	public String getResourcePath() {
		return resourcePath;
	}

	/**
	 * 
	 * @param resourcePath path of the resource, to be appended to the baseUrl
	 */
	public void setResourcePath(String resourcePath) {
		this.resourcePath = resourcePath;
	}

	/**
	 * 
	 * @return the {@link RestClient} used to perform the Rest calls
	 */
	public RestClient getRestClient() {
		return restClient;
	}

	/**
	 * 
	 * @param restClient {@link RestClient} used to perform the Rest calls
	 */
	public void setRestClient(RestClient restClient) {
		this.restClient = restClient;
	}

}