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

com.helger.smpclient.peppol.utils.W3CEndpointReferenceHelper Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (C) 2015-2024 Philip Helger
 * philip[at]helger[dot]com
 *
 * Licensed 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 com.helger.smpclient.peppol.utils;

import javax.annotation.Nonnegative;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import javax.annotation.concurrent.Immutable;
import javax.xml.transform.dom.DOMResult;

import org.w3c.dom.Document;
import org.w3c.dom.Element;

import com.helger.commons.ValueEnforcer;
import com.helger.commons.annotation.PresentForCodeCoverage;
import com.helger.commons.collection.impl.CommonsArrayList;
import com.helger.commons.collection.impl.ICommonsList;
import com.helger.xml.ChildElementIterator;
import com.helger.xml.XMLFactory;
import com.helger.xml.XMLHelper;

import jakarta.xml.ws.wsaddressing.W3CEndpointReference;
import jakarta.xml.ws.wsaddressing.W3CEndpointReferenceBuilder;

/**
 * As the default WS-Addressing binding since JAXB 2.1 uses the
 * {@link W3CEndpointReference} class, we must also use this class, otherwise
 * JAXB would complain, that there are 2 contexts for the same namespace+element
 * combination.
* The issue with {@link W3CEndpointReference} is that it can easily be created * using the {@link W3CEndpointReferenceBuilder} class, but it's not possible to * extract information from it (get....). This class offers a workaround by * using DOM serialization to access the content of a * {@link W3CEndpointReference}. In case the serialization tag names of * {@link W3CEndpointReference} change, this implementation has to be adopted! *
* The JIRA issue JAX_WS-1132 was filed to help dealing with this issue. * * @author Philip Helger */ @Immutable public final class W3CEndpointReferenceHelper { @PresentForCodeCoverage private static final W3CEndpointReferenceHelper INSTANCE = new W3CEndpointReferenceHelper (); private W3CEndpointReferenceHelper () {} /** * Create a new endpoint reference for the given address without reference * parameters. * * @param sAddress * The address to use. May not be null but may be empty to * . * @return The non-null endpoint reference for the given address */ @Nonnull public static W3CEndpointReference createEndpointReference (@Nonnull final String sAddress) { ValueEnforcer.notNull (sAddress, "Address"); return new W3CEndpointReferenceBuilder ().address (sAddress).build (); } /** * Create a new endpoint reference for the given address, using the specified * reference parameters. * * @param sAddress * The address to use. May not be null but may be empty. * @param aReferenceParameters * The non-null list of reference parameters. May not be * null. * @return The non-null endpoint reference for the given address */ @Nonnull public static W3CEndpointReference createEndpointReference (@Nonnull final String sAddress, @Nonnull final Iterable aReferenceParameters) { ValueEnforcer.notNull (sAddress, "Address"); W3CEndpointReferenceBuilder aBuilder = new W3CEndpointReferenceBuilder ().address (sAddress); for (final Element aReferenceParameter : aReferenceParameters) aBuilder = aBuilder.referenceParameter (aReferenceParameter); return aBuilder.build (); } /** * Marshal the passed endpoint reference to a DOM document and return the * document element.
* This is necessary, as {@link W3CEndpointReference} does not provide read * access methods. * * @param aEndpointReference * The endpoint to be marshaled. May not be null. * @return The document element called "EndpointReference" */ @Nonnull private static Element _convertReferenceToXML (@Nonnull final W3CEndpointReference aEndpointReference) { final Document aDoc = XMLFactory.newDocument (); final DOMResult ret = new DOMResult (aDoc); aEndpointReference.writeTo (ret); return aDoc.getDocumentElement (); } /** * Get the address contained in the passed endpoint reference.
* See https://github.com/jakartaee/jax-ws-api/issues/167 why this is done so * stupidly * * @param aEndpointReference * The endpoint reference to retrieve the address from. May not be * null. * @return The contained address. */ @Nullable public static String getAddress (@Nonnull final W3CEndpointReference aEndpointReference) { ValueEnforcer.notNull (aEndpointReference, "EndpointReference"); final Element eAddress = XMLHelper.getFirstChildElementOfName (_convertReferenceToXML (aEndpointReference), "Address"); return eAddress == null ? null : eAddress.getTextContent (); } /** * Get a list of all reference parameters contained in the passed endpoint * reference. * * @param aEndpointReference * The endpoint reference to retrieve the reference parameters. May not * be null. * @return A mutable element list */ @Nullable public static ICommonsList getReferenceParameters (@Nonnull final W3CEndpointReference aEndpointReference) { ValueEnforcer.notNull (aEndpointReference, "EndpointReference"); final Element eRefParams = XMLHelper.getFirstChildElementOfName (_convertReferenceToXML (aEndpointReference), "ReferenceParameters"); if (eRefParams == null) return null; // All all child elements of ReferenceParameters :) return new CommonsArrayList <> (new ChildElementIterator (eRefParams)); } /** * Get the reference parameter at the given index * * @param aEndpointReference * The object to retrieve the reference parameter from. May not be * null. * @param nIndex * The index to retrieve. Must be ≥ 0. * @return null if the index is invalid */ @Nullable public static Element getReferenceParameter (@Nonnull final W3CEndpointReference aEndpointReference, @Nonnegative final int nIndex) { ValueEnforcer.notNull (aEndpointReference, "EndpointReference"); ValueEnforcer.isGE0 (nIndex, "Index"); // Get all reference parameters final ICommonsList aReferenceParameters = getReferenceParameters (aEndpointReference); // And extract the one at the desired index. return aReferenceParameters == null ? null : aReferenceParameters.getAtIndex (nIndex); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy