Skip to content

Commit

Permalink
build(deps-dev): replace standard with neostandard (#355)
Browse files Browse the repository at this point in the history
* build(deps-dev): replace standard with neostandard

* chore: add eslint.config.js

* Update package.json

Signed-off-by: Frazer Smith <[email protected]>

* chore: ignore

---------

Signed-off-by: Frazer Smith <[email protected]>
  • Loading branch information
Fdawgs authored Jan 16, 2025
1 parent cdbb3ed commit fdf300d
Show file tree
Hide file tree
Showing 5 changed files with 69 additions and 58 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

[![CI](https://github.com/fastify/fastify-jwt/actions/workflows/ci.yml/badge.svg?branch=master)](https://github.com/fastify/fastify-jwt/actions/workflows/ci.yml)
[![NPM version](https://img.shields.io/npm/v/@fastify/jwt.svg?style=flat)](https://www.npmjs.com/package/@fastify/jwt)
[![js-standard-style](https://img.shields.io/badge/code%20style-standard-brightgreen.svg?style=flat)](https://standardjs.com/)
[![neostandard javascript style](https://img.shields.io/badge/code_style-neostandard-brightgreen?style=flat)](https://github.com/neostandard/neostandard)

JWT utils for Fastify, internally it uses [fast-jwt](https://github.com/nearform/fast-jwt).

Expand Down
6 changes: 6 additions & 0 deletions eslint.config.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
'use strict'

module.exports = require('neostandard')({
ignores: require('neostandard').resolveIgnoresFromGitignore(),
ts: true
})
7 changes: 4 additions & 3 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,8 @@
"type": "commonjs",
"types": "types/jwt.d.ts",
"scripts": {
"lint": "standard",
"lint:fix": "standard --fix",
"lint": "eslint",
"lint:fix": "eslint --fix",
"test": "npm run lint && npm run test:unit && npm run test:typescript",
"test:typescript": "tsd",
"test:unit": "tap",
Expand Down Expand Up @@ -71,8 +71,9 @@
"@fastify/cookie": "^11.0.1",
"@fastify/pre-commit": "^2.1.0",
"@types/node": "^22.0.0",
"eslint": "^9.17.0",
"fastify": "^5.0.0",
"standard": "^17.1.0",
"neostandard": "^0.11.9",
"tap": "^18.7.1",
"tsd": "^0.31.0"
},
Expand Down
27 changes: 16 additions & 11 deletions types/jwt.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -27,9 +27,12 @@ declare module 'fastify' {

interface FastifyRequest {
jwtVerify<Decoded extends fastifyJwt.VerifyPayloadType>(options?: fastifyJwt.FastifyJwtVerifyOptions): Promise<Decoded>
// eslint-disable-next-line @typescript-eslint/no-unused-vars
jwtVerify<Decoded extends fastifyJwt.VerifyPayloadType>(callback: VerifierCallback): void
// eslint-disable-next-line @typescript-eslint/no-unused-vars
jwtVerify<Decoded extends fastifyJwt.VerifyPayloadType>(options: fastifyJwt.FastifyJwtVerifyOptions, callback: VerifierCallback): void
jwtVerify<Decoded extends fastifyJwt.VerifyPayloadType>(options?: Partial<fastifyJwt.VerifyOptions>): Promise<Decoded>
// eslint-disable-next-line @typescript-eslint/no-unused-vars
jwtVerify<Decoded extends fastifyJwt.VerifyPayloadType>(options: Partial<fastifyJwt.VerifyOptions>, callback: VerifierCallback): void
jwtDecode<Decoded extends fastifyJwt.DecodePayloadType>(options?: fastifyJwt.FastifyJwtDecodeOptions): Promise<Decoded>
jwtDecode<Decoded extends fastifyJwt.DecodePayloadType>(callback: fastifyJwt.DecodeCallback<Decoded>): void
Expand All @@ -48,23 +51,23 @@ declare namespace fastifyJwt {
jwtVerify?: string;
jwtSign?: string;
}> =
Record<C extends { jwtDecode: string}
Record<C extends { jwtDecode: string }
? C['jwtDecode']
: C extends {namespace: string}
: C extends { namespace: string }
? `${C['namespace']}JwtDecode`
: never,
JWT['decode']>
&
Record<C extends { jwtSign: string}
Record<C extends { jwtSign: string }
? C['jwtSign']
: C extends {namespace: string}
: C extends { namespace: string }
? `${C['namespace']}JwtSign`
: never,
JWT['sign']>
&
Record<C extends { jwtVerify: string}
Record<C extends { jwtVerify: string }
? C['jwtVerify']
: C extends {namespace: string}
: C extends { namespace: string }
? `${C['namespace']}JwtVerify`
: never,
JWT['verify']>
Expand Down Expand Up @@ -97,8 +100,8 @@ declare namespace fastifyJwt {

export type SignPayloadType = FastifyJWT extends { payload: infer T }
? T extends string | object | Buffer
? T
: string | object | Buffer
? T
: string | object | Buffer
: string | object | Buffer

export type UserType = FastifyJWT extends { user: infer T }
Expand All @@ -118,13 +121,13 @@ declare namespace fastifyJwt {
(err: Error, decoded: Decoded): void
}

export interface SignOptions extends Omit<SignerOptions, "expiresIn" | "notBefore"> {
export interface SignOptions extends Omit<SignerOptions, 'expiresIn' | 'notBefore'> {
expiresIn: number | string;
notBefore: number | string;
key?: string | Buffer
}

export interface VerifyOptions extends Omit<VerifierOptions, "maxAge"> {
export interface VerifyOptions extends Omit<VerifierOptions, 'maxAge'> {
maxAge: number | string;
onlyCookie: boolean;
key?: string | Buffer
Expand Down Expand Up @@ -179,7 +182,9 @@ declare namespace fastifyJwt {
sign(payload: SignPayloadType, options: Partial<SignOptions>, callback: SignerCallback): void

verify<Decoded extends VerifyPayloadType>(token: string, options?: Partial<VerifyOptions>): Decoded
// eslint-disable-next-line @typescript-eslint/no-unused-vars
verify<Decoded extends VerifyPayloadType>(token: string, callback: VerifierCallback): void
// eslint-disable-next-line @typescript-eslint/no-unused-vars
verify<Decoded extends VerifyPayloadType>(token: string, options: Partial<VerifyOptions>, callback: VerifierCallback): void

decode<Decoded extends DecodePayloadType>(token: string, options?: Partial<DecoderOptions>): null | Decoded
Expand Down Expand Up @@ -207,5 +212,5 @@ declare namespace fastifyJwt {
export { fastifyJwt as default }
}

declare function fastifyJwt(...params: Parameters<FastifyJwt>): ReturnType<FastifyJwt>
declare function fastifyJwt (...params: Parameters<FastifyJwt>): ReturnType<FastifyJwt>
export = fastifyJwt
85 changes: 42 additions & 43 deletions types/jwt.test-d.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
import fastify from 'fastify';
import fastify from 'fastify'
import fastifyJwt, { FastifyJWTOptions, FastifyJwtNamespace, JWT, SignOptions, VerifyOptions } from '..'
import { expectAssignable, expectType } from 'tsd'

const app = fastify();
const app = fastify()

const secretOptions = {
secret: 'supersecret',
Expand Down Expand Up @@ -58,21 +58,21 @@ const jwtOptions: FastifyJWTOptions = {
? JSON.parse(payload)
: Buffer.isBuffer(payload)
? JSON.parse(payload.toString())
: payload;
: payload
return { name: objectPayload.userName }
},
namespace: 'security',
jwtVerify: 'securityVerify',
jwtSign: 'securitySign'
}

app.register(fastifyJwt, jwtOptions);
app.register(fastifyJwt, jwtOptions)

Object.values(secretOptions).forEach((value) => {
app.register(fastifyJwt, {...jwtOptions, secret: value });
app.register(fastifyJwt, { ...jwtOptions, secret: value })
})

app.register(fastifyJwt, {...jwtOptions, trusted: () => Promise.resolve(false || '' || Buffer.from('foo')) })
app.register(fastifyJwt, { ...jwtOptions, trusted: () => Promise.resolve(false || '' || Buffer.from('foo')) })

app.register(fastifyJwt, {
secret: {
Expand All @@ -85,7 +85,7 @@ app.register(fastifyJwt, {
sign: { algorithm: 'ES256' },
})

app.register(fastifyJwt, {...jwtOptions, decoratorName: 'token' })
app.register(fastifyJwt, { ...jwtOptions, decoratorName: 'token' })

// expect jwt and its subsequent methods have merged with the fastify instance
expectAssignable<object>(app.jwt)
Expand All @@ -95,27 +95,24 @@ expectAssignable<Function>(app.jwt.decode)
expectAssignable<Function>(app.jwt.lookupToken)
expectAssignable<FastifyJWTOptions['cookie']>(app.jwt.cookie)

app.addHook("preHandler", async (request, reply) => {
app.addHook('preHandler', async (request, reply) => {
// assert request and reply specific interface merges
expectAssignable<Function>(request.jwtVerify)
expectAssignable<Function>(request.jwtDecode)
expectAssignable<object | string | Buffer>(request.user)
expectAssignable<Function>(reply.jwtSign)

try {
await request.jwtVerify();
await request.jwtVerify()
} catch (err) {
reply.send(err)
}
catch (err) {
reply.send(err);
}
});
})

app.post('/signup', async (req, reply) => {
const token = app.jwt.sign({ user: "userName" });
let data = await app.jwt.verify(token);
const user = req.user;
reply.send({ token });
});
const token = app.jwt.sign({ user: 'userName' })
reply.send({ token })
})

// define custom payload
// declare module './jwt' {
Expand All @@ -138,64 +135,66 @@ app.post('/signup', async (req, reply) => {
// }
// }

expectType<JWT['decode']>(({} as FastifyJwtNamespace<{namespace: 'security'}>).securityJwtDecode)
expectType<JWT['sign']>(({} as FastifyJwtNamespace<{namespace: 'security'}>).securityJwtSign)
expectType<JWT['verify']>(({} as FastifyJwtNamespace<{namespace: 'security'}>).securityJwtVerify)
expectType<JWT['decode']>(({} as FastifyJwtNamespace<{ namespace: 'security' }>).securityJwtDecode)
expectType<JWT['sign']>(({} as FastifyJwtNamespace<{ namespace: 'security' }>).securityJwtSign)
expectType<JWT['verify']>(({} as FastifyJwtNamespace<{ namespace: 'security' }>).securityJwtVerify)

declare module 'fastify' {
interface FastifyInstance extends FastifyJwtNamespace<{namespace: 'tsdTest'}> {
interface FastifyInstance extends FastifyJwtNamespace<{ namespace: 'tsdTest' }> {
}
}

expectType<JWT['decode']>(app.tsdTestJwtDecode)
expectType<JWT['sign']>(app.tsdTestJwtSign)
expectType<JWT['verify']>(app.tsdTestJwtVerify)

expectType<JWT['decode']>(({} as FastifyJwtNamespace<{ namespace: 'security', jwtDecode: 'decode'}>).decode)
expectType<JWT['sign']>(({} as FastifyJwtNamespace<{ namespace: 'security', jwtDecode: 'decode'}>).securityJwtSign)
expectType<JWT['verify']>(({} as FastifyJwtNamespace<{ namespace: 'security', jwtDecode: 'decode'}>).securityJwtVerify)
expectType<JWT['decode']>(({} as FastifyJwtNamespace<{ namespace: 'security', jwtDecode: 'decode' }>).decode)
expectType<JWT['sign']>(({} as FastifyJwtNamespace<{ namespace: 'security', jwtDecode: 'decode' }>).securityJwtSign)
expectType<JWT['verify']>(({} as FastifyJwtNamespace<{ namespace: 'security', jwtDecode: 'decode' }>).securityJwtVerify)

expectType<JWT['decode']>(({} as FastifyJwtNamespace<{ namespace: 'security', jwtSign: 'decode'}>).securityJwtDecode)
expectType<JWT['sign']>(({} as FastifyJwtNamespace<{ namespace: 'security', jwtSign: 'sign'}>).sign)
expectType<JWT['verify']>(({} as FastifyJwtNamespace<{ namespace: 'security', jwtSign: 'decode'}>).securityJwtVerify)
expectType<JWT['decode']>(({} as FastifyJwtNamespace<{ namespace: 'security', jwtSign: 'decode' }>).securityJwtDecode)
expectType<JWT['sign']>(({} as FastifyJwtNamespace<{ namespace: 'security', jwtSign: 'sign' }>).sign)
expectType<JWT['verify']>(({} as FastifyJwtNamespace<{ namespace: 'security', jwtSign: 'decode' }>).securityJwtVerify)

expectType<JWT['decode']>(({} as FastifyJwtNamespace<{ namespace: 'security', jwtVerify: 'verify'}>).securityJwtDecode)
expectType<JWT['sign']>(({} as FastifyJwtNamespace<{ namespace: 'security', jwtVerify: 'verify'}>).securityJwtSign)
expectType<JWT['verify']>(({} as FastifyJwtNamespace<{ namespace: 'security', jwtVerify: 'verify'}>).verify)
expectType<JWT['decode']>(({} as FastifyJwtNamespace<{ namespace: 'security', jwtVerify: 'verify' }>).securityJwtDecode)
expectType<JWT['sign']>(({} as FastifyJwtNamespace<{ namespace: 'security', jwtVerify: 'verify' }>).securityJwtSign)
expectType<JWT['verify']>(({} as FastifyJwtNamespace<{ namespace: 'security', jwtVerify: 'verify' }>).verify)

expectType<JWT['decode']>(({} as FastifyJwtNamespace<{ jwtDecode: 'decode'}>).decode)
expectType<JWT['sign']>(({} as FastifyJwtNamespace<{ jwtSign: 'sign'}>).sign)
expectType<JWT['verify']>(({} as FastifyJwtNamespace<{ jwtVerify: 'verify'}>).verify)
expectType<JWT['decode']>(({} as FastifyJwtNamespace<{ jwtDecode: 'decode' }>).decode)
expectType<JWT['sign']>(({} as FastifyJwtNamespace<{ jwtSign: 'sign' }>).sign)
expectType<JWT['verify']>(({} as FastifyJwtNamespace<{ jwtVerify: 'verify' }>).verify)

let signOptions: SignOptions = {
key: "supersecret",
algorithm: "HS256",
key: 'supersecret',
algorithm: 'HS256',
mutatePayload: true,
expiresIn: 3600,
notBefore: 0,
}

// eslint-disable-next-line @typescript-eslint/no-unused-vars
signOptions = {
key: Buffer.from("supersecret", "utf-8"),
algorithm: "HS256",
key: Buffer.from('supersecret', 'utf-8'),
algorithm: 'HS256',
mutatePayload: true,
expiresIn: 3600,
notBefore: 0,
}

let verifyOptions: VerifyOptions = {
key: "supersecret",
algorithms: ["HS256"],
key: 'supersecret',
algorithms: ['HS256'],
complete: true,
cache: true,
cacheTTL: 3600,
maxAge: "1 hour",
maxAge: '1 hour',
onlyCookie: false,
}

// eslint-disable-next-line @typescript-eslint/no-unused-vars
verifyOptions = {
key: Buffer.from("supersecret", "utf-8"),
algorithms: ["HS256"],
key: Buffer.from('supersecret', 'utf-8'),
algorithms: ['HS256'],
complete: true,
cache: 3600,
cacheTTL: 3600,
Expand Down

0 comments on commit fdf300d

Please sign in to comment.