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

com.wallee.sdk.service.UserAccountRoleService Maven / Gradle / Ivy

package com.wallee.sdk.service;

import static com.wallee.sdk.ErrorCode.*;

import com.wallee.sdk.ApiClient;
import com.wallee.sdk.ErrorCode;
import com.wallee.sdk.exception.WalleeSdkException;
import com.wallee.sdk.util.URIBuilderUtil;
import com.wallee.sdk.StringUtil;

import com.wallee.sdk.model.ClientError;
import com.wallee.sdk.model.ServerError;
import com.wallee.sdk.model.UserAccountRole;


import com.fasterxml.jackson.core.type.TypeReference;
import com.google.api.client.http.*;
import com.google.api.client.json.Json;

import org.apache.http.client.utils.URIBuilder;

import java.io.IOException;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import java.util.List;
import java.util.ArrayList;
import java.util.Objects;



public class UserAccountRoleService {
    private ApiClient apiClient;

    public UserAccountRoleService(ApiClient apiClient) {
        this.apiClient = Objects.requireNonNull(apiClient, "ApiClient must be non null");
    }

    public ApiClient getApiClient() {
        return apiClient;
    }

    public void setApiClient(ApiClient apiClient) {
        this.apiClient = Objects.requireNonNull(apiClient, "ApiClient must be non null");
    }

