nuxt3-csurf
TypeScript icon, indicating that this package has built-in type declarations

1.3.1 • Public • Published

🏄‍♂️ Nuxt Cross-Site Request Forgery (CSRF) Prevention using Web Crypto API (requires Node.js 19+)

Create a middleware for CSRF token creation and validation in serverless environments.

This fork is compatible with Cloudflare Workers.

Setup

yarn add nuxt3-csurf # yarn
npm i nuxt3-csurf # npm

Usage

The only thing you need to do to use the module in the default configuration is to register the module in the modules array in nuxt.config.ts:

// nuxt.config.js
{
  modules: [
    "nuxt3-csurf",
  ],
  csurf: { // optional
    https: false, // default true if in production
    cookieKey: '', // "__Host-csrf" if https is true otherwise just "csrf"
    cookie: { // CookieSerializeOptions from unjs/cookie-es
      path: '/',
      httpOnly: true,
      sameSite: 'strict'
    },
    methodsToProtect: ['POST', 'PUT', 'PATCH'], // the request methods we want CSRF protection for
    excludedUrls: ['/nocsrf1', ['/nocsrf2/.*', 'i']], // any URLs we want to exclude from CSRF protection
    encryptSecret: /** JsonWebKey object */, // random key by default
    encryptAlgorithm: 'AES-CBC'
  } 
}

useCsrfFetch

This composable provides a convenient wrapper around useFetch. It automatically adds the CSRF token in headers.

const { data, pending, error, refresh } = useCsrfFetch('/api/login', { query: param1: 'value1' })

$csrfFetch

This helper provides a convenient wrapper around $fetch. It automatically adds the CSRF token in headers.

const { $csrfFetch } = useNuxtApp()
const { data } = await $csrfFetch('/api/login', { method: 'POST', body: , headers:  })

useCsrf

Use this composable if you need to access to the CSRF token value.

const { csrf } = useCsrf()
console.log(csrf) // something like: mo4+MrFaeXP7fhAie0o2qw==:tLUaqtHW6evx/coGQVAhtGAR+v6cxgFtrqmkOsuAMag8PHRnMwpbGGUO0TPJjL+4

Credits

Readme

Keywords

Package Sidebar

Install

npm i nuxt3-csurf

Weekly Downloads

1

Version

1.3.1

License

MIT

Unpacked Size

13.2 kB

Total Files

20

Last publish

Collaborators

  • 69u