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/README.md +28 -1
- package/dist/{chunk-SMK7KTGQ.js → chunk-L253ULJU.js} +105 -37
- package/dist/chunk-L253ULJU.js.map +1 -0
- package/dist/client.d.ts +7 -5
- package/dist/embed/pricing-table.global.js +7 -7
- package/dist/gen/openapi.d.ts +1325 -935
- package/dist/index.cjs +104 -36
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +1 -1
- package/dist/next.cjs +267 -50
- package/dist/next.cjs.map +1 -1
- package/dist/next.js +164 -15
- package/dist/next.js.map +1 -1
- package/dist/react.cjs +104 -73
- package/dist/react.cjs.map +1 -1
- package/dist/react.d.ts +29 -6
- package/dist/react.js +102 -73
- package/dist/react.js.map +1 -1
- package/dist/types.d.ts +25 -12
- package/package.json +3 -2
- package/dist/chunk-SMK7KTGQ.js.map +0 -1
package/README.md
CHANGED
|
@@ -59,6 +59,9 @@ Use built-in handlers for:
|
|
|
59
59
|
- `GET /api/priceos/v1/customer`
|
|
60
60
|
- `GET /api/priceos/v1/feature-access`
|
|
61
61
|
- `POST /api/priceos/v1/usage`
|
|
62
|
+
- `GET /api/priceos/v1/pricing-table`
|
|
63
|
+
- `POST /api/priceos/v1/checkout`
|
|
64
|
+
- `POST /api/priceos/v1/customer-portal`
|
|
62
65
|
|
|
63
66
|
App Router:
|
|
64
67
|
|
|
@@ -118,12 +121,34 @@ const { trackUsage } = useTrackUsage<MyFeatures>();
|
|
|
118
121
|
await trackUsage({ featureKey: "team_seats", amount: 1 });
|
|
119
122
|
```
|
|
120
123
|
|
|
124
|
+
Start checkout:
|
|
125
|
+
|
|
126
|
+
```tsx
|
|
127
|
+
import { useCheckout } from "priceos/react";
|
|
128
|
+
|
|
129
|
+
const { openCheckout } = useCheckout();
|
|
130
|
+
await openCheckout({
|
|
131
|
+
stripeProductKey: "starter_monthly",
|
|
132
|
+
successUrl: "https://app.acme.com/settings/billing?checkout=success",
|
|
133
|
+
cancelUrl: "https://app.acme.com/settings/billing?checkout=canceled",
|
|
134
|
+
});
|
|
135
|
+
```
|
|
136
|
+
|
|
137
|
+
Open customer portal:
|
|
138
|
+
|
|
139
|
+
```tsx
|
|
140
|
+
import { useCustomerPortal } from "priceos/react";
|
|
141
|
+
|
|
142
|
+
const { openCustomerPortal } = useCustomerPortal();
|
|
143
|
+
await openCustomerPortal();
|
|
144
|
+
```
|
|
145
|
+
|
|
121
146
|
## API surface
|
|
122
147
|
|
|
123
148
|
`PriceOS` client groups:
|
|
124
149
|
- `customers`: `get`, `link`, `create`, `update`, `delete`
|
|
125
150
|
- `features`: `getAccess(customerId, featureKey?)`
|
|
126
|
-
- `usage`: `track`, `set`, `getEvent`, `
|
|
151
|
+
- `usage`: `track`, `set`, `getEvent`, `updateEvent`, `deleteEvent`, `deleteEvents`, `trackBatch`, `listEvents`
|
|
127
152
|
- `bonuses`: `create`, `list`, `update`, `delete`
|
|
128
153
|
|
|
129
154
|
Error handling:
|
|
@@ -152,3 +177,5 @@ Options:
|
|
|
152
177
|
- [React `useFeatureAccess`](https://docs.priceos.com/react/use-feature-access)
|
|
153
178
|
- [React `useCustomer`](https://docs.priceos.com/react/use-customer)
|
|
154
179
|
- [React `useTrackUsage`](https://docs.priceos.com/react/use-track-usage)
|
|
180
|
+
- [React `useCheckout`](https://docs.priceos.com/react/use-checkout)
|
|
181
|
+
- [React `useCustomerPortal`](https://docs.priceos.com/react/use-customer-portal)
|
|
@@ -21,19 +21,16 @@ var getRetryDelayMs = (retryCount) => {
|
|
|
21
21
|
return Math.min(RETRY_DELAY_CAP_MS, backoff + jitter);
|
|
22
22
|
};
|
|
23
23
|
var resolveIdempotencyKey = (input) => {
|
|
24
|
-
const providedEventKey = typeof input.eventKey === "string" ? input.eventKey.trim() : "";
|
|
25
24
|
const providedIdempotencyKey = typeof input.idempotencyKey === "string" ? String(input.idempotencyKey).trim() : "";
|
|
26
|
-
return providedIdempotencyKey
|
|
25
|
+
return providedIdempotencyKey;
|
|
27
26
|
};
|
|
28
27
|
var withIdempotencyKey = (input) => {
|
|
29
28
|
const idempotencyKey = resolveIdempotencyKey(input);
|
|
30
29
|
if (!idempotencyKey) return input;
|
|
31
|
-
|
|
30
|
+
return {
|
|
32
31
|
...input,
|
|
33
32
|
idempotencyKey
|
|
34
33
|
};
|
|
35
|
-
delete next.eventKey;
|
|
36
|
-
return next;
|
|
37
34
|
};
|
|
38
35
|
var createLogger = (logLevel) => {
|
|
39
36
|
const shouldLog = (level) => logLevel !== "none" && LOG_LEVELS[level] <= LOG_LEVELS[logLevel];
|
|
@@ -108,6 +105,22 @@ var throwRequestError = (log, error, response, context) => {
|
|
|
108
105
|
log.error("Request failed", { context, status: response?.status, error });
|
|
109
106
|
throw new PriceOSError(getErrorMessage(error), { status: response?.status, details: error });
|
|
110
107
|
};
|
|
108
|
+
var resolveUrlResponse = (data, response) => {
|
|
109
|
+
if (data && typeof data === "object" && !Array.isArray(data)) {
|
|
110
|
+
const value = data.url;
|
|
111
|
+
if (typeof value === "string" && value.trim().length > 0) {
|
|
112
|
+
return { url: value };
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
const location = response?.headers.get("location");
|
|
116
|
+
if (location && location.trim().length > 0) {
|
|
117
|
+
return { url: location };
|
|
118
|
+
}
|
|
119
|
+
if (response?.redirected && typeof response.url === "string" && response.url.trim().length > 0) {
|
|
120
|
+
return { url: response.url };
|
|
121
|
+
}
|
|
122
|
+
return null;
|
|
123
|
+
};
|
|
111
124
|
var createRetryingFetch = (baseFetch, log) => {
|
|
112
125
|
return async (input, init) => {
|
|
113
126
|
const { method, url } = getRequestDetails(input, init);
|
|
@@ -222,9 +235,14 @@ var PriceOS = class {
|
|
|
222
235
|
}
|
|
223
236
|
});
|
|
224
237
|
this.customers = {
|
|
225
|
-
get: async (customerId) => {
|
|
238
|
+
get: async (customerId, options) => {
|
|
239
|
+
const query = options?.expand?.length ? { expand: options.expand } : void 0;
|
|
226
240
|
const { data, error, response } = await this.client.GET("/v1/customers/{customerId}", {
|
|
227
|
-
params: {
|
|
241
|
+
params: {
|
|
242
|
+
path: { customerId },
|
|
243
|
+
...query ? { query } : {},
|
|
244
|
+
header: this.header
|
|
245
|
+
}
|
|
228
246
|
});
|
|
229
247
|
if (error) throwRequestError(this.log, error, response, "GET /v1/customers/{customerId}");
|
|
230
248
|
return data ?? null;
|
|
@@ -254,6 +272,34 @@ var PriceOS = class {
|
|
|
254
272
|
if (error) throwRequestError(this.log, error, response, "PUT /v1/customers/{customerId}");
|
|
255
273
|
return data;
|
|
256
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
|
+
},
|
|
257
303
|
delete: async (customerId) => {
|
|
258
304
|
const { data, error, response } = await this.client.DELETE("/v1/customers/{customerId}", {
|
|
259
305
|
params: { path: { customerId }, header: this.header }
|
|
@@ -271,7 +317,43 @@ var PriceOS = class {
|
|
|
271
317
|
if (error) {
|
|
272
318
|
throwRequestError(this.log, error, response, "POST /v1/customers/{customerId}/customer_portal");
|
|
273
319
|
}
|
|
274
|
-
|
|
320
|
+
if (response && !response.ok) {
|
|
321
|
+
throw new PriceOSError(response.statusText || "Request failed", { status: response.status });
|
|
322
|
+
}
|
|
323
|
+
const result = resolveUrlResponse(data, response);
|
|
324
|
+
if (result) {
|
|
325
|
+
return result;
|
|
326
|
+
}
|
|
327
|
+
throw new PriceOSError("Invalid customer portal response", {
|
|
328
|
+
status: response?.status,
|
|
329
|
+
details: {
|
|
330
|
+
redirected: response?.redirected ?? false,
|
|
331
|
+
responseUrl: response?.url ?? null
|
|
332
|
+
}
|
|
333
|
+
});
|
|
334
|
+
},
|
|
335
|
+
createCheckout: async (customerId, input) => {
|
|
336
|
+
const { data, error, response } = await this.client.POST("/v1/customers/{customerId}/checkout", {
|
|
337
|
+
params: { path: { customerId }, header: this.header },
|
|
338
|
+
body: input
|
|
339
|
+
});
|
|
340
|
+
if (error) {
|
|
341
|
+
throwRequestError(this.log, error, response, "POST /v1/customers/{customerId}/checkout");
|
|
342
|
+
}
|
|
343
|
+
if (response && !response.ok) {
|
|
344
|
+
throw new PriceOSError(response.statusText || "Request failed", { status: response.status });
|
|
345
|
+
}
|
|
346
|
+
const result = resolveUrlResponse(data, response);
|
|
347
|
+
if (result) {
|
|
348
|
+
return result;
|
|
349
|
+
}
|
|
350
|
+
throw new PriceOSError("Invalid checkout response", {
|
|
351
|
+
status: response?.status,
|
|
352
|
+
details: {
|
|
353
|
+
redirected: response?.redirected ?? false,
|
|
354
|
+
responseUrl: response?.url ?? null
|
|
355
|
+
}
|
|
356
|
+
});
|
|
275
357
|
}
|
|
276
358
|
};
|
|
277
359
|
const getFeatureAccessForCustomer = async (customerId) => {
|
|
@@ -309,7 +391,20 @@ var PriceOS = class {
|
|
|
309
391
|
body: input
|
|
310
392
|
});
|
|
311
393
|
if (error) throwRequestError(this.log, error, response, "POST /v1/checkout");
|
|
312
|
-
|
|
394
|
+
if (response && !response.ok) {
|
|
395
|
+
throw new PriceOSError(response.statusText || "Request failed", { status: response.status });
|
|
396
|
+
}
|
|
397
|
+
const result = resolveUrlResponse(data, response);
|
|
398
|
+
if (result) {
|
|
399
|
+
return result;
|
|
400
|
+
}
|
|
401
|
+
throw new PriceOSError("Invalid checkout response", {
|
|
402
|
+
status: response?.status,
|
|
403
|
+
details: {
|
|
404
|
+
redirected: response?.redirected ?? false,
|
|
405
|
+
responseUrl: response?.url ?? null
|
|
406
|
+
}
|
|
407
|
+
});
|
|
313
408
|
}
|
|
314
409
|
};
|
|
315
410
|
this.bonuses = {
|
|
@@ -371,24 +466,6 @@ var PriceOS = class {
|
|
|
371
466
|
if (error) throwRequestError(this.log, error, response, "GET /v1/usage/{id}");
|
|
372
467
|
return data;
|
|
373
468
|
},
|
|
374
|
-
getEventByIdempotencyKey: async (idempotencyKey) => {
|
|
375
|
-
const { data, error, response } = await this.client.GET("/v1/usage/idempotency-key/{idempotencyKey}", {
|
|
376
|
-
params: { header: this.header, path: { idempotencyKey } }
|
|
377
|
-
});
|
|
378
|
-
if (error) {
|
|
379
|
-
throwRequestError(this.log, error, response, "GET /v1/usage/idempotency-key/{idempotencyKey}");
|
|
380
|
-
}
|
|
381
|
-
return data;
|
|
382
|
-
},
|
|
383
|
-
getEventByKey: async (eventKey) => {
|
|
384
|
-
const { data, error, response } = await this.client.GET("/v1/usage/idempotency-key/{idempotencyKey}", {
|
|
385
|
-
params: { header: this.header, path: { idempotencyKey: eventKey } }
|
|
386
|
-
});
|
|
387
|
-
if (error) {
|
|
388
|
-
throwRequestError(this.log, error, response, "GET /v1/usage/idempotency-key/{idempotencyKey}");
|
|
389
|
-
}
|
|
390
|
-
return data;
|
|
391
|
-
},
|
|
392
469
|
updateEvent: async (input) => {
|
|
393
470
|
const { id, ...body } = input;
|
|
394
471
|
const { data, error, response } = await this.client.PUT("/v1/usage/{id}", {
|
|
@@ -398,15 +475,6 @@ var PriceOS = class {
|
|
|
398
475
|
if (error) throwRequestError(this.log, error, response, "PUT /v1/usage/{id}");
|
|
399
476
|
return data;
|
|
400
477
|
},
|
|
401
|
-
voidEvent: async (input) => {
|
|
402
|
-
const { id, ...body } = input;
|
|
403
|
-
const { data, error, response } = await this.client.POST("/v1/usage/{id}/void", {
|
|
404
|
-
params: { header: this.header, path: { id } },
|
|
405
|
-
body
|
|
406
|
-
});
|
|
407
|
-
if (error) throwRequestError(this.log, error, response, "POST /v1/usage/{id}/void");
|
|
408
|
-
return data;
|
|
409
|
-
},
|
|
410
478
|
deleteEvent: async (eventId) => {
|
|
411
479
|
const { data, error, response } = await this.client.DELETE("/v1/usage/{id}", {
|
|
412
480
|
params: { header: this.header, path: { id: eventId } }
|
|
@@ -450,4 +518,4 @@ export {
|
|
|
450
518
|
PriceOSError,
|
|
451
519
|
PriceOS
|
|
452
520
|
};
|
|
453
|
-
//# sourceMappingURL=chunk-
|
|
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,15 +1,20 @@
|
|
|
1
|
-
import { CreateBonusBody, CreateBonusResponse, CreateCustomerRequest, CreateCustomerResponse, CreateCustomerPortalResponse, DeleteBonusResponse, ListBonusesRequest, ListBonusesResponse, DeleteUsageEventsBody, DeleteUsageEventsResponse, DeleteUsageEventResponse, DeleteCustomerResponse, GetUsageEventResponse,
|
|
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
|
|
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>;
|
|
17
|
+
createCheckout(customerId: string, input: CreateCustomerCheckoutRequest): Promise<CreateCustomerCheckoutResponse>;
|
|
13
18
|
};
|
|
14
19
|
type FeatureAccessRecord<TFeatureAccessMap> = TFeatureAccessMap extends Record<string, unknown> ? TFeatureAccessMap : Record<string, never>;
|
|
15
20
|
type FeatureAccessKey<TFeatureAccessMap> = keyof FeatureAccessRecord<TFeatureAccessMap> & string;
|
|
@@ -33,10 +38,7 @@ export type PriceOSUsageClient<TFeatureAccessMap = GetFeatureAccessResponse> = {
|
|
|
33
38
|
track(input: TrackUsageBody<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>): Promise<TrackUsageResponse>;
|
|
34
39
|
set(input: SetUsageBody<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>): Promise<SetUsageResponse>;
|
|
35
40
|
getEvent(eventId: string): Promise<GetUsageEventResponse>;
|
|
36
|
-
getEventByIdempotencyKey(idempotencyKey: string): Promise<GetUsageEventByIdempotencyKeyResponse>;
|
|
37
|
-
getEventByKey(eventKey: string): Promise<GetUsageEventByKeyResponse>;
|
|
38
41
|
updateEvent(input: UpdateUsageEventRequest): Promise<UpdateUsageEventResponse>;
|
|
39
|
-
voidEvent(input: VoidUsageEventRequest): Promise<VoidUsageEventResponse>;
|
|
40
42
|
deleteEvent(eventId: string): Promise<DeleteUsageEventResponse>;
|
|
41
43
|
deleteEvents(input: DeleteUsageEventsBody<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>): Promise<DeleteUsageEventsResponse>;
|
|
42
44
|
trackBatch(input: TrackUsageBatchBody<LimitFeatureKeyFromAccessMap<TFeatureAccessMap>>): Promise<TrackUsageBatchResponse>;
|