  /**
    * Add Role
    
    * This operation grants the role to the given user with in the given account.
    * 

200 - This status code indicates that a client request was successfully received, understood, and accepted. *

442 - This status code indicates that the server cannot or will not process the request due to something that is perceived to be a client error. *

542 - This status code indicates that the server encountered an unexpected condition that prevented it from fulfilling the client request. * @param userId The id of the user to whom the role is assigned. * @param accountId The account to which the role is mapped. * @param roleId The role which is mapped to the user and account. * @param appliesOnSubaccount Whether the role applies only on subaccount. * @return UserAccountRole * @throws IOException if an error occurs while attempting to invoke the API * For more information visit this link. * @see Add Role Documentation **/ public UserAccountRole addRole(Long userId, Long accountId, Long roleId, Boolean appliesOnSubaccount) throws IOException { HttpResponse response = addRoleForHttpResponse(userId, accountId, roleId, appliesOnSubaccount); String returnType = "UserAccountRole"; if(returnType.equals("String")){ return (UserAccountRole) (Object) response.parseAsString(); } TypeReference typeRef = new TypeReference() {}; if (isNoBodyResponse(response)) { throw new WalleeSdkException(ErrorCode.ENTITY_NOT_FOUND, "Entity was not found for: " + typeRef.getType().getTypeName()); } return (UserAccountRole)apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } /** * Add Role * This operation grants the role to the given user with in the given account. *

200 - This status code indicates that a client request was successfully received, understood, and accepted. *

442 - This status code indicates that the server cannot or will not process the request due to something that is perceived to be a client error. *

542 - This status code indicates that the server encountered an unexpected condition that prevented it from fulfilling the client request. * @param userId The id of the user to whom the role is assigned. * @param accountId The account to which the role is mapped. * @param roleId The role which is mapped to the user and account. * @param params Map of query params. A collection will be interpreted as passing in multiple instances of the same query param. * @return UserAccountRole * @throws IOException if an error occurs while attempting to invoke the API * For more information visit this link. * @see Add Role Documentation **/ public UserAccountRole addRole(Long userId, Long accountId, Long roleId, Map params) throws IOException { HttpResponse response = addRoleForHttpResponse(userId, accountId, roleId, params); String returnType = "UserAccountRole"; if(returnType.equals("String")){ return (UserAccountRole) (Object) response.parseAsString(); } TypeReference typeRef = new TypeReference() {}; if (isNoBodyResponse(response)) { throw new WalleeSdkException(ErrorCode.ENTITY_NOT_FOUND, "Entity was not found for: " + typeRef.getType().getTypeName()); } return (UserAccountRole)apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } public HttpResponse addRoleForHttpResponse(Long userId, Long accountId, Long roleId, Boolean appliesOnSubaccount) throws IOException { // verify the required parameter 'userId' is set if (userId == null) { throw new IllegalArgumentException("Missing the required parameter 'userId' when calling addRole"); } // verify the required parameter 'accountId' is set if (accountId == null) { throw new IllegalArgumentException("Missing the required parameter 'accountId' when calling addRole"); } // verify the required parameter 'roleId' is set if (roleId == null) { throw new IllegalArgumentException("Missing the required parameter 'roleId' when calling addRole"); } URIBuilder uriBuilder = URIBuilderUtil.create(apiClient.getBasePath() + "/user-account-role/addRole"); if (userId != null) { String key = "userId"; Object value = userId; uriBuilder = URIBuilderUtil.applyQueryParam(uriBuilder, key, value); } if (accountId != null) { String key = "accountId"; Object value = accountId; uriBuilder = URIBuilderUtil.applyQueryParam(uriBuilder, key, value); } if (roleId != null) { String key = "roleId"; Object value = roleId; uriBuilder = URIBuilderUtil.applyQueryParam(uriBuilder, key, value); } if (appliesOnSubaccount != null) { String key = "appliesOnSubaccount"; Object value = appliesOnSubaccount; uriBuilder = URIBuilderUtil.applyQueryParam(uriBuilder, key, value); } GenericUrl genericUrl = new GenericUrl(URIBuilderUtil.build(uriBuilder)); HttpContent content = apiClient.new JacksonJsonHttpContent(null); HttpRequest httpRequest = apiClient.getHttpRequestFactory().buildRequest(HttpMethods.POST, genericUrl, content); int readTimeOut = apiClient.getReadTimeOut() * 1000; httpRequest.setReadTimeout(readTimeOut); return httpRequest.execute(); } public HttpResponse addRoleForHttpResponse(Long userId, Long accountId, Long roleId, Map params) throws IOException { // verify the required parameter 'userId' is set if (userId == null) { throw new IllegalArgumentException("Missing the required parameter 'userId' when calling addRole"); } // verify the required parameter 'accountId' is set if (accountId == null) { throw new IllegalArgumentException("Missing the required parameter 'accountId' when calling addRole"); } // verify the required parameter 'roleId' is set if (roleId == null) { throw new IllegalArgumentException("Missing the required parameter 'roleId' when calling addRole"); } URIBuilder uriBuilder = URIBuilderUtil.create(apiClient.getBasePath() + "/user-account-role/addRole"); // Copy the params argument if present, to allow passing in immutable maps Map allParams = params == null ? new HashMap() : new HashMap(params); // Add the required query param 'userId' to the map of query params allParams.put("userId", userId); // Add the required query param 'accountId' to the map of query params allParams.put("accountId", accountId); // Add the required query param 'roleId' to the map of query params allParams.put("roleId", roleId); for (Map.Entry entryMap: allParams.entrySet()) { String key = entryMap.getKey(); Object value = entryMap.getValue(); if (key != null && value != null) { uriBuilder = URIBuilderUtil.applyQueryParam(uriBuilder, key, value); } } GenericUrl genericUrl = new GenericUrl(URIBuilderUtil.build(uriBuilder)); HttpContent content = apiClient.new JacksonJsonHttpContent(null); HttpRequest httpRequest = apiClient.getHttpRequestFactory().buildRequest(HttpMethods.POST, genericUrl, content); int readTimeOut = apiClient.getReadTimeOut() * 1000; httpRequest.setReadTimeout(readTimeOut); return httpRequest.execute(); } /** * List Roles * List all the roles that are assigned to the given user in the given account. *

200 - This status code indicates that a client request was successfully received, understood, and accepted. *

442 - This status code indicates that the server cannot or will not process the request due to something that is perceived to be a client error. *

542 - This status code indicates that the server encountered an unexpected condition that prevented it from fulfilling the client request. * @param userId The id of the user to whom the role is assigned. * @param accountId The account to which the role is mapped. * @return List<UserAccountRole> * @throws IOException if an error occurs while attempting to invoke the API * For more information visit this link. * @see List Roles Documentation **/ public List list(Long userId, Long accountId) throws IOException { HttpResponse response = listForHttpResponse(userId, accountId); String returnType = "List<UserAccountRole>"; if(returnType.equals("String")){ return (List) (Object) response.parseAsString(); } TypeReference typeRef = new TypeReference>() {}; if (isNoBodyResponse(response)) { throw new WalleeSdkException(ErrorCode.ENTITY_NOT_FOUND, "Entity was not found for: " + typeRef.getType().getTypeName()); } return (List)apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } /** * List Roles * List all the roles that are assigned to the given user in the given account. *

200 - This status code indicates that a client request was successfully received, understood, and accepted. *

442 - This status code indicates that the server cannot or will not process the request due to something that is perceived to be a client error. *

542 - This status code indicates that the server encountered an unexpected condition that prevented it from fulfilling the client request. * @param userId The id of the user to whom the role is assigned. * @param accountId The account to which the role is mapped. * @param params Map of query params. A collection will be interpreted as passing in multiple instances of the same query param. * @return List<UserAccountRole> * @throws IOException if an error occurs while attempting to invoke the API * For more information visit this link. * @see List Roles Documentation **/ public List list(Long userId, Long accountId, Map params) throws IOException { HttpResponse response = listForHttpResponse(userId, accountId, params); String returnType = "List<UserAccountRole>"; if(returnType.equals("String")){ return (List) (Object) response.parseAsString(); } TypeReference typeRef = new TypeReference>() {}; if (isNoBodyResponse(response)) { throw new WalleeSdkException(ErrorCode.ENTITY_NOT_FOUND, "Entity was not found for: " + typeRef.getType().getTypeName()); } return (List)apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } public HttpResponse listForHttpResponse(Long userId, Long accountId) throws IOException { // verify the required parameter 'userId' is set if (userId == null) { throw new IllegalArgumentException("Missing the required parameter 'userId' when calling list"); } // verify the required parameter 'accountId' is set if (accountId == null) { throw new IllegalArgumentException("Missing the required parameter 'accountId' when calling list"); } URIBuilder uriBuilder = URIBuilderUtil.create(apiClient.getBasePath() + "/user-account-role/list"); if (userId != null) { String key = "userId"; Object value = userId; uriBuilder = URIBuilderUtil.applyQueryParam(uriBuilder, key, value); } if (accountId != null) { String key = "accountId"; Object value = accountId; uriBuilder = URIBuilderUtil.applyQueryParam(uriBuilder, key, value); } GenericUrl genericUrl = new GenericUrl(URIBuilderUtil.build(uriBuilder)); HttpContent content = apiClient.new JacksonJsonHttpContent(null); HttpRequest httpRequest = apiClient.getHttpRequestFactory().buildRequest(HttpMethods.POST, genericUrl, content); int readTimeOut = apiClient.getReadTimeOut() * 1000; httpRequest.setReadTimeout(readTimeOut); return httpRequest.execute(); } public HttpResponse listForHttpResponse(Long userId, Long accountId, Map params) throws IOException { // verify the required parameter 'userId' is set if (userId == null) { throw new IllegalArgumentException("Missing the required parameter 'userId' when calling list"); } // verify the required parameter 'accountId' is set if (accountId == null) { throw new IllegalArgumentException("Missing the required parameter 'accountId' when calling list"); } URIBuilder uriBuilder = URIBuilderUtil.create(apiClient.getBasePath() + "/user-account-role/list"); // Copy the params argument if present, to allow passing in immutable maps Map allParams = params == null ? new HashMap() : new HashMap(params); // Add the required query param 'userId' to the map of query params allParams.put("userId", userId); // Add the required query param 'accountId' to the map of query params allParams.put("accountId", accountId); for (Map.Entry entryMap: allParams.entrySet()) { String key = entryMap.getKey(); Object value = entryMap.getValue(); if (key != null && value != null) { uriBuilder = URIBuilderUtil.applyQueryParam(uriBuilder, key, value); } } GenericUrl genericUrl = new GenericUrl(URIBuilderUtil.build(uriBuilder)); HttpContent content = apiClient.new JacksonJsonHttpContent(null); HttpRequest httpRequest = apiClient.getHttpRequestFactory().buildRequest(HttpMethods.POST, genericUrl, content); int readTimeOut = apiClient.getReadTimeOut() * 1000; httpRequest.setReadTimeout(readTimeOut); return httpRequest.execute(); } /** * Remove Role * This operation removes the specified user account role. *

442 - This status code indicates that the server cannot or will not process the request due to something that is perceived to be a client error. *

542 - This status code indicates that the server encountered an unexpected condition that prevented it from fulfilling the client request. * @param id The id of user account role which should be removed * @throws IOException if an error occurs while attempting to invoke the API * For more information visit this link. * @see Remove Role Documentation **/ public void removeRole(Long id) throws IOException { removeRoleForHttpResponse(id); } /** * Remove Role * This operation removes the specified user account role. *

442 - This status code indicates that the server cannot or will not process the request due to something that is perceived to be a client error. *

542 - This status code indicates that the server encountered an unexpected condition that prevented it from fulfilling the client request. * @param id The id of user account role which should be removed * @param params Map of query params. A collection will be interpreted as passing in multiple instances of the same query param. * @throws IOException if an error occurs while attempting to invoke the API * For more information visit this link. * @see Remove Role Documentation **/ public void removeRole(Long id, Map params) throws IOException { removeRoleForHttpResponse(id, params); } public HttpResponse removeRoleForHttpResponse(Long id) throws IOException { // verify the required parameter 'id' is set if (id == null) { throw new IllegalArgumentException("Missing the required parameter 'id' when calling removeRole"); } URIBuilder uriBuilder = URIBuilderUtil.create(apiClient.getBasePath() + "/user-account-role/removeRole"); if (id != null) { String key = "id"; Object value = id; uriBuilder = URIBuilderUtil.applyQueryParam(uriBuilder, key, value); } GenericUrl genericUrl = new GenericUrl(URIBuilderUtil.build(uriBuilder)); HttpContent content = apiClient.new JacksonJsonHttpContent(null); HttpRequest httpRequest = apiClient.getHttpRequestFactory().buildRequest(HttpMethods.POST, genericUrl, content); int readTimeOut = apiClient.getReadTimeOut() * 1000; httpRequest.setReadTimeout(readTimeOut); return httpRequest.execute(); } public HttpResponse removeRoleForHttpResponse(Long id, Map params) throws IOException { // verify the required parameter 'id' is set if (id == null) { throw new IllegalArgumentException("Missing the required parameter 'id' when calling removeRole"); } URIBuilder uriBuilder = URIBuilderUtil.create(apiClient.getBasePath() + "/user-account-role/removeRole"); // Copy the params argument if present, to allow passing in immutable maps Map allParams = params == null ? new HashMap() : new HashMap(params); // Add the required query param 'id' to the map of query params allParams.put("id", id); for (Map.Entry entryMap: allParams.entrySet()) { String key = entryMap.getKey(); Object value = entryMap.getValue(); if (key != null && value != null) { uriBuilder = URIBuilderUtil.applyQueryParam(uriBuilder, key, value); } } GenericUrl genericUrl = new GenericUrl(URIBuilderUtil.build(uriBuilder)); HttpContent content = apiClient.new JacksonJsonHttpContent(null); HttpRequest httpRequest = apiClient.getHttpRequestFactory().buildRequest(HttpMethods.POST, genericUrl, content); int readTimeOut = apiClient.getReadTimeOut() * 1000; httpRequest.setReadTimeout(readTimeOut); return httpRequest.execute(); } private boolean isNoBodyResponse(HttpResponse response) throws IOException { java.io.InputStream content = response.getContent(); return content.available() == 0; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy