diff --git a/src/app/api/transactions/history/route.ts b/src/app/api/transactions/history/route.ts index 62875f3..01ca03a 100644 --- a/src/app/api/transactions/history/route.ts +++ b/src/app/api/transactions/history/route.ts @@ -20,7 +20,9 @@ export async function GET(req: NextRequest) { const supabase = createServerClient() const { searchParams } = new URL(req.url) - const limit = Math.min(parseInt(searchParams.get('limit') || '50'), 100) + let parsedLimit = parseInt(searchParams.get('limit') || '50', 10) + if (isNaN(parsedLimit) || parsedLimit < 1) parsedLimit = 50 + const limit = Math.min(parsedLimit, 100) // 1. Fetch Sent Transactions (where customer_wallet = walletAddress) const { data: sentTransactions, error: sentError } = await supabase diff --git a/src/app/api/transactions/route.ts b/src/app/api/transactions/route.ts index b619eb7..d1cbcc9 100644 --- a/src/app/api/transactions/route.ts +++ b/src/app/api/transactions/route.ts @@ -19,7 +19,9 @@ export async function GET(req: NextRequest) { const supabase = createServerClient() const { searchParams } = new URL(req.url) const paymentLinkId = searchParams.get('payment_link_id') - const limit = Math.min(parseInt(searchParams.get('limit') || '50'), 100) + let parsedLimit = parseInt(searchParams.get('limit') || '50', 10) + if (isNaN(parsedLimit) || parsedLimit < 1) parsedLimit = 50 + const limit = Math.min(parsedLimit, 100) // eslint-disable-next-line @typescript-eslint/no-explicit-any let query = (supabase.from('transactions') as any) diff --git a/src/app/api/v1/payment-links/route.ts b/src/app/api/v1/payment-links/route.ts index 03280f8..81027a9 100644 --- a/src/app/api/v1/payment-links/route.ts +++ b/src/app/api/v1/payment-links/route.ts @@ -183,8 +183,12 @@ export async function GET(req: NextRequest) { } const { searchParams } = new URL(req.url) - const limit = Math.min(parseInt(searchParams.get('limit') || '10'), 100) - const offset = parseInt(searchParams.get('offset') || '0') + let parsedLimit = parseInt(searchParams.get('limit') || '10', 10) + if (isNaN(parsedLimit) || parsedLimit < 1) parsedLimit = 10 + const limit = Math.min(parsedLimit, 100) + + let offset = parseInt(searchParams.get('offset') || '0', 10) + if (isNaN(offset) || offset < 0) offset = 0 // eslint-disable-next-line @typescript-eslint/no-explicit-any const supabase = createServerClient() as any diff --git a/src/app/api/v1/transactions/route.ts b/src/app/api/v1/transactions/route.ts index 9beab7e..00e20c3 100644 --- a/src/app/api/v1/transactions/route.ts +++ b/src/app/api/v1/transactions/route.ts @@ -10,8 +10,13 @@ export async function GET(req: NextRequest) { } const { searchParams } = new URL(req.url) - const limit = Math.min(parseInt(searchParams.get('limit') || '10'), 100) - const offset = parseInt(searchParams.get('offset') || '0') + let parsedLimit = parseInt(searchParams.get('limit') || '10', 10) + if (isNaN(parsedLimit) || parsedLimit < 1) parsedLimit = 10 + const limit = Math.min(parsedLimit, 100) + + let offset = parseInt(searchParams.get('offset') || '0', 10) + if (isNaN(offset) || offset < 0) offset = 0 + const status = searchParams.get('status') const paymentLinkId = searchParams.get('payment_link_id')