private void addConsent(String consent, String tenantDomain) throws ConsentManagementException, IdentityRecoveryServerException { Gson gson = new Gson(); ReceiptInput receiptInput = gson.fromJson(consent, ReceiptInput.class); ConsentManager consentManager = IdentityRecoveryServiceDataHolder.getInstance().getConsentManager(); if (receiptInput.getServices().size() < 0) { throw new IdentityRecoveryServerException("A service should be available in a receipt"); } // There should be a one receipt ReceiptServiceInput receiptServiceInput = receiptInput.getServices().get(0); receiptServiceInput.setTenantDomain(tenantDomain); try { setIDPData(tenantDomain, receiptServiceInput); } catch (IdentityProviderManagementException e) { throw new ConsentManagementException("Error while retrieving identity provider data", "Error while " + "setting IDP data", e); } receiptInput.setTenantDomain(tenantDomain); consentManager.addConsent(receiptInput); }
private void validateRequiredParametersInService(ReceiptServiceInput receiptServiceInput) throws ConsentManagementException { if (isBlank(receiptServiceInput.getService())) { throw handleClientException(ERROR_CODE_SERVICE_NAME_REQUIRED, null); } if (isEmpty(receiptServiceInput.getPurposes())) { throw handleClientException(ERROR_CODE_AT_LEAST_ONE_PURPOSE_REQUIRED, null); } // Set authenticated user's tenant id if it is not set. if (isBlank(receiptServiceInput.getTenantDomain())) { receiptServiceInput.setTenantId(getTenantIdFromCarbonContext()); receiptServiceInput.setTenantDomain(getTenantDomainFromCarbonContext()); } else { receiptServiceInput.setTenantId(getTenantId(realmService, receiptServiceInput.getTenantDomain())); } }
private ReceiptServiceInput getReceiptServiceInput(ServiceProvider serviceProvider, String spTenantDomain, List<ReceiptPurposeInput> purposeInputs) { ReceiptServiceInput serviceInput = new ReceiptServiceInput(); serviceInput.setPurposes(purposeInputs); serviceInput.setTenantDomain(spTenantDomain); if (serviceProvider == null) { return serviceInput; } String spName = serviceProvider.getApplicationName(); String spDescription; spDescription = serviceProvider.getDescription(); if (StringUtils.isBlank(spDescription)) { spDescription = spName; } serviceInput.setService(spName); serviceInput.setSpDisplayName(spDescription); serviceInput.setSpDescription(spDescription); return serviceInput; }
private void setIDPData(String tenantDomain, ReceiptServiceInput receiptServiceInput) throws IdentityProviderManagementException { IdentityProviderManager idpManager = IdentityProviderManager.getInstance(); IdentityProvider residentIdP = idpManager.getResidentIdP(tenantDomain); if (StringUtils.isEmpty(receiptServiceInput.getService())) { if (log.isDebugEnabled()) { log.debug("No service name found. Hence adding resident IDP home realm ID"); } receiptServiceInput.setService(residentIdP.getHomeRealmId()); } if (StringUtils.isEmpty(receiptServiceInput.getTenantDomain())) { receiptServiceInput.setTenantDomain(tenantDomain); } if (StringUtils.isEmpty(receiptServiceInput.getSpDescription())) { if (StringUtils.isNotEmpty(residentIdP.getIdentityProviderDescription())) { receiptServiceInput.setSpDescription(residentIdP.getIdentityProviderDescription()); } else { receiptServiceInput.setSpDescription(IdentityRecoveryConstants.Consent.RESIDENT_IDP); } } if (StringUtils.isEmpty(receiptServiceInput.getSpDisplayName())) { if (StringUtils.isNotEmpty(residentIdP.getDisplayName())) { receiptServiceInput.setSpDisplayName(residentIdP.getDisplayName()); } else { receiptServiceInput.setSpDisplayName(IdentityRecoveryConstants.Consent.RESIDENT_IDP); } } }
private ReceiptServiceInput getReceiptServiceInput(ServiceProvider serviceProvider, String spTenantDomain, List<ReceiptPurposeInput> purposeInputs) { ReceiptServiceInput serviceInput = new ReceiptServiceInput(); serviceInput.setPurposes(purposeInputs); serviceInput.setTenantDomain(spTenantDomain); if (serviceProvider == null) { return serviceInput; } String spName = serviceProvider.getApplicationName(); String spDescription; spDescription = serviceProvider.getDescription(); if (StringUtils.isBlank(spDescription)) { spDescription = spName; } serviceInput.setService(spName); serviceInput.setSpDisplayName(spDescription); serviceInput.setSpDescription(spDescription); return serviceInput; }
/** * Persist the consents received from the user, while user creation. * * @param receiptInput Relevant receipt input representing consent data. * @param tenantDomain Relevant tenant domain. * @throws PostAuthenticationFailedException Post Authentication Failed Exception. */ private void addConsent(ReceiptInput receiptInput, String tenantDomain) throws PostAuthenticationFailedException { ConsentManager consentManager = FrameworkServiceDataHolder.getInstance().getConsentManager(); if (receiptInput.getServices().size() == 0) { throw new PostAuthenticationFailedException(ErrorMessages.ERROR_WHILE_ADDING_CONSENT.getCode(), String.format(ErrorMessages.ERROR_WHILE_ADDING_CONSENT.getMessage(), tenantDomain)); } // There should be one receipt ReceiptServiceInput receiptServiceInput = receiptInput.getServices().get(0); receiptServiceInput.setTenantDomain(tenantDomain); try { setIDPData(tenantDomain, receiptServiceInput); receiptInput.setTenantDomain(tenantDomain); consentManager.addConsent(receiptInput); } catch (ConsentManagementException e) { handleExceptions(String.format(ErrorMessages.ERROR_WHILE_ADDING_CONSENT.getMessage(), tenantDomain), ErrorMessages.ERROR_WHILE_ADDING_CONSENT.getCode(), e); } }
/** * Persist the consents received from the user, while user creation. * * @param receiptInput Relevant receipt input representing consent data. * @param tenantDomain Relevant tenant domain. * @throws PostAuthenticationFailedException Post Authentication Failed Exception. */ private void addConsent(ReceiptInput receiptInput, String tenantDomain) throws PostAuthenticationFailedException { ConsentManager consentManager = FrameworkServiceDataHolder.getInstance().getConsentManager(); if (receiptInput.getServices().size() == 0) { throw new PostAuthenticationFailedException(ErrorMessages.ERROR_WHILE_ADDING_CONSENT.getCode(), String.format(ErrorMessages.ERROR_WHILE_ADDING_CONSENT.getMessage(), tenantDomain)); } // There should be one receipt ReceiptServiceInput receiptServiceInput = receiptInput.getServices().get(0); receiptServiceInput.setTenantDomain(tenantDomain); try { setIDPData(tenantDomain, receiptServiceInput); receiptInput.setTenantDomain(tenantDomain); consentManager.addConsent(receiptInput); } catch (ConsentManagementException e) { handleExceptions(String.format(ErrorMessages.ERROR_WHILE_ADDING_CONSENT.getMessage(), tenantDomain), ErrorMessages.ERROR_WHILE_ADDING_CONSENT.getCode(), e); } }
receiptServiceInput.setTenantDomain(tenantDomain);
receiptServiceInput.setTenantDomain(tenantDomain);