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

io.helidon.http.ServerResponseHeaders 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.net.URI;
import java.time.Duration;
import java.time.Instant;
import java.time.ZoneId;
import java.time.ZonedDateTime;

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

import static io.helidon.http.HeaderNames.EXPIRES;
import static io.helidon.http.HeaderNames.LAST_MODIFIED;
import static io.helidon.http.HeaderNames.LOCATION;

/**
 * Mutable headers of a server response.
 */
public interface ServerResponseHeaders extends ClientResponseHeaders,
                                               WritableHeaders {

    /**
     * Create a new instance of mutable server response headers.
     *
     * @return new server response headers
     */
    static ServerResponseHeaders create() {
        return new ServerResponseHeadersImpl();
    }

    /**
     * Create a new instance of mutable server response headers.
     *
     * @param existing headers to add to these response headers
     * @return new server response headers
     */
    static ServerResponseHeaders create(Headers existing) {
        return new ServerResponseHeadersImpl(existing);
    }

    /**
     * Adds one or more acceptedTypes path document formats
     * (header {@link HeaderNames#ACCEPT_PATCH}).
     *
     * @param acceptableMediaTypes media types to add.
     * @return this instance
     */
    default ServerResponseHeaders addAcceptPatches(MediaType... acceptableMediaTypes) {
        String[] values = new String[acceptableMediaTypes.length];
        for (int i = 0; i < acceptableMediaTypes.length; i++) {
            MediaType acceptableMediaType = acceptableMediaTypes[i];
            values[i] = acceptableMediaType.text();
        }
        return add(HeaderValues.create(HeaderNames.ACCEPT_PATCH,
                                       values));
    }

    /**
     * Adds {@code Set-Cookie} header specified in RFC6265.
     *
     * @param cookie a cookie definition
     * @return this instance
     */
    ServerResponseHeaders addCookie(SetCookie cookie);

    /**
     * Adds {@code Set-Cookie} header based on RFC6265 with {@code Max-Age}
     * parameter.
     *
     * @param name   name of the cookie
     * @param value  value of the cookie
     * @param maxAge {@code Max-Age} cookie parameter
     * @return this instance
     */
    default ServerResponseHeaders addCookie(String name, String value, Duration maxAge) {
        return addCookie(SetCookie.builder(name, value)
                                 .maxAge(maxAge)
                                 .build());
    }

    /**
     * Adds {@code Set-Cookie} header based on RFC2616.
     *
     * @param name  name of the cookie
     * @param value value of the cookie
     * @return this instance
     */
    default ServerResponseHeaders addCookie(String name, String value) {
        return addCookie(SetCookie.create(name, value));
    }

    /**
     * Clears a cookie by adding a {@code Set-Cookie} header with an expiration date in the past.
     *
     * @param name name of the cookie.
     * @return this instance
     */
    ServerResponseHeaders clearCookie(String name);

    /**
     * Sets the value of {@link HeaderNames#LAST_MODIFIED} header.
     * 

* The last modified date for the requested object * * @param modified Last modified date/time. * @return this instance */ default ServerResponseHeaders lastModified(Instant modified) { ZonedDateTime dt = ZonedDateTime.ofInstant(modified, ZoneId.systemDefault()); return set(HeaderValues.create(LAST_MODIFIED, true, false, dt.format(DateTime.RFC_1123_DATE_TIME))); } /** * Sets the value of {@link HeaderNames#LAST_MODIFIED} header. *

* The last modified date for the requested object * * @param modified Last modified date/time. * @return this instance */ default ServerResponseHeaders lastModified(ZonedDateTime modified) { return set(HeaderValues.create(LAST_MODIFIED, true, false, modified.format(DateTime.RFC_1123_DATE_TIME))); } /** * Sets the value of {@link HeaderNames#LOCATION} header. *

* Used in redirection, or when a new resource has been created. * * @param location Location header value. * @return updated headers */ default ServerResponseHeaders location(URI location) { return set(HeaderValues.create(LOCATION, true, false, location.toASCIIString())); } /** * Sets the value of {@link HeaderNames#EXPIRES} header. *

* The date/time after which the response is considered stale. * * @param dateTime Expires date/time. * @return updated headers */ default ServerResponseHeaders expires(ZonedDateTime dateTime) { return set(HeaderValues.create(EXPIRES, dateTime.format(DateTime.RFC_1123_DATE_TIME))); } /** * Sets the value of {@link HeaderNames#EXPIRES} header. *

* The date/time after which the response is considered stale. * * @param dateTime Expires date/time. * @return updated headers */ default ServerResponseHeaders expires(Instant dateTime) { return set(HeaderValues.create(EXPIRES, ZonedDateTime.ofInstant(dateTime, ZoneId.systemDefault()) .format(DateTime.RFC_1123_DATE_TIME))); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy