Skip to content

Commit

Permalink
fix: use normalized Headers object for interceptors
Browse files Browse the repository at this point in the history
  • Loading branch information
manchenkoff committed Oct 2, 2024
1 parent 8160e8c commit 22602b6
Show file tree
Hide file tree
Showing 4 changed files with 19 additions and 12 deletions.
6 changes: 2 additions & 4 deletions src/runtime/interceptors/common/request.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import type { FetchContext } from 'ofetch'
import type { ConsolaInstance } from 'consola'
import { appendRequestHeaders } from '../../utils/headers'
import type { NuxtApp } from '#app'

/**
Expand All @@ -16,10 +17,7 @@ export default async function handleRequestHeaders(
const method = ctx.options.method?.toLowerCase() ?? 'get'
const headersToAdd = { Accept: 'application/json' }

ctx.options.headers = Object.assign(
ctx.options.headers || {},
headersToAdd,
)
ctx.options.headers = appendRequestHeaders(ctx.options.headers, headersToAdd)

// https://laravel.com/docs/10.x/routing#form-method-spoofing
if (method === 'put' && ctx.options.body instanceof FormData) {
Expand Down
15 changes: 8 additions & 7 deletions src/runtime/interceptors/cookie/request.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import type { FetchContext } from 'ofetch'
import type { ConsolaInstance } from 'consola'
import { useSanctumConfig } from '../../composables/useSanctumConfig'
import type { ModuleOptions } from '../../types/options'
import { appendRequestHeaders } from '../../utils/headers'
import { type NuxtApp, useCookie, useRequestHeaders, useRequestURL } from '#app'

const SECURE_METHODS = new Set(['post', 'delete', 'put', 'patch'])
Expand All @@ -15,10 +16,10 @@ const COOKIE_OPTIONS: { readonly: true } = { readonly: true }
* @returns Headers collection to pass to the API
*/
function useServerHeaders(
headers: HeadersInit | undefined,
headers: Headers,
config: ModuleOptions,
logger: ConsolaInstance,
): HeadersInit {
): Headers {
const clientHeaders = useRequestHeaders(['cookie', 'user-agent'])
const origin = config.origin ?? useRequestURL().origin

Expand All @@ -34,7 +35,7 @@ function useServerHeaders(
Object.keys(headersToAdd),
)

return Object.assign(headers || {}, headersToAdd)
return appendRequestHeaders(headers, headersToAdd)
}

/**
Expand Down Expand Up @@ -67,10 +68,10 @@ async function initCsrfCookie(
* @returns Headers collection to pass to the API
*/
async function useCsrfHeader(
headers: HeadersInit | undefined,
headers: Headers,
config: ModuleOptions,
logger: ConsolaInstance,
): Promise<HeadersInit> {
): Promise<Headers> {
if (config.csrf.cookie === undefined) {
throw new Error('`sanctum.csrf.cookie` is not defined')
}
Expand All @@ -88,14 +89,14 @@ async function useCsrfHeader(

if (!csrfToken.value) {
logger.warn(`${config.csrf.cookie} cookie is missing, unable to set ${config.csrf.header} header`)
return headers || {}
return headers
}

const headersToAdd = { [config.csrf.header]: csrfToken.value }

logger.debug(`[request] added csrf token header`, Object.keys(headersToAdd))

return Object.assign(headers || {}, headersToAdd)
return appendRequestHeaders(headers, headersToAdd)
}

/**
Expand Down
3 changes: 2 additions & 1 deletion src/runtime/interceptors/token/request.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import type { FetchContext } from 'ofetch'
import type { ConsolaInstance } from 'consola'
import { useSanctumAppConfig } from '../../composables/useSanctumAppConfig'
import { appendRequestHeaders } from '../../utils/headers'
import type { NuxtApp } from '#app'

/**
Expand Down Expand Up @@ -34,5 +35,5 @@ export default async function handleRequestTokenHeader(
Object.keys(headersToAdd),
)

ctx.options.headers = Object.assign(ctx.options.headers || {}, headersToAdd)
ctx.options.headers = appendRequestHeaders(ctx.options.headers, headersToAdd)
}
7 changes: 7 additions & 0 deletions src/runtime/utils/headers.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
export function appendRequestHeaders(headers: Headers, append: Record<string, string>): Headers {
for (const [key, value] of Object.entries(append)) {
headers.set(key, value)
}

return headers
}

0 comments on commit 22602b6

Please sign in to comment.