priceos 1.0.22 → 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/README.md CHANGED
@@ -148,7 +148,7 @@ await openCustomerPortal();
148
148
  `PriceOS` client groups:
149
149
  - `customers`: `get`, `link`, `create`, `update`, `delete`
150
150
  - `features`: `getAccess(customerId, featureKey?)`
151
- - `usage`: `track`, `set`, `getEvent`, `updateEvent`, `voidEvent`, `deleteEvent`, `deleteEvents`, `trackBatch`, `listEvents`
151
+ - `usage`: `track`, `set`, `getEvent`, `updateEvent`, `deleteEvent`, `deleteEvents`, `trackBatch`, `listEvents`
152
152
  - `bonuses`: `create`, `list`, `update`, `delete`
153
153
 
154
154
  Error handling:
@@ -235,9 +235,14 @@ var PriceOS = class {
235
235
  }
236
236
  });
237
237
  this.customers = {
238
- get: async (customerId) => {
238
+ get: async (customerId, options) => {
239
+ const query = options?.expand?.length ? { expand: options.expand } : void 0;
239
240
  const { data, error, response } = await this.client.GET("/v1/customers/{customerId}", {
240
- params: { path: { customerId }, header: this.header }
241
+ params: {
242
+ path: { customerId },
243
+ ...query ? { query } : {},
244
+ header: this.header
245
+ }
241
246
  });
242
247
  if (error) throwRequestError(this.log, error, response, "GET /v1/customers/{customerId}");
243
248
  return data ?? null;
@@ -267,6 +272,34 @@ var PriceOS = class {
267
272
  if (error) throwRequestError(this.log, error, response, "PUT /v1/customers/{customerId}");
268
273
  return data;
269
274
  },
275
+ addCustomProduct: async (input) => {
276
+ const { customerId, ...body } = input;
277
+ const { data, error, response } = await this.client.POST(
278
+ "/v1/customers/{customerId}/custom-product/add",
279
+ {
280
+ params: { path: { customerId }, header: this.header },
281
+ body
282
+ }
283
+ );
284
+ if (error) {
285
+ throwRequestError(this.log, error, response, "POST /v1/customers/{customerId}/custom-product/add");
286
+ }
287
+ return data;
288
+ },
289
+ removeCustomProduct: async (input) => {
290
+ const { customerId, ...body } = input;
291
+ const { data, error, response } = await this.client.POST(
292
+ "/v1/customers/{customerId}/custom-product/remove",
293
+ {
294
+ params: { path: { customerId }, header: this.header },
295
+ body
296
+ }
297
+ );
298
+ if (error) {
299
+ throwRequestError(this.log, error, response, "POST /v1/customers/{customerId}/custom-product/remove");
300
+ }
301
+ return data;
302
+ },
270
303
  delete: async (customerId) => {
271
304
  const { data, error, response } = await this.client.DELETE("/v1/customers/{customerId}", {
272
305
  params: { path: { customerId }, header: this.header }
@@ -442,15 +475,6 @@ var PriceOS = class {
442
475
  if (error) throwRequestError(this.log, error, response, "PUT /v1/usage/{id}");
443
476
  return data;
444
477
  },
445
- voidEvent: async (input) => {
446
- const { id, ...body } = input;
447
- const { data, error, response } = await this.client.POST("/v1/usage/{id}/void", {
448
- params: { header: this.header, path: { id } },
449
- body
450
- });
451
- if (error) throwRequestError(this.log, error, response, "POST /v1/usage/{id}/void");
452
- return data;
453
- },
454
478
  deleteEvent: async (eventId) => {
455
479
  const { data, error, response } = await this.client.DELETE("/v1/usage/{id}", {
456
480
  params: { header: this.header, path: { id: eventId } }
@@ -494,4 +518,4 @@ export {
494
518
  PriceOSError,
495
519
  PriceOS
496
520
  };
497
- //# sourceMappingURL=chunk-E3XCMBGY.js.map
521
+ //# sourceMappingURL=chunk-L253ULJU.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/client.ts"],"sourcesContent":["import createClient from \"openapi-fetch\";\nimport type { Client } from \"openapi-fetch\";\nimport type { paths } from \"./gen/openapi\";\nimport {\n AddCustomProductRequest,\n AddCustomProductResponse,\n CreateBonusBody,\n CreateBonusResponse,\n CreateCustomerCheckoutRequest,\n CreateCustomerCheckoutResponse,\n CreateCustomerRequest,\n CreateCustomerResponse,\n CreateCustomerPortalResponse,\n DeleteBonusResponse,\n ListBonusesRequest,\n ListBonusesResponse,\n DeleteUsageEventsBody,\n DeleteUsageEventsResponse,\n DeleteUsageEventResponse,\n DeleteCustomerResponse,\n GetUsageEventResponse,\n GetCustomerResponse,\n GetCustomerQuery,\n GetFeatureAccessResponse,\n LinkCustomerBody,\n LinkCustomerResponse,\n LimitFeatureKeyFromAccessMap,\n TrackedLimitFeatureKeyFromAccessMap,\n ListUsageEventsBody,\n ListUsageEventsResponse,\n SetUsageBody,\n SetUsageResponse,\n RemoveCustomProductRequest,\n RemoveCustomProductResponse,\n UpdateUsageEventRequest,\n UpdateUsageEventResponse,\n UpdateBonusRequest,\n UpdateBonusResponse,\n TrackUsageBody,\n TrackUsageBatchBody,\n TrackUsageBatchResponse,\n TrackUsageResponse,\n UpdateCustomerBody,\n UpdateCustomerResponse,\n GetPricingTableRequest,\n GetPricingTableResponse,\n CreateCheckoutRequest,\n CreateCheckoutResponse,\n} from \"./types\";\n\nexport type PriceOSLogLevel = \"none\" | \"error\" | \"warning\" | \"info\" | \"debug\";\n\n// --- Public options ---\nexport type PriceOSClientOptions = {\n logLevel?: PriceOSLogLevel;\n};\n\nconst RATE_LIMIT_STATUS = 429;\nconst MAX_RETRIES = 4;\nconst BASE_DELAY_MS = 250;\nconst BACKOFF_MULTIPLIER = 2;\nconst JITTER_MS = 250;\nconst RETRY_DELAY_CAP_MS = 5_000;\nconst REQUEST_TIMEOUT_MS = 20_000;\n\nconst LOG_LEVELS: Record<PriceOSLogLevel, number> = {\n none: 0,\n error: 1,\n warning: 2,\n info: 3,\n debug: 4,\n};\n\ntype Logger = {\n error: (message: string, details?: Record<string, unknown>) => void;\n warning: (message: string, details?: Record<string, unknown>) => void;\n info: (message: string, details?: Record<string, unknown>) => void;\n debug: (message: string, details?: Record<string, unknown>) => void;\n};\n\nconst sleep = (ms: number): Promise<void> => new Promise((resolve) => setTimeout(resolve, ms));\n\nconst getRetryDelayMs = (retryCount: number): number => {\n const backoff = BASE_DELAY_MS * Math.pow(BACKOFF_MULTIPLIER, retryCount - 1);\n const jitter = Math.random() * JITTER_MS;\n return Math.min(RETRY_DELAY_CAP_MS, backoff + jitter);\n};\n\nconst resolveIdempotencyKey = (input: { idempotencyKey?: string }) => {\n const providedIdempotencyKey =\n typeof input.idempotencyKey === \"string\"\n ? String(input.idempotencyKey).trim()\n : \"\";\n return providedIdempotencyKey;\n};\n\nconst withIdempotencyKey = <T extends { idempotencyKey?: string }>(input: T): T => {\n const idempotencyKey = resolveIdempotencyKey(input);\n if (!idempotencyKey) return input;\n return {\n ...input,\n idempotencyKey,\n };\n};\n\nconst createLogger = (logLevel: PriceOSLogLevel): Logger => {\n const shouldLog = (level: PriceOSLogLevel): boolean =>\n logLevel !== \"none\" && LOG_LEVELS[level] <= LOG_LEVELS[logLevel];\n\n const write = (\n level: PriceOSLogLevel,\n message: string,\n details?: Record<string, unknown>\n ): void => {\n if (!shouldLog(level)) return;\n const prefix = `[PriceOS] ${level.toUpperCase()}: ${message}`;\n const payload = details && Object.keys(details).length > 0 ? details : undefined;\n\n switch (level) {\n case \"error\":\n payload ? console.error(prefix, payload) : console.error(prefix);\n return;\n case \"warning\":\n payload ? console.warn(prefix, payload) : console.warn(prefix);\n return;\n case \"info\":\n payload ? console.info(prefix, payload) : console.info(prefix);\n return;\n case \"debug\":\n payload ? console.debug(prefix, payload) : console.debug(prefix);\n return;\n }\n };\n\n return {\n error: (message, details) => write(\"error\", message, details),\n warning: (message, details) => write(\"warning\", message, details),\n info: (message, details) => write(\"info\", message, details),\n debug: (message, details) => write(\"debug\", message, details),\n };\n};\n\nconst getUpstreamSignal = (input: RequestInfo | URL, init?: RequestInit): AbortSignal | undefined => {\n if (init?.signal) return init.signal;\n if (typeof Request !== \"undefined\" && input instanceof Request) return input.signal;\n return undefined;\n};\n\nconst stripSignal = (init?: RequestInit): RequestInit | undefined => {\n if (!init) return undefined;\n const { signal: _signal, ...rest } = init;\n return rest;\n};\n\nconst getRequestDetails = (\n input: RequestInfo | URL,\n init?: RequestInit\n): { method: string; url: string } => {\n const method =\n init?.method ??\n (typeof Request !== \"undefined\" && input instanceof Request ? input.method : \"GET\");\n const url =\n typeof input === \"string\"\n ? input\n : input instanceof URL\n ? input.toString()\n : input.url;\n return { method, url };\n};\n\nconst prepareRetryRequest = async (\n input: RequestInfo | URL,\n init: RequestInit | undefined,\n log: Logger,\n method: string,\n url: string\n): Promise<{ requestInput: RequestInfo | URL; baseInit?: RequestInit; canRetry: boolean }> => {\n if (!(typeof Request !== \"undefined\" && input instanceof Request)) {\n return { requestInput: input, baseInit: stripSignal(init), canRetry: true };\n }\n\n if (input.bodyUsed) {\n log.warning(\"Request body already used; retries disabled\", { method, url });\n return { requestInput: input, baseInit: stripSignal(init), canRetry: false };\n }\n\n let body: BodyInit | undefined = undefined;\n if (method !== \"GET\" && method !== \"HEAD\") {\n try {\n body = await input.clone().arrayBuffer();\n } catch (error) {\n log.warning(\"Unable to clone request body; retries disabled\", { method, url, error });\n return { requestInput: input, baseInit: stripSignal(init), canRetry: false };\n }\n }\n\n const headers = new Headers(input.headers);\n const baseInit = { ...stripSignal(init), method, headers, body };\n return { requestInput: input.url, baseInit, canRetry: true };\n};\n\nconst getErrorMessage = (error: unknown): string => {\n const maybeError = error as { error?: unknown } | null;\n if (maybeError && typeof maybeError.error === \"string\") return maybeError.error;\n return \"Request failed\";\n};\n\nconst throwRequestError = (\n log: Logger,\n error: unknown,\n response: Response | undefined,\n context: string\n): never => {\n log.error(\"Request failed\", { context, status: response?.status, error });\n throw new PriceOSError(getErrorMessage(error), { status: response?.status, details: error });\n};\n\nconst resolveUrlResponse = (\n data: unknown,\n response: Response | undefined\n): { url: string } | null => {\n if (data && typeof data === \"object\" && !Array.isArray(data)) {\n const value = (data as { url?: unknown }).url;\n if (typeof value === \"string\" && value.trim().length > 0) {\n return { url: value };\n }\n }\n\n const location = response?.headers.get(\"location\");\n if (location && location.trim().length > 0) {\n return { url: location };\n }\n\n if (response?.redirected && typeof response.url === \"string\" && response.url.trim().length > 0) {\n return { url: response.url };\n }\n\n return null;\n};\n\nconst createRetryingFetch = (baseFetch: typeof fetch, log: Logger): typeof fetch => {\n return async (input: RequestInfo | URL, init?: RequestInit): Promise<Response> => {\n const { method, url } = getRequestDetails(input, init);\n const upstreamSignal = getUpstreamSignal(input, init);\n const { requestInput, baseInit, canRetry } = await prepareRetryRequest(\n input,\n init,\n log,\n method,\n url\n );\n let attempt = 0;\n while (true) {\n log.debug(\"Request attempt\", { method, url, attempt: attempt + 1, maxRetries: MAX_RETRIES });\n const controller = new AbortController();\n const timeoutId = setTimeout(() => controller.abort(), REQUEST_TIMEOUT_MS);\n let removeAbortListener: (() => void) | null = null;\n\n if (upstreamSignal) {\n if (upstreamSignal.aborted) {\n controller.abort();\n } else {\n const onAbort = () => controller.abort();\n upstreamSignal.addEventListener(\"abort\", onAbort);\n removeAbortListener = () => upstreamSignal.removeEventListener(\"abort\", onAbort);\n }\n }\n\n try {\n const requestInit = { ...(baseInit ?? {}), signal: controller.signal };\n const response = await baseFetch(requestInput, requestInit);\n if (response.status !== RATE_LIMIT_STATUS) return response;\n\n const retryAfter = response.headers.get(\"retry-after\") ?? undefined;\n log.warning(\"Rate limit hit (429)\", {\n method,\n url,\n attempt: attempt + 1,\n maxRetries: MAX_RETRIES,\n retryAfter,\n });\n\n if (!canRetry) {\n log.warning(\"Skipping retry because request body is not replayable\", { method, url });\n return response;\n }\n\n if (attempt >= MAX_RETRIES) {\n log.error(\"Rate limit retries exhausted\", { method, url, attempts: attempt + 1 });\n return response;\n }\n\n const delayMs = getRetryDelayMs(attempt + 1);\n log.info(\"Waiting to retry after rate limit\", {\n method,\n url,\n delayMs,\n nextAttempt: attempt + 2,\n maxRetries: MAX_RETRIES,\n });\n await sleep(delayMs);\n attempt += 1;\n } catch (error) {\n if (controller.signal.aborted) {\n const abortedByCaller = upstreamSignal?.aborted ?? false;\n if (abortedByCaller) {\n log.warning(\"Request aborted by caller\", { method, url, attempt: attempt + 1 });\n } else {\n log.error(\"Request timed out\", {\n method,\n url,\n attempt: attempt + 1,\n timeoutMs: REQUEST_TIMEOUT_MS,\n });\n }\n } else {\n log.error(\"Request failed\", { method, url, attempt: attempt + 1, error });\n }\n throw error;\n } finally {\n clearTimeout(timeoutId);\n removeAbortListener?.();\n }\n }\n };\n};\n\nexport type PriceOSCustomersClient<TFeatureAccessMap = GetFeatureAccessResponse> = {\n get(\n customerId: string,\n options?: { expand?: GetCustomerQuery[\"expand\"] }\n ): Promise<GetCustomerResponse<TFeatureAccessMap> | null>;\n link(input: LinkCustomerBody): Promise<LinkCustomerResponse<TFeatureAccessMap> | null>;\n create(input: CreateCustomerRequest): Promise<CreateCustomerResponse<TFeatureAccessMap>>;\n update(input: UpdateCustomerBody): Promise<UpdateCustomerResponse<TFeatureAccessMap>>;\n addCustomProduct(input: AddCustomProductRequest): Promise<AddCustomProductResponse<TFeatureAccessMap>>;\n removeCustomProduct(\n input: RemoveCustomProductRequest\n ): Promise<RemoveCustomProductResponse<TFeatureAccessMap>>;\n delete(customerId: string): Promise<DeleteCustomerResponse>;\n createPortal(customerId: string): Promise<CreateCustomerPortalResponse>;\n createCheckout(\n customerId: string,\n input: CreateCustomerCheckoutRequest\n ): Promise<CreateCustomerCheckoutResponse>;\n};\n\ntype FeatureAccessRecord<TFeatureAccessMap> =\n TFeatureAccessMap extends Record<string, unknown> ? TFeatureAccessMap : Record<string, never>;\n\ntype FeatureAccessKey<TFeatureAccessMap> = keyof FeatureAccessRecord<TFeatureAccessMap> & string;\n\nexport type PriceOSFeaturesClient<TFeatureAccessMap = GetFeatureAccessResponse> = {\n getAccess(customerId: string): Promise<TFeatureAccessMap>;\n getAccess<TFeatureKey extends FeatureAccessKey<TFeatureAccessMap>>(\n customerId: string,\n featureKey: TFeatureKey\n ): Promise<FeatureAccessRecord<TFeatureAccessMap>[TFeatureKey]>;\n};\n\nexport type PriceOSPricingClient = {\n getTable(input?: GetPricingTableRequest): Promise<GetPricingTableResponse>;\n};\n\nexport type PriceOSCheckoutClient = {\n create(input: CreateCheckoutRequest): Promise<CreateCheckoutResponse>;\n};\n\nexport type PriceOSBonusesClient<TFeatureAccessMap = GetFeatureAccessResponse> = {\n create(\n input: CreateBonusBody<TrackedLimitFeatureKeyFromAccessMap<TFeatureAccessMap>>\n ): Promise<CreateBonusResponse>;\n list(\n input: ListBonusesRequest<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>\n ): Promise<ListBonusesResponse>;\n update(input: UpdateBonusRequest): Promise<UpdateBonusResponse>;\n delete(bonusId: string): Promise<DeleteBonusResponse>;\n};\n\nexport type PriceOSUsageClient<TFeatureAccessMap = GetFeatureAccessResponse> = {\n track(\n input: TrackUsageBody<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>\n ): Promise<TrackUsageResponse>;\n set(\n input: SetUsageBody<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>\n ): Promise<SetUsageResponse>;\n getEvent(eventId: string): Promise<GetUsageEventResponse>;\n updateEvent(input: UpdateUsageEventRequest): Promise<UpdateUsageEventResponse>;\n deleteEvent(eventId: string): Promise<DeleteUsageEventResponse>;\n deleteEvents(\n input: DeleteUsageEventsBody<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>\n ): Promise<DeleteUsageEventsResponse>;\n trackBatch(\n input: TrackUsageBatchBody<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>\n ): Promise<TrackUsageBatchResponse>;\n listEvents(\n input: ListUsageEventsBody<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>\n ): Promise<ListUsageEventsResponse>;\n};\n\n// --- Public SDK surface type ---\nexport type PriceOSHttpClient<TFeatureAccessMap = GetFeatureAccessResponse> = {\n customers: PriceOSCustomersClient<TFeatureAccessMap>;\n features: PriceOSFeaturesClient<TFeatureAccessMap>;\n pricing: PriceOSPricingClient;\n checkout: PriceOSCheckoutClient;\n bonuses: PriceOSBonusesClient<TFeatureAccessMap>;\n usage: PriceOSUsageClient<TFeatureAccessMap>;\n};\n\nexport class PriceOSError extends Error {\n status?: number;\n details?: unknown;\n\n constructor(message: string, opts?: { status?: number; details?: unknown }) {\n super(message);\n this.name = \"PriceOSError\";\n this.status = opts?.status;\n this.details = opts?.details;\n }\n}\n\nexport class PriceOS<TFeatureAccessMap = GetFeatureAccessResponse>\n implements PriceOSHttpClient<TFeatureAccessMap>\n{\n private client: Client<paths>;\n private header: { \"x-api-key\": string };\n private log: Logger;\n customers: PriceOSCustomersClient<TFeatureAccessMap>;\n features: PriceOSFeaturesClient<TFeatureAccessMap>;\n pricing: PriceOSPricingClient;\n checkout: PriceOSCheckoutClient;\n bonuses: PriceOSBonusesClient<TFeatureAccessMap>;\n usage: PriceOSUsageClient<TFeatureAccessMap>;\n\n constructor(apiKey: string, opts: PriceOSClientOptions = {}) {\n const logLevel = opts.logLevel ?? \"none\";\n this.log = createLogger(logLevel);\n const baseUrl = \"https://api.priceos.com\";\n this.header = { \"x-api-key\": apiKey };\n const fetchWithRetry = createRetryingFetch(fetch, this.log);\n this.client = createClient<paths>({\n baseUrl,\n fetch: fetchWithRetry,\n headers: {\n \"x-api-key\": apiKey,\n },\n });\n\n this.customers = {\n get: async (\n customerId: string,\n options?: { expand?: GetCustomerQuery[\"expand\"] }\n ): Promise<GetCustomerResponse<TFeatureAccessMap> | null> => {\n const query = options?.expand?.length ? { expand: options.expand } : undefined;\n const { data, error, response } = await this.client.GET(\"/v1/customers/{customerId}\", {\n params: {\n path: { customerId },\n ...(query ? { query } : {}),\n header: this.header,\n },\n });\n if (error) throwRequestError(this.log, error, response, \"GET /v1/customers/{customerId}\");\n return (data ?? null) as GetCustomerResponse<TFeatureAccessMap> | null;\n },\n link: async (\n input: LinkCustomerBody\n ): Promise<LinkCustomerResponse<TFeatureAccessMap> | null> => {\n const { data, error, response } = await this.client.POST(\"/v1/customers/link\", {\n params: { header: this.header },\n body: input,\n });\n if (error) throwRequestError(this.log, error, response, \"POST /v1/customers/link\");\n return (data ?? null) as LinkCustomerResponse<TFeatureAccessMap> | null;\n },\n create: async (input: CreateCustomerRequest): Promise<CreateCustomerResponse<TFeatureAccessMap>> => {\n const { data, error, response } = await this.client.POST(\"/v1/customers\", {\n params: { header: this.header },\n body: input,\n });\n if (error) throwRequestError(this.log, error, response, \"POST /v1/customers\");\n return data! as CreateCustomerResponse<TFeatureAccessMap>;\n },\n update: async (input: UpdateCustomerBody): Promise<UpdateCustomerResponse<TFeatureAccessMap>> => {\n const { customerId, ...body } = input;\n const { data, error, response } = await this.client.PUT(\"/v1/customers/{customerId}\", {\n params: { path: { customerId }, header: this.header },\n body,\n });\n if (error) throwRequestError(this.log, error, response, \"PUT /v1/customers/{customerId}\");\n return data! as UpdateCustomerResponse<TFeatureAccessMap>;\n },\n addCustomProduct: async (\n input: AddCustomProductRequest\n ): Promise<AddCustomProductResponse<TFeatureAccessMap>> => {\n const { customerId, ...body } = input;\n const { data, error, response } = await this.client.POST(\n \"/v1/customers/{customerId}/custom-product/add\",\n {\n params: { path: { customerId }, header: this.header },\n body,\n }\n );\n if (error) {\n throwRequestError(this.log, error, response, \"POST /v1/customers/{customerId}/custom-product/add\");\n }\n return data! as AddCustomProductResponse<TFeatureAccessMap>;\n },\n removeCustomProduct: async (\n input: RemoveCustomProductRequest\n ): Promise<RemoveCustomProductResponse<TFeatureAccessMap>> => {\n const { customerId, ...body } = input;\n const { data, error, response } = await this.client.POST(\n \"/v1/customers/{customerId}/custom-product/remove\",\n {\n params: { path: { customerId }, header: this.header },\n body,\n }\n );\n if (error) {\n throwRequestError(this.log, error, response, \"POST /v1/customers/{customerId}/custom-product/remove\");\n }\n return data! as RemoveCustomProductResponse<TFeatureAccessMap>;\n },\n delete: async (customerId: string): Promise<DeleteCustomerResponse> => {\n const { data, error, response } = await this.client.DELETE(\"/v1/customers/{customerId}\", {\n params: { path: { customerId }, header: this.header },\n });\n if (error) throwRequestError(this.log, error, response, \"DELETE /v1/customers/{customerId}\");\n return data! as DeleteCustomerResponse;\n },\n createPortal: async (customerId: string): Promise<CreateCustomerPortalResponse> => {\n const { data, error, response } = await this.client.POST(\n \"/v1/customers/{customerId}/customer_portal\",\n {\n params: { path: { customerId }, header: this.header },\n }\n );\n if (error) {\n throwRequestError(this.log, error, response, \"POST /v1/customers/{customerId}/customer_portal\");\n }\n if (response && !response.ok) {\n throw new PriceOSError(response.statusText || \"Request failed\", { status: response.status });\n }\n const result = resolveUrlResponse(data, response);\n if (result) {\n return result as CreateCustomerPortalResponse;\n }\n throw new PriceOSError(\"Invalid customer portal response\", {\n status: response?.status,\n details: {\n redirected: response?.redirected ?? false,\n responseUrl: response?.url ?? null,\n },\n });\n },\n createCheckout: async (\n customerId: string,\n input: CreateCustomerCheckoutRequest\n ): Promise<CreateCustomerCheckoutResponse> => {\n const { data, error, response } = await this.client.POST(\"/v1/customers/{customerId}/checkout\", {\n params: { path: { customerId }, header: this.header },\n body: input,\n });\n if (error) {\n throwRequestError(this.log, error, response, \"POST /v1/customers/{customerId}/checkout\");\n }\n if (response && !response.ok) {\n throw new PriceOSError(response.statusText || \"Request failed\", { status: response.status });\n }\n const result = resolveUrlResponse(data, response);\n if (result) {\n return result as CreateCustomerCheckoutResponse;\n }\n throw new PriceOSError(\"Invalid checkout response\", {\n status: response?.status,\n details: {\n redirected: response?.redirected ?? false,\n responseUrl: response?.url ?? null,\n },\n });\n },\n };\n\n const getFeatureAccessForCustomer = async (customerId: string): Promise<TFeatureAccessMap> => {\n const { data, error, response } = await this.client.GET(\"/v1/feature-access\", {\n params: { query: { customerId }, header: this.header },\n });\n if (error) throwRequestError(this.log, error, response, \"GET /v1/feature-access\");\n return data! as TFeatureAccessMap;\n };\n\n function getFeatureAccess(customerId: string): Promise<TFeatureAccessMap>;\n function getFeatureAccess<TFeatureKey extends FeatureAccessKey<TFeatureAccessMap>>(\n customerId: string,\n featureKey: TFeatureKey\n ): Promise<FeatureAccessRecord<TFeatureAccessMap>[TFeatureKey]>;\n async function getFeatureAccess<TFeatureKey extends FeatureAccessKey<TFeatureAccessMap>>(\n customerId: string,\n featureKey?: TFeatureKey\n ): Promise<TFeatureAccessMap | FeatureAccessRecord<TFeatureAccessMap>[TFeatureKey]> {\n const featureAccess = await getFeatureAccessForCustomer(customerId);\n if (featureKey === undefined) return featureAccess;\n return (featureAccess as FeatureAccessRecord<TFeatureAccessMap>)[featureKey];\n }\n\n this.features = {\n getAccess: getFeatureAccess,\n };\n\n this.pricing = {\n getTable: async (input: GetPricingTableRequest = {}): Promise<GetPricingTableResponse> => {\n const query = {\n ...(typeof input.customerId === \"string\" ? { customerId: input.customerId } : {}),\n ...(typeof input.pricingTableKey === \"string\" ? { pricingTableKey: input.pricingTableKey } : {}),\n };\n const { data, error, response } = await this.client.GET(\"/v1/pricing-table\", {\n params: { query, header: this.header },\n });\n if (error) throwRequestError(this.log, error, response, \"GET /v1/pricing-table\");\n return data! as GetPricingTableResponse;\n },\n };\n\n this.checkout = {\n create: async (input: CreateCheckoutRequest): Promise<CreateCheckoutResponse> => {\n const { data, error, response } = await this.client.POST(\"/v1/checkout\", {\n params: { header: this.header },\n body: input,\n });\n if (error) throwRequestError(this.log, error, response, \"POST /v1/checkout\");\n if (response && !response.ok) {\n throw new PriceOSError(response.statusText || \"Request failed\", { status: response.status });\n }\n const result = resolveUrlResponse(data, response);\n if (result) {\n return result as CreateCheckoutResponse;\n }\n throw new PriceOSError(\"Invalid checkout response\", {\n status: response?.status,\n details: {\n redirected: response?.redirected ?? false,\n responseUrl: response?.url ?? null,\n },\n });\n },\n };\n\n this.bonuses = {\n create: async (\n input: CreateBonusBody<TrackedLimitFeatureKeyFromAccessMap<TFeatureAccessMap>>\n ): Promise<CreateBonusResponse> => {\n const { data, error, response } = await this.client.POST(\"/v1/bonuses\", {\n params: { header: this.header },\n body: input,\n });\n if (error) throwRequestError(this.log, error, response, \"POST /v1/bonuses\");\n return data!;\n },\n list: async (\n input: ListBonusesRequest<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>\n ): Promise<ListBonusesResponse> => {\n const { data, error, response } = await this.client.GET(\"/v1/bonuses\", {\n params: { header: this.header, query: input },\n });\n if (error) throwRequestError(this.log, error, response, \"GET /v1/bonuses\");\n return data!;\n },\n update: async (input: UpdateBonusRequest): Promise<UpdateBonusResponse> => {\n const { bonusId, ...body } = input;\n const { data, error, response } = await this.client.PUT(\"/v1/bonuses/{bonusId}\", {\n params: { header: this.header, path: { bonusId } },\n body,\n });\n if (error) throwRequestError(this.log, error, response, \"PUT /v1/bonuses/{bonusId}\");\n return data!;\n },\n delete: async (bonusId: string): Promise<DeleteBonusResponse> => {\n const { data, error, response } = await this.client.DELETE(\"/v1/bonuses/{bonusId}\", {\n params: { header: this.header, path: { bonusId } },\n });\n if (error) throwRequestError(this.log, error, response, \"DELETE /v1/bonuses/{bonusId}\");\n return data!;\n },\n };\n\n this.usage = {\n track: async (\n input: TrackUsageBody<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>\n ): Promise<TrackUsageResponse> => {\n const body = withIdempotencyKey(input);\n const { data, error, response } = await this.client.POST(\"/v1/usage\", {\n params: { header: this.header },\n body,\n });\n if (error) throwRequestError(this.log, error, response, \"POST /v1/usage\");\n return data!;\n },\n set: async (\n input: SetUsageBody<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>\n ): Promise<SetUsageResponse> => {\n const body = withIdempotencyKey(input);\n const { data, error, response } = await this.client.POST(\"/v1/usage/set\", {\n params: { header: this.header },\n body,\n });\n if (error) throwRequestError(this.log, error, response, \"POST /v1/usage/set\");\n return data!;\n },\n getEvent: async (eventId: string): Promise<GetUsageEventResponse> => {\n const { data, error, response } = await this.client.GET(\"/v1/usage/{id}\", {\n params: { header: this.header, path: { id: eventId } },\n });\n if (error) throwRequestError(this.log, error, response, \"GET /v1/usage/{id}\");\n return data!;\n },\n updateEvent: async (input: UpdateUsageEventRequest): Promise<UpdateUsageEventResponse> => {\n const { id, ...body } = input;\n const { data, error, response } = await this.client.PUT(\"/v1/usage/{id}\", {\n params: { header: this.header, path: { id } },\n body,\n });\n if (error) throwRequestError(this.log, error, response, \"PUT /v1/usage/{id}\");\n return data!;\n },\n deleteEvent: async (eventId: string): Promise<DeleteUsageEventResponse> => {\n const { data, error, response } = await this.client.DELETE(\"/v1/usage/{id}\", {\n params: { header: this.header, path: { id: eventId } },\n });\n if (error) throwRequestError(this.log, error, response, \"DELETE /v1/usage/{id}\");\n return data!;\n },\n deleteEvents: async (\n input: DeleteUsageEventsBody<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>\n ): Promise<DeleteUsageEventsResponse> => {\n const { data, error, response } = await this.client.POST(\"/v1/usage/delete\", {\n params: { header: this.header },\n body: input,\n });\n if (error) throwRequestError(this.log, error, response, \"POST /v1/usage/delete\");\n return data!;\n },\n trackBatch: async (\n input: TrackUsageBatchBody<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>\n ): Promise<TrackUsageBatchResponse> => {\n const body = {\n ...input,\n events: input.events.map((event) => withIdempotencyKey(event)),\n };\n const { data, error, response } = await this.client.POST(\"/v1/usage/batch\", {\n params: { header: this.header },\n body,\n });\n if (error) throwRequestError(this.log, error, response, \"POST /v1/usage/batch\");\n return data!;\n },\n listEvents: async (\n input: ListUsageEventsBody<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>\n ): Promise<ListUsageEventsResponse> => {\n const { data, error, response } = await this.client.POST(\"/v1/usage/events\", {\n params: { header: this.header },\n body: input,\n });\n if (error) throwRequestError(this.log, error, response, \"POST /v1/usage/events\");\n return data!;\n },\n };\n }\n}\n"],"mappings":"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","names":[]}
package/dist/client.d.ts CHANGED
@@ -1,13 +1,17 @@
1
- import { CreateBonusBody, CreateBonusResponse, CreateCustomerCheckoutRequest, CreateCustomerCheckoutResponse, CreateCustomerRequest, CreateCustomerResponse, CreateCustomerPortalResponse, DeleteBonusResponse, ListBonusesRequest, ListBonusesResponse, DeleteUsageEventsBody, DeleteUsageEventsResponse, DeleteUsageEventResponse, DeleteCustomerResponse, GetUsageEventResponse, GetCustomerResponse, GetFeatureAccessResponse, LinkCustomerBody, LinkCustomerResponse, LimitFeatureKeyFromAccessMap, TrackedLimitFeatureKeyFromAccessMap, ListUsageEventsBody, ListUsageEventsResponse, SetUsageBody, SetUsageResponse, UpdateUsageEventRequest, UpdateUsageEventResponse, VoidUsageEventRequest, VoidUsageEventResponse, UpdateBonusRequest, UpdateBonusResponse, TrackUsageBody, TrackUsageBatchBody, TrackUsageBatchResponse, TrackUsageResponse, UpdateCustomerBody, UpdateCustomerResponse, GetPricingTableRequest, GetPricingTableResponse, CreateCheckoutRequest, CreateCheckoutResponse } from "./types";
1
+ import { AddCustomProductRequest, AddCustomProductResponse, CreateBonusBody, CreateBonusResponse, CreateCustomerCheckoutRequest, CreateCustomerCheckoutResponse, CreateCustomerRequest, CreateCustomerResponse, CreateCustomerPortalResponse, DeleteBonusResponse, ListBonusesRequest, ListBonusesResponse, DeleteUsageEventsBody, DeleteUsageEventsResponse, DeleteUsageEventResponse, DeleteCustomerResponse, GetUsageEventResponse, GetCustomerResponse, GetCustomerQuery, GetFeatureAccessResponse, LinkCustomerBody, LinkCustomerResponse, LimitFeatureKeyFromAccessMap, TrackedLimitFeatureKeyFromAccessMap, ListUsageEventsBody, ListUsageEventsResponse, SetUsageBody, SetUsageResponse, RemoveCustomProductRequest, RemoveCustomProductResponse, UpdateUsageEventRequest, UpdateUsageEventResponse, UpdateBonusRequest, UpdateBonusResponse, TrackUsageBody, TrackUsageBatchBody, TrackUsageBatchResponse, TrackUsageResponse, UpdateCustomerBody, UpdateCustomerResponse, GetPricingTableRequest, GetPricingTableResponse, CreateCheckoutRequest, CreateCheckoutResponse } from "./types";
2
2
  export type PriceOSLogLevel = "none" | "error" | "warning" | "info" | "debug";
3
3
  export type PriceOSClientOptions = {
4
4
  logLevel?: PriceOSLogLevel;
5
5
  };
6
6
  export type PriceOSCustomersClient<TFeatureAccessMap = GetFeatureAccessResponse> = {
7
- get(customerId: string): Promise<GetCustomerResponse<TFeatureAccessMap> | null>;
7
+ get(customerId: string, options?: {
8
+ expand?: GetCustomerQuery["expand"];
9
+ }): Promise<GetCustomerResponse<TFeatureAccessMap> | null>;
8
10
  link(input: LinkCustomerBody): Promise<LinkCustomerResponse<TFeatureAccessMap> | null>;
9
11
  create(input: CreateCustomerRequest): Promise<CreateCustomerResponse<TFeatureAccessMap>>;
10
12
  update(input: UpdateCustomerBody): Promise<UpdateCustomerResponse<TFeatureAccessMap>>;
13
+ addCustomProduct(input: AddCustomProductRequest): Promise<AddCustomProductResponse<TFeatureAccessMap>>;
14
+ removeCustomProduct(input: RemoveCustomProductRequest): Promise<RemoveCustomProductResponse<TFeatureAccessMap>>;
11
15
  delete(customerId: string): Promise<DeleteCustomerResponse>;
12
16
  createPortal(customerId: string): Promise<CreateCustomerPortalResponse>;
13
17
  createCheckout(customerId: string, input: CreateCustomerCheckoutRequest): Promise<CreateCustomerCheckoutResponse>;
@@ -35,7 +39,6 @@ export type PriceOSUsageClient<TFeatureAccessMap = GetFeatureAccessResponse> = {
35
39
  set(input: SetUsageBody<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>): Promise<SetUsageResponse>;
36
40
  getEvent(eventId: string): Promise<GetUsageEventResponse>;
37
41
  updateEvent(input: UpdateUsageEventRequest): Promise<UpdateUsageEventResponse>;
38
- voidEvent(input: VoidUsageEventRequest): Promise<VoidUsageEventResponse>;
39
42
  deleteEvent(eventId: string): Promise<DeleteUsageEventResponse>;
40
43
  deleteEvents(input: DeleteUsageEventsBody<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>): Promise<DeleteUsageEventsResponse>;
41
44
  trackBatch(input: TrackUsageBatchBody<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>): Promise<TrackUsageBatchResponse>;