security: address remaining code scanning alerts (#253)
This commit is contained in:
27
src/services/oauth/crypto.test.ts
Normal file
27
src/services/oauth/crypto.test.ts
Normal file
@@ -0,0 +1,27 @@
|
||||
import assert from 'node:assert/strict'
|
||||
import test from 'node:test'
|
||||
|
||||
import {
|
||||
generateCodeChallenge,
|
||||
generateCodeVerifier,
|
||||
generateState,
|
||||
} from './crypto.ts'
|
||||
|
||||
test('generateCodeChallenge returns the RFC 7636 S256 challenge', async () => {
|
||||
const challenge = await generateCodeChallenge(
|
||||
'dBjftJeZ4CVP-mB92K27uhbUJU1p1r_wW1gFWFOEjXk',
|
||||
)
|
||||
assert.equal(challenge, 'E9Melhoa2OwvFrEMTJguCHaoeK1t8URWbuGJSstw-cM')
|
||||
})
|
||||
|
||||
test('generateCodeVerifier returns a URL-safe random string', () => {
|
||||
const verifier = generateCodeVerifier()
|
||||
assert.match(verifier, /^[A-Za-z0-9_-]+$/)
|
||||
assert.ok(verifier.length >= 43)
|
||||
})
|
||||
|
||||
test('generateState returns a URL-safe random string', () => {
|
||||
const state = generateState()
|
||||
assert.match(state, /^[A-Za-z0-9_-]+$/)
|
||||
assert.ok(state.length >= 43)
|
||||
})
|
||||
@@ -1,4 +1,4 @@
|
||||
import { createHash, randomBytes } from 'crypto'
|
||||
import { randomBytes, webcrypto } from 'crypto'
|
||||
|
||||
function base64URLEncode(buffer: Buffer): string {
|
||||
return buffer
|
||||
@@ -12,10 +12,10 @@ export function generateCodeVerifier(): string {
|
||||
return base64URLEncode(randomBytes(32))
|
||||
}
|
||||
|
||||
export function generateCodeChallenge(verifier: string): string {
|
||||
const hash = createHash('sha256')
|
||||
hash.update(verifier)
|
||||
return base64URLEncode(hash.digest())
|
||||
export async function generateCodeChallenge(verifier: string): Promise<string> {
|
||||
const encoded = new TextEncoder().encode(verifier)
|
||||
const digest = await webcrypto.subtle.digest('SHA-256', encoded)
|
||||
return base64URLEncode(Buffer.from(digest))
|
||||
}
|
||||
|
||||
export function generateState(): string {
|
||||
|
||||
@@ -52,7 +52,7 @@ export class OAuthService {
|
||||
this.port = await this.authCodeListener.start()
|
||||
|
||||
// Generate PKCE values and state
|
||||
const codeChallenge = crypto.generateCodeChallenge(this.codeVerifier)
|
||||
const codeChallenge = await crypto.generateCodeChallenge(this.codeVerifier)
|
||||
const state = crypto.generateState()
|
||||
|
||||
// Build auth URLs for both automatic and manual flows
|
||||
|
||||
Reference in New Issue
Block a user