io.undertow.servlet.spec.SessionCookieConfigImpl Maven / Gradle / Ivy
The newest version!
/*
* JBoss, Home of Professional Open Source.
* Copyright 2014 Red Hat, Inc., and individual 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 io.undertow.servlet.spec;
import io.undertow.server.HttpServerExchange;
import io.undertow.server.session.SessionConfig;
import io.undertow.servlet.UndertowServletMessages;
import jakarta.servlet.SessionCookieConfig;
import java.util.Collections;
import java.util.Map;
import java.util.TreeMap;
/**
* @author Stuart Douglas
*/
public class SessionCookieConfigImpl implements SessionCookieConfig, SessionConfig {
private static final String COOKIE_COMMENT_ATTR = "Comment";
private static final String COOKIE_DOMAIN_ATTR = "Domain";
private static final String COOKIE_MAX_AGE_ATTR = "Max-Age";
private static final String COOKIE_PATH_ATTR = "Path";
private static final String COOKIE_SECURE_ATTR = "Secure";
private static final String COOKIE_HTTP_ONLY_ATTR = "HttpOnly";
private final ServletContextImpl servletContext;
private final io.undertow.server.session.SessionCookieConfig delegate;
private SessionConfig fallback;
private static final int DEFAULT_MAX_AGE = -1;
private static final boolean DEFAULT_HTTP_ONLY = false;
private static final boolean DEFAULT_SECURE = false;
private final Map attributes = new TreeMap<>(String.CASE_INSENSITIVE_ORDER);
public SessionCookieConfigImpl(final ServletContextImpl servletContext) {
this.servletContext = servletContext;
this.delegate = new io.undertow.server.session.SessionCookieConfig();
}
@Override
public String rewriteUrl(final String originalUrl, final String sessionid) {
if(fallback != null) {
return fallback.rewriteUrl(originalUrl, sessionid);
}
return originalUrl;
}
@Override
public void setSessionId(final HttpServerExchange exchange, final String sessionId) {
delegate.setSessionId(exchange, sessionId);
}
@Override
public void clearSession(final HttpServerExchange exchange, final String sessionId) {
delegate.clearSession(exchange, sessionId);
}
@Override
public String findSessionId(final HttpServerExchange exchange) {
String existing = delegate.findSessionId(exchange);
if(existing != null) {
return existing;
}
if(fallback != null) {
return fallback.findSessionId(exchange);
}
return null;
}
@Override
public SessionCookieSource sessionCookieSource(HttpServerExchange exchange) {
String existing = delegate.findSessionId(exchange);
if (existing != null) {
return SessionCookieSource.COOKIE;
}
if(fallback != null) {
String id = fallback.findSessionId(exchange);
return id != null ? fallback.sessionCookieSource(exchange) : SessionCookieSource.NONE;
}
return SessionCookieSource.NONE;
}
public String getName() {
return delegate.getCookieName();
}
public void setName(final String name) {
if(servletContext.isInitialized()) {
throw UndertowServletMessages.MESSAGES.servletContextAlreadyInitialized();
}
delegate.setCookieName(name);
}
public String getDomain() {
return getAttribute(COOKIE_DOMAIN_ATTR);
}
public void setDomain(final String domain) {
if(servletContext.isInitialized()) {
throw UndertowServletMessages.MESSAGES.servletContextAlreadyInitialized();
}
delegate.setDomain(domain);
setAttribute(COOKIE_DOMAIN_ATTR, domain);
}
public String getPath() {
return getAttribute(COOKIE_PATH_ATTR);
}
public void setPath(final String path) {
if(servletContext.isInitialized()) {
throw UndertowServletMessages.MESSAGES.servletContextAlreadyInitialized();
}
delegate.setPath(path);
setAttribute(COOKIE_PATH_ATTR, path);
}
@Deprecated
public String getComment() {
return getAttribute(COOKIE_COMMENT_ATTR);
}
@Deprecated
public void setComment(final String comment) {
if(servletContext.isInitialized()) {
throw UndertowServletMessages.MESSAGES.servletContextAlreadyInitialized();
}
delegate.setComment(comment);
setAttribute(COOKIE_COMMENT_ATTR, comment);
}
public boolean isHttpOnly() {
String value = getAttribute(COOKIE_HTTP_ONLY_ATTR);
return value == null ? DEFAULT_HTTP_ONLY : Boolean.parseBoolean(value);
}
public void setHttpOnly(final boolean httpOnly) {
if(servletContext.isInitialized()) {
throw UndertowServletMessages.MESSAGES.servletContextAlreadyInitialized();
}
delegate.setHttpOnly(httpOnly);
setAttribute(COOKIE_HTTP_ONLY_ATTR, String.valueOf(httpOnly));
}
public boolean isSecure() {
String value = getAttribute(COOKIE_SECURE_ATTR);
return value == null ? DEFAULT_SECURE : Boolean.parseBoolean(value); }
public void setSecure(final boolean secure) {
if(servletContext.isInitialized()) {
throw UndertowServletMessages.MESSAGES.servletContextAlreadyInitialized();
}
delegate.setSecure(secure);
setAttribute(COOKIE_SECURE_ATTR, String.valueOf(secure));
}
public int getMaxAge() {
String value = getAttribute(COOKIE_MAX_AGE_ATTR);
return value == null ? DEFAULT_MAX_AGE : Integer.parseInt(value);
}
public void setMaxAge(final int maxAge) {
if(servletContext.isInitialized()) {
throw UndertowServletMessages.MESSAGES.servletContextAlreadyInitialized();
}
this.delegate.setMaxAge(maxAge);
setAttribute(COOKIE_MAX_AGE_ATTR, String.valueOf(maxAge));
}
public SessionConfig getFallback() {
return fallback;
}
public void setFallback(final SessionConfig fallback) {
this.fallback = fallback;
}
@Override
public void setAttribute(final String name, final String value) {
if(servletContext.isInitialized()) {
throw UndertowServletMessages.MESSAGES.servletContextAlreadyInitialized();
}
attributes.put(name, value);
}
@Override
public String getAttribute(final String name) {
return attributes.get(name);
}
@Override
public Map getAttributes() {
return Collections.unmodifiableMap(attributes);
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy