/******************************************************************************* * Copyright (c) Apr 17, 2011 Zend Technologies Ltd. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html *******************************************************************************/ package org.zend.webapi.internal.core.connection.request; import java.util.Date; import org.restlet.Request; import org.restlet.data.MediaType; import org.restlet.data.Method; import org.restlet.representation.Representation; import org.zend.webapi.core.connection.data.IResponseData.ResponseType; import org.zend.webapi.core.connection.data.values.ServerType; import org.zend.webapi.core.connection.data.values.WebApiVersion; import org.zend.webapi.core.connection.response.ResponseCode; /** * Remove/undeploy an existing application. This process is asynchronous – the * initial request will start the removal process and the initial response will * show information about the application being removed – however the removal * process will proceed after the response is returned. The user is expected to * continue checking the application status using the applicationGetStatus * method until the removal process is complete. Once applicationGetStatus * contains no information about the specific application, it has been * completely removed. * * Request Parameters: * <table border="1"> * <tr> * <th>Parameter</th> * <th>Type</th> * <th>Required</th> * <th>Description</th> * </tr> * <tr> * <td>appId</td> * <td>Integer</td> * <td>Yes</td> * <td>Application ID to remove.</td> * </tr> * </table> * * @author Wojtek, 2011 * */ public class ApplicationRemoveRequest extends AbstractRequest { public static final MediaType FORM = MediaType.register( "application/x-www-form-urlencoded", "Form"); private static final ResponseCode[] RESPONSE_CODES = new ResponseCode[] { ResponseCode.ACCEPTED }; public ApplicationRemoveRequest(WebApiVersion version, Date date, String keyName, String userAgent, String host, String secretKey, ServerType type) { super(version, date, keyName, userAgent, host, secretKey, type); } /* * (non-Javadoc) * * @see org.zend.webapi.core.connection.request.IRequest#getMethod() */ public Method getMethod() { return Method.POST; } /** * Application ID to remove. * * @param appId */ public void setAppId(int appId) { addParameter("appId", appId); } /* * (non-Javadoc) * * @see org.zend.webapi.internal.core.connection.request.AbstractRequest# * getResponseCodeList() */ @Override protected ResponseCode[] getValidResponseCode() { return RESPONSE_CODES; } /* * (non-Javadoc) * * @see * org.zend.webapi.core.connection.request.IRequest#getExpectedResponseDataType * () */ public ResponseType getExpectedResponseDataType() { return ResponseType.APPLICATION_INFO; } @Override public void applyParameters(Request request) { Representation rep = new MultipartRepresentation(getParameters(), FORM); request.setEntity(rep); } /* * (non-Javadoc) * * @see org.zend.webapi.internal.core.connection.request.AbstractRequest# * getMethodName() */ protected String getRequestName() { return "applicationRemove"; } }