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

io.helidon.http.WritableHeaders Maven / Gradle / Ivy

/*
 * Copyright (c) 2022, 2023 Oracle and/or its affiliates.
 *
 * 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 io.helidon.http;

import java.util.Collection;
import java.util.function.Consumer;

import io.helidon.common.media.type.MediaType;

/**
 * HTTP Headers that are mutable.
 *
 * @param  type of the headers (for inheritance)
 */
public interface WritableHeaders> extends Headers {
    /**
     * Create a new instance of writable headers.
     *
     * @return mutable HTTP headers
     */
    static WritableHeaders create() {
        return new HeadersImpl<>();
    }

    /**
     * Create a new instance of writable headers from existing headers.
     *
     * @param headers headers to add to the new mutable instance
     * @return mutable HTTP headers
     */
    static WritableHeaders create(Headers headers) {
        return new HeadersImpl<>(headers);
    }

    /**
     * Set a value of a header unless it is already present.
     *
     * @param header header with value to set
     * @return this instance
     */
    B setIfAbsent(Header header);

    /**
     * Add a header or add a header value if the header is already present.
     *
     * @param header header with value
     * @return this instance
     */
    B add(Header header);

    /**
     * Add a header or add a header value if the header is already present.
     *
     * @param header header name
     * @param value header value(s)
     * @return this instance
     */
    default B add(HeaderName header, String... value) {
        return add(HeaderValues.create(header, value));
    }

    /**
     * Add a header or add a header value if the header is already present.
     *
     * @param header header name
     * @param value header value
     * @return this instance
     */
    default B add(HeaderName header, int value) {
        return add(HeaderValues.create(header, value));
    }

    /**
     * Add a header or add a header value if the header is already present.
     *
     * @param header header name
     * @param value header value
     * @return this instance
     */
    default B add(HeaderName header, long value) {
        return add(HeaderValues.create(header, value));
    }

    /**
     * Remove a header.
     *
     * @param name name of the header to remove
     * @return this instance
     */
    B remove(HeaderName name);

    /**
     * Remove a header.
     *
     * @param name name of the header to remove
     * @param removedConsumer consumer to be called with existing header; if the header did not exist, consumer will not be
     *                        called
     * @return this instance
     */
    B remove(HeaderName name, Consumer
removedConsumer); /** * Sets the MIME type of the response body. * * @param contentType Media type of the content, {@link io.helidon.http.HttpMediaType} may be used to add parameters * @return this instance */ default B contentType(MediaType contentType) { return set(HeaderValues.create(HeaderNameEnum.CONTENT_TYPE, contentType.text())); } /** * Set a header and replace it if it already existed. * * @param header header to set * @return this instance */ B set(Header header); /** * Set a header and replace it if it already existed. * Use {@link #set(Header)} for headers that are known in advance (use a constant), * or for headers obtained from Helidon server or client. This method is intended for headers that are unknown or change * value often. * * @param name header name to set * @param values value(s) of the header * @return this instance */ default B set(HeaderName name, String... values) { return set(HeaderValues.create(name, true, false, values)); } /** * Set a header and replace it if it already existed. * Use {@link #set(Header)} for headers that are known in advance (use a constant), * or for headers obtained from Helidon server or client. This method is intended for headers that are unknown or change * value often. * * @param name header name to set * @param value integer value of the header * @return this instance */ default B set(HeaderName name, int value) { return set(HeaderValues.create(name, true, false, value)); } /** * Set a header and replace it if it already existed. * Use {@link #set(Header)} for headers that are known in advance (use a constant), * or for headers obtained from Helidon server or client. This method is intended for headers that are unknown or change * value often. * * @param name header name to set * @param value long value of the header * @return this instance */ default B set(HeaderName name, long value) { return set(HeaderValues.create(name, true, false, value)); } /** * Set a header and replace it if it already existed. * Use {@link #set(Header)} for headers that are known in advance (use a constant), * or for headers obtained from Helidon server or client. This method is intended for headers that are unknown or change * value often. * * @param name header name to set * @param values value(s) of the header * @return this instance */ default B set(HeaderName name, Collection values) { return set(HeaderValues.create(name, values)); } /** * Content length of the entity in bytes. * If not configured and a non-streaming entity is used, it will be configured based on * the entity length. For streaming entities without content length we switch to chunked * encoding (HTTP/1). * * @param length length of the entity * @return this instance */ default B contentLength(long length) { return set(HeaderValues.create(HeaderNameEnum.CONTENT_LENGTH, true, false, String.valueOf(length))); } /** * Clear all current headers. * * @return this instance */ B clear(); /** * For each header from the provided headers, set its value on these headers. * If a header exists on these headers and on the provided headers, it would be replaced with the value(s) from * provided headers. * * @param headers to read headers from and set them on this instance * @return this instance */ B from(Headers headers); }