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

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

/*
 * 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;

/**
 * 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 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); /** * 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 Map data(); /** * @return the time the session was last accessed */ long lastAccessed(); /** * Destroy the session */ void destroy(); /** * @return has the session been destroyed? */ boolean isDestroyed(); /** * @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(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy