681d460938
Motivation: We have quite a bit of code duplication between HTTP/1, HTTP/2, SPDY, and STOMP codec, because they all have a notion of 'headers', which is a multimap of string names and values. Modifications: - Add TextHeaders and its default implementation - Add AsciiString to replace HttpHeaderEntity - Borrowed some portion from Apache Harmony's java.lang.String. - Reimplement HttpHeaders, SpdyHeaders, and StompHeaders using TextHeaders - Add AsciiHeadersEncoder to reuse the encoding a TextHeaders - Used a dedicated encoder for HTTP headers for better performance though - Remove shortcut methods in SpdyHeaders - Replace SpdyHeaders.getStatus() with HttpResponseStatus.parseLine() Result: - Removed quite a bit of code duplication in the header implementations. - Slightly better performance thanks to improved header validation and hash code calculation
90 lines
2.5 KiB
Java
90 lines
2.5 KiB
Java
/*
|
|
* Copyright 2013 The Netty Project
|
|
*
|
|
* The Netty Project 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 io.netty.handler.codec.spdy;
|
|
|
|
import io.netty.handler.codec.AsciiString;
|
|
import io.netty.handler.codec.TextHeaderProcessor;
|
|
import io.netty.handler.codec.TextHeaders;
|
|
|
|
/**
|
|
* Provides the constants for the standard SPDY HTTP header names and commonly
|
|
* used utility methods that access a {@link SpdyHeadersFrame}.
|
|
*/
|
|
public interface SpdyHeaders extends TextHeaders {
|
|
|
|
/**
|
|
* SPDY HTTP header names
|
|
*/
|
|
final class HttpNames {
|
|
/**
|
|
* {@code ":host"}
|
|
*/
|
|
public static final AsciiString HOST = new AsciiString(":host");
|
|
/**
|
|
* {@code ":method"}
|
|
*/
|
|
public static final AsciiString METHOD = new AsciiString(":method");
|
|
/**
|
|
* {@code ":path"}
|
|
*/
|
|
public static final AsciiString PATH = new AsciiString(":path");
|
|
/**
|
|
* {@code ":scheme"}
|
|
*/
|
|
public static final AsciiString SCHEME = new AsciiString(":scheme");
|
|
/**
|
|
* {@code ":status"}
|
|
*/
|
|
public static final AsciiString STATUS = new AsciiString(":status");
|
|
/**
|
|
* {@code ":version"}
|
|
*/
|
|
public static final AsciiString VERSION = new AsciiString(":version");
|
|
|
|
private HttpNames() { }
|
|
}
|
|
|
|
@Override
|
|
SpdyHeaders add(CharSequence name, Object value);
|
|
|
|
@Override
|
|
SpdyHeaders add(CharSequence name, Iterable<?> values);
|
|
|
|
@Override
|
|
SpdyHeaders add(CharSequence name, Object... values);
|
|
|
|
@Override
|
|
SpdyHeaders add(TextHeaders headers);
|
|
|
|
@Override
|
|
SpdyHeaders set(CharSequence name, Object value);
|
|
|
|
@Override
|
|
SpdyHeaders set(CharSequence name, Iterable<?> values);
|
|
|
|
@Override
|
|
SpdyHeaders set(CharSequence name, Object... values);
|
|
|
|
@Override
|
|
SpdyHeaders set(TextHeaders headers);
|
|
|
|
@Override
|
|
SpdyHeaders clear();
|
|
|
|
@Override
|
|
SpdyHeaders forEachEntry(TextHeaderProcessor processor);
|
|
}
|