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

io.vertx.ext.web.Session Maven / Gradle / Ivy

There is a newer version: 5.0.0.CR1
Show newest version
/*
 * Copyright 2014 Red Hat, Inc.
 *
 *  All rights reserved. This program and the accompanying materials
 *  are made available under the terms of the Eclipse Public License v1.0
 *  and Apache License v2.0 which accompanies this distribution.
 *
 *  The Eclipse Public License is available at
 *  http://www.eclipse.org/legal/epl-v10.html
 *
 *  The Apache License v2.0 is available at
 *  http://www.opensource.org/licenses/apache2.0.php
 *
 *  You may elect to redistribute this code under either of these licenses.
 */

package io.vertx.ext.web;

import io.vertx.codegen.annotations.Fluent;
import io.vertx.codegen.annotations.GenIgnore;
import io.vertx.codegen.annotations.VertxGen;

import java.util.Map;
import java.util.function.Function;

/**
 * Represents a browser session.
 * 

* Sessions persist between HTTP requests for a single browser session. They are deleted when the browser is closed, or * they time-out. Session cookies are used to maintain sessions using a secure UUID. *

* Sessions can be used to maintain data for a browser session, e.g. a shopping basket. *

* The context must have first been routed to a {@link io.vertx.ext.web.handler.SessionHandler} * for sessions to be available. * * @author Tim Fox */ @VertxGen public interface Session { /** * @return The new unique ID of the session. */ Session regenerateId(); /** * @return The unique ID of the session. This is generated using a random secure UUID. */ String id(); /** * Put some data in a session * * @param key the key for the data * @param obj the data * @return a reference to this, so the API can be used fluently */ @Fluent Session put(String key, Object obj); /** * Put some data in a session if absent * * @param key the key for the data * @param obj the data * @return a reference to this, so the API can be used fluently */ @Fluent Session putIfAbsent(String key, Object obj); /** * Put some data in a session if absent. * * If the specified key is not already associated with a value (or is mapped * to {@code null}), attempts to compute its value using the given mapping * function and enters it into this map unless {@code null}. * * @param key the key for the data * @param mappingFunction a mapping function * @return a reference to this, so the API can be used fluently */ @Fluent Session computeIfAbsent(String key, Function mappingFunction); /** * Get some data from the session * * @param key the key of the data * @return the data */ T get(String key); /** * Remove some data from the session * * @param key the key of the data * @return the data that was there or null if none there */ T remove(String key); /** * @return the session data as a map */ @GenIgnore(GenIgnore.PERMITTED_TYPE) Map data(); /** * @return true if the session has data */ boolean isEmpty(); /** * @return the time the session was last accessed */ long lastAccessed(); /** * Destroy the session */ void destroy(); /** * @return has the session been destroyed? */ boolean isDestroyed(); /** * @return has the session been renewed? */ boolean isRegenerated(); /** * @return old ID if renewed */ String oldId(); /** * @return the amount of time in ms, after which the session will expire, if not accessed. */ long timeout(); /** * Mark the session as being accessed. */ void setAccessed(); /** * The short representation of the session to be added to the session cookie. By default is the session id. * * @return short representation string. */ default String value() { return id(); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy