Package org.apache.webdav.lib.methods

Source Code of org.apache.webdav.lib.methods.MoveMethod

/*
* $Header: /home/cvs/jakarta-slide/webdavclient/clientlib/src/java/org/apache/webdav/lib/methods/MoveMethod.java,v 1.6 2004/07/28 09:30:40 ib Exp $
* $Revision: 1.6 $
* $Date: 2004/07/28 09:30:40 $
*
* ====================================================================
*
* Copyright 1999-2002 The Apache Software Foundation
*
* 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 org.apache.webdav.lib.methods;

import java.io.IOException;
import org.apache.commons.httpclient.HttpConnection;
import org.apache.commons.httpclient.HttpException;
import org.apache.commons.httpclient.HttpState;
import org.apache.commons.httpclient.protocol.Protocol;


/**
* MOVE Method.
*
*/
public class MoveMethod
    extends XMLResponseMethodBase {


    // ----------------------------------------------------------- Constructors


    /**
     * Method constructor.
     */
    public MoveMethod() {
    }


    /**
     * Method constructor.
     */
    public MoveMethod(String source) {
        super(source);
    }


    /**
     * Method constructor.
     */
    public MoveMethod(String source, String destination) {
        this(source);
        setDestination(destination);
    }


    /**
     * Method constructor.
     */
    public MoveMethod(String source, String destination, boolean overwrite) {
        this(source, destination);
        setOverwrite(overwrite);
    }


    // ----------------------------------------------------- Instance Variables


    /**
     * Destination.
     */
    private String destination;


    /**
     * Overwrite.
     */
    private boolean overwrite = true;


    // ------------------------------------------------------------- Properties



    /**
     * Set a header value, redirecting the special case of the Overwrite and Destination
     * headers to {@link #setOverwrite} and {@link #setDestination} as appropriate.
     *
     * @param headerName Header name
     * @param headerValue Header value
     */
    public void setRequestHeader(String headerName, String headerValue) {
        if (headerName.equalsIgnoreCase("Overwrite")){
            setOverwrite(! (headerValue.equalsIgnoreCase("F") ||
                           headerValue.equalsIgnoreCase("False") ) );
        }
        else if(headerName.equalsIgnoreCase("Destination")){
            setDestination(headerValue);
        }
        else{
            super.setRequestHeader(headerName, headerValue);
        }
    }



    /**
     * Destination setter.
     *
     * @param destination New destination value
     */
    public void setDestination(String destination) {
        checkNotUsed();
        this.destination = destination;
    }


    /**
     * Destination getter.
     *
     * @return String destination value
     */
    public String getDestination() {
        return destination;
    }


    /**
     * Overwrite setter.
     *
     * @param overwrite New overwrite value
     */
    public void setOverwrite(boolean overwrite) {
        checkNotUsed();
        this.overwrite = overwrite;
    }


    /**
     * Overwrite getter.
     *
     * @return boolean Overwrite value
     */
    public boolean isOverwrite() {
        return overwrite;
    }


    /**
     * Overwrite getter.
     *
     * @return boolean Overwrite value
     */
    public boolean getOverwrite() {
        return overwrite;
    }


    // --------------------------------------------------- WebdavMethod Methods


    public String getName() {
        return "MOVE";
    }

    /**
     * Generate additional headers needed by the request.
     *
     * @param state State token
     * @param conn The connection being used to make the request.
     */
    public void addRequestHeaders(HttpState state, HttpConnection conn)
    throws IOException, HttpException {

        super.addRequestHeaders(state, conn);

        String absoluteDestination = getAbsoluteDestination(conn, destination);
        super.setRequestHeader("Destination", absoluteDestination);

        if (!isOverwrite())
            super.setRequestHeader("Overwrite", "F");

    }

    /**
     * A client of the {@link MoveMethod} can specify a destination as either an
     * absolute URL (possibly to a different server), or as a absolute path on
     * the same server, but this function makes sure that the path sent to the
     * server is always an absolute URL.
     *
     * <p>Note that this function will add server and port to the request -
     * however, port is not added if it is the default port for the scheme
     * in question. </p>
     *
     * <p>This function is static so that it can be reused by the {@link CopyMethod}.
     * </p>
     *
     * @param conn  The connection for the current request, in case the caller
     *  specifies an absolute path.
     *
     * @param absolutePathOrURL If an absolute URL, nothing done, but if an absolute
     *  path, it is converted into an absolute URL.
     *
     * @return An absolute URL
     */
    static String getAbsoluteDestination(HttpConnection conn, String absolutePathOrURL) {

        String absoluteDestination = absolutePathOrURL;

        // is this an absolute path?
        if (absolutePathOrURL.startsWith("/")) {

            // yes - get the protocol to start the URL with the appropriate scheme.
            Protocol protocol = conn.getProtocol();
            StringBuffer bufDest = new StringBuffer(protocol.getScheme());
            bufDest.append("://").append(conn.getHost());

            // only add in the port if it is not the default port.
            if (conn.getPort() != protocol.getDefaultPort()) {
                bufDest.append(':').append(conn.getPort());
            }

            // append the path.
            bufDest.append(absolutePathOrURL);
            absoluteDestination = bufDest.toString();
        }
        return absoluteDestination;
    }


}
TOP

Related Classes of org.apache.webdav.lib.methods.MoveMethod

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.