N
Nuxt11mo ago
Nook

useFetch informs the the method is not available for the route

Following this thread https://discord.com/channels/473401852243869706/473406506579263488/1222265282048032872 I managed to narrow down the reproduction of the issue. Given the following tree
server/api
├── audits
│ ├── [auditId]
│ │ ├── index.delete.ts
│ │ └── index.get.ts
│ ├── index.get.ts
│ ├── index.post.ts
│ └── progression.get.ts
server/api
├── audits
│ ├── [auditId]
│ │ ├── index.delete.ts
│ │ └── index.get.ts
│ ├── index.get.ts
│ ├── index.post.ts
│ └── progression.get.ts
  and nitro-routes.d.ts
// Generated by nitro
import type { Serialize, Simplify } from 'nitropack'
declare module 'nitropack' {
type Awaited<T> = T extends PromiseLike<infer U> ? Awaited<U> : T
interface InternalApi {
'/api/audits/:auditId': {
'delete': Simplify<Serialize<Awaited<ReturnType<typeof import('../../server/api/audits/[auditId]/index.delete').default>>>>
'get': Simplify<Serialize<Awaited<ReturnType<typeof import('../../server/api/audits/[auditId]/index.get').default>>>>
}
'/api/audits': {
'get': Simplify<Serialize<Awaited<ReturnType<typeof import('../../server/api/audits/index.get').default>>>>
'post': Simplify<Serialize<Awaited<ReturnType<typeof import('../../server/api/audits/index.post').default>>>>
}
'/api/audits/progression': {
'get': Simplify<Serialize<Awaited<ReturnType<typeof import('../../server/api/audits/progression.get').default>>>>
}
}
}
export {}
// Generated by nitro
import type { Serialize, Simplify } from 'nitropack'
declare module 'nitropack' {
type Awaited<T> = T extends PromiseLike<infer U> ? Awaited<U> : T
interface InternalApi {
'/api/audits/:auditId': {
'delete': Simplify<Serialize<Awaited<ReturnType<typeof import('../../server/api/audits/[auditId]/index.delete').default>>>>
'get': Simplify<Serialize<Awaited<ReturnType<typeof import('../../server/api/audits/[auditId]/index.get').default>>>>
}
'/api/audits': {
'get': Simplify<Serialize<Awaited<ReturnType<typeof import('../../server/api/audits/index.get').default>>>>
'post': Simplify<Serialize<Awaited<ReturnType<typeof import('../../server/api/audits/index.post').default>>>>
}
'/api/audits/progression': {
'get': Simplify<Serialize<Awaited<ReturnType<typeof import('../../server/api/audits/progression.get').default>>>>
}
}
}
export {}
And this code:
const onDelete = async (id: string) => {
await $fetch(`/api/audits/${id}`, {
method: 'DELETE',
})
})
const onDelete = async (id: string) => {
await $fetch(`/api/audits/${id}`, {
method: 'DELETE',
})
})
We receive the following error:
Type '"DELETE"' is not assignable to type '"get" | "GET" | undefined'.ts(2322)
(property) NitroFetchOptions<`/api/audits/${string}`, "get">.method?: "get" | "GET" | undefined
Type '"DELETE"' is not assignable to type '"get" | "GET" | undefined'.ts(2322)
(property) NitroFetchOptions<`/api/audits/${string}`, "get">.method?: "get" | "GET" | undefined
The reason is that /api/audits/${id} is assignable to /api/audits/progression and that's why only the get method is allowed.
0 Replies
No replies yetBe the first to reply to this messageJoin

Did you find this page helpful?