Socket
Socket
Sign inDemoInstall

@sidebase/nuxt-session

Package Overview
Dependencies
Maintainers
1
Versions
21
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@sidebase/nuxt-session

![nuxt session logo](./.github/session.png)


Version published
Weekly downloads
866
decreased by-9.03%
Maintainers
1
Weekly downloads
 
Created
Source

nuxt session logo

nuxt-session

Follow us on Twitter Join our Discord GitHub stars

Nuxt session middleware to persist data across multiple requests, supports many backends via unjs/unstorage: memory, redis, fs, ...

Features

  • ✔️ Persistent sessions across requests
  • ✔️ Storage via unjs/unstorage - use memory, redis, fs, cloudflare-kv, ... to store your session data
  • ✔️ Configurable session duration
  • ✔️ Automatic session storage cleanup on expiry
  • ✔️ Transport method: Cookies

Use the module-playground (see playground below) to play around with the module.

Usage

  1. Install the package:
    npm i @sidebase/nuxt-session
    
  2. Add the package to your nuxt.config.ts:
    export default defineNuxtConfig({
      modules: ['@sidebase/nuxt-session'],
    })
    
  3. Each request will now have a session at event.context.session that looks like:
    {
      id: 'TLyEy2Mav2G_sawgek7fqqj6EaWrO9LDAfLjhjHRKbE6M-_nGhT1iK7sTwqZ-xoT',
      createdAt: '2022-10-12T09:12:38.406Z'
    }
    

All modifications of ``event.context.session` will automatically be stored. Here's an endpoint that persists a counter per user:

// File: `playground/server/api/count.get.ts`
export default defineEventHandler(async (event: CompatibilityEvent) => {
  // Get the current count or set to 0 if this is the first request
  const currentCount = event.context.session.count || 0

  // Increase the count
  event.context.session.count = currentCount + 1

  // Return the count
  return event.context.session.count
})

To use the session on the client side (i.e., in your client app) you could create an endpoint that returns the session (or a part of it):

// File: `server/api/me.get.ts`
export default defineEventHandler((event: CompatibilityEvent) => event.context.session)

Playground

An example page making use of nuxt-session: nuxt session counter example

See the playground to interactively use this:

> git clone https://github.com/sidebase/nuxt-session

> cd nuxt-session

> npm i

> npm run dev:prepare

> npm run dev

# -> open http://localhost:3000

Development

  • Run npm run dev:prepare to generate type stubs.
  • Use npm run dev to start playground in development mode.
  • Run npm run lint to run eslint
  • Run npm run type to run typescheck via tsc

FAQs

Package last updated on 13 Oct 2022

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc