/*
* Copyright 2011 by Graz University of Technology, Austria
* MOCCA has been developed by the E-Government Innovation Center EGIZ, a joint
* initiative of the Federal Chancellery Austria and Graz University of Technology.
*
* Licensed under the EUPL, Version 1.1 or - as soon they will be approved by
* the European Commission - subsequent versions of the EUPL (the "Licence");
* You may not use this work except in compliance with the Licence.
* You may obtain a copy of the Licence at:
* http://www.osor.eu/eupl/
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the Licence is distributed on an "AS IS" basis,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the Licence for the specific language governing permissions and
* limitations under the Licence.
*
* This product combines work with different licenses. See the "NOTICE" text
* file for details on the various modules and licenses.
* The "NOTICE" text file is part of the distribution. Any derivative works
* that you distribute must include a readable copy of the "NOTICE" text file.
*/
package at.gv.egiz.bku.slcommands.impl;
import javax.xml.bind.JAXBElement;
import javax.xml.bind.JAXBException;
import javax.xml.bind.Marshaller;
import javax.xml.transform.Result;
import javax.xml.transform.Templates;
import javax.xml.transform.dom.DOMResult;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import at.buergerkarte.namespaces.securitylayer._1_2_3.CreateCMSSignatureResponseType;
import at.buergerkarte.namespaces.securitylayer._1_2_3.ObjectFactory;
import at.gv.egiz.bku.slcommands.CreateCMSSignatureResult;
import at.gv.egiz.bku.slcommands.SLMarshallerFactory;
import at.gv.egiz.bku.slexceptions.SLRuntimeException;
/**
* This implements the result of the security layer command CreateCMSSignature
.
*
* @author tkellner
*/
public class CreateCMSSignatureResultImpl extends SLResultImpl implements CreateCMSSignatureResult {
/**
* Logging facility.
*/
private final Logger log = LoggerFactory.getLogger(CreateCMSSignatureResultImpl.class);
/**
* The CMSSignature data.
*/
protected byte[] signature;
/**
* The CMSSignatureResponse.
*/
private Element content;
/**
* Creates a new instance of this CreateCMSSignatureResultImpl with the given
* signature signature
.
*
* @param document the signature document
*
* @throws NullPointerException if document
is null
*/
public CreateCMSSignatureResultImpl(byte[] signature) {
super();
if (signature == null)
throw new NullPointerException("Argument 'signature' must not be null.");
this.signature = signature;
marshallCreateCMSSignatureResponse();
}
/**
* Marshalls the CreateCMSSignatureResponse
.
*/
private void marshallCreateCMSSignatureResponse() {
ObjectFactory factory = new ObjectFactory();
CreateCMSSignatureResponseType createCreateCMSSignatureResponseType = factory.createCreateCMSSignatureResponseType();
createCreateCMSSignatureResponseType.setCMSSignature(signature);
JAXBElement createCreateCMSSignatureResponse = factory.createCreateCMSSignatureResponse(createCreateCMSSignatureResponseType);
DOMResult res = new DOMResult();
Marshaller marshaller = SLMarshallerFactory.getInstance().createMarshaller(false);
try {
marshaller.marshal(createCreateCMSSignatureResponse, res);
} catch (JAXBException e) {
log.error("Failed to marshall 'CreateCMSSignatureResponse'.", e);
throw new SLRuntimeException(e);
}
content = ((Document)res.getNode()).getDocumentElement();
}
@Override
public void writeTo(Result result, Templates templates, boolean fragment) {
writeTo(content, result, templates, fragment);
}
@Override
public Element getContent() {
return content;
}
}