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

com.sun.xml.ws.security.trust.WSTrustElementFactory Maven / Gradle / Ivy

There is a newer version: 4.0.4
Show newest version
/*
 * Copyright (c) 1997, 2022 Oracle and/or its affiliates. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Distribution License v. 1.0, which is available at
 * http://www.eclipse.org/org/documents/edl-v10.php.
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */

package com.sun.xml.ws.security.trust;

import com.sun.xml.ws.security.trust.elements.OnBehalfOf;
import com.sun.xml.ws.security.trust.elements.str.DirectReference;
import com.sun.xml.ws.security.trust.elements.str.KeyIdentifier;

import com.sun.xml.ws.api.security.trust.Claims;
import com.sun.xml.ws.api.security.trust.WSTrustException;
import com.sun.xml.ws.security.trust.elements.ActAs;
import com.sun.xml.ws.security.trust.elements.AllowPostdating;
import com.sun.xml.ws.security.trust.elements.BinarySecret;
import com.sun.xml.ws.security.trust.elements.BaseSTSRequest;
import com.sun.xml.ws.security.trust.elements.BaseSTSResponse;
import com.sun.xml.ws.security.trust.elements.CancelTarget;
import com.sun.xml.ws.security.trust.elements.Entropy;
import com.sun.xml.ws.security.trust.elements.IssuedTokens;
import com.sun.xml.ws.security.trust.elements.Lifetime;
import com.sun.xml.ws.security.trust.elements.RenewTarget;
import com.sun.xml.ws.security.trust.elements.Renewing;
import com.sun.xml.ws.security.trust.elements.RequestSecurityToken;
import com.sun.xml.ws.security.trust.elements.RequestSecurityTokenResponse;
import com.sun.xml.ws.security.trust.elements.RequestSecurityTokenResponseCollection;
import com.sun.xml.ws.security.trust.elements.RequestedProofToken;
import com.sun.xml.ws.security.trust.elements.RequestedAttachedReference;
import com.sun.xml.ws.security.trust.elements.RequestedUnattachedReference;
import com.sun.xml.ws.security.trust.elements.RequestedSecurityToken;
import com.sun.xml.ws.security.trust.elements.SecondaryParameters;
import com.sun.xml.ws.api.security.trust.Status;
import com.sun.xml.ws.security.trust.elements.UseKey;
import com.sun.xml.ws.security.trust.elements.ValidateTarget;
import java.net.URI;

import com.sun.xml.ws.policy.impl.bindings.AppliesTo;

import com.sun.xml.ws.security.EncryptedKey;
import com.sun.xml.ws.security.trust.elements.str.Reference;
import com.sun.xml.ws.security.trust.elements.str.SecurityTokenReference;
import com.sun.xml.ws.security.Token;
import com.sun.xml.ws.security.SecurityContextToken;
import com.sun.xml.ws.security.secconv.WSSCVersion;
import com.sun.xml.ws.security.wsu10.AttributedDateTime;
import java.util.List;

import java.util.Map;
import java.util.HashMap;
import javax.xml.transform.Source;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;

import jakarta.xml.bind.JAXBContext;
import jakarta.xml.bind.JAXBElement;
import jakarta.xml.bind.JAXBException;
import jakarta.xml.bind.Marshaller;

