Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
   * JBoss, Home of Professional Open Source
   * Copyright 2011 Red Hat Inc. and/or its affiliates and other contributors
   * as indicated by the @authors tag. All rights reserved.
   * See the copyright.txt in the distribution for a
   * full listing of individual contributors.
   * This copyrighted material is made available to anyone wishing to use,
   * modify, copy, or redistribute it subject to the terms and conditions
  * of the GNU Lesser General Public License, v. 2.1.
  * This program is distributed in the hope that it will be useful, but WITHOUT A
  * 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,
  * v.2.1 along with this distribution; if not, write to the Free Software
  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
  * MA  02110-1301, USA.
 import static;
 import static;
 import static;
 import static;
 import static;
 import static;
 import static;
Handles addition of a deployment to the model.

Brian Stansberry (c) 2011 Red Hat Inc.
 public class DeploymentAddHandler implements OperationStepHandler {
     public static final String OPERATION_NAME = ;
     private final ContentRepository contentRepository;

Constructor for a slave Host Controller
     public DeploymentAddHandler() {

Constructor for a master Host Controller

contentRepository the master content repository. If null this handler will function as a slave handler would.
     public DeploymentAddHandler(final ContentRepository contentRepository) {
         this. = contentRepository;

     public void execute(OperationContext contextModelNode operationthrows OperationFailedException {
         final Resource resource = context.createResource(.);
         ModelNode newModel = resource.getModel();
         // Store the rest of the attributes.
         // If we correct any of them (e.g. WFLY-3184) then pass the correction on to any slaves
         ModelNode correctedOperation = operation.clone();
         for (AttributeDefinition def : ) {
         // TODO: JBAS-9020: for the moment overlays are not supported, so there is a single content item
         ModelNode content = newModel.require(.getName());
         ModelNode contentItemNode = content.require(0);
         final ModelNode opAddr = correctedOperation.get();
         PathAddress address = PathAddress.pathAddress(opAddr);
         final String name = address.getLastElement().getValue();
         if (!newModel.hasDefined(.getName())) {
         byte[] hash = null;
         if (contentItemNode.hasDefined(.getName())) {
             hash = contentItemNode.require(.getName()).asBytes();
            // If we are the master, validate that we actually have this content. If we're not the master
            // we do not need the content until it's added to a server group we care about, so we defer
            // pulling it until then
            if ( != null && !.hasContent(hash)) {
                if (context.isBooting()) {
                    if (context.getRunningMode() == .) {
                        // The deployment content is missing, which would be a fatal boot error if we were going to actually
                        // install services. In ADMIN-ONLY mode we allow it to give the admin a chance to correct the problem
                        ..reportAdminOnlyMissingDeploymentContent(HashUtil.bytesToHexString(hash), name);
                    } else {
                        throw createFailureException(.noDeploymentContentWithHashAtBoot(HashUtil.bytesToHexString(hash), name));
                } else {
                    throw createFailureException(.noDeploymentContentWithHash(HashUtil.bytesToHexString(hash)));
        } else if (DeploymentHandlerUtils.hasValidContentAdditionParameterDefined(contentItemNode)) {
            if ( == null) {
                // This is a slave DC. We can't handle this operation; it should have been fixed up on the master DC
                throw createFailureException(.slaveCannotAcceptUploads());
            try {
                // Store and transform operation
                hash = DeploymentUploadUtil.storeContentAndTransformOperation(contextcorrectedOperation);
            } catch (IOException e) {
                throw createFailureException(e.toString());
            contentItemNode = new ModelNode();
            // We have altered contentItemNode from what's in the newModel, so store it back to model
            content = new ModelNode();
        } // else would have failed validation
        if ( != null && hash != null) {
            final byte[] contentHash = hash;
            context.completeStep(new OperationContext.ResultHandler() {
                public void handleResult(ResultAction resultActionOperationContext contextModelNode operation) {
                    if (resultAction == .) {
        } else {
    private static OperationFailedException createFailureException(String msg) {
        return new OperationFailedException(msg);
New to GrepCode? Check out our FAQ X