Nuxt (v3.x) module to handle
.well-knownURIs with middlewaresSee https://www.iana.org/assignments/well-known-uris/well-known-uris.xhtml
⚠️ Only tested with SSR mode (not SSG and CSR)
Nuxt Well-Known module is integrated with the Nuxt Devtools.
security.txtchange-passwordcontent-uris@zadigetvoltaire/nuxt-well-known dependency to your project# Using pnpm
pnpm add -D @zadigetvoltaire/nuxt-well-known
# Using yarn
yarn add --dev @zadigetvoltaire/nuxt-well-known
# Using npm
npm install --save-dev @zadigetvoltaire/nuxt-well-known
@zadigetvoltaire/nuxt-well-known to the modules section of nuxt.config.tsexport default defineNuxtConfig({
modules: [
'@zadigetvoltaire/nuxt-well-known'
],
})
nuxtConfig.wellKnown or in nuxtConfig.runtimeConfig.public.wellKnownThis module supports 2 ways of configuration:
wellKnown of the Nuxt configexport default defineNuxtConfig({
...
wellKnown: {
devtools: true,
securityTxt: {
disabled: false,
contacts: ['[email protected]'],
expires: new Date('2025-02-03')
},
changePassword: {
disabled: false,
redirectTo: 'https://example.com/password-recovery'
}
}
...
runtimeConfig: {
public: {
wellKnown: {
devtools: true,
securityTxt: {
disabled: false,
contacts: ['[email protected]'],
expires: new Date('2025-02-03').toISOString() // ⚠️ in runtime config, `expires` should be a string
},
changePassword: {
disabled: false,
redirectTo: 'https://example.com/password-recovery'
}
}
}
}
})
interface ModuleOptions {
/**
* Enable Nuxt Devtools integration
*
* @default true
*/
devtools?: boolean
securityTxt?: SecurityTxtOptions,
changePassword?: ChangePasswordOptions,
contentUris?: ContentUriOptions[],
}
security.txtThis middleware will generate a security.txt file available under /.well-known/security.txt URI.
Model options:
type SecurityTxtOptions = {
disabled?: boolean;
contacts: string[]; // https://www.rfc-editor.org/rfc/rfc9116#section-2.5.3
expires: string | Date; // https://www.rfc-editor.org/rfc/rfc9116#section-2.5.5
encryption?: string[]; // https://www.rfc-editor.org/rfc/rfc9116#section-2.5.4
acknowledgments?: string[]; // https://www.rfc-editor.org/rfc/rfc9116#section-2.5.1
preferredLanguages?: string[]; // https://www.rfc-editor.org/rfc/rfc9116#section-2.5.8
canonical?: string[]; // https://www.rfc-editor.org/rfc/rfc9116#section-2.5.2
policy?: string[]; // https://www.rfc-editor.org/rfc/rfc9116#section-2.5.7
hiring?: string[]; // https://www.rfc-editor.org/rfc/rfc9116#section-2.5.6
}
change-passwordThis middleware will redirect requests of /.well-known/change-password to the configured target URL.
type ChangePasswordOptions = {
disabled?: boolean;
redirectTo: string;
}
content-urisWith this middleware, you can generate uris with content
type ContentUriOptions = {
disabled?: boolean;
path: string;
content: string;
}
Example:
// nuxt.config.ts
export default defineNuxtConfig({
modules: [
'@zadigetvoltaire/nuxt-well-known',
],
wellKnown: {
contentUris: [
{ path: 'apple-developer-merchantid-domain-association', content: 'merchantid' },
{ path: 'content-uri.txt', content: 'content-uri' }
]
}
})
Will render:
https://example.com/.well-known/apple-developer-merchantid-domain-association --> merchantidhttps://example.com/.well-known/content-uri.txt --> content-uriThat's it! You can now use Nuxt Well-Known in your Nuxt app ✨
# Install dependencies, prepare apps & run dev server
make start
# Run dev server
pnpm dev
# Develop with playground, with bundled client ui
pnpm play:prod
# Run ESLint
pnpm lint
# Run Vitest
pnpm test
pnpm test:watch
⚠ This command should be executed only on the main branch
This command will:
pnpm release
© Zadig&Voltaire is a registered trademark of ZV FRANCE