/**
 * A Factory for creating the WS-Trust schema elements, and marshalling/un-marshalling them
 * 

* The default Implementation classes for all these WS-Trust schema Elements would assume * that JAXB Bindings were generated for ws-trust.xsd schema in a particular fixed namespace/package. * The default implementation classes for all these WS-Trust Element Interfaces would hence wrap * the schema generated classes. *

*

* An STS Service can create a RequestSecurityToken from the JAXBBean(i.e RequestSecurityTokenType) * it receives, as an SEI method parameter, in the following manner *

*
 * RequestSecurityTokenType tok=...//obtained as JAXWS SEI method paramater
 * ObjectFactory factory = new ObjectFactory();
 * JAXBElement<RequestSecurityTokenType> rst= factory.createRequestSecurityToken(tok);
 * WSTrustElementFactory fact= ..
 * RequestSecurityToken requestSecurityToken= fact.createRSTFrom(rst);
 * 
*

* To get back a JAXB Bean from an instance of RequestSecurityToken the following can be done *

 * JAXBElement<RequestSecurityTokenType> elem = fact.toJAXBElement(requestSecurityToken);
 * RequestSecurityTokenType tok = elem.getValue();
 * 
* * @author Kumar Jayanti */ public abstract class WSTrustElementFactory { private static JAXBContext jaxbContext = null; private static JAXBContext jaxbContext13 = null; private static Map intMap = new HashMap<>(); static { try { jaxbContext = JAXBContext.newInstance("com.sun.xml.ws.security.trust.impl.bindings:com.sun.xml.ws.security.secconv.impl.bindings:com.sun.xml.ws.security.secext10:com.sun.xml.security.core.ai:com.sun.xml.security.core.dsig:com.sun.xml.ws.policy.impl.bindings"); jaxbContext13 = JAXBContext.newInstance("com.sun.xml.ws.security.trust.impl.wssx.bindings:com.sun.xml.ws.security.secconv.impl.wssx.bindings:com.sun.xml.ws.security.secext10:com.sun.xml.security.core.ai:com.sun.xml.security.core.dsig:com.sun.xml.ws.policy.impl.bindings"); } catch (JAXBException jbe) { throw new RuntimeException(jbe.getMessage(),jbe); } } protected WSTrustElementFactory() {} public static JAXBContext getContext() { return jaxbContext; } public static JAXBContext getContext(WSTrustVersion wstVer) { if (wstVer instanceof com.sun.xml.ws.security.trust.impl.wssx.WSTrustVersion13){ return jaxbContext13; } return jaxbContext; } public static WSTrustElementFactory newInstance() { return newInstance(WSTrustVersion.WS_TRUST_10_NS_URI); } public static WSTrustElementFactory newInstance(String nsUri){ WSTrustElementFactory fac = intMap.get(nsUri); if (fac != null){ return fac; } String type = getInstanceClassName(nsUri); try { Class clazz = null; final ClassLoader loader = Thread.currentThread().getContextClassLoader(); if (loader == null) { clazz = Class.forName(type); } else { clazz = loader.loadClass(type); } if (clazz != null) { @SuppressWarnings("unchecked") Class typedClass = (Class) clazz; fac = typedClass.getConstructor().newInstance(); } } catch (Exception ex) { throw new RuntimeException("unable to initialize the WSTrustElementFactory for the protocol " + nsUri, ex); } intMap.put(nsUri, fac); return fac; } public static WSTrustElementFactory newInstance(WSTrustVersion wstVer) { return newInstance(wstVer.getNamespaceURI()); } public static WSTrustElementFactory newInstance(WSSCVersion wsscVer) { return newInstance(wsscVer.getNamespaceURI()); } private static String getInstanceClassName(String nsUri) { if (WSTrustVersion.WS_TRUST_10_NS_URI.equals(nsUri)){ return "com.sun.xml.ws.security.trust.impl.WSTrustElementFactoryImpl"; } else if (WSTrustVersion.WS_TRUST_13_NS_URI.equals(nsUri)){ return "com.sun.xml.ws.security.trust.impl.wssx.WSTrustElementFactoryImpl"; } else if (WSSCVersion.WSSC_10_NS_URI.equals(nsUri)){ return "com.sun.xml.ws.security.secconv.WSSCElementFactory"; }else if (WSSCVersion.WSSC_13_NS_URI.equals(nsUri)){ return "com.sun.xml.ws.security.secconv.WSSCElementFactory13"; } return "com.sun.xml.ws.security.trust.impl.WSTrustElementFactoryImpl"; } /** * Create an RST for Issue from the given arguments * Any of the arguments can be null since they are all optional, but one of tokenType and AppliesTo must be present */ public abstract RequestSecurityToken createRSTForIssue(URI tokenType, URI requestType, URI context, AppliesTo scopes, Claims claims, Entropy entropy, Lifetime lifetime); /** * create an RSTR for Issue from the given arguments * Any of the arguments can be null since they are all optional, but one of RequestedSecurityToken or RequestedProofToken should be returned */ public abstract RequestSecurityTokenResponse createRSTRForIssue(URI tokenType, URI context, RequestedSecurityToken token, AppliesTo scopes, RequestedAttachedReference attachedRef, RequestedUnattachedReference unattachedRef, RequestedProofToken proofToken, Entropy entropy, Lifetime lifetime); /** *Create a collection of RequestSecurityTokenResponse(s) */ public abstract RequestSecurityTokenResponseCollection createRSTRCollectionForIssue(URI tokenType, URI context, RequestedSecurityToken token, AppliesTo scopes, RequestedAttachedReference attachedRef, RequestedUnattachedReference unattachedRef, RequestedProofToken proofToken, Entropy entropy, Lifetime lifetime); /** * Create a wst:IssuedTokens object */ public abstract IssuedTokens createIssuedTokens(RequestSecurityTokenResponseCollection issuedTokens); /** * Create an Entropy with a BinarySecret */ public abstract Entropy createEntropy(BinarySecret secret); /** * Create an Entropy with an xenc:EncryptedKey */ public abstract Entropy createEntropy(EncryptedKey key); /** * Create SecondaryParameters */ public abstract SecondaryParameters createSecondaryParameters(); /** * Create a BinarySecret */ public abstract BinarySecret createBinarySecret(byte[] rawValue, String type); /** * Create a BinarySecret */ public abstract BinarySecret createBinarySecret(Element elem) throws WSTrustException; public abstract UseKey createUseKey(Token token, String sig); public abstract OnBehalfOf createOnBehalfOf(Token oboToken); public abstract ActAs createActAs(Token token); public abstract ValidateTarget createValidateTarget(Token token); public abstract Status createStatus(String code, String reason); /** * Create a Lifetime. */ public abstract Lifetime createLifetime(AttributedDateTime created, AttributedDateTime expires); /** * Create a RequestedProofToken. */ public abstract RequestedProofToken createRequestedProofToken(); /** * Create a RequestedSecurityToken. */ public abstract RequestedSecurityToken createRequestedSecurityToken(Token token); public abstract RequestedSecurityToken createRequestedSecurityToken(); public abstract DirectReference createDirectReference(String valueType, String uri); public abstract KeyIdentifier createKeyIdentifier(String valueType, String encodingType); public abstract SecurityTokenReference createSecurityTokenReference(Reference ref); public abstract SecurityContextToken createSecurityContextToken(final URI identifier, final String instance, final String wsuId); /** * Create a RequestedAttachedReference. */ public abstract RequestedAttachedReference createRequestedAttachedReference(SecurityTokenReference str); /** * Create a RequestedUnattachedReference. */ public abstract RequestedUnattachedReference createRequestedUnattachedReference(SecurityTokenReference str); /** *Create an RST for a Renewal Request */ public abstract RequestSecurityToken createRSTForRenew(URI tokenType, URI requestType, URI context, RenewTarget target, AllowPostdating apd, Renewing renewingInfo); /** *Create an RSTR for a Renewal Response */ public abstract RequestSecurityTokenResponse createRSTRForRenew(URI tokenType, URI context, RequestedSecurityToken token, RequestedAttachedReference attachedReference, RequestedUnattachedReference unattachedRef, RequestedProofToken proofToken, Entropy entropy, Lifetime lifetime); public abstract RenewTarget createRenewTarget(SecurityTokenReference str); public abstract CancelTarget createCancelTarget(SecurityTokenReference str); /** *Create an RST for Token Cancellation */ public abstract RequestSecurityToken createRSTForCancel(URI requestType, CancelTarget target); /** *Create an RSTR for a Successful Token Cancellation */ public abstract RequestSecurityTokenResponse createRSTRForCancel(); /** *Create an RST for Token Validation *

*TODO: Not clear from Spec whether the Token to be validated is ever sent ? *TODO: There is a mention of special case where a SOAPEnvelope may be specified as * a security token if the requestor desires the envelope to be validated. *

*/ public abstract RequestSecurityToken createRSTForValidate(URI tokenType, URI requestType); /** * create an RSTR for validate request. */ public abstract RequestSecurityTokenResponse createRSTRForValidate(URI tokenType, RequestedSecurityToken token, Status status); public abstract RequestSecurityTokenResponseCollection createRSTRC(List rstrs); /** * Create an Empty RST */ public abstract RequestSecurityToken createRST(); /** * Create an Empty RSTR */ public abstract RequestSecurityTokenResponse createRSTR(); /** * create an RST from a Source */ public abstract RequestSecurityToken createRSTFrom(Source src); /** * create an RST from DOM Element */ public abstract RequestSecurityToken createRSTFrom(Element elem); /** * create an RSTR from a Source */ public abstract RequestSecurityTokenResponse createRSTRFrom(Source src); /** * create an RSTR from DOM Element */ public abstract RequestSecurityTokenResponse createRSTRFrom(Element elem); /** * Create RSTR Collection from Source */ public abstract RequestSecurityTokenResponseCollection createRSTRCollectionFrom(Source src); /** * Create RSTR Collection from Element */ public abstract RequestSecurityTokenResponseCollection createRSTRCollectionFrom(Element elem); public abstract Claims createClaims(Element elem)throws WSTrustException; public abstract Claims createClaims(Claims claims); public abstract Claims createClaims(); /** * create an RST from JAXBElement *

* NOTE: an STS Implementor can call *

     * JAXBElement<RequestSecurityTokenType> elem=
     * ObjectFactory.createRequestSecurityToken(<JAXBBean for RST>)
     * 
* The JAXBBean for RST is the one generated from the ws-trust.xsd schema * The default implementation expects the packagename of the generated JAXB Beans to be fixed. * */ public abstract RequestSecurityToken createRSTFrom(JAXBElement elem); /** * create an RSTR from JAXBElement *

* NOTE: an STS Implementor can call *

     * JAXBElement<RequestSecurityTokenResponseType> elem=
     * ObjectFactory.createRequestSecurityTokenResponse(<JAXBBean for RSTR>);
     * 
* The <JAXBBean for RSTR> is the one generated from the ws-trust.xsd schema * The default implementation expects the packagename of the generated JAXB Beans to be fixed. * */ public abstract RequestSecurityTokenResponse createRSTRFrom(JAXBElement elem); /** * create an RSTR Collection from JAXBElement *

* NOTE: an STS Implementor can call *

     * JAXBElement<RequestSecurityTokenResponseCollectionType> elem=
     * ObjectFactory.createRequestSecurityTokenResponseCollection(<JAXBBean for RSTR Collection>
     * 
* The <JAXBBean for RSTR Collection> is the one generated from the ws-trust.xsd schema * The default implementation expects the packagename of the generated JAXB Beans to be fixed. * */ public abstract RequestSecurityTokenResponseCollection createRSTRCollectionFrom(JAXBElement elem); public abstract SecurityTokenReference createSecurityTokenReference(JAXBElement elem); public abstract JAXBElement toJAXBElement(BaseSTSRequest request); public abstract JAXBElement toJAXBElement(BaseSTSResponse response); /** * convert an SecurityTokenReference to a JAXBElement */ public abstract JAXBElement toJAXBElement(SecurityTokenReference str); /** * convert an RST to a JAXBElement */ public abstract JAXBElement toJAXBElement(RequestSecurityToken rst); /** * convert an RSTR to a JAXBElement */ public abstract JAXBElement toJAXBElement(RequestSecurityTokenResponse rstr); /** * convert an RSTR Collection to a JAXBElement */ public abstract JAXBElement toJAXBElement(RequestSecurityTokenResponseCollection rstrCollection); public abstract Source toSource(BaseSTSRequest request); public abstract Source toSource(BaseSTSResponse response); /** * Marshal an RST to a Source. *

* Note: Useful for Dispatch Client implementations *

*/ public abstract Source toSource(RequestSecurityToken rst); /** * Marshal an RSTR to a Source *

* Note: Useful for STS implementations which are JAXWS Providers *

*/ public abstract Source toSource(RequestSecurityTokenResponse rstr); /** * Marshal an RSTR Collection to a Source *

* Note: Useful for STS implementations which are JAXWS Providers *

*/ public abstract Source toSource(RequestSecurityTokenResponseCollection rstrCollection); public abstract Element toElement(BaseSTSRequest request); public abstract Element toElement(BaseSTSResponse response); /** * Marshal an RST to a DOM Element. *

* Note: Useful for Dispatch Client implementations *

*/ public abstract Element toElement(RequestSecurityToken rst); /** * Marshal an RSTR to DOM Element *

* Note: Useful for STS implementations which are JAXWS Providers *

*/ public abstract Element toElement(RequestSecurityTokenResponse rstr); public abstract Element toElement(RequestSecurityTokenResponse rstr, Document doc); /** * Marshal an RSTR Collection to a DOM Element *

* Note: Useful for STS implementations which are JAXWS Providers *

*/ public abstract Element toElement(RequestSecurityTokenResponseCollection rstrCollection); /** * Marshal an BinarySecret to a DOM Element *

* Note: Useful for STS implementations which are JAXWS Providers *

*/ public abstract Element toElement(BinarySecret binarySecret); /** * Marshal an STR to a DOM Element. *

* Note: Useful for Dispatch Client implementations *

*/ public abstract Element toElement(SecurityTokenReference str, Document doc); /** * Marshal an BinarySecret to a DOM Element. *

* Note: Useful for Dispatch Client implementations *

*/ public abstract Element toElement(BinarySecret binarySecret, Document doc); public Element toElement(Object jaxbEle){ if (jaxbEle instanceof Element){ return (Element)jaxbEle; } try{ DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); dbf.setNamespaceAware(true); DocumentBuilder db = dbf.newDocumentBuilder(); Document doc = db.newDocument(); getMarshaller().marshal(jaxbEle, doc); return doc.getDocumentElement(); } catch (Exception ex) { throw new RuntimeException(ex.getMessage(), ex); } } public abstract Marshaller getMarshaller(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy