org.jboss.as.webservices.dmr.WSSubsystemReader Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jbossws-wildfly821-server-integration
Show all versions of jbossws-wildfly821-server-integration
JBossWS WildFly 8.2.1.Final Server Side Integration
The newest version!
/*
* JBoss, Home of Professional Open Source.
* Copyright 2012, Red Hat, Inc., and individual contributors
* as indicated by the @author tags. See the copyright.txt file in the
* distribution for a full listing of individual contributors.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.jboss.as.webservices.dmr;
import static javax.xml.stream.XMLStreamConstants.END_ELEMENT;
import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.OP_ADDR;
import static org.jboss.as.controller.parsing.ParseUtils.requireNoAttributes;
import static org.jboss.as.controller.parsing.ParseUtils.requireNoNamespaceAttribute;
import static org.jboss.as.controller.parsing.ParseUtils.unexpectedAttribute;
import static org.jboss.as.controller.parsing.ParseUtils.unexpectedElement;
import static org.jboss.as.webservices.dmr.Constants.CLIENT_CONFIG;
import static org.jboss.as.webservices.dmr.Constants.ENDPOINT_CONFIG;
import static org.jboss.as.webservices.dmr.Constants.HANDLER;
import static org.jboss.as.webservices.dmr.Constants.POST_HANDLER_CHAIN;
import static org.jboss.as.webservices.dmr.Constants.PRE_HANDLER_CHAIN;
import static org.jboss.as.webservices.dmr.Constants.PROPERTY;
import java.util.ArrayList;
import java.util.EnumSet;
import java.util.LinkedList;
import java.util.List;
import javax.xml.stream.XMLStreamException;
import org.jboss.as.controller.PathAddress;
import org.jboss.as.controller.operations.common.Util;
import org.jboss.as.controller.parsing.ParseUtils;
import org.jboss.dmr.ModelNode;
import org.jboss.staxmapper.XMLElementReader;
import org.jboss.staxmapper.XMLExtendedStreamReader;
/**
* @author Richard Opalka
* @author Alessio Soldano
*/
final class WSSubsystemReader implements XMLElementReader> {
private static final WSSubsystemReader INSTANCE = new WSSubsystemReader();
private WSSubsystemReader() {
// forbidden instantiation
}
static WSSubsystemReader getInstance() {
return INSTANCE;
}
@Override
public void readElement(final XMLExtendedStreamReader reader, final List list) throws XMLStreamException {
// no attributes
requireNoAttributes(reader);
final PathAddress address = PathAddress.pathAddress(WSExtension.SUBSYSTEM_PATH);
final ModelNode subsystem = Util.createAddOperation(address);
final List endpointConfigs = new ArrayList();
final List clientConfigs = new ArrayList();
// elements
final EnumSet encountered = EnumSet.noneOf(Element.class);
while (reader.hasNext() && reader.nextTag() != END_ELEMENT) {
switch (Namespace.forUri(reader.getNamespaceURI())) {
case WEBSERVICES_1_1: {
final Element element = Element.forName(reader.getLocalName());
if (element != Element.ENDPOINT_CONFIG && !encountered.add(element)) {
throw unexpectedElement(reader);
}
switch (element) {
case MODIFY_WSDL_ADDRESS: {
final String value = parseElementNoAttributes(reader);
Attributes.MODIFY_WSDL_ADDRESS.parseAndSetParameter(value, subsystem, reader);
break;
}
case WSDL_HOST: {
final String value = parseElementNoAttributes(reader);
Attributes.WSDL_HOST.parseAndSetParameter(value, subsystem, reader);
break;
}
case WSDL_PORT: {
final String value = parseElementNoAttributes(reader);
Attributes.WSDL_PORT.parseAndSetParameter(value, subsystem, reader);
break;
}
case WSDL_SECURE_PORT: {
final String value = parseElementNoAttributes(reader);
Attributes.WSDL_SECURE_PORT.parseAndSetParameter(value, subsystem, reader);
break;
}
case ENDPOINT_CONFIG: {
readConfig(reader, address, endpointConfigs, false);
break;
}
default: {
throw unexpectedElement(reader);
}
}
break;
}
case WEBSERVICES_1_2: {
final Element element = Element.forName(reader.getLocalName());
if (element != Element.ENDPOINT_CONFIG && element != Element.CLIENT_CONFIG && !encountered.add(element)) {
throw unexpectedElement(reader);
}
switch (element) {
case MODIFY_WSDL_ADDRESS: {
final String value = parseElementNoAttributes(reader);
Attributes.MODIFY_WSDL_ADDRESS.parseAndSetParameter(value, subsystem, reader);
break;
}
case WSDL_HOST: {
final String value = parseElementNoAttributes(reader);
Attributes.WSDL_HOST.parseAndSetParameter(value, subsystem, reader);
break;
}
case WSDL_PORT: {
final String value = parseElementNoAttributes(reader);
Attributes.WSDL_PORT.parseAndSetParameter(value, subsystem, reader);
break;
}
case WSDL_SECURE_PORT: {
final String value = parseElementNoAttributes(reader);
Attributes.WSDL_SECURE_PORT.parseAndSetParameter(value, subsystem, reader);
break;
}
case ENDPOINT_CONFIG: {
readConfig(reader, address, endpointConfigs, false);
break;
}
case CLIENT_CONFIG: {
readConfig(reader, address, clientConfigs, true);
break;
}
default: {
throw unexpectedElement(reader);
}
}
break;
}
default: {
throw unexpectedElement(reader);
}
}
}
list.add(subsystem);
list.addAll(endpointConfigs);
list.addAll(clientConfigs);
}
private String parseElementNoAttributes(final XMLExtendedStreamReader reader) throws XMLStreamException {
// no attributes
requireNoAttributes(reader);
return reader.getElementText().trim();
}
private void readConfig(final XMLExtendedStreamReader reader, final PathAddress parentAddress, final List operationList, final boolean client) throws XMLStreamException {
String configName = null;
final int count = reader.getAttributeCount();
for (int i = 0; i < count; i++) {
requireNoNamespaceAttribute(reader, i);
final String value = reader.getAttributeValue(i);
final Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case NAME:
configName = value;
break;
default:
throw unexpectedAttribute(reader, i);
}
}
final PathAddress address = parentAddress.append(client ? CLIENT_CONFIG : ENDPOINT_CONFIG, configName);
final ModelNode node = Util.createAddOperation(address);
operationList.add(node);
final EnumSet encountered = EnumSet.noneOf(Element.class);
while (reader.nextTag() != END_ELEMENT) {
final Element element = Element.forName(reader.getLocalName());
if (element != Element.PRE_HANDLER_CHAIN && element != Element.POST_HANDLER_CHAIN && element != Element.PROPERTY
&& !encountered.add(element)) {
throw unexpectedElement(reader);
}
switch (element) {
case PRE_HANDLER_CHAIN: {
parseHandlerChain(reader, operationList, true, address);
break;
}
case POST_HANDLER_CHAIN: {
parseHandlerChain(reader, operationList, false, address);
break;
}
case PROPERTY: {
final ModelNode operation = parseProperty(reader, address);
operationList.add(operation);
break;
}
default: {
throw unexpectedElement(reader);
}
}
}
}
private ModelNode parseProperty(final XMLExtendedStreamReader reader, PathAddress parentAddress) throws XMLStreamException {
final ModelNode operation = Util.createAddOperation(null);
String propertyName = null;
final int count = reader.getAttributeCount();
for (int i = 0; i < count; i++) {
requireNoNamespaceAttribute(reader, i);
final String value = reader.getAttributeValue(i);
final Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case NAME:
propertyName = value;
break;
case VALUE:
Attributes.VALUE.parseAndSetParameter(value, operation, reader);
break;
default:
throw unexpectedAttribute(reader, i);
}
}
ParseUtils.requireNoContent(reader);
operation.get(OP_ADDR).set(parentAddress.append(PROPERTY, propertyName).toModelNode());
return operation;
}
private void parseHandlerChain(final XMLExtendedStreamReader reader, final List operationList, final boolean isPreHandlerChain, PathAddress parentAddress)
throws XMLStreamException {
final ModelNode operation = Util.createAddOperation();
String handlerChainId = null;
final int count = reader.getAttributeCount();
for (int i = 0; i < count; i++) {
requireNoNamespaceAttribute(reader, i);
final String value = reader.getAttributeValue(i);
final Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case NAME:
handlerChainId = value;
break;
case PROTOCOL_BINDINGS:
Attributes.PROTOCOL_BINDINGS.parseAndSetParameter(value, operation, reader);
break;
default:
throw unexpectedAttribute(reader, i);
}
}
final String handlerChainType = isPreHandlerChain ? PRE_HANDLER_CHAIN : POST_HANDLER_CHAIN;
PathAddress address = parentAddress.append(handlerChainType, handlerChainId);
operation.get(OP_ADDR).set(address.toModelNode());
final EnumSet encountered = EnumSet.noneOf(Element.class);
final List addHandlerOperations = new LinkedList();
while (reader.nextTag() != END_ELEMENT) {
final Element element = Element.forName(reader.getLocalName());
if (element != Element.HANDLER && !encountered.add(element)) {
throw unexpectedElement(reader);
}
switch (element) {
case HANDLER: {
parseHandler(reader, addHandlerOperations, address);
break;
}
default: {
throw unexpectedElement(reader);
}
}
}
operationList.add(operation);
operationList.addAll(addHandlerOperations);
}
private void parseHandler(final XMLExtendedStreamReader reader, final List operations, PathAddress parentAddress) throws XMLStreamException {
String handlerName = null;
final ModelNode operation = Util.createAddOperation();
final int count = reader.getAttributeCount();
for (int i = 0; i < count; i++) {
requireNoNamespaceAttribute(reader, i);
final String value = reader.getAttributeValue(i);
final Attribute attribute = Attribute.forName(reader.getAttributeLocalName(i));
switch (attribute) {
case NAME:
handlerName = value;
break;
case CLASS:
Attributes.CLASS.parseAndSetParameter(value, operation, reader);
break;
default:
throw unexpectedAttribute(reader, i);
}
}
ParseUtils.requireNoContent(reader);
operation.get(OP_ADDR).set(parentAddress.append(HANDLER, handlerName).toModelNode());
operations.add(operation);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy