use of generated.TCTokenType in project open-ecard by ecsec.
the class AndroidMarshaller method marshal.
@Override
public synchronized Document marshal(Object o) throws MarshallingTypeException {
Document document = documentBuilder.newDocument();
document.setXmlStandalone(true);
Element rootElement = null;
if (o instanceof DestroyChannel) {
DestroyChannel destroyChannel = (DestroyChannel) o;
rootElement = createElementIso(document, o.getClass().getSimpleName());
rootElement.setAttribute("xmlns:iso", "urn:iso:std:iso-iec:24727:tech:schema");
Element emSlotHandle = createElementIso(document, "SlotHandle");
emSlotHandle.appendChild(document.createTextNode(ByteUtils.toHexString(destroyChannel.getSlotHandle())));
rootElement.appendChild(emSlotHandle);
} else if (o instanceof DestroyChannelResponse) {
DestroyChannelResponse response = (DestroyChannelResponse) o;
rootElement = createElementIso(document, o.getClass().getSimpleName());
rootElement.setAttribute("xmlns:iso", "urn:iso:std:iso-iec:24727:tech:schema");
if (response.getProfile() != null) {
Element emProfile = createElementIso(document, "Profile");
emProfile.appendChild(document.createTextNode(response.getProfile()));
rootElement.appendChild(emProfile);
}
if (response.getRequestID() != null) {
Element emRequest = createElementIso(document, "RequestID");
emRequest.appendChild(document.createElement(response.getRequestID()));
rootElement.appendChild(emRequest);
}
if (response.getResult() != null) {
Element emResult = marshalResult(response.getResult(), document);
rootElement.appendChild(emResult);
}
} else if (o instanceof EstablishChannel) {
EstablishChannel establishChannel = (EstablishChannel) o;
rootElement = createElementIso(document, o.getClass().getSimpleName());
rootElement.setAttribute("xmlns:iso", "urn:iso:std:iso-iec:24727:tech:schema");
Element emSlotHandle = createElementIso(document, "SlotHandle");
emSlotHandle.appendChild(document.createTextNode(ByteUtils.toHexString(establishChannel.getSlotHandle())));
rootElement.appendChild(emSlotHandle);
Element emAuthProtData = createElementIso(document, "AuthenticationProtocolData");
emAuthProtData.setAttribute("Protocol", establishChannel.getAuthenticationProtocolData().getProtocol());
for (Element e : establishChannel.getAuthenticationProtocolData().getAny()) {
Element eClone = createElementIso(document, e.getLocalName());
eClone.setTextContent(e.getTextContent());
eClone.setAttribute("xmlns", "urn:iso:std:iso-iec:24727:tech:schema");
emAuthProtData.appendChild(eClone);
}
if (establishChannel.getProfile() != null) {
Element emProfile = createElementIso(document, "Profile");
emProfile.appendChild(document.createTextNode(establishChannel.getProfile()));
rootElement.appendChild(emProfile);
}
if (establishChannel.getRequestID() != null) {
Element emRequest = createElementIso(document, "RequestID");
emRequest.appendChild(document.createElement(establishChannel.getRequestID()));
rootElement.appendChild(emRequest);
}
rootElement.appendChild(emAuthProtData);
} else if (o instanceof EstablishChannelResponse) {
EstablishChannelResponse response = (EstablishChannelResponse) o;
rootElement = createElementIso(document, o.getClass().getSimpleName());
rootElement.setAttribute("xmlns:iso", "urn:iso:std:iso-iec:24727:tech:schema");
if (response.getProfile() != null) {
Element emProfile = createElementIso(document, "Profile");
emProfile.appendChild(document.createTextNode(response.getProfile()));
rootElement.appendChild(emProfile);
}
if (response.getRequestID() != null) {
Element emRequest = createElementIso(document, "RequestID");
emRequest.appendChild(document.createElement(response.getRequestID()));
rootElement.appendChild(emRequest);
}
if (response.getResult() != null) {
Element emResult = marshalResult(response.getResult(), document);
rootElement.appendChild(emResult);
}
if (response.getAuthenticationProtocolData() != null) {
Element emAuthProtData = createElementIso(document, "AuthenticationProtocolData");
emAuthProtData.setAttribute("Protocol", response.getAuthenticationProtocolData().getProtocol());
for (Element e : response.getAuthenticationProtocolData().getAny()) {
Element eClone = createElementIso(document, e.getLocalName());
eClone.setTextContent(e.getTextContent());
eClone.setAttribute("xmlns", "urn:iso:std:iso-iec:24727:tech:schema");
emAuthProtData.appendChild(eClone);
}
}
} else if (o instanceof DIDAuthenticate) {
DIDAuthenticate auth = (DIDAuthenticate) o;
rootElement = createElementIso(document, o.getClass().getSimpleName());
rootElement.setAttribute("xmlns:iso", "urn:iso:std:iso-iec:24727:tech:schema");
Element em;
if (auth.getConnectionHandle() != null) {
em = marshalConnectionHandle(auth.getConnectionHandle(), document);
rootElement.appendChild(em);
}
if (auth.getDIDScope() != null) {
em = createElementIso(document, "DIDScope");
em.appendChild(document.createTextNode(auth.getDIDScope().value()));
rootElement.appendChild(em);
}
if (auth.getDIDName() != null) {
em = createElementIso(document, "DIDName");
em.appendChild(document.createTextNode(auth.getDIDName()));
rootElement.appendChild(em);
}
if (auth.getAuthenticationProtocolData() != null) {
DIDAuthenticationDataType d = auth.getAuthenticationProtocolData();
em = createElementIso(document, "AuthenticationProtocolData");
em.setAttribute("xmlns:xsi", "http://www.w3.org/2001/XMLSchema-instance");
if (d instanceof EAC1OutputType) {
em.setAttribute("xsi:type", "iso:EAC1OutputType");
} else if (d instanceof EAC2OutputType) {
em.setAttribute("xsi:type", "iso:EAC2OutputType");
} else if (d instanceof EAC1InputType) {
em.setAttribute("xsi:type", "iso:EAC1InputType");
} else if (d instanceof EAC2InputType) {
em.setAttribute("xsi:type", "iso:EAC2InputType");
} else {
String msg = "Marshalling a DIDAuthenticationDataType of " + d.getClass().getName() + " in DIDAuthentication is not supported";
LOG.error(msg);
throw new MarshallingTypeException(msg);
}
for (Element e : d.getAny()) {
Element elemCopy = createElementIso(document, e.getLocalName());
elemCopy.setTextContent(e.getTextContent());
em.appendChild(elemCopy);
}
for (Map.Entry<QName, String> entry : d.getOtherAttributes().entrySet()) {
em.setAttribute(entry.getKey().getNamespaceURI(), entry.getValue());
}
if (d.getProtocol() != null) {
em.setAttribute("Protocol", d.getProtocol());
}
rootElement.appendChild(em);
}
if (auth.getSAMConnectionHandle() != null) {
em = marshalConnectionHandle(auth.getSAMConnectionHandle(), document);
rootElement.appendChild(em);
}
if (auth.getProfile() != null) {
Element emProfile = createElementIso(document, "Profile");
emProfile.appendChild(document.createTextNode(auth.getProfile()));
rootElement.appendChild(emProfile);
}
if (auth.getRequestID() != null) {
Element emRequest = createElementIso(document, "RequestID");
emRequest.appendChild(document.createElement(auth.getRequestID()));
rootElement.appendChild(emRequest);
}
} else if (o instanceof DIDAuthenticateResponse) {
DIDAuthenticateResponse didAuthenticateResponse = (DIDAuthenticateResponse) o;
rootElement = createElementIso(document, o.getClass().getSimpleName());
rootElement.setAttribute("xmlns:iso", "urn:iso:std:iso-iec:24727:tech:schema");
rootElement.appendChild(marshalResult(didAuthenticateResponse.getResult(), document));
if (didAuthenticateResponse.getAuthenticationProtocolData() != null) {
DIDAuthenticationDataType didAuthenticationDataType = didAuthenticateResponse.getAuthenticationProtocolData();
Element elemEACOutput = createElementIso(document, "AuthenticationProtocolData");
elemEACOutput.setAttribute("xmlns:xsi", "http://www.w3.org/2001/XMLSchema-instance");
if (didAuthenticationDataType instanceof EAC1OutputType) {
elemEACOutput.setAttribute("xsi:type", "iso:EAC1OutputType");
} else if (didAuthenticationDataType instanceof EAC2OutputType) {
elemEACOutput.setAttribute("xsi:type", "iso:EAC2OutputType");
} else {
String msg = "Marshalling a DIDAuthenticationDataType of " + didAuthenticationDataType.getClass().getName() + " in DIDAuthentication is not supported";
throw new MarshallingTypeException(msg);
}
for (Element e : didAuthenticationDataType.getAny()) {
Element elemCopy = createElementIso(document, e.getLocalName());
elemCopy.setTextContent(e.getTextContent());
elemEACOutput.appendChild(elemCopy);
}
rootElement.appendChild(elemEACOutput);
}
// else only the result (with error) is returned
} else if (o instanceof InitializeFrameworkResponse) {
InitializeFrameworkResponse initializeFrameworkResponse = (InitializeFrameworkResponse) o;
rootElement = createElementEcapi(document, o.getClass().getSimpleName());
rootElement.appendChild(marshalResult(initializeFrameworkResponse.getResult(), document));
Element emVersion = createElementEcapi(document, "Version");
Element emMajor = createElementEcapi(document, "Major");
emMajor.appendChild(document.createTextNode(initializeFrameworkResponse.getVersion().getMajor().toString()));
emVersion.appendChild(emMajor);
Element emMinor = createElementEcapi(document, "Minor");
emMinor.appendChild(document.createTextNode(initializeFrameworkResponse.getVersion().getMinor().toString()));
emVersion.appendChild(emMinor);
Element emSubMinor = createElementEcapi(document, "SubMinor");
emSubMinor.appendChild(document.createTextNode(initializeFrameworkResponse.getVersion().getSubMinor().toString()));
emVersion.appendChild(emSubMinor);
rootElement.appendChild(emVersion);
} else if (o instanceof InternationalStringType) {
InternationalStringType internationalStringType = (InternationalStringType) o;
rootElement = marshalInternationStringType(internationalStringType, document, internationalStringType.getClass().getSimpleName());
} else if (o instanceof Result) {
Result r = (Result) o;
rootElement = marshalResult(r, document);
} else if (o instanceof iso.std.iso_iec._24727.tech.schema.StartPAOS) {
rootElement = createElementIso(document, o.getClass().getSimpleName());
rootElement.setAttribute("xmlns:iso", "urn:iso:std:iso-iec:24727:tech:schema");
StartPAOS startPAOS = (StartPAOS) o;
Element em = createElementIso(document, "SessionIdentifier");
em.appendChild(document.createTextNode(startPAOS.getSessionIdentifier()));
rootElement.appendChild(em);
rootElement.appendChild(marshalConnectionHandle(startPAOS.getConnectionHandle().get(0), document));
} else if (o instanceof TransmitResponse) {
rootElement = createElementIso(document, o.getClass().getSimpleName());
rootElement.setAttribute("xmlns:iso", "urn:iso:std:iso-iec:24727:tech:schema");
TransmitResponse transmitResponsePOJO = (TransmitResponse) o;
Element em = marshalResult(transmitResponsePOJO.getResult(), document);
rootElement.appendChild(em);
for (int i = 0; i < transmitResponsePOJO.getOutputAPDU().size(); i++) {
em = createElementIso(document, "OutputAPDU");
em.appendChild(document.createTextNode(ByteUtils.toHexString(transmitResponsePOJO.getOutputAPDU().get(i))));
rootElement.appendChild(em);
}
} else if (o instanceof EstablishContext) {
rootElement = createElementIso(document, o.getClass().getSimpleName());
rootElement.setAttribute("xmlns:iso", "urn:iso:std:iso-iec:24727:tech:schema");
} else if (o instanceof EstablishContextResponse) {
rootElement = createElementIso(document, o.getClass().getSimpleName());
rootElement.setAttribute("xmlns:iso", "urn:iso:std:iso-iec:24727:tech:schema");
EstablishContextResponse establishContextResponse = (EstablishContextResponse) o;
Element em = createElementIso(document, "ContextHandle");
em.appendChild(document.createTextNode(ByteUtils.toHexString(establishContextResponse.getContextHandle())));
rootElement.appendChild(em);
em = marshalResult(establishContextResponse.getResult(), document);
rootElement.appendChild(em);
} else if (o instanceof GetStatus) {
rootElement = createElementIso(document, o.getClass().getSimpleName());
rootElement.setAttribute("xmlns:iso", "urn:iso:std:iso-iec:24727:tech:schema");
GetStatus getStatus = (GetStatus) o;
Element em = createElementIso(document, "ContextHandle");
em.appendChild(document.createTextNode(ByteUtils.toHexString(getStatus.getContextHandle())));
rootElement.appendChild(em);
if (getStatus.getIFDName() != null) {
em = createElementIso(document, "IFDName");
em.appendChild(document.createTextNode(getStatus.getIFDName()));
rootElement.appendChild(em);
}
} else if (o instanceof Wait) {
rootElement = createElementIso(document, o.getClass().getSimpleName());
rootElement.setAttribute("xmlns:iso", "urn:iso:std:iso-iec:24727:tech:schema");
Wait w = (Wait) o;
Element em = createElementIso(document, "ContextHandle");
em.appendChild(document.createTextNode(ByteUtils.toHexString(w.getContextHandle())));
rootElement.appendChild(em);
if (w.getTimeOut() != null) {
em = createElementIso(document, "TimeOut");
em.appendChild(document.createTextNode(w.getTimeOut().toString(16)));
rootElement.appendChild(em);
}
if (w.getCallback() != null) {
ChannelHandleType callback = w.getCallback();
em = createElementIso(document, "Callback");
if (callback.getBinding() != null) {
Element em2 = createElementIso(document, "Binding");
em2.appendChild(document.createTextNode(callback.getBinding()));
em.appendChild(em2);
}
if (callback.getSessionIdentifier() != null) {
Element em2 = createElementIso(document, "SessionIdentifier");
em2.appendChild(document.createTextNode(callback.getSessionIdentifier()));
em.appendChild(em2);
}
if (callback.getProtocolTerminationPoint() != null) {
Element em2 = createElementIso(document, "ProtocolTerminationPoint");
em2.appendChild(document.createTextNode(callback.getProtocolTerminationPoint()));
em.appendChild(em2);
}
if (callback.getPathSecurity() != null) {
PathSecurityType pathSecurityType = callback.getPathSecurity();
Element em2 = createElementIso(document, "PathSecurity");
Element em3 = createElementIso(document, "Protocol");
em3.appendChild(document.createTextNode(pathSecurityType.getProtocol()));
em2.appendChild(em3);
if (pathSecurityType.getParameters() != null) {
em3 = createElementIso(document, "Parameters");
em3.appendChild(document.createTextNode(pathSecurityType.getParameters().toString()));
em2.appendChild(em3);
}
em.appendChild(em2);
}
rootElement.appendChild(em);
}
} else if (o instanceof Connect) {
rootElement = createElementIso(document, o.getClass().getSimpleName());
rootElement.setAttribute("xmlns:iso", "urn:iso:std:iso-iec:24727:tech:schema");
Connect c = (Connect) o;
Element em = createElementIso(document, "ContextHandle");
em.appendChild(document.createTextNode(ByteUtils.toHexString(c.getContextHandle())));
rootElement.appendChild(em);
em = createElementIso(document, "IFDName");
em.appendChild(document.createTextNode(c.getIFDName()));
rootElement.appendChild(em);
em = createElementIso(document, "Slot");
em.appendChild(document.createTextNode(c.getSlot().toString()));
rootElement.appendChild(em);
if (c.isExclusive() != null) {
em = createElementIso(document, "Exclusive");
em.appendChild(document.createTextNode(c.isExclusive().toString()));
rootElement.appendChild(em);
}
} else if (o instanceof ConnectResponse) {
rootElement = createElementIso(document, o.getClass().getSimpleName());
rootElement.setAttribute("xmlns:iso", "urn:iso:std:iso-iec:24727:tech:schema");
ConnectResponse cr = (ConnectResponse) o;
Element em = createElementIso(document, "SlotHandle");
if (cr.getSlotHandle() != null) {
em.appendChild(document.createTextNode(ByteUtils.toHexString(cr.getSlotHandle())));
rootElement.appendChild(em);
}
em = marshalResult(cr.getResult(), document);
rootElement.appendChild(em);
} else if (o instanceof ListIFDs) {
rootElement = createElementIso(document, o.getClass().getSimpleName());
rootElement.setAttribute("xmlns:iso", "urn:iso:std:iso-iec:24727:tech:schema");
ListIFDs c = (ListIFDs) o;
Element em = createElementIso(document, "ContextHandle");
em.appendChild(document.createTextNode(ByteUtils.toHexString(c.getContextHandle())));
rootElement.appendChild(em);
} else if (o instanceof ListIFDsResponse) {
rootElement = createElementIso(document, o.getClass().getSimpleName());
rootElement.setAttribute("xmlns:iso", "urn:iso:std:iso-iec:24727:tech:schema");
ListIFDsResponse listIFDsResponse = (ListIFDsResponse) o;
for (String s : listIFDsResponse.getIFDName()) {
Element em = createElementIso(document, "IFDName");
em.appendChild(document.createTextNode(s));
rootElement.appendChild(em);
}
Element em = marshalResult(listIFDsResponse.getResult(), document);
rootElement.appendChild(em);
} else if (o instanceof Transmit) {
rootElement = createElementIso(document, o.getClass().getSimpleName());
rootElement.setAttribute("xmlns:iso", "urn:iso:std:iso-iec:24727:tech:schema");
Transmit t = (Transmit) o;
Element em = createElementIso(document, "SlotHandle");
em.appendChild(document.createTextNode(ByteUtils.toHexString(t.getSlotHandle())));
rootElement.appendChild(em);
for (int i = 0; i < t.getInputAPDUInfo().size(); i++) {
em = createElementIso(document, "InputAPDUInfo");
rootElement.appendChild(em);
Element em2 = createElementIso(document, "InputAPDU");
em2.appendChild(document.createTextNode(ByteUtils.toHexString(t.getInputAPDUInfo().get(i).getInputAPDU())));
em.appendChild(em2);
for (int y = 0; y < t.getInputAPDUInfo().get(i).getAcceptableStatusCode().size(); y++) {
em2 = createElementIso(document, "AcceptableStatusCode");
em2.appendChild(document.createTextNode(ByteUtils.toHexString(t.getInputAPDUInfo().get(i).getAcceptableStatusCode().get(y))));
em.appendChild(em2);
}
}
} else if (o instanceof RecognitionTree) {
rootElement = createElementIso(document, o.getClass().getSimpleName());
RecognitionTree recognitionTree = (RecognitionTree) o;
for (CardCall c : recognitionTree.getCardCall()) {
rootElement.appendChild(marshalCardCall(c, document));
}
} else if (o instanceof CardCall) {
CardCall c = (CardCall) o;
rootElement = (Element) marshalCardCall(c, document);
} else if (o instanceof Disconnect) {
Disconnect d = (Disconnect) o;
rootElement = createElementIso(document, d.getClass().getSimpleName());
Element em = createElementIso(document, "SlotHandle");
em.appendChild(document.createTextNode(ByteUtils.toHexString(d.getSlotHandle())));
rootElement.appendChild(em);
if (d.getAction() != null) {
em = createElementIso(document, "Action");
em.appendChild(document.createTextNode(d.getAction().value()));
}
} else if (o instanceof DisconnectResponse) {
rootElement = createElementIso(document, o.getClass().getSimpleName());
DisconnectResponse response = (DisconnectResponse) o;
String profile = response.getProfile();
if (profile != null) {
Element emProfile = createElementIso(document, "Profile");
emProfile.appendChild(document.createTextNode(profile));
rootElement.appendChild(emProfile);
}
String requestID = response.getRequestID();
if (requestID != null) {
Element emRequest = createElementIso(document, "RequestID");
emRequest.appendChild(document.createElement(requestID));
rootElement.appendChild(emRequest);
}
Element emResult = marshalResult(response.getResult(), document);
rootElement.appendChild(emResult);
} else if (o instanceof GetIFDCapabilities) {
GetIFDCapabilities getIFDCapabilities = (GetIFDCapabilities) o;
rootElement = createElementIso(document, o.getClass().getSimpleName());
Element emContextHandle = createElementIso(document, "ContextHandle");
emContextHandle.appendChild(document.createTextNode(ByteUtils.toHexString(getIFDCapabilities.getContextHandle())));
rootElement.appendChild(emContextHandle);
Element emIFDName = createElementIso(document, "IFDName");
emIFDName.appendChild(document.createTextNode(getIFDCapabilities.getIFDName()));
rootElement.appendChild(emIFDName);
} else if (o instanceof GetIFDCapabilitiesResponse) {
try {
GetIFDCapabilitiesResponse response = (GetIFDCapabilitiesResponse) o;
rootElement = createElementIso(document, o.getClass().getSimpleName());
String profile = response.getProfile();
if (profile != null) {
Element emProfile = createElementIso(document, "Profile");
emProfile.appendChild(document.createTextNode(profile));
rootElement.appendChild(emProfile);
}
String requestID = response.getRequestID();
if (requestID != null) {
Element emRequest = createElementIso(document, "RequestID");
emRequest.appendChild(document.createElement(requestID));
rootElement.appendChild(emRequest);
}
Element emResult = marshalResult(response.getResult(), document);
rootElement.appendChild(emResult);
if (response.getIFDCapabilities() != null) {
Element emIFDCaps = marshalIFDCapabilities(response.getIFDCapabilities(), document);
rootElement.appendChild(emIFDCaps);
}
} catch (Exception ex) {
LOG.error(ex.getMessage(), ex);
}
} else if (o instanceof TCTokenType) {
TCTokenType tctoken = (TCTokenType) o;
rootElement = document.createElement(o.getClass().getSimpleName());
Element em = document.createElement("ServerAddress");
em.appendChild(document.createTextNode(tctoken.getServerAddress()));
rootElement.appendChild(em);
em = document.createElement("SessionIdentifier");
em.appendChild(document.createTextNode(tctoken.getSessionIdentifier()));
rootElement.appendChild(em);
em = document.createElement("RefreshAddress");
em.appendChild(document.createTextNode(tctoken.getRefreshAddress()));
rootElement.appendChild(em);
// Optional element CommunicationErrorAddress
String communicationErrorAddress = tctoken.getCommunicationErrorAddress();
if (communicationErrorAddress != null) {
em = document.createElement("CommunicationErrorAddress");
em.appendChild(document.createTextNode(tctoken.getCommunicationErrorAddress()));
rootElement.appendChild(em);
}
em = document.createElement("Binding");
em.appendChild(document.createTextNode(tctoken.getBinding()));
rootElement.appendChild(em);
// Optional element PathSecurity-Protocol
String pathSecurityProtocol = tctoken.getPathSecurityProtocol();
if (pathSecurityProtocol != null) {
em = document.createElement("PathSecurity-Protocol");
em.appendChild(document.createTextNode(tctoken.getPathSecurityProtocol()));
rootElement.appendChild(em);
}
// Optional element PathSecurity-Parameters
TCTokenType.PathSecurityParameters pathSecurityParameters = tctoken.getPathSecurityParameters();
if (pathSecurityParameters != null) {
em = document.createElement("PSK");
em.appendChild(document.createTextNode(ByteUtils.toHexString(pathSecurityParameters.getPSK())));
Element em1 = document.createElement("PathSecurity-Parameters");
em1.appendChild(em);
rootElement.appendChild(em1);
}
} else if (o instanceof CardApplicationPath) {
CardApplicationPath p = (CardApplicationPath) o;
rootElement = createElementIso(document, "CardApplicationPath");
Element em = createElementIso(document, "CardAppPathRequest");
String profile = p.getProfile();
if (profile != null) {
Element emProfile = createElementIso(document, "Profile");
emProfile.appendChild(document.createTextNode(profile));
rootElement.appendChild(emProfile);
}
String requestID = p.getRequestID();
if (requestID != null) {
Element emRequest = createElementIso(document, "RequestID");
emRequest.appendChild(document.createElement(requestID));
rootElement.appendChild(emRequest);
}
// ChannelHandle
ChannelHandleType h = p.getCardAppPathRequest().getChannelHandle();
Element emChild = createElementIso(document, "ChannelHandle");
em.appendChild(emChild);
Element emChildOfCH;
if (h.getProtocolTerminationPoint() != null) {
emChildOfCH = createElementIso(document, "ProtocolTerminationPoint");
emChildOfCH.appendChild(document.createTextNode(h.getProtocolTerminationPoint()));
emChild.appendChild(emChildOfCH);
}
if (h.getSessionIdentifier() != null) {
emChildOfCH = createElementIso(document, "SessionIdentifier");
emChildOfCH.appendChild(document.createTextNode(h.getSessionIdentifier()));
emChild.appendChild(emChildOfCH);
}
if (h.getBinding() != null) {
emChildOfCH = createElementIso(document, "Binding");
emChildOfCH.appendChild(document.createTextNode(h.getBinding()));
emChild.appendChild(emChildOfCH);
}
PathSecurityType ps = h.getPathSecurity();
if (ps != null) {
emChildOfCH = createElementIso(document, "PathSecurity");
Element emChildOfPS = createElementIso(document, "Protocol");
emChildOfPS.appendChild(document.createTextNode(ps.getProtocol()));
emChildOfCH.appendChild(emChildOfPS);
// TODO here any type parsen
LOG.error("AnyType of CardApplicationPath: " + ps.getParameters().toString());
emChild.appendChild(emChildOfCH);
}
// context handle
emChild = createElementIso(document, "ContextHandle");
emChild.appendChild(document.createTextNode(ByteUtils.toHexString(p.getCardAppPathRequest().getContextHandle())));
em.appendChild(emChild);
// IFDName
emChild = createElementIso(document, "IFDName");
emChild.appendChild(document.createTextNode(p.getCardAppPathRequest().getIFDName()));
em.appendChild(emChild);
// SlotIndex
emChild = createElementIso(document, "SlotIndex");
emChild.appendChild(document.createTextNode(p.getCardAppPathRequest().getSlotIndex().toString()));
em.appendChild(emChild);
// Card Application
emChild = createElementIso(document, "CardApplication");
emChild.appendChild(document.createTextNode(ByteUtils.toHexString(p.getCardAppPathRequest().getCardApplication())));
em.appendChild(emChild);
rootElement.appendChild(em);
} else if (o instanceof CardApplicationPathResponse) {
CardApplicationPathResponse resp = (CardApplicationPathResponse) o;
rootElement = createElementIso(document, "CardApplicationPathResponse");
String profile = resp.getProfile();
if (profile != null) {
Element emProfile = createElementIso(document, "Profile");
emProfile.appendChild(document.createTextNode(profile));
rootElement.appendChild(emProfile);
}
String requestID = resp.getRequestID();
if (requestID != null) {
Element emRequest = createElementIso(document, "RequestID");
emRequest.appendChild(document.createElement(requestID));
rootElement.appendChild(emRequest);
}
Result result = resp.getResult();
if (result != null) {
Element emResult = marshalResult(resp.getResult(), document);
rootElement.appendChild(emResult);
}
Element em = createElementIso(document, "CardAppPathResultSet");
for (CardApplicationPathType path : resp.getCardAppPathResultSet().getCardApplicationPathResult()) {
em.appendChild(marshalCardApplicationPathResult(path, document, "CardAppPathRequest"));
}
rootElement.appendChild(em);
} else if (o instanceof BeginTransaction) {
BeginTransaction t = (BeginTransaction) o;
rootElement = createElementIso(document, "BeginTransaction");
Element em = createElementIso(document, "SlotHandle");
em.appendChild(document.createTextNode(ByteUtils.toHexString(t.getSlotHandle())));
rootElement.appendChild(em);
} else if (o instanceof BeginTransactionResponse) {
BeginTransactionResponse response = (BeginTransactionResponse) o;
rootElement = createElementIso(document, "BeginTransactionResponse");
String profile = response.getProfile();
if (profile != null) {
Element emProfile = createElementIso(document, "Profile");
emProfile.appendChild(document.createTextNode(profile));
rootElement.appendChild(emProfile);
}
String requestID = response.getRequestID();
if (requestID != null) {
Element emRequest = createElementIso(document, "RequestID");
emRequest.appendChild(document.createElement(requestID));
rootElement.appendChild(emRequest);
}
Element emResult = marshalResult(response.getResult(), document);
rootElement.appendChild(emResult);
} else if (o instanceof EndTransaction) {
EndTransaction end = (EndTransaction) o;
rootElement = createElementIso(document, "EndTransaction");
Element em = createElementIso(document, "SlotHandle");
em.appendChild(document.createTextNode(ByteUtils.toHexString(end.getSlotHandle())));
rootElement.appendChild(em);
} else if (o instanceof EndTransactionResponse) {
EndTransactionResponse response = (EndTransactionResponse) o;
rootElement = createElementIso(document, "EndTransactionResponse");
String profile = response.getProfile();
if (profile != null) {
Element emProfile = createElementIso(document, "Profile");
emProfile.appendChild(document.createTextNode(profile));
rootElement.appendChild(emProfile);
}
String requestID = response.getRequestID();
if (requestID != null) {
Element emRequest = createElementIso(document, "RequestID");
emRequest.appendChild(document.createElement(requestID));
rootElement.appendChild(emRequest);
}
Element emResult = marshalResult(response.getResult(), document);
rootElement.appendChild(emResult);
} else if (o instanceof CardApplicationConnect) {
CardApplicationConnect c = (CardApplicationConnect) o;
rootElement = createElementIso(document, "CardApplicationConnect");
// Card Application Path
rootElement.appendChild(marshalCardApplicationPathResult(c.getCardApplicationPath(), document, "CardApplicationPath"));
Element em;
if (c.getOutput() != null) {
em = createElementIso(document, "Output");
em.appendChild(marshalOutput(c.getOutput(), document));
rootElement.appendChild(em);
}
// Exclusive Use
if (c.isExclusiveUse() != null) {
em = createElementIso(document, "ExclusiveUse");
em.appendChild(document.createTextNode(Boolean.toString(c.isExclusiveUse())));
rootElement.appendChild(em);
}
} else if (o instanceof CardApplicationConnectResponse) {
CardApplicationConnectResponse resp = (CardApplicationConnectResponse) o;
rootElement = createElementIso(document, "CardApplicationConnectResponse");
appendResponseValues(resp.getProfile(), resp.getRequestID(), resp.getResult(), rootElement, document);
ConnectionHandleType ch = resp.getConnectionHandle();
if (ch != null) {
Element em = marshalConnectionHandle(ch, document);
rootElement.appendChild(em);
}
} else if (o instanceof CardApplicationDisconnect) {
CardApplicationDisconnect c = (CardApplicationDisconnect) o;
rootElement = createElementIso(document, "CardApplicationDisconnect");
if (c.getConnectionHandle() != null) {
rootElement.appendChild(marshalConnectionHandle(c.getConnectionHandle(), document));
}
if (c.getAction() != null) {
Element em = createElementIso(document, "Action");
em.appendChild(document.createTextNode(c.getAction().value()));
rootElement.appendChild(em);
}
String profile = c.getProfile();
if (profile != null) {
Element emProfile = createElementIso(document, "Profile");
emProfile.appendChild(document.createTextNode(profile));
rootElement.appendChild(emProfile);
}
String requestID = c.getRequestID();
if (requestID != null) {
Element emRequest = createElementIso(document, "RequestID");
emRequest.appendChild(document.createElement(requestID));
rootElement.appendChild(emRequest);
}
} else if (o instanceof CardApplicationDisconnectResponse) {
CardApplicationDisconnectResponse response = (CardApplicationDisconnectResponse) o;
rootElement = createElementIso(document, "CardApplicationDisconnectResponse");
String profile = response.getProfile();
if (profile != null) {
Element emProfile = createElementIso(document, "Profile");
emProfile.appendChild(document.createTextNode(profile));
rootElement.appendChild(emProfile);
}
String requestID = response.getRequestID();
if (requestID != null) {
Element emRequest = createElementIso(document, "RequestID");
emRequest.appendChild(document.createElement(requestID));
rootElement.appendChild(emRequest);
}
if (response.getResult() != null) {
Element emResult = marshalResult(response.getResult(), document);
rootElement.appendChild(emResult);
}
} else {
throw new IllegalArgumentException("Cannot marshal " + o.getClass().getSimpleName());
}
document.appendChild(rootElement);
return document;
}
use of generated.TCTokenType in project open-ecard by ecsec.
the class TlsConnectionHandler method setUpClient.
public void setUpClient() throws ConnectionError {
try {
TCTokenType token = tokenRequest.getTCToken();
String cardType = null;
if (handle != null) {
if (handle.getRecognitionInfo() != null) {
cardType = handle.getRecognitionInfo().getCardType();
}
if (cardType == null) {
cardType = tokenRequest.getCardType();
}
}
// eID servers usually have problems with sni, so disable it for them
// TODO: check occasionally if this still holds
boolean doSni = !"http://bsi.bund.de/cif/npa.xml".equals(cardType);
sessionId = token.getSessionIdentifier();
serverAddress = new URL(token.getServerAddress());
String serverHost = serverAddress.getHost();
if (Boolean.valueOf(OpenecardProperties.getProperty("legacy.session"))) {
serverAddress = fixServerAddress(serverAddress, sessionId);
}
// extract connection parameters from endpoint
hostname = serverAddress.getHost();
port = serverAddress.getPort();
if (port == -1) {
port = serverAddress.getDefaultPort();
}
resource = serverAddress.getFile();
resource = resource.isEmpty() ? "/" : resource;
String secProto = token.getPathSecurityProtocol();
// use same channel as demanded in TR-03124 sec. 2.4.3
if (isSameChannel()) {
tlsClient = tokenRequest.getTokenContext().getTlsClient();
if (tlsClient instanceof ClientCertDefaultTlsClient) {
((ClientCertDefaultTlsClient) tlsClient).setEnforceSameSession(true);
}
} else {
// kill open channel in tctoken request, it is not needed anymore
if (tokenRequest.getTokenContext() != null) {
tokenRequest.getTokenContext().closeStream();
}
// determine TLS version to use
ProtocolVersion version = ProtocolVersion.TLSv12;
ProtocolVersion minVersion = ProtocolVersion.TLSv12;
switch(secProto) {
case "urn:ietf:rfc:5246":
// no changes
break;
case "urn:ietf:rfc:4279":
minVersion = ProtocolVersion.TLSv11;
break;
}
// Set up TLS connection
DynamicAuthentication tlsAuth = new DynamicAuthentication(serverHost);
TlsCrypto crypto = new BcTlsCrypto(ReusableSecureRandom.getInstance());
switch(secProto) {
case "urn:ietf:rfc:4279":
{
byte[] psk = token.getPathSecurityParameters().getPSK();
TlsPSKIdentity pskId = new BasicTlsPSKIdentity(sessionId, psk);
tlsClient = new ClientCertPSKTlsClient(crypto, pskId, serverHost, doSni);
tlsClient.setClientVersion(version);
tlsClient.setMinimumVersion(minVersion);
break;
}
case "urn:ietf:rfc:5246":
{
// use a smartcard for client authentication if needed
tlsAuth.setCredentialFactory(makeSmartCardCredential());
tlsClient = new ClientCertDefaultTlsClient(crypto, serverHost, doSni);
tlsClient.setClientVersion(version);
tlsClient.setMinimumVersion(minVersion);
// add PKIX verifier
if (verifyCertificates) {
tlsAuth.addCertificateVerifier(new JavaSecVerifier());
}
break;
}
default:
throw new ConnectionError(UNKNOWN_SEC_PROTOCOL, secProto);
}
// make sure nobody changes the server when the connection gets reestablished
tlsAuth.addCertificateVerifier(new SameCertVerifier());
// save eService certificate for use in EAC
tlsAuth.addCertificateVerifier(new SaveEServiceCertHandler());
// set the authentication class in the tls client
tlsClient.setAuthentication(tlsAuth);
}
} catch (MalformedURLException ex) {
throw new ConnectionError(MALFORMED_URL, ex, "ServerAddress");
}
}
use of generated.TCTokenType in project open-ecard by ecsec.
the class TCTokenParserTest method testParseMalformed.
@Test
public void testParseMalformed() throws Exception {
String data = FileUtils.toString(FileUtils.resolveResourceAsStream(getClass(), "TCToken-malformed.xml"));
data = TCTokenHacks.fixPathSecurityParameters(data);
TCTokenParser parser = new TCTokenParser();
List<TCToken> tokens = parser.parse(data);
TCTokenType t = tokens.get(0);
assertEquals(t.getSessionIdentifier(), "3eab1b41ecc1ce5246acf6f4e275");
assertEquals(t.getServerAddress().toString(), "https://eid-ref.my-service.de:443");
assertEquals(t.getRefreshAddress().toString(), "https://eid.services.my.net:443/?sessionID=D9D6851A7C02167A5699DA57657664715F4D9C44E50A94F7A83909D24AFA997A");
assertEquals(t.getBinding(), "urn:liberty:paos:2006-08");
assertEquals(t.getPathSecurityParameters().getPSK(), StringUtils.toByteArray("b7e9dd2ba2568c3c8d572aaadb3eebf7d4515e66d5fc2fd8e46626725a9abba2"));
}
use of generated.TCTokenType in project open-ecard by ecsec.
the class TCTokenParserTest method testParse.
@Test(enabled = true)
public void testParse() throws Exception {
InputStream testFile = FileUtils.resolveResourceAsStream(getClass(), "TCToken.xml");
TCTokenParser parser = new TCTokenParser();
List<TCToken> tokens = parser.parse(testFile);
TCTokenType t = tokens.get(0);
assertEquals(t.getSessionIdentifier(), "3eab1b41ecc1ce5246acf6f4e2751234");
assertEquals(t.getServerAddress().toString(), "https://eid-ref.my-service.de:443");
assertEquals(t.getRefreshAddress().toString(), "https://eid.services.my.net:443/?sessionID=D9D6851A7C02167A5699DA57657664715F4D9C44E50A94F7A83909D24AFA997A");
assertEquals(t.getBinding(), "urn:liberty:paos:2006-08");
}
use of generated.TCTokenType in project open-ecard by ecsec.
the class TlsConnectionHandler method isSameChannel.
public boolean isSameChannel() {
TCTokenType token = tokenRequest.getTCToken();
String secProto = token.getPathSecurityProtocol();
// check security proto
if (secProto == null || "".equals(secProto)) {
return true;
}
// check PSK value
if (secProto.equals("urn:ietf:rfc:4279")) {
TCTokenType.PathSecurityParameters pathsecParams = token.getPathSecurityParameters();
return pathsecParams == null || pathsecParams.getPSK() == null || pathsecParams.getPSK().length == 0;
} else {
return false;
}
}
Aggregations