Class

AdaptiveStore

AdaptiveStore()

Constructor

# new AdaptiveStore()

Session store that persists data in the browser's localStorage (see LocalStorageStore) if that is available or in a cookie (see CookieStore) if it is not.

This is the default store that Ember Simple Auth will use when the application doesn't define a custom store.

This session store does not work with FastBoot. In order to use Ember Simple Auth with FastBoot, configure the CookieStore as the application's session store.

View Source session-stores/adaptive.ts, line 28

Extends

Members

String

# _cookieDomain

The domain to use for the cookie if localStorage is not available, e.g., "example.com", ".example.com" (which includes all subdomains) or "subdomain.example.com". If not explicitly set, the cookie domain defaults to the domain the session was authenticated on.

Properties:
Name Type Description
cookieDomain
Default Value:
  • null

View Source session-stores/adaptive.ts, line 282

Integer

# _cookieExpirationTime

The expiration time for the cookie in seconds if localStorage is not available. A value of null will make the cookie a session cookie that expires and gets deleted when the browser is closed.

Properties:
Name Type Description
cookieExpirationTime
Default Value:
  • null

View Source session-stores/adaptive.ts, line 346

String

# _cookieName

The name of the cookie to use if localStorage is not available.

Properties:
Name Type Description
cookieName
Default Value:
  • ember_simple_auth-session

View Source session-stores/adaptive.ts, line 324

String

# _cookiePath

The path to use for the cookie, e.g., "/", "/something".

Properties:
Name Type Description
cookiePath
Default Value:
  • '/'

View Source session-stores/adaptive.ts, line 334

Boolean

# _partitioned

Allows servers to assert that a cookie should opt in to partitioned storage, i.e. use a separate cookie per top level site if the cookie is used in a third party context

Available options:
- null
- true
Properties:
Name Type Description
partitioned
Default Value:
  • null

View Source session-stores/adaptive.ts, line 314

String

# _sameSite

Allows servers to assert that a cookie ought not to be sent along with cross-site requests, which provides some protection against cross-site request forgery attacks (CSRF).

Available options:
- "Strict"
- "Lax"
Properties:
Name Type Description
sameSite
Default Value:
  • null

View Source session-stores/adaptive.ts, line 298

String

# localStorageKey

The localStorage key the store persists data in if localStorage is available.

Properties:
Name Type Description
localStorageKey
Default Value:
  • 'ember_simple_auth-session'

View Source session-stores/adaptive.ts, line 269

String

# static _cookieDomain

The domain to use for the cookie if localStorage is not available, e.g., "example.com", ".example.com" (which includes all subdomains) or "subdomain.example.com". If not explicitly set, the cookie domain defaults to the domain the session was authenticated on.

Properties:
Name Type Description
cookieDomain
Default Value:
  • null

View Source session-stores/adaptive.ts, line 69

Integer

# static _cookieExpirationTime

The expiration time for the cookie in seconds if localStorage is not available. A value of null will make the cookie a session cookie that expires and gets deleted when the browser is closed.

Properties:
Name Type Description
cookieExpirationTime
Default Value:
  • null

View Source session-stores/adaptive.ts, line 138

String

# static _cookieName

The name of the cookie to use if localStorage is not available.

Properties:
Name Type Description
cookieName
Default Value:
  • ember_simple_auth-session

View Source session-stores/adaptive.ts, line 114

String

# static _cookiePath

The path to use for the cookie, e.g., "/", "/something".

Properties:
Name Type Description
cookiePath
Default Value:
  • '/'

View Source session-stores/adaptive.ts, line 125

Boolean

# static _partitioned

Allows servers to assert that a cookie should opt in to partitioned storage, i.e. use a separate cookie per top level site if the cookie is used in a third party context

  Available options:
  - null
  - true
Properties:
Name Type Description
partitioned
Default Value:
  • null

View Source session-stores/adaptive.ts, line 103

String

# static _sameSite

Allows servers to assert that a cookie ought not to be sent along with cross-site requests, which provides some protection against cross-site request forgery attacks (CSRF).

  Available options:
  - "Strict"
  - "Lax"
Properties:
Name Type Description
sameSite
Default Value:
  • null

View Source session-stores/adaptive.ts, line 86

String

# static localStorageKey

The localStorage key the store persists data in if localStorage is available.

Properties:
Name Type Description
localStorageKey
Default Value:
  • 'ember_simple_auth-session'

View Source session-stores/adaptive.ts, line 56

Methods

# static clear() → {Promise}

Clears the store by deleting the LocalStorageStore.key from localStorage if that is available or by deleting the cookie if it is not.

View Source session-stores/adaptive.ts, line 368

A promise that resolves when the store has been cleared successfully and rejects otherwise.

Promise

# static persist(data) → {Promise}

Persists the data in the localStorage if it is available or in a cookie if it is not.

Parameters:
Name Type Description
data Object

The data to persist

View Source session-stores/adaptive.ts, line 347

A promise that resolves when the data has successfully been persisted and rejects otherwise.

Promise

# static restore() → {Promise}

Returns all data currently stored in the localStorage if that is available - or if it is not, in the cookie - as a plain object.

View Source session-stores/adaptive.ts, line 358

A promise that resolves with the data currently persisted in the store when the data has been restored successfully and rejects otherwise.

Promise