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

org.keycloak.http.HttpResponse Maven / Gradle / Ivy

There is a newer version: 26.0.5
Show newest version
/*
 * Copyright 2022 Red Hat, Inc. and/or its affiliates
 * and other contributors as indicated by the @author tags.
 *
 * 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 org.keycloak.http;

/**
 * 

Represents an out coming HTTP response. * *

Instances of this class can be obtained from {@link org.keycloak.models.KeycloakContext#getHttpResponse}. */ public interface HttpResponse { /** * Gets a status code. */ int getStatus(); /** * Sets a status code. * * @param statusCode the status code */ void setStatus(int statusCode); /** * Add a value to the current list of values for the header with the given {@code name}. * * @param name the header name * @param value the header value */ void addHeader(String name, String value); /** * Set a header. Any existing values will be replaced. * * @param name the header name * @param value the header value */ void setHeader(String name, String value); /** * Sets a new cookie only if not yet set. * * @param cookie the cookie */ void setCookieIfAbsent(HttpCookie cookie); /** * Adding cookies at the end of the transaction helps when retrying a transaction might add the * cookie multiple times. In some scenarios it must not be added at the end of the transaction, * as at that time the response has already been sent to the caller ("committed"), so the code * needs to make a choice. As retrying transactions is the exception, adding cookies at the end * of the transaction is also the exception and needs to be switched on where necessary. */ void setWriteCookiesOnTransactionComplete(); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy