All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.signalfx.shaded.apache.http.impl.cookie.NetscapeDraftSpec Maven / Gradle / Ivy

Go to download

Bare minimum core library needed to sending metrics to SignalFx from Java clients

The newest version!
/*
 * ====================================================================
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  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.
 * ====================================================================
 *
 * This software consists of voluntary contributions made by many
 * individuals on behalf of the Apache Software Foundation.  For more
 * information on the Apache Software Foundation, please see
 * .
 *
 */

package com.signalfx.shaded.apache.http.impl.cookie;

import java.util.ArrayList;
import java.util.List;

import com.signalfx.shaded.apache.http.FormattedHeader;
import com.signalfx.shaded.apache.http.Header;
import com.signalfx.shaded.apache.http.HeaderElement;
import com.signalfx.shaded.apache.http.annotation.Contract;
import com.signalfx.shaded.apache.http.annotation.Obsolete;
import com.signalfx.shaded.apache.http.annotation.ThreadingBehavior;
import com.signalfx.shaded.apache.http.cookie.CommonCookieAttributeHandler;
import com.signalfx.shaded.apache.http.cookie.Cookie;
import com.signalfx.shaded.apache.http.cookie.CookieOrigin;
import com.signalfx.shaded.apache.http.cookie.MalformedCookieException;
import com.signalfx.shaded.apache.http.cookie.SM;
import com.signalfx.shaded.apache.http.message.BufferedHeader;
import com.signalfx.shaded.apache.http.message.ParserCursor;
import com.signalfx.shaded.apache.http.util.Args;
import com.signalfx.shaded.apache.http.util.CharArrayBuffer;

/**
 * This {@link com.signalfx.shaded.apache.http.cookie.CookieSpec} implementation conforms to
 * the original draft specification published by Netscape Communications.
 * It should be avoided unless absolutely necessary for compatibility with
 * legacy applications.
 * 

* Rendered obsolete by {@link com.signalfx.shaded.apache.http.impl.cookie.RFC6265LaxSpec}. * * @since 4.0 * @see org.apache.http.impl.cookie.RFC6265LaxSpec */ @Obsolete @Contract(threading = ThreadingBehavior.SAFE) public class NetscapeDraftSpec extends CookieSpecBase { protected static final String EXPIRES_PATTERN = "EEE, dd-MMM-yy HH:mm:ss z"; /** Default constructor */ public NetscapeDraftSpec(final String[] datepatterns) { super(new BasicPathHandler(), new NetscapeDomainHandler(), new BasicSecureHandler(), new BasicCommentHandler(), new BasicExpiresHandler( datepatterns != null ? datepatterns.clone() : new String[]{EXPIRES_PATTERN})); } NetscapeDraftSpec(final CommonCookieAttributeHandler... handlers) { super(handlers); } public NetscapeDraftSpec() { this((String[]) null); } /** * Parses the Set-Cookie value into an array of {@code Cookie}s. * *

Syntax of the Set-Cookie HTTP Response Header:

* *

This is the format a CGI script would use to add to * the HTTP headers a new piece of data which is to be stored by * the client for later retrieval.

* *
      *  Set-Cookie: NAME=VALUE; expires=DATE; path=PATH; domain=DOMAIN_NAME; secure
      * 
* *

Please note that the Netscape draft specification does not fully conform to the HTTP * header format. Comma character if present in {@code Set-Cookie} will not be treated * as a header element separator

* * @see * The Cookie Spec. * * @param header the {@code Set-Cookie} received from the server * @return an array of {@code Cookie}s parsed from the Set-Cookie value * @throws MalformedCookieException if an exception occurs during parsing */ @Override public List parse(final Header header, final CookieOrigin origin) throws MalformedCookieException { Args.notNull(header, "Header"); Args.notNull(origin, "Cookie origin"); if (!header.getName().equalsIgnoreCase(SM.SET_COOKIE)) { throw new MalformedCookieException("Unrecognized cookie header '" + header.toString() + "'"); } final NetscapeDraftHeaderParser parser = NetscapeDraftHeaderParser.DEFAULT; final CharArrayBuffer buffer; final ParserCursor cursor; if (header instanceof FormattedHeader) { buffer = ((FormattedHeader) header).getBuffer(); cursor = new ParserCursor( ((FormattedHeader) header).getValuePos(), buffer.length()); } else { final String s = header.getValue(); if (s == null) { throw new MalformedCookieException("Header value is null"); } buffer = new CharArrayBuffer(s.length()); buffer.append(s); cursor = new ParserCursor(0, buffer.length()); } return parse(new HeaderElement[] { parser.parseHeader(buffer, cursor) }, origin); } @Override public List
formatCookies(final List cookies) { Args.notEmpty(cookies, "List of cookies"); final CharArrayBuffer buffer = new CharArrayBuffer(20 * cookies.size()); buffer.append(SM.COOKIE); buffer.append(": "); for (int i = 0; i < cookies.size(); i++) { final Cookie cookie = cookies.get(i); if (i > 0) { buffer.append("; "); } buffer.append(cookie.getName()); final String s = cookie.getValue(); if (s != null) { buffer.append("="); buffer.append(s); } } final List
headers = new ArrayList
(1); headers.add(new BufferedHeader(buffer)); return headers; } @Override public int getVersion() { return 0; } @Override public Header getVersionHeader() { return null; } @Override public String toString() { return "netscape"; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy