com.sksamuel.scruffy.session

SessionManager

trait SessionManager extends AnyRef

Responsible for managing sessions in an underlying store. The backing store could be a database, in memory, network etc.

Linear Supertypes
AnyRef, Any
Known Subclasses
Ordering
  1. Alphabetic
  2. By inheritance
Inherited
  1. SessionManager
  2. AnyRef
  3. Any
  1. Hide All
  2. Show all
Learn more about member selection
Visibility
  1. Public
  2. All

Abstract Value Members

  1. abstract def create(id: String)(implicit executor: ExecutionContext): Future[Session]

    Create a new empty session.

    Create a new empty session. The id is a hint to the session manager and implementations can ignore if needed. This is useful for distributed implementations where id coordination may be time consuming or unfeasible. Because of that, you should check the id from the session after it is created as the id may differ.

    id

    a hint to the id, which may or may not be honoured.

  2. abstract def create(implicit executor: ExecutionContext): Future[Session]

    Create a new empty session.

    Create a new empty session. The newly created session will be assigned an id by the underlying implementation.

    returns

    a Future which when completed contains the created Session.

  3. abstract def expire(id: String)(implicit executor: ExecutionContext): Future[Unit]

    Mark the session identified by the given id as expired and remove it from the underlying implementation.

    Mark the session identified by the given id as expired and remove it from the underlying implementation.

    id

    the id of the session to expire/remove

    returns

    a Future which is completed once the session has been removed from the backing store.

  4. abstract def get(id: String)(implicit executor: ExecutionContext): Future[Option[Session]]

    Returns a Session for the given id.

    Returns a Session for the given id. If no session exists, then the result from the Future will contain a None.

  5. abstract def update(session: Session)(implicit executor: ExecutionContext): Future[Session]

    Save the given session to the backing store.

    Save the given session to the backing store.

    session

    the session to persist

    returns

    a Future which is completed once the session has been persisted.

Concrete Value Members

  1. final def !=(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  2. final def !=(arg0: Any): Boolean

    Definition Classes
    Any
  3. final def ##(): Int

    Definition Classes
    AnyRef → Any
  4. final def ==(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  5. final def ==(arg0: Any): Boolean

    Definition Classes
    Any
  6. final def asInstanceOf[T0]: T0

    Definition Classes
    Any
  7. def clone(): AnyRef

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  8. final def eq(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  9. def equals(arg0: Any): Boolean

    Definition Classes
    AnyRef → Any
  10. def exists(id: String)(implicit executor: ExecutionContext): Future[Boolean]

    Returns true if the session identified by the given id exists in this session manager.

  11. def expire(session: Session)(implicit executor: ExecutionContext): Future[Unit]

    Mark the given session as expired and remove it from the underlying implementation.

    Mark the given session as expired and remove it from the underlying implementation. If the session does not exist or has already expired, then this is a no-op.

  12. def finalize(): Unit

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  13. def generateId: String

  14. final def getClass(): Class[_]

    Definition Classes
    AnyRef → Any
  15. def getOrCreate(id: String)(implicit executor: ExecutionContext): Future[Session]

    Returns a session for the given id or creates a new session if none is available.

    Returns a session for the given id or creates a new session if none is available.

    Implementations are free to ignore the given id when creating an new session and can assign a different id. This is useful for distributed implementations where id coordination may be time consuming or unfeasible.

  16. def hashCode(): Int

    Definition Classes
    AnyRef → Any
  17. final def isInstanceOf[T0]: Boolean

    Definition Classes
    Any
  18. final def ne(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  19. final def notify(): Unit

    Definition Classes
    AnyRef
  20. final def notifyAll(): Unit

    Definition Classes
    AnyRef
  21. final def synchronized[T0](arg0: ⇒ T0): T0

    Definition Classes
    AnyRef
  22. def toString(): String

    Definition Classes
    AnyRef → Any
  23. final def wait(): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  24. final def wait(arg0: Long, arg1: Int): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  25. final def wait(arg0: Long): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )

Inherited from AnyRef

Inherited from Any

Ungrouped