priceos 1.0.21 → 1.0.23

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/next.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  PriceOS,
3
3
  PriceOSError
4
- } from "./chunk-SMK7KTGQ.js";
4
+ } from "./chunk-L253ULJU.js";
5
5
 
6
6
  // src/next.ts
7
7
  var DEFAULT_BASE_PATH = "/api/priceos";
@@ -10,6 +10,7 @@ var FEATURE_ACCESS_PATH = "v1/feature-access";
10
10
  var TRACK_USAGE_PATH = "v1/usage";
11
11
  var PRICING_TABLE_PATH = "v1/pricing-table";
12
12
  var CHECKOUT_PATH = "v1/checkout";
13
+ var CUSTOMER_PORTAL_PATH = "v1/customer-portal";
13
14
  var normalizePath = (value) => value.replace(/^\/+/, "");
14
15
  var logTrackUsageError = (message, details) => {
15
16
  if (details === void 0) {
@@ -27,6 +28,18 @@ var normalizeCustomerId = (value) => {
27
28
  const normalized = value.trim();
28
29
  return normalized.length ? normalized : null;
29
30
  };
31
+ var parseCustomerExpand = (url) => {
32
+ const expandValues = [...url.searchParams.getAll("expand"), ...url.searchParams.getAll("expand[]")].flatMap((value) => value.split(",")).map((value) => value.trim()).filter((value) => value.length > 0);
33
+ if (!expandValues.length) {
34
+ return { data: {} };
35
+ }
36
+ const normalizedValues = Array.from(new Set(expandValues));
37
+ const invalidValue = normalizedValues.find((value) => value !== "subscriptions");
38
+ if (invalidValue) {
39
+ return { error: `Invalid expand value: ${invalidValue}` };
40
+ }
41
+ return { data: { expand: normalizedValues } };
42
+ };
30
43
  var parseTrackUsageBody = async (request) => {
31
44
  let rawBody;
32
45
  try {
@@ -50,7 +63,7 @@ var parseTrackUsageBody = async (request) => {
50
63
  if (!Number.isFinite(amount) || amount <= 0) {
51
64
  return { error: "amount must be a positive number" };
52
65
  }
53
- const idempotencyKeyRaw = body.idempotencyKey ?? body.eventKey;
66
+ const idempotencyKeyRaw = body.idempotencyKey;
54
67
  const idempotencyKey = idempotencyKeyRaw === void 0 ? void 0 : typeof idempotencyKeyRaw === "string" && idempotencyKeyRaw.trim().length > 0 ? idempotencyKeyRaw.trim() : null;
55
68
  if (idempotencyKey === null) {
56
69
  return { error: "idempotencyKey must be a non-empty string" };
@@ -115,13 +128,20 @@ var parseCheckoutBody = async (request) => {
115
128
  return { error: "Invalid JSON body" };
116
129
  }
117
130
  const body = rawBody;
118
- const stripePriceId = typeof body.stripePriceId === "string" && body.stripePriceId.trim().length > 0 ? body.stripePriceId.trim() : "";
119
- if (!stripePriceId) {
120
- return { error: "stripePriceId is required" };
131
+ const stripeProductKey = typeof body.stripeProductKey === "string" && body.stripeProductKey.trim().length > 0 ? body.stripeProductKey.trim() : void 0;
132
+ const stripePriceId = typeof body.stripePriceId === "string" && body.stripePriceId.trim().length > 0 ? body.stripePriceId.trim() : void 0;
133
+ if (!stripeProductKey && !stripePriceId) {
134
+ return { error: "stripeProductKey or stripePriceId is required" };
121
135
  }
122
- const successUrl = typeof body.successUrl === "string" && body.successUrl.trim().length > 0 ? body.successUrl.trim() : "";
123
- if (!successUrl) {
124
- return { error: "successUrl is required" };
136
+ const successUrlRaw = body.successUrl;
137
+ if (successUrlRaw !== void 0 && typeof successUrlRaw !== "string") {
138
+ return { error: "successUrl must be a non-empty string" };
139
+ }
140
+ const successUrl = normalizeCustomerId(
141
+ typeof successUrlRaw === "string" ? successUrlRaw : void 0
142
+ );
143
+ if (successUrlRaw !== void 0 && !successUrl) {
144
+ return { error: "successUrl must be a non-empty string" };
125
145
  }
126
146
  const cancelUrl = typeof body.cancelUrl === "string" && body.cancelUrl.trim().length > 0 ? body.cancelUrl.trim() : void 0;
127
147
  const customerId = typeof body.customerId === "string" && body.customerId.trim().length > 0 ? body.customerId.trim() : void 0;
@@ -136,16 +156,71 @@ var parseCheckoutBody = async (request) => {
136
156
  }
137
157
  }
138
158
  }
159
+ const checkoutParamsRaw = body.checkoutParams;
160
+ if (checkoutParamsRaw !== void 0 && (!checkoutParamsRaw || typeof checkoutParamsRaw !== "object" || Array.isArray(checkoutParamsRaw))) {
161
+ return { error: "checkoutParams must be an object" };
162
+ }
163
+ const customerInfoRaw = body.customerInfo;
164
+ if (customerInfoRaw !== void 0 && (!customerInfoRaw || typeof customerInfoRaw !== "object" || Array.isArray(customerInfoRaw))) {
165
+ return { error: "customerInfo must be an object" };
166
+ }
167
+ const customerInfoRecord = customerInfoRaw;
168
+ const customerName = normalizeCustomerId(
169
+ typeof customerInfoRecord?.name === "string" ? customerInfoRecord.name : void 0
170
+ );
171
+ const customerEmail = normalizeCustomerId(
172
+ typeof customerInfoRecord?.email === "string" ? customerInfoRecord.email : void 0
173
+ );
139
174
  return {
140
175
  data: {
141
- stripePriceId,
142
- successUrl,
176
+ ...stripeProductKey ? { stripeProductKey } : {},
177
+ ...stripePriceId ? { stripePriceId } : {},
178
+ ...successUrl ? { successUrl } : {},
143
179
  ...cancelUrl ? { cancelUrl } : {},
144
180
  ...customerId ? { customerId } : {},
145
- ...metadataRaw ? { metadata: metadataRaw } : {}
181
+ ...metadataRaw ? { metadata: metadataRaw } : {},
182
+ ...checkoutParamsRaw ? { checkoutParams: checkoutParamsRaw } : {},
183
+ ...customerInfoRaw ? {
184
+ customerInfo: {
185
+ ...customerName ? { name: customerName } : {},
186
+ ...customerEmail ? { email: customerEmail } : {}
187
+ }
188
+ } : {}
146
189
  }
147
190
  };
148
191
  };
192
+ var parseCustomerPortalBody = async (request) => {
193
+ let rawText = "";
194
+ try {
195
+ rawText = await request.text();
196
+ } catch {
197
+ return { error: "Invalid JSON body" };
198
+ }
199
+ if (!rawText.trim()) return { data: {} };
200
+ let rawBody;
201
+ try {
202
+ rawBody = JSON.parse(rawText);
203
+ } catch {
204
+ return { error: "Invalid JSON body" };
205
+ }
206
+ if (!rawBody || typeof rawBody !== "object" || Array.isArray(rawBody)) {
207
+ return { error: "Invalid JSON body" };
208
+ }
209
+ const body = rawBody;
210
+ const customerIdRaw = body.customerId;
211
+ if (customerIdRaw !== void 0 && typeof customerIdRaw !== "string") {
212
+ return { error: "customerId must be a non-empty string" };
213
+ }
214
+ const customerId = normalizeCustomerId(
215
+ typeof customerIdRaw === "string" ? customerIdRaw : void 0
216
+ );
217
+ if (customerIdRaw !== void 0 && !customerId) {
218
+ return { error: "customerId must be a non-empty string" };
219
+ }
220
+ return {
221
+ data: customerId ? { customerId } : {}
222
+ };
223
+ };
149
224
  var handleGetCustomer = async (request, url, client, getCustomerId) => {
150
225
  if (request.method.toUpperCase() !== "GET") {
151
226
  return new Response("Method not allowed.", { status: 405 });
@@ -157,8 +232,12 @@ var handleGetCustomer = async (request, url, client, getCustomerId) => {
157
232
  if (errorResponse || !customerId) {
158
233
  return errorResponse ?? jsonResponse(401, { error: "Customer not identified" });
159
234
  }
235
+ const expandResult = parseCustomerExpand(url);
236
+ if (!expandResult.data) {
237
+ return jsonResponse(400, { error: expandResult.error ?? "Invalid request" });
238
+ }
160
239
  try {
161
- const data = await client.customers.get(customerId);
240
+ const data = await client.customers.get(customerId, expandResult.data);
162
241
  return jsonResponse(200, data);
163
242
  } catch (error) {
164
243
  if (error instanceof PriceOSError) {
@@ -289,12 +368,79 @@ var handleCreateCheckout = async (request, client, getCustomerId) => {
289
368
  request
290
369
  );
291
370
  if (errorResponse) return errorResponse;
371
+ if (parsed.data.customerId && resolvedCustomerId && parsed.data.customerId !== resolvedCustomerId) {
372
+ return jsonResponse(403, { error: "customerId must match authenticated customer" });
373
+ }
374
+ const customerId = parsed.data.customerId ?? resolvedCustomerId;
375
+ if (!customerId) {
376
+ return jsonResponse(401, { error: "Customer not identified" });
377
+ }
378
+ if (parsed.data.stripePriceId) {
379
+ const requestOrigin = new URL(request.url).origin;
380
+ const successUrl = parsed.data.successUrl ?? `${requestOrigin}/settings/billing?checkout=success`;
381
+ const cancelUrl = parsed.data.cancelUrl ?? successUrl;
382
+ try {
383
+ const data = await client.checkout.create({
384
+ stripePriceId: parsed.data.stripePriceId,
385
+ successUrl,
386
+ cancelUrl,
387
+ ...parsed.data.metadata ? { metadata: parsed.data.metadata } : {},
388
+ customerId
389
+ });
390
+ return jsonResponse(200, data);
391
+ } catch (error) {
392
+ if (error instanceof PriceOSError) {
393
+ return jsonResponse(error.status ?? 500, { error: error.message });
394
+ }
395
+ return jsonResponse(500, { error: "Request failed" });
396
+ }
397
+ }
398
+ if (!parsed.data.stripeProductKey) {
399
+ return jsonResponse(400, { error: "stripeProductKey is required" });
400
+ }
401
+ const checkoutParams = {
402
+ ...parsed.data.checkoutParams ?? {},
403
+ ...parsed.data.cancelUrl ? { cancel_url: parsed.data.cancelUrl } : {},
404
+ ...parsed.data.metadata ? { metadata: parsed.data.metadata } : {}
405
+ };
292
406
  const body = {
293
- ...parsed.data,
294
- ...parsed.data.customerId ?? resolvedCustomerId ? { customerId: parsed.data.customerId ?? resolvedCustomerId ?? void 0 } : {}
407
+ stripeProductKey: parsed.data.stripeProductKey,
408
+ ...parsed.data.successUrl ? { successUrl: parsed.data.successUrl } : {},
409
+ ...parsed.data.customerInfo ? { customerInfo: parsed.data.customerInfo } : {},
410
+ ...Object.keys(checkoutParams).length ? { checkoutParams } : {}
295
411
  };
296
412
  try {
297
- const data = await client.checkout.create(body);
413
+ const data = await client.customers.createCheckout(customerId, body);
414
+ return jsonResponse(200, data);
415
+ } catch (error) {
416
+ if (error instanceof PriceOSError) {
417
+ return jsonResponse(error.status ?? 500, { error: error.message });
418
+ }
419
+ return jsonResponse(500, { error: "Request failed" });
420
+ }
421
+ };
422
+ var handleCreateCustomerPortal = async (request, client, getCustomerId) => {
423
+ if (request.method.toUpperCase() !== "POST") {
424
+ return new Response("Method not allowed.", { status: 405 });
425
+ }
426
+ const parsed = await parseCustomerPortalBody(request);
427
+ if (!parsed.data) {
428
+ return jsonResponse(400, { error: parsed.error ?? "Invalid request body" });
429
+ }
430
+ const { customerId: resolvedCustomerId, errorResponse } = await resolveOptionalCustomerId(
431
+ getCustomerId,
432
+ request
433
+ );
434
+ if (errorResponse) return errorResponse;
435
+ if (parsed.data.customerId && resolvedCustomerId && parsed.data.customerId !== resolvedCustomerId) {
436
+ return jsonResponse(403, { error: "customerId must match authenticated customer" });
437
+ }
438
+ const customerId = parsed.data.customerId ?? resolvedCustomerId;
439
+ if (!customerId) {
440
+ return jsonResponse(401, { error: "Customer not identified" });
441
+ }
442
+ try {
443
+ const data = await client.customers.createPortal(customerId);
298
444
  return jsonResponse(200, data);
299
445
  } catch (error) {
300
446
  if (error instanceof PriceOSError) {
@@ -343,6 +489,9 @@ function priceosHandler(options = {}) {
343
489
  if (path === CHECKOUT_PATH) {
344
490
  return handleCreateCheckout(request, client, getCustomerId);
345
491
  }
492
+ if (path === CUSTOMER_PORTAL_PATH) {
493
+ return handleCreateCustomerPortal(request, client, getCustomerId);
494
+ }
346
495
  return new Response("Not found.", { status: 404 });
347
496
  };
348
497
  return Object.assign(handler, {
package/dist/next.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/next.ts"],"sourcesContent":["import { PriceOS, PriceOSError } from \"./client\";\nimport type { CreateCheckoutRequest, TrackUsageResponse } from \"./types\";\n\nexport type PriceOSGetCustomerId = (\n request: Request\n) => string | null | undefined | Promise<string | null | undefined>;\n\nexport type PriceOSPagesRequest = {\n method?: string;\n headers?: Record<string, string | string[] | undefined>;\n url?: string;\n socket?: { encrypted?: boolean };\n body?: unknown;\n};\n\nexport type PriceOSPagesResponse = {\n status?: (code: number) => PriceOSPagesResponse;\n setHeader?: (name: string, value: string | string[]) => void;\n end?: (body?: string) => void;\n statusCode?: number;\n};\n\nexport type PriceOSPagesGetCustomerId = (\n request: PriceOSPagesRequest,\n normalizedRequest: Request\n) => string | null | undefined | Promise<string | null | undefined>;\n\nexport type PriceOSNextHandlerOptions = {\n apiKey?: string;\n basePath?: string;\n getCustomerId?: PriceOSGetCustomerId;\n};\n\nexport type PriceOSRouteHandler = (request: Request) => Promise<Response>;\nexport type PriceOSRouteMethodHandlers = PriceOSRouteHandler & {\n GET: PriceOSRouteHandler;\n POST: PriceOSRouteHandler;\n};\n\nexport type PriceOSPagesHandlerOptions = Omit<PriceOSNextHandlerOptions, \"getCustomerId\"> & {\n getCustomerId?: PriceOSPagesGetCustomerId;\n};\n\ntype TrackUsageRequestBody = {\n featureKey: string;\n amount?: number;\n idempotencyKey?: string;\n eventKey?: string;\n occurredAt?: number;\n metadata?: Record<string, string>;\n};\n\ntype CheckoutRequestBody = {\n stripePriceId: string;\n successUrl: string;\n cancelUrl?: string;\n customerId?: string;\n metadata?: Record<string, string>;\n};\n\nconst DEFAULT_BASE_PATH = \"/api/priceos\";\nconst CUSTOMER_PATH = \"v1/customer\";\nconst FEATURE_ACCESS_PATH = \"v1/feature-access\";\nconst TRACK_USAGE_PATH = \"v1/usage\";\nconst PRICING_TABLE_PATH = \"v1/pricing-table\";\nconst CHECKOUT_PATH = \"v1/checkout\";\n\nconst normalizePath = (value: string) => value.replace(/^\\/+/, \"\");\nconst logTrackUsageError = (message: string, details?: Record<string, unknown>) => {\n if (details === undefined) {\n console.error(\"[priceos/next][trackUsage]\", message);\n return;\n }\n console.error(\"[priceos/next][trackUsage]\", message, details);\n};\n\nconst jsonResponse = (status: number, body: unknown) =>\n new Response(JSON.stringify(body), {\n status,\n headers: { \"content-type\": \"application/json\" },\n });\n\nconst normalizeCustomerId = (value: string | null | undefined) => {\n if (typeof value !== \"string\") return null;\n const normalized = value.trim();\n return normalized.length ? normalized : null;\n};\n\nconst parseTrackUsageBody = async (request: Request): Promise<{ data?: TrackUsageRequestBody; error?: string }> => {\n let rawBody: unknown;\n try {\n rawBody = await request.json();\n } catch {\n return { error: \"Invalid JSON body\" };\n }\n\n if (!rawBody || typeof rawBody !== \"object\" || Array.isArray(rawBody)) {\n return { error: \"Invalid JSON body\" };\n }\n\n const body = rawBody as Record<string, unknown>;\n\n if (\"customerId\" in body) {\n return { error: \"customerId must be set via getCustomerId\" };\n }\n\n const featureKey = typeof body.featureKey === \"string\" ? body.featureKey.trim() : \"\";\n if (!featureKey) {\n return { error: \"featureKey is required\" };\n }\n\n const amountRaw = body.amount;\n const amount = amountRaw === undefined ? 1 : Number(amountRaw);\n if (!Number.isFinite(amount) || amount <= 0) {\n return { error: \"amount must be a positive number\" };\n }\n\n const idempotencyKeyRaw = body.idempotencyKey ?? body.eventKey;\n const idempotencyKey =\n idempotencyKeyRaw === undefined\n ? undefined\n : typeof idempotencyKeyRaw === \"string\" && idempotencyKeyRaw.trim().length > 0\n ? idempotencyKeyRaw.trim()\n : null;\n if (idempotencyKey === null) {\n return { error: \"idempotencyKey must be a non-empty string\" };\n }\n\n const occurredAtRaw = body.occurredAt;\n const occurredAt = occurredAtRaw === undefined ? undefined : Number(occurredAtRaw);\n if (occurredAtRaw !== undefined && !Number.isFinite(occurredAt)) {\n return { error: \"occurredAt must be a valid Unix timestamp (ms)\" };\n }\n\n const metadataRaw = body.metadata;\n if (metadataRaw !== undefined) {\n if (!metadataRaw || typeof metadataRaw !== \"object\" || Array.isArray(metadataRaw)) {\n return { error: \"metadata must be an object of string values\" };\n }\n for (const [key, value] of Object.entries(metadataRaw as Record<string, unknown>)) {\n if (typeof key !== \"string\" || typeof value !== \"string\") {\n return { error: \"metadata must be an object of string values\" };\n }\n }\n }\n\n return {\n data: {\n featureKey,\n amount,\n ...(idempotencyKey ? { idempotencyKey } : {}),\n ...(occurredAt !== undefined ? { occurredAt } : {}),\n ...(metadataRaw ? { metadata: metadataRaw as Record<string, string> } : {}),\n },\n };\n};\n\nconst resolveCustomerId = async (\n getCustomerId: PriceOSGetCustomerId,\n request: Request\n): Promise<{ customerId?: string; errorResponse?: Response }> => {\n let customerId: string | null | undefined;\n try {\n customerId = await getCustomerId(request);\n } catch {\n return { errorResponse: jsonResponse(500, { error: \"Failed to resolve customerId\" }) };\n }\n\n const normalizedCustomerId = normalizeCustomerId(customerId);\n if (!normalizedCustomerId) {\n return { errorResponse: jsonResponse(401, { error: \"Customer not identified\" }) };\n }\n\n return { customerId: normalizedCustomerId };\n};\n\nconst resolveOptionalCustomerId = async (\n getCustomerId: PriceOSGetCustomerId | undefined,\n request: Request\n): Promise<{ customerId: string | null; errorResponse?: Response }> => {\n if (!getCustomerId) return { customerId: null };\n let customerId: string | null | undefined;\n try {\n customerId = await getCustomerId(request);\n } catch {\n return { customerId: null, errorResponse: jsonResponse(500, { error: \"Failed to resolve customerId\" }) };\n }\n return { customerId: normalizeCustomerId(customerId) };\n};\n\nconst parseCheckoutBody = async (request: Request): Promise<{ data?: CheckoutRequestBody; error?: string }> => {\n let rawBody: unknown;\n try {\n rawBody = await request.json();\n } catch {\n return { error: \"Invalid JSON body\" };\n }\n\n if (!rawBody || typeof rawBody !== \"object\" || Array.isArray(rawBody)) {\n return { error: \"Invalid JSON body\" };\n }\n\n const body = rawBody as Record<string, unknown>;\n const stripePriceId =\n typeof body.stripePriceId === \"string\" && body.stripePriceId.trim().length > 0\n ? body.stripePriceId.trim()\n : \"\";\n if (!stripePriceId) {\n return { error: \"stripePriceId is required\" };\n }\n\n const successUrl =\n typeof body.successUrl === \"string\" && body.successUrl.trim().length > 0\n ? body.successUrl.trim()\n : \"\";\n if (!successUrl) {\n return { error: \"successUrl is required\" };\n }\n\n const cancelUrl =\n typeof body.cancelUrl === \"string\" && body.cancelUrl.trim().length > 0\n ? body.cancelUrl.trim()\n : undefined;\n const customerId =\n typeof body.customerId === \"string\" && body.customerId.trim().length > 0\n ? body.customerId.trim()\n : undefined;\n\n const metadataRaw = body.metadata;\n if (metadataRaw !== undefined) {\n if (!metadataRaw || typeof metadataRaw !== \"object\" || Array.isArray(metadataRaw)) {\n return { error: \"metadata must be an object of string values\" };\n }\n for (const [key, value] of Object.entries(metadataRaw as Record<string, unknown>)) {\n if (typeof key !== \"string\" || typeof value !== \"string\") {\n return { error: \"metadata must be an object of string values\" };\n }\n }\n }\n\n return {\n data: {\n stripePriceId,\n successUrl,\n ...(cancelUrl ? { cancelUrl } : {}),\n ...(customerId ? { customerId } : {}),\n ...(metadataRaw ? { metadata: metadataRaw as Record<string, string> } : {}),\n },\n };\n};\n\nconst handleGetCustomer = async (\n request: Request,\n url: URL,\n client: PriceOS,\n getCustomerId: PriceOSGetCustomerId\n) => {\n if (request.method.toUpperCase() !== \"GET\") {\n return new Response(\"Method not allowed.\", { status: 405 });\n }\n\n if (url.searchParams.has(\"customerId\")) {\n return jsonResponse(400, { error: \"customerId must be set via getCustomerId\" });\n }\n\n const { customerId, errorResponse } = await resolveCustomerId(getCustomerId, request);\n if (errorResponse || !customerId) {\n return errorResponse ?? jsonResponse(401, { error: \"Customer not identified\" });\n }\n\n try {\n const data = await client.customers.get(customerId);\n return jsonResponse(200, data);\n } catch (error) {\n if (error instanceof PriceOSError) {\n return jsonResponse(error.status ?? 500, { error: error.message });\n }\n return jsonResponse(500, { error: \"Request failed\" });\n }\n};\n\nconst handleTrackUsage = async (\n request: Request,\n url: URL,\n client: PriceOS,\n getCustomerId: PriceOSGetCustomerId\n) => {\n try {\n if (request.method.toUpperCase() !== \"POST\") {\n logTrackUsageError(\"Method not allowed\", {\n path: url.pathname,\n method: request.method,\n });\n return new Response(\"Method not allowed.\", { status: 405 });\n }\n\n if (url.searchParams.has(\"customerId\")) {\n logTrackUsageError(\"Rejected request with customerId query param\", {\n path: url.pathname,\n method: request.method,\n });\n return jsonResponse(400, { error: \"customerId must be set via getCustomerId\" });\n }\n\n const parsed = await parseTrackUsageBody(request);\n if (!parsed.data) {\n logTrackUsageError(\"Invalid request body\", {\n path: url.pathname,\n method: request.method,\n error: parsed.error ?? \"Invalid request body\",\n });\n return jsonResponse(400, { error: parsed.error ?? \"Invalid request body\" });\n }\n\n const { customerId, errorResponse } = await resolveCustomerId(getCustomerId, request);\n if (errorResponse || !customerId) {\n logTrackUsageError(\"Failed to resolve customerId\", {\n path: url.pathname,\n method: request.method,\n status: errorResponse?.status ?? 401,\n });\n return errorResponse ?? jsonResponse(401, { error: \"Customer not identified\" });\n }\n\n try {\n const data = await client.usage.track({\n customerId,\n ...parsed.data,\n });\n return jsonResponse(200, data as TrackUsageResponse);\n } catch (error) {\n logTrackUsageError(\"Upstream trackUsage call failed\", {\n path: url.pathname,\n method: request.method,\n customerId,\n featureKey: parsed.data.featureKey,\n amount: parsed.data.amount,\n error,\n });\n if (error instanceof PriceOSError) {\n return jsonResponse(error.status ?? 500, { error: error.message });\n }\n return jsonResponse(500, { error: \"Request failed\" });\n }\n } catch (error) {\n logTrackUsageError(\"Unexpected unhandled error\", {\n path: url.pathname,\n method: request.method,\n error,\n });\n return jsonResponse(500, { error: \"Request failed\" });\n }\n};\n\nconst handleGetFeatureAccess = async (\n request: Request,\n url: URL,\n client: PriceOS,\n getCustomerId: PriceOSGetCustomerId\n) => {\n if (request.method.toUpperCase() !== \"GET\") {\n return new Response(\"Method not allowed.\", { status: 405 });\n }\n\n if (url.searchParams.has(\"customerId\")) {\n return jsonResponse(400, { error: \"customerId must be set via getCustomerId\" });\n }\n\n const { customerId, errorResponse } = await resolveCustomerId(getCustomerId, request);\n if (errorResponse || !customerId) {\n return errorResponse ?? jsonResponse(401, { error: \"Customer not identified\" });\n }\n\n try {\n const data = await client.features.getAccess(customerId);\n return jsonResponse(200, data);\n } catch (error) {\n if (error instanceof PriceOSError) {\n return jsonResponse(error.status ?? 500, { error: error.message });\n }\n return jsonResponse(500, { error: \"Request failed\" });\n }\n};\n\nconst handleGetPricingTable = async (\n request: Request,\n url: URL,\n client: PriceOS,\n getCustomerId?: PriceOSGetCustomerId\n) => {\n if (request.method.toUpperCase() !== \"GET\") {\n return new Response(\"Method not allowed.\", { status: 405 });\n }\n\n const queryCustomerId = normalizeCustomerId(url.searchParams.get(\"customerId\"));\n const queryPricingTableKey = normalizeCustomerId(url.searchParams.get(\"pricingTableKey\"));\n const { customerId: resolvedCustomerId, errorResponse } = await resolveOptionalCustomerId(\n getCustomerId,\n request\n );\n if (errorResponse) return errorResponse;\n\n const customerId = queryCustomerId ?? resolvedCustomerId;\n\n try {\n const data = await client.pricing.getTable({\n ...(customerId ? { customerId } : {}),\n ...(queryPricingTableKey ? { pricingTableKey: queryPricingTableKey } : {}),\n });\n return jsonResponse(200, data);\n } catch (error) {\n if (error instanceof PriceOSError) {\n return jsonResponse(error.status ?? 500, { error: error.message });\n }\n return jsonResponse(500, { error: \"Request failed\" });\n }\n};\n\nconst handleCreateCheckout = async (\n request: Request,\n client: PriceOS,\n getCustomerId?: PriceOSGetCustomerId\n) => {\n if (request.method.toUpperCase() !== \"POST\") {\n return new Response(\"Method not allowed.\", { status: 405 });\n }\n\n const parsed = await parseCheckoutBody(request);\n if (!parsed.data) {\n return jsonResponse(400, { error: parsed.error ?? \"Invalid request body\" });\n }\n\n const { customerId: resolvedCustomerId, errorResponse } = await resolveOptionalCustomerId(\n getCustomerId,\n request\n );\n if (errorResponse) return errorResponse;\n\n const body: CreateCheckoutRequest = {\n ...parsed.data,\n ...(parsed.data.customerId ?? resolvedCustomerId\n ? { customerId: parsed.data.customerId ?? resolvedCustomerId ?? undefined }\n : {}),\n };\n\n try {\n const data = await client.checkout.create(body);\n return jsonResponse(200, data);\n } catch (error) {\n if (error instanceof PriceOSError) {\n return jsonResponse(error.status ?? 500, { error: error.message });\n }\n return jsonResponse(500, { error: \"Request failed\" });\n }\n};\n\nexport function priceosHandler(options: PriceOSNextHandlerOptions = {}): PriceOSRouteMethodHandlers {\n const envApiKey = (globalThis as { process?: { env?: Record<string, string | undefined> } })\n .process?.env?.PRICEOS_API_KEY;\n const apiKey = options.apiKey ?? envApiKey;\n const getCustomerId = options.getCustomerId;\n const basePath = (options.basePath ?? DEFAULT_BASE_PATH).replace(/\\/+$/, \"\");\n\n const handler: PriceOSRouteHandler = async (request: Request) => {\n if (!apiKey) {\n return new Response(\"Missing PRICEOS_API_KEY.\", { status: 500 });\n }\n\n let path = \"\";\n const url = new URL(request.url);\n const pathname = url.pathname;\n if (pathname.startsWith(basePath)) {\n path = normalizePath(pathname.slice(basePath.length));\n }\n\n const client = new PriceOS(apiKey);\n\n if (path === CUSTOMER_PATH) {\n if (!getCustomerId) {\n return jsonResponse(500, { error: \"Missing getCustomerId function\" });\n }\n return handleGetCustomer(request, url, client, getCustomerId);\n }\n\n if (path === FEATURE_ACCESS_PATH) {\n if (!getCustomerId) {\n return jsonResponse(500, { error: \"Missing getCustomerId function\" });\n }\n return handleGetFeatureAccess(request, url, client, getCustomerId);\n }\n\n if (path === TRACK_USAGE_PATH) {\n if (!getCustomerId) {\n return jsonResponse(500, { error: \"Missing getCustomerId function\" });\n }\n return handleTrackUsage(request, url, client, getCustomerId);\n }\n\n if (path === PRICING_TABLE_PATH) {\n return handleGetPricingTable(request, url, client, getCustomerId);\n }\n\n if (path === CHECKOUT_PATH) {\n return handleCreateCheckout(request, client, getCustomerId);\n }\n\n return new Response(\"Not found.\", { status: 404 });\n };\n\n return Object.assign(handler, {\n GET: handler,\n POST: handler,\n });\n}\n\nconst getHeaderValue = (\n headers: Record<string, string | string[] | undefined> | undefined,\n key: string\n) => {\n if (!headers) return undefined;\n const value = headers[key] ?? headers[key.toLowerCase()] ?? headers[key.toUpperCase()];\n if (value !== undefined) {\n if (Array.isArray(value)) return value.join(\",\");\n return value;\n }\n const entry = Object.entries(headers).find(([headerKey]) => headerKey.toLowerCase() === key.toLowerCase());\n if (!entry) return undefined;\n const [, entryValue] = entry;\n if (Array.isArray(entryValue)) return entryValue.join(\",\");\n return entryValue;\n};\n\nconst toHeaders = (headers: Record<string, string | string[] | undefined> | undefined) => {\n const result = new Headers();\n if (!headers) return result;\n for (const [key, value] of Object.entries(headers)) {\n if (typeof value === \"string\") result.set(key, value);\n if (Array.isArray(value)) result.set(key, value.join(\",\"));\n }\n return result;\n};\n\nconst buildRequest = (req: PriceOSPagesRequest) => {\n const headers = req.headers ?? {};\n const forwardedProto = getHeaderValue(headers, \"x-forwarded-proto\");\n const protocol =\n forwardedProto?.split(\",\")[0]?.trim() ?? (req.socket?.encrypted ? \"https\" : \"http\");\n const host =\n getHeaderValue(headers, \"x-forwarded-host\") ??\n getHeaderValue(headers, \"host\") ??\n \"localhost\";\n const url = new URL(req.url ?? \"/\", `${protocol}://${host}`);\n\n const method = (req.method ?? \"GET\").toUpperCase();\n const normalizedHeaders = toHeaders(headers);\n const init: RequestInit = {\n method,\n headers: normalizedHeaders,\n };\n\n if (method !== \"GET\" && method !== \"HEAD\" && req.body !== undefined) {\n if (typeof req.body === \"string\") {\n init.body = req.body;\n } else {\n init.body = JSON.stringify(req.body);\n if (!normalizedHeaders.has(\"content-type\")) {\n normalizedHeaders.set(\"content-type\", \"application/json\");\n }\n }\n }\n\n return new Request(url, init);\n};\n\nconst sendResponse = async (res: PriceOSPagesResponse, response: Response) => {\n if (typeof res.status === \"function\") {\n res.status(response.status);\n } else {\n res.statusCode = response.status;\n }\n\n if (typeof res.setHeader === \"function\") {\n response.headers.forEach((value, key) => {\n res.setHeader?.(key, value);\n });\n }\n\n const body = await response.text();\n res.end?.(body || undefined);\n};\n\nexport function priceosPagesHandler(options: PriceOSPagesHandlerOptions = {}) {\n return async (req: PriceOSPagesRequest, res: PriceOSPagesResponse) => {\n const getCustomerId = options.getCustomerId;\n const request = buildRequest(req);\n const handler = priceosHandler({\n ...options,\n getCustomerId: getCustomerId ? (normalizedRequest) => getCustomerId(req, normalizedRequest) : undefined,\n });\n const response = await handler(request);\n await sendResponse(res, response);\n };\n}\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../src/next.ts"],"sourcesContent":["import { PriceOS, PriceOSError } from \"./client\";\nimport type {\n CreateCheckoutResponse,\n CreateCustomerCheckoutRequest,\n CreateCustomerCheckoutResponse,\n CreateCustomerPortalResponse,\n GetCustomerExpand,\n TrackUsageResponse,\n} from \"./types\";\n\nexport type PriceOSGetCustomerId = (\n request: Request\n) => string | null | undefined | Promise<string | null | undefined>;\n\nexport type PriceOSPagesRequest = {\n method?: string;\n headers?: Record<string, string | string[] | undefined>;\n url?: string;\n socket?: { encrypted?: boolean };\n body?: unknown;\n};\n\nexport type PriceOSPagesResponse = {\n status?: (code: number) => PriceOSPagesResponse;\n setHeader?: (name: string, value: string | string[]) => void;\n end?: (body?: string) => void;\n statusCode?: number;\n};\n\nexport type PriceOSPagesGetCustomerId = (\n request: PriceOSPagesRequest,\n normalizedRequest: Request\n) => string | null | undefined | Promise<string | null | undefined>;\n\nexport type PriceOSNextHandlerOptions = {\n apiKey?: string;\n basePath?: string;\n getCustomerId?: PriceOSGetCustomerId;\n};\n\nexport type PriceOSRouteHandler = (request: Request) => Promise<Response>;\nexport type PriceOSRouteMethodHandlers = PriceOSRouteHandler & {\n GET: PriceOSRouteHandler;\n POST: PriceOSRouteHandler;\n};\n\nexport type PriceOSPagesHandlerOptions = Omit<PriceOSNextHandlerOptions, \"getCustomerId\"> & {\n getCustomerId?: PriceOSPagesGetCustomerId;\n};\n\ntype TrackUsageRequestBody = {\n featureKey: string;\n amount?: number;\n idempotencyKey?: string;\n occurredAt?: number;\n metadata?: Record<string, string>;\n};\n\ntype CheckoutRequestBody = {\n stripeProductKey?: string;\n stripePriceId?: string;\n successUrl?: string;\n cancelUrl?: string;\n customerId?: string;\n metadata?: Record<string, string>;\n checkoutParams?: Record<string, unknown>;\n customerInfo?: {\n name?: string;\n email?: string;\n };\n};\n\ntype CustomerPortalRequestBody = {\n customerId?: string;\n};\n\nconst DEFAULT_BASE_PATH = \"/api/priceos\";\nconst CUSTOMER_PATH = \"v1/customer\";\nconst FEATURE_ACCESS_PATH = \"v1/feature-access\";\nconst TRACK_USAGE_PATH = \"v1/usage\";\nconst PRICING_TABLE_PATH = \"v1/pricing-table\";\nconst CHECKOUT_PATH = \"v1/checkout\";\nconst CUSTOMER_PORTAL_PATH = \"v1/customer-portal\";\n\nconst normalizePath = (value: string) => value.replace(/^\\/+/, \"\");\nconst logTrackUsageError = (message: string, details?: Record<string, unknown>) => {\n if (details === undefined) {\n console.error(\"[priceos/next][trackUsage]\", message);\n return;\n }\n console.error(\"[priceos/next][trackUsage]\", message, details);\n};\n\nconst jsonResponse = (status: number, body: unknown) =>\n new Response(JSON.stringify(body), {\n status,\n headers: { \"content-type\": \"application/json\" },\n });\n\nconst normalizeCustomerId = (value: string | null | undefined) => {\n if (typeof value !== \"string\") return null;\n const normalized = value.trim();\n return normalized.length ? normalized : null;\n};\n\nconst parseCustomerExpand = (url: URL): { data?: { expand?: GetCustomerExpand[] }; error?: string } => {\n const expandValues = [...url.searchParams.getAll(\"expand\"), ...url.searchParams.getAll(\"expand[]\")]\n .flatMap((value) => value.split(\",\"))\n .map((value) => value.trim())\n .filter((value) => value.length > 0);\n\n if (!expandValues.length) {\n return { data: {} };\n }\n\n const normalizedValues = Array.from(new Set(expandValues));\n const invalidValue = normalizedValues.find((value) => value !== \"subscriptions\");\n if (invalidValue) {\n return { error: `Invalid expand value: ${invalidValue}` };\n }\n\n return { data: { expand: normalizedValues as GetCustomerExpand[] } };\n};\n\nconst parseTrackUsageBody = async (request: Request): Promise<{ data?: TrackUsageRequestBody; error?: string }> => {\n let rawBody: unknown;\n try {\n rawBody = await request.json();\n } catch {\n return { error: \"Invalid JSON body\" };\n }\n\n if (!rawBody || typeof rawBody !== \"object\" || Array.isArray(rawBody)) {\n return { error: \"Invalid JSON body\" };\n }\n\n const body = rawBody as Record<string, unknown>;\n\n if (\"customerId\" in body) {\n return { error: \"customerId must be set via getCustomerId\" };\n }\n\n const featureKey = typeof body.featureKey === \"string\" ? body.featureKey.trim() : \"\";\n if (!featureKey) {\n return { error: \"featureKey is required\" };\n }\n\n const amountRaw = body.amount;\n const amount = amountRaw === undefined ? 1 : Number(amountRaw);\n if (!Number.isFinite(amount) || amount <= 0) {\n return { error: \"amount must be a positive number\" };\n }\n\n const idempotencyKeyRaw = body.idempotencyKey;\n const idempotencyKey =\n idempotencyKeyRaw === undefined\n ? undefined\n : typeof idempotencyKeyRaw === \"string\" && idempotencyKeyRaw.trim().length > 0\n ? idempotencyKeyRaw.trim()\n : null;\n if (idempotencyKey === null) {\n return { error: \"idempotencyKey must be a non-empty string\" };\n }\n\n const occurredAtRaw = body.occurredAt;\n const occurredAt = occurredAtRaw === undefined ? undefined : Number(occurredAtRaw);\n if (occurredAtRaw !== undefined && !Number.isFinite(occurredAt)) {\n return { error: \"occurredAt must be a valid Unix timestamp (ms)\" };\n }\n\n const metadataRaw = body.metadata;\n if (metadataRaw !== undefined) {\n if (!metadataRaw || typeof metadataRaw !== \"object\" || Array.isArray(metadataRaw)) {\n return { error: \"metadata must be an object of string values\" };\n }\n for (const [key, value] of Object.entries(metadataRaw as Record<string, unknown>)) {\n if (typeof key !== \"string\" || typeof value !== \"string\") {\n return { error: \"metadata must be an object of string values\" };\n }\n }\n }\n\n return {\n data: {\n featureKey,\n amount,\n ...(idempotencyKey ? { idempotencyKey } : {}),\n ...(occurredAt !== undefined ? { occurredAt } : {}),\n ...(metadataRaw ? { metadata: metadataRaw as Record<string, string> } : {}),\n },\n };\n};\n\nconst resolveCustomerId = async (\n getCustomerId: PriceOSGetCustomerId,\n request: Request\n): Promise<{ customerId?: string; errorResponse?: Response }> => {\n let customerId: string | null | undefined;\n try {\n customerId = await getCustomerId(request);\n } catch {\n return { errorResponse: jsonResponse(500, { error: \"Failed to resolve customerId\" }) };\n }\n\n const normalizedCustomerId = normalizeCustomerId(customerId);\n if (!normalizedCustomerId) {\n return { errorResponse: jsonResponse(401, { error: \"Customer not identified\" }) };\n }\n\n return { customerId: normalizedCustomerId };\n};\n\nconst resolveOptionalCustomerId = async (\n getCustomerId: PriceOSGetCustomerId | undefined,\n request: Request\n): Promise<{ customerId: string | null; errorResponse?: Response }> => {\n if (!getCustomerId) return { customerId: null };\n let customerId: string | null | undefined;\n try {\n customerId = await getCustomerId(request);\n } catch {\n return { customerId: null, errorResponse: jsonResponse(500, { error: \"Failed to resolve customerId\" }) };\n }\n return { customerId: normalizeCustomerId(customerId) };\n};\n\nconst parseCheckoutBody = async (request: Request): Promise<{ data?: CheckoutRequestBody; error?: string }> => {\n let rawBody: unknown;\n try {\n rawBody = await request.json();\n } catch {\n return { error: \"Invalid JSON body\" };\n }\n\n if (!rawBody || typeof rawBody !== \"object\" || Array.isArray(rawBody)) {\n return { error: \"Invalid JSON body\" };\n }\n\n const body = rawBody as Record<string, unknown>;\n const stripeProductKey =\n typeof body.stripeProductKey === \"string\" && body.stripeProductKey.trim().length > 0\n ? body.stripeProductKey.trim()\n : undefined;\n const stripePriceId =\n typeof body.stripePriceId === \"string\" && body.stripePriceId.trim().length > 0\n ? body.stripePriceId.trim()\n : undefined;\n if (!stripeProductKey && !stripePriceId) {\n return { error: \"stripeProductKey or stripePriceId is required\" };\n }\n\n const successUrlRaw = body.successUrl;\n if (successUrlRaw !== undefined && typeof successUrlRaw !== \"string\") {\n return { error: \"successUrl must be a non-empty string\" };\n }\n const successUrl = normalizeCustomerId(\n typeof successUrlRaw === \"string\" ? successUrlRaw : undefined\n );\n if (successUrlRaw !== undefined && !successUrl) {\n return { error: \"successUrl must be a non-empty string\" };\n }\n\n const cancelUrl =\n typeof body.cancelUrl === \"string\" && body.cancelUrl.trim().length > 0\n ? body.cancelUrl.trim()\n : undefined;\n const customerId =\n typeof body.customerId === \"string\" && body.customerId.trim().length > 0\n ? body.customerId.trim()\n : undefined;\n\n const metadataRaw = body.metadata;\n if (metadataRaw !== undefined) {\n if (!metadataRaw || typeof metadataRaw !== \"object\" || Array.isArray(metadataRaw)) {\n return { error: \"metadata must be an object of string values\" };\n }\n for (const [key, value] of Object.entries(metadataRaw as Record<string, unknown>)) {\n if (typeof key !== \"string\" || typeof value !== \"string\") {\n return { error: \"metadata must be an object of string values\" };\n }\n }\n }\n\n const checkoutParamsRaw = body.checkoutParams;\n if (checkoutParamsRaw !== undefined && (!checkoutParamsRaw || typeof checkoutParamsRaw !== \"object\" || Array.isArray(checkoutParamsRaw))) {\n return { error: \"checkoutParams must be an object\" };\n }\n\n const customerInfoRaw = body.customerInfo;\n if (customerInfoRaw !== undefined && (!customerInfoRaw || typeof customerInfoRaw !== \"object\" || Array.isArray(customerInfoRaw))) {\n return { error: \"customerInfo must be an object\" };\n }\n const customerInfoRecord = customerInfoRaw as Record<string, unknown> | undefined;\n const customerName = normalizeCustomerId(\n typeof customerInfoRecord?.name === \"string\" ? customerInfoRecord.name : undefined\n );\n const customerEmail = normalizeCustomerId(\n typeof customerInfoRecord?.email === \"string\" ? customerInfoRecord.email : undefined\n );\n\n return {\n data: {\n ...(stripeProductKey ? { stripeProductKey } : {}),\n ...(stripePriceId ? { stripePriceId } : {}),\n ...(successUrl ? { successUrl } : {}),\n ...(cancelUrl ? { cancelUrl } : {}),\n ...(customerId ? { customerId } : {}),\n ...(metadataRaw ? { metadata: metadataRaw as Record<string, string> } : {}),\n ...(checkoutParamsRaw ? { checkoutParams: checkoutParamsRaw as Record<string, unknown> } : {}),\n ...(customerInfoRaw\n ? {\n customerInfo: {\n ...(customerName ? { name: customerName } : {}),\n ...(customerEmail ? { email: customerEmail } : {}),\n },\n }\n : {}),\n },\n };\n};\n\nconst parseCustomerPortalBody = async (\n request: Request\n): Promise<{ data?: CustomerPortalRequestBody; error?: string }> => {\n let rawText = \"\";\n try {\n rawText = await request.text();\n } catch {\n return { error: \"Invalid JSON body\" };\n }\n\n if (!rawText.trim()) return { data: {} };\n\n let rawBody: unknown;\n try {\n rawBody = JSON.parse(rawText);\n } catch {\n return { error: \"Invalid JSON body\" };\n }\n\n if (!rawBody || typeof rawBody !== \"object\" || Array.isArray(rawBody)) {\n return { error: \"Invalid JSON body\" };\n }\n\n const body = rawBody as Record<string, unknown>;\n const customerIdRaw = body.customerId;\n if (customerIdRaw !== undefined && typeof customerIdRaw !== \"string\") {\n return { error: \"customerId must be a non-empty string\" };\n }\n const customerId = normalizeCustomerId(\n typeof customerIdRaw === \"string\" ? customerIdRaw : undefined\n );\n if (customerIdRaw !== undefined && !customerId) {\n return { error: \"customerId must be a non-empty string\" };\n }\n\n return {\n data: customerId ? { customerId } : {},\n };\n};\n\nconst handleGetCustomer = async (\n request: Request,\n url: URL,\n client: PriceOS,\n getCustomerId: PriceOSGetCustomerId\n) => {\n if (request.method.toUpperCase() !== \"GET\") {\n return new Response(\"Method not allowed.\", { status: 405 });\n }\n\n if (url.searchParams.has(\"customerId\")) {\n return jsonResponse(400, { error: \"customerId must be set via getCustomerId\" });\n }\n\n const { customerId, errorResponse } = await resolveCustomerId(getCustomerId, request);\n if (errorResponse || !customerId) {\n return errorResponse ?? jsonResponse(401, { error: \"Customer not identified\" });\n }\n\n const expandResult = parseCustomerExpand(url);\n if (!expandResult.data) {\n return jsonResponse(400, { error: expandResult.error ?? \"Invalid request\" });\n }\n\n try {\n const data = await client.customers.get(customerId, expandResult.data);\n return jsonResponse(200, data);\n } catch (error) {\n if (error instanceof PriceOSError) {\n return jsonResponse(error.status ?? 500, { error: error.message });\n }\n return jsonResponse(500, { error: \"Request failed\" });\n }\n};\n\nconst handleTrackUsage = async (\n request: Request,\n url: URL,\n client: PriceOS,\n getCustomerId: PriceOSGetCustomerId\n) => {\n try {\n if (request.method.toUpperCase() !== \"POST\") {\n logTrackUsageError(\"Method not allowed\", {\n path: url.pathname,\n method: request.method,\n });\n return new Response(\"Method not allowed.\", { status: 405 });\n }\n\n if (url.searchParams.has(\"customerId\")) {\n logTrackUsageError(\"Rejected request with customerId query param\", {\n path: url.pathname,\n method: request.method,\n });\n return jsonResponse(400, { error: \"customerId must be set via getCustomerId\" });\n }\n\n const parsed = await parseTrackUsageBody(request);\n if (!parsed.data) {\n logTrackUsageError(\"Invalid request body\", {\n path: url.pathname,\n method: request.method,\n error: parsed.error ?? \"Invalid request body\",\n });\n return jsonResponse(400, { error: parsed.error ?? \"Invalid request body\" });\n }\n\n const { customerId, errorResponse } = await resolveCustomerId(getCustomerId, request);\n if (errorResponse || !customerId) {\n logTrackUsageError(\"Failed to resolve customerId\", {\n path: url.pathname,\n method: request.method,\n status: errorResponse?.status ?? 401,\n });\n return errorResponse ?? jsonResponse(401, { error: \"Customer not identified\" });\n }\n\n try {\n const data = await client.usage.track({\n customerId,\n ...parsed.data,\n });\n return jsonResponse(200, data as TrackUsageResponse);\n } catch (error) {\n logTrackUsageError(\"Upstream trackUsage call failed\", {\n path: url.pathname,\n method: request.method,\n customerId,\n featureKey: parsed.data.featureKey,\n amount: parsed.data.amount,\n error,\n });\n if (error instanceof PriceOSError) {\n return jsonResponse(error.status ?? 500, { error: error.message });\n }\n return jsonResponse(500, { error: \"Request failed\" });\n }\n } catch (error) {\n logTrackUsageError(\"Unexpected unhandled error\", {\n path: url.pathname,\n method: request.method,\n error,\n });\n return jsonResponse(500, { error: \"Request failed\" });\n }\n};\n\nconst handleGetFeatureAccess = async (\n request: Request,\n url: URL,\n client: PriceOS,\n getCustomerId: PriceOSGetCustomerId\n) => {\n if (request.method.toUpperCase() !== \"GET\") {\n return new Response(\"Method not allowed.\", { status: 405 });\n }\n\n if (url.searchParams.has(\"customerId\")) {\n return jsonResponse(400, { error: \"customerId must be set via getCustomerId\" });\n }\n\n const { customerId, errorResponse } = await resolveCustomerId(getCustomerId, request);\n if (errorResponse || !customerId) {\n return errorResponse ?? jsonResponse(401, { error: \"Customer not identified\" });\n }\n\n try {\n const data = await client.features.getAccess(customerId);\n return jsonResponse(200, data);\n } catch (error) {\n if (error instanceof PriceOSError) {\n return jsonResponse(error.status ?? 500, { error: error.message });\n }\n return jsonResponse(500, { error: \"Request failed\" });\n }\n};\n\nconst handleGetPricingTable = async (\n request: Request,\n url: URL,\n client: PriceOS,\n getCustomerId?: PriceOSGetCustomerId\n) => {\n if (request.method.toUpperCase() !== \"GET\") {\n return new Response(\"Method not allowed.\", { status: 405 });\n }\n\n const queryCustomerId = normalizeCustomerId(url.searchParams.get(\"customerId\"));\n const queryPricingTableKey = normalizeCustomerId(url.searchParams.get(\"pricingTableKey\"));\n const { customerId: resolvedCustomerId, errorResponse } = await resolveOptionalCustomerId(\n getCustomerId,\n request\n );\n if (errorResponse) return errorResponse;\n\n const customerId = queryCustomerId ?? resolvedCustomerId;\n\n try {\n const data = await client.pricing.getTable({\n ...(customerId ? { customerId } : {}),\n ...(queryPricingTableKey ? { pricingTableKey: queryPricingTableKey } : {}),\n });\n return jsonResponse(200, data);\n } catch (error) {\n if (error instanceof PriceOSError) {\n return jsonResponse(error.status ?? 500, { error: error.message });\n }\n return jsonResponse(500, { error: \"Request failed\" });\n }\n};\n\nconst handleCreateCheckout = async (\n request: Request,\n client: PriceOS,\n getCustomerId?: PriceOSGetCustomerId\n) => {\n if (request.method.toUpperCase() !== \"POST\") {\n return new Response(\"Method not allowed.\", { status: 405 });\n }\n\n const parsed = await parseCheckoutBody(request);\n if (!parsed.data) {\n return jsonResponse(400, { error: parsed.error ?? \"Invalid request body\" });\n }\n\n const { customerId: resolvedCustomerId, errorResponse } = await resolveOptionalCustomerId(\n getCustomerId,\n request\n );\n if (errorResponse) return errorResponse;\n\n if (\n parsed.data.customerId &&\n resolvedCustomerId &&\n parsed.data.customerId !== resolvedCustomerId\n ) {\n return jsonResponse(403, { error: \"customerId must match authenticated customer\" });\n }\n\n const customerId = parsed.data.customerId ?? resolvedCustomerId;\n if (!customerId) {\n return jsonResponse(401, { error: \"Customer not identified\" });\n }\n\n if (parsed.data.stripePriceId) {\n const requestOrigin = new URL(request.url).origin;\n const successUrl = parsed.data.successUrl ?? `${requestOrigin}/settings/billing?checkout=success`;\n const cancelUrl = parsed.data.cancelUrl ?? successUrl;\n try {\n const data = await client.checkout.create({\n stripePriceId: parsed.data.stripePriceId,\n successUrl,\n cancelUrl,\n ...(parsed.data.metadata ? { metadata: parsed.data.metadata } : {}),\n customerId,\n });\n return jsonResponse(200, data as CreateCheckoutResponse);\n } catch (error) {\n if (error instanceof PriceOSError) {\n return jsonResponse(error.status ?? 500, { error: error.message });\n }\n return jsonResponse(500, { error: \"Request failed\" });\n }\n }\n\n if (!parsed.data.stripeProductKey) {\n return jsonResponse(400, { error: \"stripeProductKey is required\" });\n }\n\n const checkoutParams: Record<string, unknown> = {\n ...(parsed.data.checkoutParams ?? {}),\n ...(parsed.data.cancelUrl ? { cancel_url: parsed.data.cancelUrl } : {}),\n ...(parsed.data.metadata ? { metadata: parsed.data.metadata } : {}),\n };\n\n const body: CreateCustomerCheckoutRequest = {\n stripeProductKey: parsed.data.stripeProductKey,\n ...(parsed.data.successUrl ? { successUrl: parsed.data.successUrl } : {}),\n ...(parsed.data.customerInfo ? { customerInfo: parsed.data.customerInfo } : {}),\n ...(Object.keys(checkoutParams).length ? { checkoutParams } : {}),\n };\n\n try {\n const data = await client.customers.createCheckout(customerId, body);\n return jsonResponse(200, data as CreateCustomerCheckoutResponse);\n } catch (error) {\n if (error instanceof PriceOSError) {\n return jsonResponse(error.status ?? 500, { error: error.message });\n }\n return jsonResponse(500, { error: \"Request failed\" });\n }\n};\n\nconst handleCreateCustomerPortal = async (\n request: Request,\n client: PriceOS,\n getCustomerId?: PriceOSGetCustomerId\n) => {\n if (request.method.toUpperCase() !== \"POST\") {\n return new Response(\"Method not allowed.\", { status: 405 });\n }\n\n const parsed = await parseCustomerPortalBody(request);\n if (!parsed.data) {\n return jsonResponse(400, { error: parsed.error ?? \"Invalid request body\" });\n }\n\n const { customerId: resolvedCustomerId, errorResponse } = await resolveOptionalCustomerId(\n getCustomerId,\n request\n );\n if (errorResponse) return errorResponse;\n\n if (\n parsed.data.customerId &&\n resolvedCustomerId &&\n parsed.data.customerId !== resolvedCustomerId\n ) {\n return jsonResponse(403, { error: \"customerId must match authenticated customer\" });\n }\n\n const customerId = parsed.data.customerId ?? resolvedCustomerId;\n if (!customerId) {\n return jsonResponse(401, { error: \"Customer not identified\" });\n }\n\n try {\n const data = await client.customers.createPortal(customerId);\n return jsonResponse(200, data as CreateCustomerPortalResponse);\n } catch (error) {\n if (error instanceof PriceOSError) {\n return jsonResponse(error.status ?? 500, { error: error.message });\n }\n return jsonResponse(500, { error: \"Request failed\" });\n }\n};\n\nexport function priceosHandler(options: PriceOSNextHandlerOptions = {}): PriceOSRouteMethodHandlers {\n const envApiKey = (globalThis as { process?: { env?: Record<string, string | undefined> } })\n .process?.env?.PRICEOS_API_KEY;\n const apiKey = options.apiKey ?? envApiKey;\n const getCustomerId = options.getCustomerId;\n const basePath = (options.basePath ?? DEFAULT_BASE_PATH).replace(/\\/+$/, \"\");\n\n const handler: PriceOSRouteHandler = async (request: Request) => {\n if (!apiKey) {\n return new Response(\"Missing PRICEOS_API_KEY.\", { status: 500 });\n }\n\n let path = \"\";\n const url = new URL(request.url);\n const pathname = url.pathname;\n if (pathname.startsWith(basePath)) {\n path = normalizePath(pathname.slice(basePath.length));\n }\n\n const client = new PriceOS(apiKey);\n\n if (path === CUSTOMER_PATH) {\n if (!getCustomerId) {\n return jsonResponse(500, { error: \"Missing getCustomerId function\" });\n }\n return handleGetCustomer(request, url, client, getCustomerId);\n }\n\n if (path === FEATURE_ACCESS_PATH) {\n if (!getCustomerId) {\n return jsonResponse(500, { error: \"Missing getCustomerId function\" });\n }\n return handleGetFeatureAccess(request, url, client, getCustomerId);\n }\n\n if (path === TRACK_USAGE_PATH) {\n if (!getCustomerId) {\n return jsonResponse(500, { error: \"Missing getCustomerId function\" });\n }\n return handleTrackUsage(request, url, client, getCustomerId);\n }\n\n if (path === PRICING_TABLE_PATH) {\n return handleGetPricingTable(request, url, client, getCustomerId);\n }\n\n if (path === CHECKOUT_PATH) {\n return handleCreateCheckout(request, client, getCustomerId);\n }\n\n if (path === CUSTOMER_PORTAL_PATH) {\n return handleCreateCustomerPortal(request, client, getCustomerId);\n }\n\n return new Response(\"Not found.\", { status: 404 });\n };\n\n return Object.assign(handler, {\n GET: handler,\n POST: handler,\n });\n}\n\nconst getHeaderValue = (\n headers: Record<string, string | string[] | undefined> | undefined,\n key: string\n) => {\n if (!headers) return undefined;\n const value = headers[key] ?? headers[key.toLowerCase()] ?? headers[key.toUpperCase()];\n if (value !== undefined) {\n if (Array.isArray(value)) return value.join(\",\");\n return value;\n }\n const entry = Object.entries(headers).find(([headerKey]) => headerKey.toLowerCase() === key.toLowerCase());\n if (!entry) return undefined;\n const [, entryValue] = entry;\n if (Array.isArray(entryValue)) return entryValue.join(\",\");\n return entryValue;\n};\n\nconst toHeaders = (headers: Record<string, string | string[] | undefined> | undefined) => {\n const result = new Headers();\n if (!headers) return result;\n for (const [key, value] of Object.entries(headers)) {\n if (typeof value === \"string\") result.set(key, value);\n if (Array.isArray(value)) result.set(key, value.join(\",\"));\n }\n return result;\n};\n\nconst buildRequest = (req: PriceOSPagesRequest) => {\n const headers = req.headers ?? {};\n const forwardedProto = getHeaderValue(headers, \"x-forwarded-proto\");\n const protocol =\n forwardedProto?.split(\",\")[0]?.trim() ?? (req.socket?.encrypted ? \"https\" : \"http\");\n const host =\n getHeaderValue(headers, \"x-forwarded-host\") ??\n getHeaderValue(headers, \"host\") ??\n \"localhost\";\n const url = new URL(req.url ?? \"/\", `${protocol}://${host}`);\n\n const method = (req.method ?? \"GET\").toUpperCase();\n const normalizedHeaders = toHeaders(headers);\n const init: RequestInit = {\n method,\n headers: normalizedHeaders,\n };\n\n if (method !== \"GET\" && method !== \"HEAD\" && req.body !== undefined) {\n if (typeof req.body === \"string\") {\n init.body = req.body;\n } else {\n init.body = JSON.stringify(req.body);\n if (!normalizedHeaders.has(\"content-type\")) {\n normalizedHeaders.set(\"content-type\", \"application/json\");\n }\n }\n }\n\n return new Request(url, init);\n};\n\nconst sendResponse = async (res: PriceOSPagesResponse, response: Response) => {\n if (typeof res.status === \"function\") {\n res.status(response.status);\n } else {\n res.statusCode = response.status;\n }\n\n if (typeof res.setHeader === \"function\") {\n response.headers.forEach((value, key) => {\n res.setHeader?.(key, value);\n });\n }\n\n const body = await response.text();\n res.end?.(body || undefined);\n};\n\nexport function priceosPagesHandler(options: PriceOSPagesHandlerOptions = {}) {\n return async (req: PriceOSPagesRequest, res: PriceOSPagesResponse) => {\n const getCustomerId = options.getCustomerId;\n const request = buildRequest(req);\n const handler = priceosHandler({\n ...options,\n getCustomerId: getCustomerId ? (normalizedRequest) => getCustomerId(req, normalizedRequest) : undefined,\n });\n const response = await handler(request);\n await sendResponse(res, response);\n };\n}\n"],"mappings":"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","names":[]}