/* * Copyright (c) 2014 WSO2 Inc. (http://www.wso2.org) All Rights Reserved. * * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.idp.mgt.dao; import org.wso2.carbon.identity.application.common.model.FederatedAuthenticatorConfig; import org.wso2.carbon.identity.application.common.model.IdentityProvider; import org.wso2.carbon.identity.application.common.model.Property; import org.wso2.carbon.identity.application.common.util.IdentityApplicationConstants; import org.wso2.carbon.identity.application.common.util.IdentityApplicationManagementUtil; import org.wso2.carbon.idp.mgt.internal.IdPManagementServiceComponent; import java.util.Iterator; import java.util.Map; import java.util.Map.Entry; public class FileBasedIdPMgtDAO { /** * @param idPName * @param tenantDomain * @return */ public IdentityProvider getIdPByName(String idPName, String tenantDomain) { return IdPManagementServiceComponent.getFileBasedIdPs().get(idPName); } /** * @param property * @param value * @param tenantDomain * @return */ public IdentityProvider getIdPByAuthenticatorPropertyValue(String property, String value, String tenantDomain) { Map<String, IdentityProvider> identityProviders = IdPManagementServiceComponent.getFileBasedIdPs(); for (Iterator<Entry<String, IdentityProvider>> iterator = identityProviders.entrySet().iterator(); iterator .hasNext(); ) { Entry<String, IdentityProvider> entry = iterator.next(); FederatedAuthenticatorConfig[] federatedAuthenticatorConfigs = entry.getValue(). getFederatedAuthenticatorConfigs(); // Get SAML2 Web SSO authenticator FederatedAuthenticatorConfig samlAuthenticatorConfig = IdentityApplicationManagementUtil. getFederatedAuthenticator( federatedAuthenticatorConfigs, IdentityApplicationConstants.Authenticator.SAML2SSO.NAME); if (samlAuthenticatorConfig != null) { Property samlProperty = IdentityApplicationManagementUtil.getProperty(samlAuthenticatorConfig. getProperties(), property); if (samlProperty != null) { if (value.equalsIgnoreCase(samlProperty.getValue())) { return entry.getValue(); } } } } return null; } /** * @param realmId * @param tenantDomain * @return */ public IdentityProvider getIdPByRealmId(String realmId, String tenantDomain) { Map<String, IdentityProvider> map = IdPManagementServiceComponent.getFileBasedIdPs(); for (Iterator<Entry<String, IdentityProvider>> iterator = map.entrySet().iterator(); iterator .hasNext(); ) { Entry<String, IdentityProvider> entry = iterator.next(); if (entry.getValue().getHomeRealmId() != null && entry.getValue().getHomeRealmId().equals(realmId)) { return entry.getValue(); } } return null; } }