use of com.sun.identity.liberty.ws.disco.jaxb.ResourceOfferingType in project OpenAM by OpenRock.
the class SMDiscoveryServiceData method setDiscoEntryData.
private static void setDiscoEntryData(DiscoEntryElement entry, SMDiscoEntryData smDisco) {
ResourceOfferingType resOff = entry.getResourceOffering();
ResourceIDType resourceIdType = resOff.getResourceID();
ServiceInstanceType serviceInstance = resOff.getServiceInstance();
String providerID = serviceInstance.getProviderID();
String serviceType = serviceInstance.getServiceType();
smDisco.entryId = resOff.getEntryID();
smDisco.resourceIdAttribute = resourceIdType.getId();
smDisco.resourceIdValue = resourceIdType.getValue();
smDisco.serviceType = serviceType;
smDisco.providerId = providerID;
smDisco.abstractValue = resOff.getAbstract();
OptionsType optType = resOff.getOptions();
if (optType != null) {
smDisco.options = optType.getOption();
smDisco.noOption = false;
} else {
smDisco.noOption = true;
}
List list = serviceInstance.getDescription();
if (list != null && !list.isEmpty()) {
for (Iterator iter = list.iterator(); iter.hasNext(); ) {
SMDescriptionData smDesc = new SMDescriptionData();
DescriptionType desc = (DescriptionType) iter.next();
smDesc.setDescriptionEntry(desc);
smDisco.descData.add(smDesc);
}
} else {
debug.error("SMDiscoveryServiceData.setDiscoEntryData: " + "No description exists in the disco entry");
}
smDisco.directives = getDirectiveEntry(entry);
}
use of com.sun.identity.liberty.ws.disco.jaxb.ResourceOfferingType in project OpenAM by OpenRock.
the class AuthnSvcUtils method setResourceOfferingAndCredentials.
/**
* Sets resource offering and credentials to the SASL response based on
* provided sso token.
* @param saslResp a SASL response
* @param message a SOAP message containing a SASL request
* @param userDN Distinguished Name of the User.
* @return <code>true</code> if it sets correctly
*/
public static boolean setResourceOfferingAndCredentials(SASLResponse saslResp, Message message, String userDN) {
try {
DiscoEntryElement discoEntry = (DiscoEntryElement) DiscoServiceManager.getBootstrappingDiscoEntry();
ResourceOfferingType offering = discoEntry.getResourceOffering();
if (!DiscoServiceManager.useImpliedResource()) {
ServiceInstanceType serviceInstance = offering.getServiceInstance();
String providerID = serviceInstance.getProviderID();
ResourceIDMapper idMapper = DiscoServiceManager.getResourceIDMapper(providerID);
if (idMapper == null) {
idMapper = DiscoServiceManager.getDefaultResourceIDMapper();
}
ObjectFactory fac = new com.sun.identity.liberty.ws.disco.jaxb.ObjectFactory();
ResourceIDType resourceID = fac.createResourceIDType();
String resourceIDValue = idMapper.getResourceID(providerID, userDN);
if (AuthnSvcUtils.debug.messageEnabled()) {
AuthnSvcUtils.debug.message("AuthnSvcUtils.setResourceOfferingAndCredentials" + "Offering: ResourceID Value:" + resourceIDValue);
}
resourceID.setValue(resourceIDValue);
offering.setResourceID(resourceID);
} else {
ObjectFactory fac = new com.sun.identity.liberty.ws.disco.jaxb.ObjectFactory();
ResourceIDType resourceID = fac.createResourceIDType();
resourceID.setValue(DiscoConstants.IMPLIED_RESOURCE);
offering.setResourceID(resourceID);
}
List discoEntryList = new ArrayList();
discoEntryList.add(discoEntry);
Map map = DiscoUtils.checkPolicyAndHandleDirectives(userDN, message, discoEntryList, null, null, null, message.getToken());
List offerings = (List) map.get(DiscoUtils.OFFERINGS);
if (offerings.isEmpty()) {
if (AuthnSvcUtils.debug.messageEnabled()) {
AuthnSvcUtils.debug.message("AuthnSvcUtils.setResourceOfferingAndCredentials" + "no ResourceOffering");
}
return false;
}
ResourceOffering ro = (ResourceOffering) offerings.get(0);
saslResp.setResourceOffering(ro);
List assertions = (List) map.get(DiscoUtils.CREDENTIALS);
if ((assertions != null) && (!assertions.isEmpty())) {
Iterator iter = assertions.iterator();
List credentials = new ArrayList();
while (iter.hasNext()) {
SecurityAssertion assertion = (SecurityAssertion) iter.next();
Document doc = XMLUtils.toDOMDocument(assertion.toString(true, true), AuthnSvcUtils.debug);
credentials.add(doc.getDocumentElement());
}
saslResp.setCredentials(credentials);
}
return true;
} catch (Exception ex) {
debug.error("AuthnSvcUtils.setResourceOfferingAndCredentials:", ex);
return false;
}
}
Aggregations