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

com.identityx.clientSDK.repositories.RegistrationChallengeRepository 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 java.util.HashMap;

import com.daon.identityx.rest.model.def.ResourcePaths;
import com.daon.identityx.rest.model.pojo.RegistrationChallenge;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.identityx.auth.impl.QueryString;
import com.identityx.clientSDK.collections.RegistrationChallengeCollection;
import com.identityx.clientSDK.exceptions.IdxRestException;
import com.identityx.clientSDK.expandSpecs.RegistrationChallengeExpandSpecForGet;
import com.identityx.clientSDK.queryHolders.QueryHolder;
import com.identityx.clientSDK.queryHolders.SensitiveDataSpec;


/**
 * 
 * repository for the RegistrationChallenge entity
 *
 */
public class RegistrationChallengeRepository extends BaseRepository {

	public RegistrationChallengeRepository() {
		super(RegistrationChallenge.class, RegistrationChallengeCollection.class);
		setResourcePath(ResourcePaths.defaultRegistrationChallengePath);
	}
	
	@Override
	public RegistrationChallengeCollection list(QueryHolder queryHolder) throws IdxRestException {
		throw new UnsupportedOperationException("Use TokenRepository");
	}

	/**
	 * Executes a get operation on a Rest service
	 * @param href url of the Rest service 
	 * @param expandSpec {@link RegistrationChallengeExpandSpecForGet}  
	 * @return the deserialised resource returned by the Rest service 
	 * @throws IdxRestException
	 */
	public RegistrationChallenge get(String href, RegistrationChallengeExpandSpecForGet expandSpec, SensitiveDataSpec sensitiveDataSpec) throws IdxRestException {
		
		return this.get(href, expandSpec, sensitiveDataSpec, null);
	}

	public RegistrationChallenge get(String href, RegistrationChallengeExpandSpecForGet expandSpec, SensitiveDataSpec sensitiveDataSpec, HashMap requestSpecificHeaders) throws IdxRestException {
		
		QueryString queryString = new QueryString();
		if (expandSpec != null) {							
			try {
				queryString.put("expand", (new ObjectMapper()).writeValueAsString(expandSpec));
			} catch (JsonProcessingException e) {
				throw new IdxRestException("Failed to convert to JSON", e);
			}
		}
		
		if (sensitiveDataSpec != null) {							
			queryString.put("sensitiveData", String.valueOf(sensitiveDataSpec.getSensitiveData()));
		}
		
		return super.get(href, queryString, requestSpecificHeaders);
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy