⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 subscribemethod.java

📁 jsr170接口的java实现。是个apache的开源项目。
💻 JAVA
字号:
/** Licensed to the Apache Software Foundation (ASF) under one or more* contributor license agreements.  The ASF licenses this file to You* 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.jackrabbit.webdav.client.methods;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.apache.jackrabbit.webdav.DavMethods;import org.apache.jackrabbit.webdav.DavConstants;import org.apache.jackrabbit.webdav.DavServletResponse;import org.apache.jackrabbit.webdav.DavException;import org.apache.jackrabbit.webdav.xml.DomUtil;import org.apache.jackrabbit.webdav.header.CodedUrlHeader;import org.apache.jackrabbit.webdav.header.DepthHeader;import org.apache.jackrabbit.webdav.header.TimeoutHeader;import org.apache.jackrabbit.webdav.observation.SubscriptionInfo;import org.apache.jackrabbit.webdav.observation.SubscriptionDiscovery;import org.apache.jackrabbit.webdav.observation.ObservationConstants;import org.apache.jackrabbit.webdav.observation.Subscription;import org.apache.commons.httpclient.Header;import org.apache.commons.httpclient.HttpMethodBase;import org.apache.commons.httpclient.HttpState;import org.apache.commons.httpclient.HttpConnection;import org.w3c.dom.Element;import java.io.IOException;/** * <code>SubscribeMethod</code>... */public class SubscribeMethod extends DavMethodBase implements ObservationConstants {    private static Logger log = LoggerFactory.getLogger(SubscribeMethod.class);    private SubscriptionDiscovery subscriptionDiscovery;    /**     * Create a new <code>SubscribeMethod</code> used to register to the     * observation events specified within the given <code>SubscriptionInfo</code>.     * See {@link #SubscribeMethod(String, SubscriptionInfo, String)} for a     * constructor that allows to redefined an existing subscription.     *     * @param uri     * @param subscriptionInfo     * @throws IOException     */    public SubscribeMethod(String uri, SubscriptionInfo subscriptionInfo) throws IOException {        this(uri, subscriptionInfo, null);    }    /**     * Create a new <code>SubscribeMethod</code> used to register to the     * observation events specified within the given <code>SubscriptionInfo</code>.     * Note that in contrast to {@link #SubscribeMethod(String, SubscriptionInfo)}     * this constructor optionally takes a subscription id identifying a     * subscription made before. In this case the subscription will be modified     * according to the definitions present in the <code>SubscriptionInfo</code>.     * If the id is <code>null</code> this constructor is identical to     * {@link #SubscribeMethod(String, SubscriptionInfo)}.     *     * @param uri     * @param subscriptionInfo     * @throws IOException     */    public SubscribeMethod(String uri, SubscriptionInfo subscriptionInfo, String subscriptionId) throws IOException {        super(uri);        if (subscriptionInfo == null) {            throw new IllegalArgumentException("SubscriptionInfo must not be null.");        }        // optional subscriptionId (only required to modify an existing subscription)        if (subscriptionId != null) {           setRequestHeader(new CodedUrlHeader(HEADER_SUBSCRIPTIONID, subscriptionId));        }        // optional timeout header        long to = subscriptionInfo.getTimeOut();        if (to != DavConstants.UNDEFINED_TIMEOUT) {            setRequestHeader(new TimeoutHeader(subscriptionInfo.getTimeOut()));        }        // always set depth header since value is boolean flag        setRequestHeader(new DepthHeader(subscriptionInfo.isDeep()));        setRequestBody(subscriptionInfo);    }    public SubscriptionDiscovery getResponseAsSubscriptionDiscovery() throws IOException, DavException {        checkUsed();        if (subscriptionDiscovery != null) {            return subscriptionDiscovery;        } else {            DavException dx = getResponseException();            if (dx != null) {                throw dx;            } else {                throw new DavException(getStatusCode(), getName() + " resulted with unexpected status: " + getStatusLine());            }        }    }    public String getSubscriptionId() {        checkUsed();        Header sbHeader = getResponseHeader(HEADER_SUBSCRIPTIONID);        if (sbHeader != null) {            CodedUrlHeader cuh = new CodedUrlHeader(HEADER_SUBSCRIPTIONID, sbHeader.getValue());            return cuh.getCodedUrl();        }        return null;    }    //---------------------------------------------------------< HttpMethod >---    public String getName() {        return DavMethods.METHOD_SUBSCRIBE;    }    //------------------------------------------------------< DavMethodBase >---    protected boolean isSuccess(int statusCode) {        return DavServletResponse.SC_OK == statusCode;    }   //------------------------------------------------------< HttpMethodBase >---    /**     * Retrieves the DAV:subscriptiondiscovery property present in the response body     * and builds 'Subscription' objects from the corresponding DAV:subscription     * child elements inside the discovery. If parsing the response body     * fails for whatever reason or if the DAV:subscriptiondiscovery did not contain     * at least a single DAV:subscription entry (the one created by the SUBSCRIBE     * call) this methods in addition resets the 'success' flag to false.     *     * @param httpState     * @param httpConnection     * @see HttpMethodBase#processResponseBody(HttpState, HttpConnection)     */    protected void processResponseBody(HttpState httpState, HttpConnection httpConnection) {        // in case of successful response code -> parse xml body discovery object        if (getSuccess()) {            try {                setSuccess(buildDiscoveryFromRoot(getRootElement()));            } catch (IOException e) {                log.error("Error while parsing multistatus response: " + e);                setSuccess(false);            }        }    }    //------------------------------------------------------------< private >---    /**     *     * @param root     * @return     */    private boolean buildDiscoveryFromRoot(Element root) {        if (DomUtil.matches(root, XML_PROP, DavConstants.NAMESPACE) &&            DomUtil.hasChildElement(root, SUBSCRIPTIONDISCOVERY.getName(), SUBSCRIPTIONDISCOVERY.getNamespace())) {            Element sdElem = DomUtil.getChildElement(root, SUBSCRIPTIONDISCOVERY.getName(), SUBSCRIPTIONDISCOVERY.getNamespace());            SubscriptionDiscovery sd = SubscriptionDiscovery.createFromXml(sdElem);            if (((Subscription[])sd.getValue()).length > 0) {                subscriptionDiscovery = sd;                return true;            } else {                log.debug("Missing 'subscription' elements in SUBSCRIBE response body. At least a single subscription must be present if SUBSCRIBE was successful.");            }        } else {            log.debug("Missing DAV:prop response body in SUBSCRIBE method.");        }        return false;    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -