@edgebound/bigcommerce 0.0.1

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.
Files changed (45) hide show
  1. package/dist/bigcommerce.fetcher-D1TyK4y4.d.mts +90 -0
  2. package/dist/bigcommerce.fetcher-D1TyK4y4.d.ts +90 -0
  3. package/dist/chunk-7GBRYAQG.mjs +272 -0
  4. package/dist/chunk-7GBRYAQG.mjs.map +1 -0
  5. package/dist/chunk-CERZFSUE.mjs +20 -0
  6. package/dist/chunk-CERZFSUE.mjs.map +1 -0
  7. package/dist/companies.d.mts +2 -0
  8. package/dist/companies.d.ts +2 -0
  9. package/dist/companies.js +2 -0
  10. package/dist/companies.js.map +1 -0
  11. package/dist/companies.mjs +1 -0
  12. package/dist/companies.mjs.map +1 -0
  13. package/dist/currencies.d.mts +2 -0
  14. package/dist/currencies.d.ts +2 -0
  15. package/dist/currencies.js +2 -0
  16. package/dist/currencies.js.map +1 -0
  17. package/dist/currencies.mjs +1 -0
  18. package/dist/currencies.mjs.map +1 -0
  19. package/dist/customers.d.mts +65 -0
  20. package/dist/customers.d.ts +65 -0
  21. package/dist/customers.js +399 -0
  22. package/dist/customers.js.map +1 -0
  23. package/dist/customers.mjs +107 -0
  24. package/dist/customers.mjs.map +1 -0
  25. package/dist/index.d.mts +29 -0
  26. package/dist/index.d.ts +29 -0
  27. package/dist/index.js +304 -0
  28. package/dist/index.js.map +1 -0
  29. package/dist/index.mjs +37 -0
  30. package/dist/index.mjs.map +1 -0
  31. package/dist/orders.d.mts +416 -0
  32. package/dist/orders.d.ts +416 -0
  33. package/dist/orders.js +608 -0
  34. package/dist/orders.js.map +1 -0
  35. package/dist/orders.mjs +314 -0
  36. package/dist/orders.mjs.map +1 -0
  37. package/dist/products.d.mts +32 -0
  38. package/dist/products.d.ts +32 -0
  39. package/dist/products.js +409 -0
  40. package/dist/products.js.map +1 -0
  41. package/dist/products.mjs +119 -0
  42. package/dist/products.mjs.map +1 -0
  43. package/dist/validation.error-CHLpPYC_.d.mts +14 -0
  44. package/dist/validation.error-CHLpPYC_.d.ts +14 -0
  45. package/package.json +63 -0
@@ -0,0 +1,409 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+
30
+ // src/bigcommerce-entities/products/index.ts
31
+ var products_exports = {};
32
+ __export(products_exports, {
33
+ setProductVisibility: () => setProductVisibility,
34
+ setProductsInventory: () => setProductsInventory
35
+ });
36
+ module.exports = __toCommonJS(products_exports);
37
+
38
+ // src/bigcommerce-entities/products/set-inventory.ts
39
+ var import_effect8 = require("effect");
40
+
41
+ // src/constants.ts
42
+ var import_effect = require("effect");
43
+ var DEFAULT_TIMEOUT_MS = 3e4;
44
+ var API_BASE_URLS = {
45
+ B2B: "https://api-b2b.bigcommerce.com/api",
46
+ REGULAR: "https://api.bigcommerce.com/stores"
47
+ };
48
+ var UPDATE_INVENTORY_BATCH_SIZE = 2e3;
49
+ var UPDATE_INVENTORY_CONCURRENCY = 2;
50
+ var DEFAULT_RETRY_TIMES = 2;
51
+ var DEFAULT_RETRY_WAIT = 200;
52
+ var DEFAULT_RETRY_SCHEDULE = import_effect.Schedule.exponential(import_effect.Duration.millis(DEFAULT_RETRY_WAIT));
53
+ var RETRY_POLICY_WITH_BACKOFF = import_effect.Schedule.exponential(
54
+ import_effect.Duration.millis(DEFAULT_RETRY_WAIT),
55
+ 2
56
+ ).pipe(import_effect.Schedule.intersect(import_effect.Schedule.recurs(DEFAULT_RETRY_TIMES)));
57
+
58
+ // src/core/bigcommerce.error.ts
59
+ var import_effect2 = require("effect");
60
+ var BigCommerceUnprocessableEntityError = class extends import_effect2.Data.TaggedError(
61
+ "BigCommerceUnprocessableEntityError"
62
+ ) {
63
+ };
64
+ var BigCommerceUnauthorizedError = class extends import_effect2.Data.TaggedError(
65
+ "BigCommerceUnauthorizedError"
66
+ ) {
67
+ };
68
+ var BigCommerceForbiddenError = class extends import_effect2.Data.TaggedError("BigCommerceForbiddenError") {
69
+ };
70
+ var BigCommerceNotFoundError = class extends import_effect2.Data.TaggedError("BigCommerceNotFoundError") {
71
+ };
72
+ var BigCommerceConflictError = class extends import_effect2.Data.TaggedError("BigCommerceConflictError") {
73
+ };
74
+ var BigCommerceConnectionError = class extends import_effect2.Data.TaggedError("BigCommerceConnectionError") {
75
+ };
76
+ var BigCommerceUnknownError = class extends import_effect2.Data.TaggedError("BigCommerceUnknownError") {
77
+ };
78
+ var BigCommerceInvalidResponseError = class extends import_effect2.Data.TaggedError(
79
+ "BigCommerceInvalidResponseError"
80
+ ) {
81
+ };
82
+ var BigCommerceInvalidRequestError = class extends import_effect2.Data.TaggedError(
83
+ "BigCommerceInvalidRequestError"
84
+ ) {
85
+ };
86
+ var BigCommerceParseResponseError = class extends import_effect2.Data.TaggedError(
87
+ "BigCommerceParseResponseError"
88
+ ) {
89
+ };
90
+
91
+ // src/core/bigcommerce.fetcher.ts
92
+ var import_effect3 = require("effect");
93
+ var BigCommerceFetcher = class extends import_effect3.Context.Tag("BigCommerceFetcher")() {
94
+ };
95
+
96
+ // src/core/bigcommerce.fetcher.live.ts
97
+ var import_effect5 = require("effect");
98
+
99
+ // src/core/config.ts
100
+ var import_effect4 = require("effect");
101
+ var NoBigCommerceConfigError = class extends import_effect4.Data.TaggedError("NoBigCommerceConfigError") {
102
+ };
103
+ var BigCommerceConfig = class extends import_effect4.Context.Tag("BigCommerceConfig")() {
104
+ };
105
+ var getBigCommerceConfig = (key) => {
106
+ return import_effect4.Config.nested(import_effect4.Config.string(key), "BIGCOMMERCE").pipe(
107
+ import_effect4.Effect.mapError(() => new NoBigCommerceConfigError({ key }))
108
+ );
109
+ };
110
+ var getBigCommerceTimeout = () => {
111
+ return import_effect4.Config.nested(import_effect4.Config.number("TIMEOUT"), "BIGCOMMERCE").pipe(
112
+ import_effect4.Effect.mapError(() => new NoBigCommerceConfigError({ key: "TIMEOUT" })),
113
+ // Default to 30 seconds if not configured
114
+ import_effect4.Effect.orElse(() => import_effect4.Effect.succeed(DEFAULT_TIMEOUT_MS))
115
+ );
116
+ };
117
+ var BigCommerceConfigLive = import_effect4.Layer.effect(
118
+ BigCommerceConfig,
119
+ import_effect4.Effect.gen(function* () {
120
+ const [storeHash, clientId, clientSecret, accessToken, timeout] = yield* import_effect4.Effect.all([
121
+ getBigCommerceConfig("STORE_HASH"),
122
+ getBigCommerceConfig("CLIENT_ID"),
123
+ getBigCommerceConfig("CLIENT_SECRET"),
124
+ getBigCommerceConfig("ACCESS_TOKEN"),
125
+ getBigCommerceTimeout()
126
+ ]);
127
+ return {
128
+ getStoreHash: import_effect4.Effect.succeed(storeHash),
129
+ getClientId: import_effect4.Effect.succeed(clientId),
130
+ getClientSecret: import_effect4.Effect.succeed(clientSecret),
131
+ getAccessToken: import_effect4.Effect.succeed(accessToken),
132
+ getTimeout: import_effect4.Effect.succeed(timeout)
133
+ };
134
+ })
135
+ );
136
+ var BigCommerceConfigTest = import_effect4.Layer.succeed(BigCommerceConfig, {
137
+ getAccessToken: import_effect4.Effect.succeed("test"),
138
+ getClientId: import_effect4.Effect.succeed("test"),
139
+ getClientSecret: import_effect4.Effect.succeed("test"),
140
+ getStoreHash: import_effect4.Effect.succeed("test"),
141
+ getTimeout: import_effect4.Effect.succeed(DEFAULT_TIMEOUT_MS)
142
+ });
143
+
144
+ // src/core/bigcommerce.fetcher.live.ts
145
+ var BigCommerceStatusCodes = {
146
+ UNAUTHORIZED: 401,
147
+ CONFLICT: 409,
148
+ FORBIDDEN: 403,
149
+ NOT_FOUND: 404,
150
+ UNPROCESSABLE_ENTITY: 422,
151
+ INTERNAL_SERVER_ERROR: 500,
152
+ BAD_GATEWAY: 502,
153
+ SERVICE_UNAVAILABLE: 503,
154
+ GATEWAY_TIMEOUT: 504,
155
+ INVALID_REQUEST: 400
156
+ };
157
+ var BigCommerceFetcherLive = import_effect5.Layer.effect(
158
+ BigCommerceFetcher,
159
+ import_effect5.Effect.gen(function* () {
160
+ const config = yield* BigCommerceConfig;
161
+ const storeHash = yield* config.getStoreHash;
162
+ const accessToken = yield* config.getAccessToken;
163
+ const timeout = yield* config.getTimeout;
164
+ return {
165
+ fetch: (params) => {
166
+ const base = getBase(params);
167
+ const headers = {
168
+ Accept: "application/json",
169
+ "Content-Type": "application/json",
170
+ "x-auth-token": accessToken
171
+ };
172
+ if (params.isB2B) {
173
+ headers["x-store-hash"] = storeHash;
174
+ }
175
+ const url = applyParams(base.replace("[storeHash]", storeHash), params.query);
176
+ return import_effect5.Effect.tryPromise({
177
+ try: () => fetch(url, {
178
+ headers,
179
+ signal: AbortSignal.timeout(timeout),
180
+ method: params.method,
181
+ ...params.body && { body: JSON.stringify(params.body) }
182
+ }),
183
+ catch: (error) => {
184
+ if (error instanceof Error && error.name === "TimeoutError") {
185
+ return new BigCommerceConnectionError({
186
+ message: `Request timeout after ${timeout}ms`,
187
+ type: "timeout"
188
+ });
189
+ }
190
+ if (error instanceof Error && error.name === "AbortError") {
191
+ return new BigCommerceConnectionError({
192
+ message: `Request timeout after ${timeout}ms`,
193
+ type: "timeout"
194
+ });
195
+ }
196
+ return new BigCommerceUnknownError({ cause: error });
197
+ }
198
+ }).pipe(
199
+ import_effect5.Effect.tapError(
200
+ (error) => import_effect5.Effect.logError("Failed to fetch from BigCommerce API", error.cause)
201
+ ),
202
+ import_effect5.Effect.flatMap((response) => transformResponse(response, params.resultSchema))
203
+ );
204
+ }
205
+ };
206
+ })
207
+ );
208
+ var applyParams = (url, params) => {
209
+ const base = new URL(url);
210
+ if (!params) {
211
+ return base;
212
+ }
213
+ for (const [key, value] of Object.entries(params)) {
214
+ base.searchParams.append(key, `${value}`);
215
+ }
216
+ return base;
217
+ };
218
+ var getBase = ({
219
+ isB2B,
220
+ path,
221
+ version
222
+ }) => {
223
+ if (isB2B) {
224
+ return `${API_BASE_URLS.B2B}/${version}/io/${path}`;
225
+ }
226
+ return `${API_BASE_URLS.REGULAR}/[storeHash]/${version}/${path}`;
227
+ };
228
+ function processSuccessResponse(response, schema) {
229
+ return import_effect5.Effect.tryPromise({
230
+ try: () => response.json(),
231
+ catch: (error) => new BigCommerceInvalidResponseError({ cause: error })
232
+ }).pipe(
233
+ import_effect5.Effect.tapError(
234
+ (error) => import_effect5.Effect.logError("Error parsing response from BigCommerce API", error.cause)
235
+ ),
236
+ import_effect5.Effect.tryMap({
237
+ try: (json) => schema.parse(json),
238
+ catch: (error) => new BigCommerceParseResponseError({ error })
239
+ })
240
+ );
241
+ }
242
+ var processErrorResponse = (response) => {
243
+ const code = response.status;
244
+ return import_effect5.Effect.tryPromise({
245
+ try: () => response.json(),
246
+ catch: (error) => new BigCommerceInvalidResponseError({ cause: error })
247
+ }).pipe(
248
+ import_effect5.Effect.tapError((error) => import_effect5.Effect.logError("Error parsing error response", error.cause)),
249
+ import_effect5.Effect.flatMap(
250
+ (errorDetails) => import_effect5.Effect.fail(
251
+ import_effect5.Match.value(code).pipe(
252
+ import_effect5.Match.when(
253
+ BigCommerceStatusCodes.INVALID_REQUEST,
254
+ () => new BigCommerceInvalidRequestError({ errorDetails })
255
+ ),
256
+ import_effect5.Match.when(BigCommerceStatusCodes.UNAUTHORIZED, () => new BigCommerceUnauthorizedError()),
257
+ import_effect5.Match.when(BigCommerceStatusCodes.FORBIDDEN, () => new BigCommerceForbiddenError()),
258
+ import_effect5.Match.when(BigCommerceStatusCodes.NOT_FOUND, () => new BigCommerceNotFoundError()),
259
+ import_effect5.Match.when(
260
+ BigCommerceStatusCodes.CONFLICT,
261
+ () => new BigCommerceConflictError({ details: errorDetails })
262
+ ),
263
+ import_effect5.Match.when(
264
+ BigCommerceStatusCodes.UNPROCESSABLE_ENTITY,
265
+ () => new BigCommerceUnprocessableEntityError({ errorDetails })
266
+ ),
267
+ import_effect5.Match.when(
268
+ (code2) => code2 >= 500,
269
+ () => new BigCommerceConnectionError({
270
+ message: `Server error: ${code}`,
271
+ type: code === BigCommerceStatusCodes.INTERNAL_SERVER_ERROR ? "internalError" : code === BigCommerceStatusCodes.BAD_GATEWAY || code === BigCommerceStatusCodes.GATEWAY_TIMEOUT ? "timeout" : "internalError"
272
+ })
273
+ ),
274
+ import_effect5.Match.orElse(() => new BigCommerceUnknownError({ cause: errorDetails }))
275
+ )
276
+ )
277
+ )
278
+ );
279
+ };
280
+ var transformResponse = (response, schema) => {
281
+ if (response.ok) {
282
+ return processSuccessResponse(response, schema);
283
+ }
284
+ return processErrorResponse(response);
285
+ };
286
+
287
+ // src/validation/index.ts
288
+ var import_effect7 = require("effect");
289
+
290
+ // src/validation/validation.error.ts
291
+ var import_effect6 = require("effect");
292
+ var InputValidationError = class extends import_effect6.Data.TaggedError("InputValidationError") {
293
+ };
294
+
295
+ // src/validation/index.ts
296
+ var validateInput = (schema, data) => {
297
+ return import_effect7.Effect.try({
298
+ try: () => schema.parse(data),
299
+ catch: (error) => new InputValidationError({ input: data, error })
300
+ });
301
+ };
302
+
303
+ // src/bigcommerce-entities/products/schemas/set-inventory.schema.ts
304
+ var z = __toESM(require("zod"));
305
+ var SetProductInventoryItemSchema = z.union([
306
+ z.object({
307
+ location_id: z.int(),
308
+ product_id: z.int(),
309
+ quantity: z.int().min(0)
310
+ }),
311
+ z.object({
312
+ location_id: z.int(),
313
+ sku: z.string(),
314
+ quantity: z.int().min(0)
315
+ })
316
+ ]);
317
+ var SetProductInventorySchema = z.object({
318
+ reason: z.string(),
319
+ items: z.array(SetProductInventoryItemSchema)
320
+ });
321
+ var SetInventoryResponseSchema = z.object({
322
+ transaction_id: z.string()
323
+ });
324
+
325
+ // src/bigcommerce-entities/products/set-inventory.ts
326
+ var setProductsInventory = (reason, items) => {
327
+ return import_effect8.Stream.fromIterable(items).pipe(
328
+ import_effect8.Stream.grouped(UPDATE_INVENTORY_BATCH_SIZE),
329
+ import_effect8.Stream.mapEffect((chunk) => updateProductInventory(reason, chunk), {
330
+ concurrency: UPDATE_INVENTORY_CONCURRENCY
331
+ }),
332
+ import_effect8.Stream.runCollect,
333
+ import_effect8.Effect.map(import_effect8.Chunk.toArray)
334
+ );
335
+ };
336
+ var updateProductInventory = (reason, items) => {
337
+ return import_effect8.Effect.gen(function* () {
338
+ const validatedBody = yield* validateInput(SetProductInventorySchema, {
339
+ reason,
340
+ items: import_effect8.Chunk.toArray(items)
341
+ });
342
+ const fetcher = yield* BigCommerceFetcher;
343
+ return yield* import_effect8.Effect.retry(
344
+ fetcher.fetch({
345
+ isB2B: false,
346
+ method: "PUT",
347
+ path: "inventory/adjustments/absolute",
348
+ version: "v3",
349
+ body: validatedBody,
350
+ resultSchema: SetInventoryResponseSchema
351
+ }),
352
+ RETRY_POLICY_WITH_BACKOFF
353
+ );
354
+ });
355
+ };
356
+
357
+ // src/bigcommerce-entities/products/update-products.ts
358
+ var import_effect9 = require("effect");
359
+ var z3 = __toESM(require("zod"));
360
+
361
+ // src/bigcommerce-entities/products/schemas/update-products.schema.ts
362
+ var z2 = __toESM(require("zod"));
363
+ var UpdateProductVisibilitySchema = z2.object({
364
+ id: z2.number(),
365
+ is_visible: z2.boolean()
366
+ });
367
+ var UpdateProductSchema = z2.union([UpdateProductVisibilitySchema]);
368
+ var UpdateProductResponseSchema = z2.any();
369
+
370
+ // src/bigcommerce-entities/products/update-products.ts
371
+ var UpdateProductArraySchema = z3.array(UpdateProductSchema);
372
+ var updateProducts = (dtos) => {
373
+ return import_effect9.Stream.fromIterable(dtos).pipe(
374
+ import_effect9.Stream.grouped(UPDATE_INVENTORY_BATCH_SIZE),
375
+ import_effect9.Stream.mapEffect((chunk) => updateProductBatch(chunk), {
376
+ concurrency: UPDATE_INVENTORY_CONCURRENCY
377
+ }),
378
+ import_effect9.Stream.runCollect,
379
+ import_effect9.Effect.map(import_effect9.Chunk.toArray)
380
+ );
381
+ };
382
+ var updateProductBatch = (items) => {
383
+ return import_effect9.Effect.gen(function* () {
384
+ const validatedBody = yield* validateInput(UpdateProductArraySchema, import_effect9.Chunk.toArray(items));
385
+ const fetcher = yield* BigCommerceFetcher;
386
+ return yield* import_effect9.Effect.retry(
387
+ fetcher.fetch({
388
+ isB2B: false,
389
+ method: "PUT",
390
+ path: "inventory/adjustments/absolute",
391
+ version: "v3",
392
+ body: validatedBody,
393
+ resultSchema: UpdateProductResponseSchema
394
+ }),
395
+ RETRY_POLICY_WITH_BACKOFF
396
+ );
397
+ });
398
+ };
399
+
400
+ // src/bigcommerce-entities/products/set-visibility.ts
401
+ var setProductVisibility = (dtos) => {
402
+ return updateProducts(dtos);
403
+ };
404
+ // Annotate the CommonJS export names for ESM import in node:
405
+ 0 && (module.exports = {
406
+ setProductVisibility,
407
+ setProductsInventory
408
+ });
409
+ //# sourceMappingURL=products.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/bigcommerce-entities/products/index.ts","../src/bigcommerce-entities/products/set-inventory.ts","../src/constants.ts","../src/core/bigcommerce.error.ts","../src/core/bigcommerce.fetcher.ts","../src/core/bigcommerce.fetcher.live.ts","../src/core/config.ts","../src/validation/index.ts","../src/validation/validation.error.ts","../src/bigcommerce-entities/products/schemas/set-inventory.schema.ts","../src/bigcommerce-entities/products/update-products.ts","../src/bigcommerce-entities/products/schemas/update-products.schema.ts","../src/bigcommerce-entities/products/set-visibility.ts"],"sourcesContent":["export * from './schemas';\nexport * from './set-inventory';\nexport * from './set-visibility';\n","import { Chunk, Effect, Stream } from 'effect';\nimport {\n RETRY_POLICY_WITH_BACKOFF,\n UPDATE_INVENTORY_BATCH_SIZE,\n UPDATE_INVENTORY_CONCURRENCY,\n} from '../../constants';\nimport { BigCommerceFetcher } from '../../core';\nimport { validateInput } from '../../validation';\nimport {\n SetInventoryResponseSchema,\n SetProductInventorySchema,\n type SetProductInventoryItemInput,\n} from './schemas/set-inventory.schema';\n\nexport const setProductsInventory = (reason: string, items: SetProductInventoryItemInput[]) => {\n return Stream.fromIterable(items).pipe(\n Stream.grouped(UPDATE_INVENTORY_BATCH_SIZE),\n Stream.mapEffect((chunk) => updateProductInventory(reason, chunk), {\n concurrency: UPDATE_INVENTORY_CONCURRENCY,\n }),\n Stream.runCollect,\n Effect.map(Chunk.toArray),\n );\n};\n\nconst updateProductInventory = (\n reason: string,\n items: Chunk.Chunk<SetProductInventoryItemInput>,\n) => {\n return Effect.gen(function* () {\n const validatedBody = yield* validateInput(SetProductInventorySchema, {\n reason,\n items: Chunk.toArray(items),\n });\n const fetcher = yield* BigCommerceFetcher;\n return yield* Effect.retry(\n fetcher.fetch({\n isB2B: false,\n method: 'PUT',\n path: 'inventory/adjustments/absolute',\n version: 'v3',\n body: validatedBody,\n resultSchema: SetInventoryResponseSchema,\n }),\n RETRY_POLICY_WITH_BACKOFF,\n );\n });\n};\n","import { Duration, Schedule } from 'effect';\n\nexport const DEFAULT_TIMEOUT_MS = 30000;\nexport const API_BASE_URLS = {\n B2B: 'https://api-b2b.bigcommerce.com/api',\n REGULAR: 'https://api.bigcommerce.com/stores',\n} as const;\nexport const GET_ORDER_BATCH_SIZE = 250;\nexport const UPDATE_PRODUCT_BATCH_SIZE = 5;\nexport const UPDATE_INVENTORY_BATCH_SIZE = 2000;\nexport const UPDATE_INVENTORY_CONCURRENCY = 2;\nexport const DEFAULT_RETRY_TIMES = 2;\nexport const DEFAULT_RETRY_WAIT = 200;\nexport const DEFAULT_RETRY_SCHEDULE = Schedule.exponential(Duration.millis(DEFAULT_RETRY_WAIT));\nexport const RETRY_POLICY_WITH_BACKOFF = Schedule.exponential(\n Duration.millis(DEFAULT_RETRY_WAIT),\n 2,\n).pipe(Schedule.intersect(Schedule.recurs(DEFAULT_RETRY_TIMES)));\nexport const GET_CUSTOMERS_BATCH_SIZE = 100;\n","import { Data } from 'effect';\nimport * as z from 'zod';\nexport class BigCommerceUnprocessableEntityError extends Data.TaggedError(\n 'BigCommerceUnprocessableEntityError',\n)<{\n readonly errorDetails: unknown;\n}> {}\n\nexport class BigCommerceUnauthorizedError extends Data.TaggedError(\n 'BigCommerceUnauthorizedError',\n) {}\n\nexport class BigCommerceForbiddenError extends Data.TaggedError('BigCommerceForbiddenError') {}\n\nexport class BigCommerceNotFoundError extends Data.TaggedError('BigCommerceNotFoundError') {}\n\nexport class BigCommerceConflictError extends Data.TaggedError('BigCommerceConflictError')<{\n readonly details: unknown;\n}> {}\n\nexport class BigCommerceConnectionError extends Data.TaggedError('BigCommerceConnectionError')<{\n readonly message: string;\n readonly type: 'timeout' | 'internalError' | 'unknown';\n}> {}\n\nexport class BigCommerceUnknownError extends Data.TaggedError('BigCommerceUnknownError')<{\n cause: unknown;\n}> {}\n\nexport class BigCommerceInvalidResponseError extends Data.TaggedError(\n 'BigCommerceInvalidResponseError',\n)<{\n cause: unknown;\n}> {}\n\nexport class BigCommerceInvalidRequestError extends Data.TaggedError(\n 'BigCommerceInvalidRequestError',\n)<{\n readonly errorDetails: unknown;\n}> {}\n\nexport class BigCommerceParseResponseError extends Data.TaggedError(\n 'BigCommerceParseResponseError',\n)<{\n readonly error: z.ZodError;\n}> {}\n\nexport type SomeBigCommerceError =\n | BigCommerceUnprocessableEntityError\n | BigCommerceUnauthorizedError\n | BigCommerceForbiddenError\n | BigCommerceNotFoundError\n | BigCommerceConflictError\n | BigCommerceConnectionError\n | BigCommerceUnknownError\n | BigCommerceInvalidResponseError\n | BigCommerceInvalidRequestError\n | BigCommerceParseResponseError;\n","import { Context, Effect } from 'effect';\nimport * as z from 'zod';\nimport { type SomeBigCommerceError } from './bigcommerce.error';\nexport type BigCommerceFetchMethods = 'GET' | 'POST' | 'PUT' | 'DELETE';\nexport interface BigCommerceFetchParams<\n // Always send json for now, maybe later send a Blob\n Body extends Record<string, unknown> | Array<Record<string, unknown>>,\n Query extends Record<string, string>,\n Result extends z.ZodType,\n> {\n readonly body?: Body;\n readonly query?: Query;\n readonly method: BigCommerceFetchMethods;\n readonly path: string;\n readonly headers?: Record<string, string>;\n readonly isB2B: boolean;\n readonly version: 'v3' | 'v2';\n readonly resultSchema: Result;\n}\n\nexport class BigCommerceFetcher extends Context.Tag('BigCommerceFetcher')<\n BigCommerceFetcher,\n {\n readonly fetch: <\n Body extends Record<string, unknown> | Array<Record<string, unknown>>,\n Query extends Record<string, string>,\n Result extends z.ZodType,\n >(\n params: BigCommerceFetchParams<Body, Query, Result>,\n ) => Effect.Effect<z.output<Result>, SomeBigCommerceError>;\n }\n>() {}\n","import { Effect, Layer, Match } from 'effect';\nimport * as z from 'zod';\nimport { API_BASE_URLS } from '../constants';\nimport {\n BigCommerceConflictError,\n BigCommerceConnectionError,\n BigCommerceForbiddenError,\n BigCommerceInvalidRequestError,\n BigCommerceInvalidResponseError,\n BigCommerceNotFoundError,\n BigCommerceParseResponseError,\n BigCommerceUnauthorizedError,\n BigCommerceUnknownError,\n BigCommerceUnprocessableEntityError,\n type SomeBigCommerceError,\n} from './bigcommerce.error';\nimport { BigCommerceFetcher } from './bigcommerce.fetcher';\nimport { BigCommerceConfig } from './config';\n\nconst BigCommerceStatusCodes = {\n UNAUTHORIZED: 401,\n CONFLICT: 409,\n FORBIDDEN: 403,\n NOT_FOUND: 404,\n UNPROCESSABLE_ENTITY: 422,\n INTERNAL_SERVER_ERROR: 500,\n BAD_GATEWAY: 502,\n SERVICE_UNAVAILABLE: 503,\n GATEWAY_TIMEOUT: 504,\n INVALID_REQUEST: 400,\n} as const;\n\nexport const BigCommerceFetcherLive = Layer.effect(\n BigCommerceFetcher,\n Effect.gen(function* () {\n const config = yield* BigCommerceConfig;\n const storeHash = yield* config.getStoreHash;\n const accessToken = yield* config.getAccessToken;\n const timeout = yield* config.getTimeout;\n return {\n fetch: (params) => {\n const base = getBase(params);\n const headers: Record<string, string> = {\n Accept: 'application/json',\n 'Content-Type': 'application/json',\n 'x-auth-token': accessToken,\n };\n\n if (params.isB2B) {\n headers['x-store-hash'] = storeHash;\n }\n const url = applyParams(base.replace('[storeHash]', storeHash), params.query);\n\n return Effect.tryPromise({\n try: () =>\n fetch(url, {\n headers,\n signal: AbortSignal.timeout(timeout),\n method: params.method,\n ...(params.body && { body: JSON.stringify(params.body) }),\n }),\n catch: (error) => {\n if (error instanceof Error && error.name === 'TimeoutError') {\n return new BigCommerceConnectionError({\n message: `Request timeout after ${timeout}ms`,\n type: 'timeout',\n });\n }\n if (error instanceof Error && error.name === 'AbortError') {\n return new BigCommerceConnectionError({\n message: `Request timeout after ${timeout}ms`,\n type: 'timeout',\n });\n }\n return new BigCommerceUnknownError({ cause: error });\n },\n }).pipe(\n Effect.tapError((error) =>\n Effect.logError('Failed to fetch from BigCommerce API', error.cause),\n ),\n Effect.flatMap((response) => transformResponse(response, params.resultSchema)),\n );\n },\n };\n }),\n);\nconst applyParams = (url: string, params?: Record<string, string | number>): URL => {\n const base = new URL(url);\n if (!params) {\n return base;\n }\n for (const [key, value] of Object.entries(params)) {\n base.searchParams.append(key, `${value}`);\n }\n return base;\n};\n\nconst getBase = ({\n isB2B,\n path,\n version,\n}: {\n isB2B: boolean;\n path: string;\n version: 'v3' | 'v2';\n}): string => {\n if (isB2B) {\n return `${API_BASE_URLS.B2B}/${version}/io/${path}`;\n }\n return `${API_BASE_URLS.REGULAR}/[storeHash]/${version}/${path}`;\n};\nfunction processSuccessResponse<Schema extends z.ZodTypeAny>(response: Response, schema: Schema) {\n return Effect.tryPromise({\n try: () => response.json(),\n catch: (error) => new BigCommerceInvalidResponseError({ cause: error }),\n }).pipe(\n Effect.tapError((error) =>\n Effect.logError('Error parsing response from BigCommerce API', error.cause),\n ),\n Effect.tryMap({\n try: (json) => schema.parse(json),\n catch: (error) => new BigCommerceParseResponseError({ error: error as z.ZodError }),\n }),\n );\n}\nconst processErrorResponse = (response: Response) => {\n const code = response.status;\n return Effect.tryPromise({\n try: () => response.json(),\n catch: (error) => new BigCommerceInvalidResponseError({ cause: error }),\n }).pipe(\n Effect.tapError((error) => Effect.logError('Error parsing error response', error.cause)),\n Effect.flatMap((errorDetails) =>\n Effect.fail(\n Match.value(code).pipe(\n Match.when(\n BigCommerceStatusCodes.INVALID_REQUEST,\n () => new BigCommerceInvalidRequestError({ errorDetails }),\n ),\n Match.when(BigCommerceStatusCodes.UNAUTHORIZED, () => new BigCommerceUnauthorizedError()),\n Match.when(BigCommerceStatusCodes.FORBIDDEN, () => new BigCommerceForbiddenError()),\n Match.when(BigCommerceStatusCodes.NOT_FOUND, () => new BigCommerceNotFoundError()),\n Match.when(\n BigCommerceStatusCodes.CONFLICT,\n () => new BigCommerceConflictError({ details: errorDetails }),\n ),\n Match.when(\n BigCommerceStatusCodes.UNPROCESSABLE_ENTITY,\n () => new BigCommerceUnprocessableEntityError({ errorDetails }),\n ),\n Match.when(\n (code) => code >= 500,\n () =>\n new BigCommerceConnectionError({\n message: `Server error: ${code}`,\n type:\n code === BigCommerceStatusCodes.INTERNAL_SERVER_ERROR\n ? 'internalError'\n : code === BigCommerceStatusCodes.BAD_GATEWAY ||\n code === BigCommerceStatusCodes.GATEWAY_TIMEOUT\n ? 'timeout'\n : 'internalError',\n }),\n ),\n Match.orElse(() => new BigCommerceUnknownError({ cause: errorDetails })),\n ),\n ),\n ),\n );\n};\n\nconst transformResponse = <Schema extends z.ZodTypeAny>(\n response: Response,\n schema: Schema,\n): Effect.Effect<z.output<Schema>, SomeBigCommerceError> => {\n if (response.ok) {\n return processSuccessResponse(response, schema);\n }\n return processErrorResponse(response);\n};\n\n// type PendingErrors = Exclude<\n// SomeBigCommerceError,\n// Effect.Effect.Error<ReturnType<typeof processErrorResponse>> | BigCommerceParseResponseError\n// >;\n","import { Config, Context, Data, Effect, Layer } from 'effect';\nimport { DEFAULT_TIMEOUT_MS } from '../constants';\n\n// Define a custom error type using Data.TaggedError\nexport class NoBigCommerceConfigError extends Data.TaggedError('NoBigCommerceConfigError')<{\n readonly key: string;\n}> {}\n\nexport class BigCommerceConfig extends Context.Tag('BigCommerceConfig')<\n BigCommerceConfig,\n {\n readonly getStoreHash: Effect.Effect<string, NoBigCommerceConfigError, string>;\n readonly getClientId: Effect.Effect<string, NoBigCommerceConfigError, string>;\n readonly getClientSecret: Effect.Effect<string, NoBigCommerceConfigError, string>;\n readonly getAccessToken: Effect.Effect<string, NoBigCommerceConfigError, string>;\n readonly getTimeout: Effect.Effect<number, NoBigCommerceConfigError, string>;\n }\n>() {}\n\nconst getBigCommerceConfig = (key: string) => {\n return Config.nested(Config.string(key), 'BIGCOMMERCE').pipe(\n Effect.mapError(() => new NoBigCommerceConfigError({ key })),\n );\n};\n\nconst getBigCommerceTimeout = () => {\n return Config.nested(Config.number('TIMEOUT'), 'BIGCOMMERCE').pipe(\n Effect.mapError(() => new NoBigCommerceConfigError({ key: 'TIMEOUT' })),\n // Default to 30 seconds if not configured\n Effect.orElse(() => Effect.succeed(DEFAULT_TIMEOUT_MS)),\n );\n};\n\nexport const BigCommerceConfigLive = Layer.effect(\n BigCommerceConfig,\n Effect.gen(function* () {\n const [storeHash, clientId, clientSecret, accessToken, timeout] = yield* Effect.all([\n getBigCommerceConfig('STORE_HASH'),\n getBigCommerceConfig('CLIENT_ID'),\n getBigCommerceConfig('CLIENT_SECRET'),\n getBigCommerceConfig('ACCESS_TOKEN'),\n getBigCommerceTimeout(),\n ]);\n\n return {\n getStoreHash: Effect.succeed(storeHash),\n getClientId: Effect.succeed(clientId),\n getClientSecret: Effect.succeed(clientSecret),\n getAccessToken: Effect.succeed(accessToken),\n getTimeout: Effect.succeed(timeout),\n };\n }),\n);\n\nexport const BigCommerceConfigTest = Layer.succeed(BigCommerceConfig, {\n getAccessToken: Effect.succeed('test'),\n getClientId: Effect.succeed('test'),\n getClientSecret: Effect.succeed('test'),\n getStoreHash: Effect.succeed('test'),\n getTimeout: Effect.succeed(DEFAULT_TIMEOUT_MS),\n});\n","import { Effect } from 'effect';\nimport * as z from 'zod';\nimport { InputValidationError } from './validation.error';\nexport const validateInput = <Schema extends z.ZodType>(schema: Schema, data: z.input<Schema>) => {\n return Effect.try({\n try: () => schema.parse(data),\n catch: (error) => new InputValidationError({ input: data, error: error as z.ZodError }),\n });\n};\n","import { Data } from 'effect';\nimport * as z from 'zod';\nexport class InputValidationError extends Data.TaggedError('InputValidationError')<{\n input: unknown;\n error: z.ZodError;\n}> {}\n","import * as z from 'zod';\nexport const SetProductInventoryItemSchema = z.union([\n z.object({\n location_id: z.int(),\n product_id: z.int(),\n quantity: z.int().min(0),\n }),\n z.object({\n location_id: z.int(),\n sku: z.string(),\n quantity: z.int().min(0),\n }),\n]);\nexport const SetProductInventorySchema = z.object({\n reason: z.string(),\n items: z.array(SetProductInventoryItemSchema),\n});\nexport const SetInventoryResponseSchema = z.object({\n transaction_id: z.string(),\n});\nexport type SetProductInventoryInput = z.input<typeof SetProductInventorySchema>;\nexport type SetProductInventoryItemInput = z.input<typeof SetProductInventoryItemSchema>;\nexport type SetInventoryResponse = z.output<typeof SetInventoryResponseSchema>;\n","import { Chunk, Effect, Stream } from 'effect';\nimport * as z from 'zod';\nimport {\n RETRY_POLICY_WITH_BACKOFF,\n UPDATE_INVENTORY_BATCH_SIZE,\n UPDATE_INVENTORY_CONCURRENCY,\n} from '../../constants';\nimport { BigCommerceFetcher } from '../../core';\nimport { validateInput } from '../../validation';\nimport {\n UpdateProductResponseSchema,\n UpdateProductSchema,\n type UpdateProductInput,\n} from './schemas/update-products.schema';\nconst UpdateProductArraySchema = z.array(UpdateProductSchema);\nexport const updateProducts = (dtos: UpdateProductInput[]) => {\n return Stream.fromIterable(dtos).pipe(\n Stream.grouped(UPDATE_INVENTORY_BATCH_SIZE),\n Stream.mapEffect((chunk) => updateProductBatch(chunk), {\n concurrency: UPDATE_INVENTORY_CONCURRENCY,\n }),\n Stream.runCollect,\n Effect.map(Chunk.toArray),\n );\n};\n\nconst updateProductBatch = (items: Chunk.Chunk<UpdateProductInput>) => {\n return Effect.gen(function* () {\n const validatedBody = yield* validateInput(UpdateProductArraySchema, Chunk.toArray(items));\n const fetcher = yield* BigCommerceFetcher;\n return yield* Effect.retry(\n fetcher.fetch({\n isB2B: false,\n method: 'PUT',\n path: 'inventory/adjustments/absolute',\n version: 'v3',\n body: validatedBody,\n resultSchema: UpdateProductResponseSchema,\n }),\n RETRY_POLICY_WITH_BACKOFF,\n );\n });\n};\n","import * as z from 'zod';\nexport const UpdateProductVisibilitySchema = z.object({\n id: z.number(),\n is_visible: z.boolean(),\n});\n\nexport const UpdateProductSchema = z.union([UpdateProductVisibilitySchema]);\n\nexport const UpdateProductResponseSchema = z.any();\n\nexport type UpdateProductInput = z.input<typeof UpdateProductSchema>;\nexport type UpdateProductVisibilityInput = z.input<typeof UpdateProductVisibilitySchema>;\nexport type UpdateProductResponse = z.output<typeof UpdateProductResponseSchema>;\n","import type { UpdateProductVisibilityInput } from './schemas/update-products.schema';\nimport { updateProducts } from './update-products';\n\nexport const setProductVisibility = (dtos: UpdateProductVisibilityInput[]) => {\n return updateProducts(dtos);\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,IAAAA,iBAAsC;;;ACAtC,oBAAmC;AAE5B,IAAM,qBAAqB;AAC3B,IAAM,gBAAgB;AAAA,EAC3B,KAAK;AAAA,EACL,SAAS;AACX;AAGO,IAAM,8BAA8B;AACpC,IAAM,+BAA+B;AACrC,IAAM,sBAAsB;AAC5B,IAAM,qBAAqB;AAC3B,IAAM,yBAAyB,uBAAS,YAAY,uBAAS,OAAO,kBAAkB,CAAC;AACvF,IAAM,4BAA4B,uBAAS;AAAA,EAChD,uBAAS,OAAO,kBAAkB;AAAA,EAClC;AACF,EAAE,KAAK,uBAAS,UAAU,uBAAS,OAAO,mBAAmB,CAAC,CAAC;;;ACjB/D,IAAAC,iBAAqB;AAEd,IAAM,sCAAN,cAAkD,oBAAK;AAAA,EAC5D;AACF,EAEG;AAAC;AAEG,IAAM,+BAAN,cAA2C,oBAAK;AAAA,EACrD;AACF,EAAE;AAAC;AAEI,IAAM,4BAAN,cAAwC,oBAAK,YAAY,2BAA2B,EAAE;AAAC;AAEvF,IAAM,2BAAN,cAAuC,oBAAK,YAAY,0BAA0B,EAAE;AAAC;AAErF,IAAM,2BAAN,cAAuC,oBAAK,YAAY,0BAA0B,EAEtF;AAAC;AAEG,IAAM,6BAAN,cAAyC,oBAAK,YAAY,4BAA4B,EAG1F;AAAC;AAEG,IAAM,0BAAN,cAAsC,oBAAK,YAAY,yBAAyB,EAEpF;AAAC;AAEG,IAAM,kCAAN,cAA8C,oBAAK;AAAA,EACxD;AACF,EAEG;AAAC;AAEG,IAAM,iCAAN,cAA6C,oBAAK;AAAA,EACvD;AACF,EAEG;AAAC;AAEG,IAAM,gCAAN,cAA4C,oBAAK;AAAA,EACtD;AACF,EAEG;AAAC;;;AC7CJ,IAAAC,iBAAgC;AAoBzB,IAAM,qBAAN,cAAiC,uBAAQ,IAAI,oBAAoB,EAWtE,EAAE;AAAC;;;AC/BL,IAAAC,iBAAqC;;;ACArC,IAAAC,iBAAqD;AAI9C,IAAM,2BAAN,cAAuC,oBAAK,YAAY,0BAA0B,EAEtF;AAAC;AAEG,IAAM,oBAAN,cAAgC,uBAAQ,IAAI,mBAAmB,EASpE,EAAE;AAAC;AAEL,IAAM,uBAAuB,CAAC,QAAgB;AAC5C,SAAO,sBAAO,OAAO,sBAAO,OAAO,GAAG,GAAG,aAAa,EAAE;AAAA,IACtD,sBAAO,SAAS,MAAM,IAAI,yBAAyB,EAAE,IAAI,CAAC,CAAC;AAAA,EAC7D;AACF;AAEA,IAAM,wBAAwB,MAAM;AAClC,SAAO,sBAAO,OAAO,sBAAO,OAAO,SAAS,GAAG,aAAa,EAAE;AAAA,IAC5D,sBAAO,SAAS,MAAM,IAAI,yBAAyB,EAAE,KAAK,UAAU,CAAC,CAAC;AAAA;AAAA,IAEtE,sBAAO,OAAO,MAAM,sBAAO,QAAQ,kBAAkB,CAAC;AAAA,EACxD;AACF;AAEO,IAAM,wBAAwB,qBAAM;AAAA,EACzC;AAAA,EACA,sBAAO,IAAI,aAAa;AACtB,UAAM,CAAC,WAAW,UAAU,cAAc,aAAa,OAAO,IAAI,OAAO,sBAAO,IAAI;AAAA,MAClF,qBAAqB,YAAY;AAAA,MACjC,qBAAqB,WAAW;AAAA,MAChC,qBAAqB,eAAe;AAAA,MACpC,qBAAqB,cAAc;AAAA,MACnC,sBAAsB;AAAA,IACxB,CAAC;AAED,WAAO;AAAA,MACL,cAAc,sBAAO,QAAQ,SAAS;AAAA,MACtC,aAAa,sBAAO,QAAQ,QAAQ;AAAA,MACpC,iBAAiB,sBAAO,QAAQ,YAAY;AAAA,MAC5C,gBAAgB,sBAAO,QAAQ,WAAW;AAAA,MAC1C,YAAY,sBAAO,QAAQ,OAAO;AAAA,IACpC;AAAA,EACF,CAAC;AACH;AAEO,IAAM,wBAAwB,qBAAM,QAAQ,mBAAmB;AAAA,EACpE,gBAAgB,sBAAO,QAAQ,MAAM;AAAA,EACrC,aAAa,sBAAO,QAAQ,MAAM;AAAA,EAClC,iBAAiB,sBAAO,QAAQ,MAAM;AAAA,EACtC,cAAc,sBAAO,QAAQ,MAAM;AAAA,EACnC,YAAY,sBAAO,QAAQ,kBAAkB;AAC/C,CAAC;;;ADzCD,IAAM,yBAAyB;AAAA,EAC7B,cAAc;AAAA,EACd,UAAU;AAAA,EACV,WAAW;AAAA,EACX,WAAW;AAAA,EACX,sBAAsB;AAAA,EACtB,uBAAuB;AAAA,EACvB,aAAa;AAAA,EACb,qBAAqB;AAAA,EACrB,iBAAiB;AAAA,EACjB,iBAAiB;AACnB;AAEO,IAAM,yBAAyB,qBAAM;AAAA,EAC1C;AAAA,EACA,sBAAO,IAAI,aAAa;AACtB,UAAM,SAAS,OAAO;AACtB,UAAM,YAAY,OAAO,OAAO;AAChC,UAAM,cAAc,OAAO,OAAO;AAClC,UAAM,UAAU,OAAO,OAAO;AAC9B,WAAO;AAAA,MACL,OAAO,CAAC,WAAW;AACjB,cAAM,OAAO,QAAQ,MAAM;AAC3B,cAAM,UAAkC;AAAA,UACtC,QAAQ;AAAA,UACR,gBAAgB;AAAA,UAChB,gBAAgB;AAAA,QAClB;AAEA,YAAI,OAAO,OAAO;AAChB,kBAAQ,cAAc,IAAI;AAAA,QAC5B;AACA,cAAM,MAAM,YAAY,KAAK,QAAQ,eAAe,SAAS,GAAG,OAAO,KAAK;AAE5E,eAAO,sBAAO,WAAW;AAAA,UACvB,KAAK,MACH,MAAM,KAAK;AAAA,YACT;AAAA,YACA,QAAQ,YAAY,QAAQ,OAAO;AAAA,YACnC,QAAQ,OAAO;AAAA,YACf,GAAI,OAAO,QAAQ,EAAE,MAAM,KAAK,UAAU,OAAO,IAAI,EAAE;AAAA,UACzD,CAAC;AAAA,UACH,OAAO,CAAC,UAAU;AAChB,gBAAI,iBAAiB,SAAS,MAAM,SAAS,gBAAgB;AAC3D,qBAAO,IAAI,2BAA2B;AAAA,gBACpC,SAAS,yBAAyB,OAAO;AAAA,gBACzC,MAAM;AAAA,cACR,CAAC;AAAA,YACH;AACA,gBAAI,iBAAiB,SAAS,MAAM,SAAS,cAAc;AACzD,qBAAO,IAAI,2BAA2B;AAAA,gBACpC,SAAS,yBAAyB,OAAO;AAAA,gBACzC,MAAM;AAAA,cACR,CAAC;AAAA,YACH;AACA,mBAAO,IAAI,wBAAwB,EAAE,OAAO,MAAM,CAAC;AAAA,UACrD;AAAA,QACF,CAAC,EAAE;AAAA,UACD,sBAAO;AAAA,YAAS,CAAC,UACf,sBAAO,SAAS,wCAAwC,MAAM,KAAK;AAAA,UACrE;AAAA,UACA,sBAAO,QAAQ,CAAC,aAAa,kBAAkB,UAAU,OAAO,YAAY,CAAC;AAAA,QAC/E;AAAA,MACF;AAAA,IACF;AAAA,EACF,CAAC;AACH;AACA,IAAM,cAAc,CAAC,KAAa,WAAkD;AAClF,QAAM,OAAO,IAAI,IAAI,GAAG;AACxB,MAAI,CAAC,QAAQ;AACX,WAAO;AAAA,EACT;AACA,aAAW,CAAC,KAAK,KAAK,KAAK,OAAO,QAAQ,MAAM,GAAG;AACjD,SAAK,aAAa,OAAO,KAAK,GAAG,KAAK,EAAE;AAAA,EAC1C;AACA,SAAO;AACT;AAEA,IAAM,UAAU,CAAC;AAAA,EACf;AAAA,EACA;AAAA,EACA;AACF,MAIc;AACZ,MAAI,OAAO;AACT,WAAO,GAAG,cAAc,GAAG,IAAI,OAAO,OAAO,IAAI;AAAA,EACnD;AACA,SAAO,GAAG,cAAc,OAAO,gBAAgB,OAAO,IAAI,IAAI;AAChE;AACA,SAAS,uBAAoD,UAAoB,QAAgB;AAC/F,SAAO,sBAAO,WAAW;AAAA,IACvB,KAAK,MAAM,SAAS,KAAK;AAAA,IACzB,OAAO,CAAC,UAAU,IAAI,gCAAgC,EAAE,OAAO,MAAM,CAAC;AAAA,EACxE,CAAC,EAAE;AAAA,IACD,sBAAO;AAAA,MAAS,CAAC,UACf,sBAAO,SAAS,+CAA+C,MAAM,KAAK;AAAA,IAC5E;AAAA,IACA,sBAAO,OAAO;AAAA,MACZ,KAAK,CAAC,SAAS,OAAO,MAAM,IAAI;AAAA,MAChC,OAAO,CAAC,UAAU,IAAI,8BAA8B,EAAE,MAA2B,CAAC;AAAA,IACpF,CAAC;AAAA,EACH;AACF;AACA,IAAM,uBAAuB,CAAC,aAAuB;AACnD,QAAM,OAAO,SAAS;AACtB,SAAO,sBAAO,WAAW;AAAA,IACvB,KAAK,MAAM,SAAS,KAAK;AAAA,IACzB,OAAO,CAAC,UAAU,IAAI,gCAAgC,EAAE,OAAO,MAAM,CAAC;AAAA,EACxE,CAAC,EAAE;AAAA,IACD,sBAAO,SAAS,CAAC,UAAU,sBAAO,SAAS,gCAAgC,MAAM,KAAK,CAAC;AAAA,IACvF,sBAAO;AAAA,MAAQ,CAAC,iBACd,sBAAO;AAAA,QACL,qBAAM,MAAM,IAAI,EAAE;AAAA,UAChB,qBAAM;AAAA,YACJ,uBAAuB;AAAA,YACvB,MAAM,IAAI,+BAA+B,EAAE,aAAa,CAAC;AAAA,UAC3D;AAAA,UACA,qBAAM,KAAK,uBAAuB,cAAc,MAAM,IAAI,6BAA6B,CAAC;AAAA,UACxF,qBAAM,KAAK,uBAAuB,WAAW,MAAM,IAAI,0BAA0B,CAAC;AAAA,UAClF,qBAAM,KAAK,uBAAuB,WAAW,MAAM,IAAI,yBAAyB,CAAC;AAAA,UACjF,qBAAM;AAAA,YACJ,uBAAuB;AAAA,YACvB,MAAM,IAAI,yBAAyB,EAAE,SAAS,aAAa,CAAC;AAAA,UAC9D;AAAA,UACA,qBAAM;AAAA,YACJ,uBAAuB;AAAA,YACvB,MAAM,IAAI,oCAAoC,EAAE,aAAa,CAAC;AAAA,UAChE;AAAA,UACA,qBAAM;AAAA,YACJ,CAACC,UAASA,SAAQ;AAAA,YAClB,MACE,IAAI,2BAA2B;AAAA,cAC7B,SAAS,iBAAiB,IAAI;AAAA,cAC9B,MACE,SAAS,uBAAuB,wBAC5B,kBACA,SAAS,uBAAuB,eAC9B,SAAS,uBAAuB,kBAChC,YACA;AAAA,YACV,CAAC;AAAA,UACL;AAAA,UACA,qBAAM,OAAO,MAAM,IAAI,wBAAwB,EAAE,OAAO,aAAa,CAAC,CAAC;AAAA,QACzE;AAAA,MACF;AAAA,IACF;AAAA,EACF;AACF;AAEA,IAAM,oBAAoB,CACxB,UACA,WAC0D;AAC1D,MAAI,SAAS,IAAI;AACf,WAAO,uBAAuB,UAAU,MAAM;AAAA,EAChD;AACA,SAAO,qBAAqB,QAAQ;AACtC;;;AEnLA,IAAAC,iBAAuB;;;ACAvB,IAAAC,iBAAqB;AAEd,IAAM,uBAAN,cAAmC,oBAAK,YAAY,sBAAsB,EAG9E;AAAC;;;ADFG,IAAM,gBAAgB,CAA2B,QAAgB,SAA0B;AAChG,SAAO,sBAAO,IAAI;AAAA,IAChB,KAAK,MAAM,OAAO,MAAM,IAAI;AAAA,IAC5B,OAAO,CAAC,UAAU,IAAI,qBAAqB,EAAE,OAAO,MAAM,MAA2B,CAAC;AAAA,EACxF,CAAC;AACH;;;AERA,QAAmB;AACZ,IAAM,gCAAkC,QAAM;AAAA,EACjD,SAAO;AAAA,IACP,aAAe,MAAI;AAAA,IACnB,YAAc,MAAI;AAAA,IAClB,UAAY,MAAI,EAAE,IAAI,CAAC;AAAA,EACzB,CAAC;AAAA,EACC,SAAO;AAAA,IACP,aAAe,MAAI;AAAA,IACnB,KAAO,SAAO;AAAA,IACd,UAAY,MAAI,EAAE,IAAI,CAAC;AAAA,EACzB,CAAC;AACH,CAAC;AACM,IAAM,4BAA8B,SAAO;AAAA,EAChD,QAAU,SAAO;AAAA,EACjB,OAAS,QAAM,6BAA6B;AAC9C,CAAC;AACM,IAAM,6BAA+B,SAAO;AAAA,EACjD,gBAAkB,SAAO;AAC3B,CAAC;;;ARLM,IAAM,uBAAuB,CAAC,QAAgB,UAA0C;AAC7F,SAAO,sBAAO,aAAa,KAAK,EAAE;AAAA,IAChC,sBAAO,QAAQ,2BAA2B;AAAA,IAC1C,sBAAO,UAAU,CAAC,UAAU,uBAAuB,QAAQ,KAAK,GAAG;AAAA,MACjE,aAAa;AAAA,IACf,CAAC;AAAA,IACD,sBAAO;AAAA,IACP,sBAAO,IAAI,qBAAM,OAAO;AAAA,EAC1B;AACF;AAEA,IAAM,yBAAyB,CAC7B,QACA,UACG;AACH,SAAO,sBAAO,IAAI,aAAa;AAC7B,UAAM,gBAAgB,OAAO,cAAc,2BAA2B;AAAA,MACpE;AAAA,MACA,OAAO,qBAAM,QAAQ,KAAK;AAAA,IAC5B,CAAC;AACD,UAAM,UAAU,OAAO;AACvB,WAAO,OAAO,sBAAO;AAAA,MACnB,QAAQ,MAAM;AAAA,QACZ,OAAO;AAAA,QACP,QAAQ;AAAA,QACR,MAAM;AAAA,QACN,SAAS;AAAA,QACT,MAAM;AAAA,QACN,cAAc;AAAA,MAChB,CAAC;AAAA,MACD;AAAA,IACF;AAAA,EACF,CAAC;AACH;;;AS/CA,IAAAC,iBAAsC;AACtC,IAAAC,KAAmB;;;ACDnB,IAAAC,KAAmB;AACZ,IAAM,gCAAkC,UAAO;AAAA,EACpD,IAAM,UAAO;AAAA,EACb,YAAc,WAAQ;AACxB,CAAC;AAEM,IAAM,sBAAwB,SAAM,CAAC,6BAA6B,CAAC;AAEnE,IAAM,8BAAgC,OAAI;;;ADMjD,IAAM,2BAA6B,SAAM,mBAAmB;AACrD,IAAM,iBAAiB,CAAC,SAA+B;AAC5D,SAAO,sBAAO,aAAa,IAAI,EAAE;AAAA,IAC/B,sBAAO,QAAQ,2BAA2B;AAAA,IAC1C,sBAAO,UAAU,CAAC,UAAU,mBAAmB,KAAK,GAAG;AAAA,MACrD,aAAa;AAAA,IACf,CAAC;AAAA,IACD,sBAAO;AAAA,IACP,sBAAO,IAAI,qBAAM,OAAO;AAAA,EAC1B;AACF;AAEA,IAAM,qBAAqB,CAAC,UAA2C;AACrE,SAAO,sBAAO,IAAI,aAAa;AAC7B,UAAM,gBAAgB,OAAO,cAAc,0BAA0B,qBAAM,QAAQ,KAAK,CAAC;AACzF,UAAM,UAAU,OAAO;AACvB,WAAO,OAAO,sBAAO;AAAA,MACnB,QAAQ,MAAM;AAAA,QACZ,OAAO;AAAA,QACP,QAAQ;AAAA,QACR,MAAM;AAAA,QACN,SAAS;AAAA,QACT,MAAM;AAAA,QACN,cAAc;AAAA,MAChB,CAAC;AAAA,MACD;AAAA,IACF;AAAA,EACF,CAAC;AACH;;;AEvCO,IAAM,uBAAuB,CAAC,SAAyC;AAC5E,SAAO,eAAe,IAAI;AAC5B;","names":["import_effect","import_effect","import_effect","import_effect","import_effect","code","import_effect","import_effect","import_effect","z","z"]}
@@ -0,0 +1,119 @@
1
+ import {
2
+ validateInput
3
+ } from "./chunk-CERZFSUE.mjs";
4
+ import {
5
+ BigCommerceFetcher,
6
+ RETRY_POLICY_WITH_BACKOFF,
7
+ UPDATE_INVENTORY_BATCH_SIZE,
8
+ UPDATE_INVENTORY_CONCURRENCY
9
+ } from "./chunk-7GBRYAQG.mjs";
10
+
11
+ // src/bigcommerce-entities/products/set-inventory.ts
12
+ import { Chunk, Effect, Stream } from "effect";
13
+
14
+ // src/bigcommerce-entities/products/schemas/set-inventory.schema.ts
15
+ import * as z from "zod";
16
+ var SetProductInventoryItemSchema = z.union([
17
+ z.object({
18
+ location_id: z.int(),
19
+ product_id: z.int(),
20
+ quantity: z.int().min(0)
21
+ }),
22
+ z.object({
23
+ location_id: z.int(),
24
+ sku: z.string(),
25
+ quantity: z.int().min(0)
26
+ })
27
+ ]);
28
+ var SetProductInventorySchema = z.object({
29
+ reason: z.string(),
30
+ items: z.array(SetProductInventoryItemSchema)
31
+ });
32
+ var SetInventoryResponseSchema = z.object({
33
+ transaction_id: z.string()
34
+ });
35
+
36
+ // src/bigcommerce-entities/products/set-inventory.ts
37
+ var setProductsInventory = (reason, items) => {
38
+ return Stream.fromIterable(items).pipe(
39
+ Stream.grouped(UPDATE_INVENTORY_BATCH_SIZE),
40
+ Stream.mapEffect((chunk) => updateProductInventory(reason, chunk), {
41
+ concurrency: UPDATE_INVENTORY_CONCURRENCY
42
+ }),
43
+ Stream.runCollect,
44
+ Effect.map(Chunk.toArray)
45
+ );
46
+ };
47
+ var updateProductInventory = (reason, items) => {
48
+ return Effect.gen(function* () {
49
+ const validatedBody = yield* validateInput(SetProductInventorySchema, {
50
+ reason,
51
+ items: Chunk.toArray(items)
52
+ });
53
+ const fetcher = yield* BigCommerceFetcher;
54
+ return yield* Effect.retry(
55
+ fetcher.fetch({
56
+ isB2B: false,
57
+ method: "PUT",
58
+ path: "inventory/adjustments/absolute",
59
+ version: "v3",
60
+ body: validatedBody,
61
+ resultSchema: SetInventoryResponseSchema
62
+ }),
63
+ RETRY_POLICY_WITH_BACKOFF
64
+ );
65
+ });
66
+ };
67
+
68
+ // src/bigcommerce-entities/products/update-products.ts
69
+ import { Chunk as Chunk2, Effect as Effect2, Stream as Stream2 } from "effect";
70
+ import * as z3 from "zod";
71
+
72
+ // src/bigcommerce-entities/products/schemas/update-products.schema.ts
73
+ import * as z2 from "zod";
74
+ var UpdateProductVisibilitySchema = z2.object({
75
+ id: z2.number(),
76
+ is_visible: z2.boolean()
77
+ });
78
+ var UpdateProductSchema = z2.union([UpdateProductVisibilitySchema]);
79
+ var UpdateProductResponseSchema = z2.any();
80
+
81
+ // src/bigcommerce-entities/products/update-products.ts
82
+ var UpdateProductArraySchema = z3.array(UpdateProductSchema);
83
+ var updateProducts = (dtos) => {
84
+ return Stream2.fromIterable(dtos).pipe(
85
+ Stream2.grouped(UPDATE_INVENTORY_BATCH_SIZE),
86
+ Stream2.mapEffect((chunk) => updateProductBatch(chunk), {
87
+ concurrency: UPDATE_INVENTORY_CONCURRENCY
88
+ }),
89
+ Stream2.runCollect,
90
+ Effect2.map(Chunk2.toArray)
91
+ );
92
+ };
93
+ var updateProductBatch = (items) => {
94
+ return Effect2.gen(function* () {
95
+ const validatedBody = yield* validateInput(UpdateProductArraySchema, Chunk2.toArray(items));
96
+ const fetcher = yield* BigCommerceFetcher;
97
+ return yield* Effect2.retry(
98
+ fetcher.fetch({
99
+ isB2B: false,
100
+ method: "PUT",
101
+ path: "inventory/adjustments/absolute",
102
+ version: "v3",
103
+ body: validatedBody,
104
+ resultSchema: UpdateProductResponseSchema
105
+ }),
106
+ RETRY_POLICY_WITH_BACKOFF
107
+ );
108
+ });
109
+ };
110
+
111
+ // src/bigcommerce-entities/products/set-visibility.ts
112
+ var setProductVisibility = (dtos) => {
113
+ return updateProducts(dtos);
114
+ };
115
+ export {
116
+ setProductVisibility,
117
+ setProductsInventory
118
+ };
119
+ //# sourceMappingURL=products.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/bigcommerce-entities/products/set-inventory.ts","../src/bigcommerce-entities/products/schemas/set-inventory.schema.ts","../src/bigcommerce-entities/products/update-products.ts","../src/bigcommerce-entities/products/schemas/update-products.schema.ts","../src/bigcommerce-entities/products/set-visibility.ts"],"sourcesContent":["import { Chunk, Effect, Stream } from 'effect';\nimport {\n RETRY_POLICY_WITH_BACKOFF,\n UPDATE_INVENTORY_BATCH_SIZE,\n UPDATE_INVENTORY_CONCURRENCY,\n} from '../../constants';\nimport { BigCommerceFetcher } from '../../core';\nimport { validateInput } from '../../validation';\nimport {\n SetInventoryResponseSchema,\n SetProductInventorySchema,\n type SetProductInventoryItemInput,\n} from './schemas/set-inventory.schema';\n\nexport const setProductsInventory = (reason: string, items: SetProductInventoryItemInput[]) => {\n return Stream.fromIterable(items).pipe(\n Stream.grouped(UPDATE_INVENTORY_BATCH_SIZE),\n Stream.mapEffect((chunk) => updateProductInventory(reason, chunk), {\n concurrency: UPDATE_INVENTORY_CONCURRENCY,\n }),\n Stream.runCollect,\n Effect.map(Chunk.toArray),\n );\n};\n\nconst updateProductInventory = (\n reason: string,\n items: Chunk.Chunk<SetProductInventoryItemInput>,\n) => {\n return Effect.gen(function* () {\n const validatedBody = yield* validateInput(SetProductInventorySchema, {\n reason,\n items: Chunk.toArray(items),\n });\n const fetcher = yield* BigCommerceFetcher;\n return yield* Effect.retry(\n fetcher.fetch({\n isB2B: false,\n method: 'PUT',\n path: 'inventory/adjustments/absolute',\n version: 'v3',\n body: validatedBody,\n resultSchema: SetInventoryResponseSchema,\n }),\n RETRY_POLICY_WITH_BACKOFF,\n );\n });\n};\n","import * as z from 'zod';\nexport const SetProductInventoryItemSchema = z.union([\n z.object({\n location_id: z.int(),\n product_id: z.int(),\n quantity: z.int().min(0),\n }),\n z.object({\n location_id: z.int(),\n sku: z.string(),\n quantity: z.int().min(0),\n }),\n]);\nexport const SetProductInventorySchema = z.object({\n reason: z.string(),\n items: z.array(SetProductInventoryItemSchema),\n});\nexport const SetInventoryResponseSchema = z.object({\n transaction_id: z.string(),\n});\nexport type SetProductInventoryInput = z.input<typeof SetProductInventorySchema>;\nexport type SetProductInventoryItemInput = z.input<typeof SetProductInventoryItemSchema>;\nexport type SetInventoryResponse = z.output<typeof SetInventoryResponseSchema>;\n","import { Chunk, Effect, Stream } from 'effect';\nimport * as z from 'zod';\nimport {\n RETRY_POLICY_WITH_BACKOFF,\n UPDATE_INVENTORY_BATCH_SIZE,\n UPDATE_INVENTORY_CONCURRENCY,\n} from '../../constants';\nimport { BigCommerceFetcher } from '../../core';\nimport { validateInput } from '../../validation';\nimport {\n UpdateProductResponseSchema,\n UpdateProductSchema,\n type UpdateProductInput,\n} from './schemas/update-products.schema';\nconst UpdateProductArraySchema = z.array(UpdateProductSchema);\nexport const updateProducts = (dtos: UpdateProductInput[]) => {\n return Stream.fromIterable(dtos).pipe(\n Stream.grouped(UPDATE_INVENTORY_BATCH_SIZE),\n Stream.mapEffect((chunk) => updateProductBatch(chunk), {\n concurrency: UPDATE_INVENTORY_CONCURRENCY,\n }),\n Stream.runCollect,\n Effect.map(Chunk.toArray),\n );\n};\n\nconst updateProductBatch = (items: Chunk.Chunk<UpdateProductInput>) => {\n return Effect.gen(function* () {\n const validatedBody = yield* validateInput(UpdateProductArraySchema, Chunk.toArray(items));\n const fetcher = yield* BigCommerceFetcher;\n return yield* Effect.retry(\n fetcher.fetch({\n isB2B: false,\n method: 'PUT',\n path: 'inventory/adjustments/absolute',\n version: 'v3',\n body: validatedBody,\n resultSchema: UpdateProductResponseSchema,\n }),\n RETRY_POLICY_WITH_BACKOFF,\n );\n });\n};\n","import * as z from 'zod';\nexport const UpdateProductVisibilitySchema = z.object({\n id: z.number(),\n is_visible: z.boolean(),\n});\n\nexport const UpdateProductSchema = z.union([UpdateProductVisibilitySchema]);\n\nexport const UpdateProductResponseSchema = z.any();\n\nexport type UpdateProductInput = z.input<typeof UpdateProductSchema>;\nexport type UpdateProductVisibilityInput = z.input<typeof UpdateProductVisibilitySchema>;\nexport type UpdateProductResponse = z.output<typeof UpdateProductResponseSchema>;\n","import type { UpdateProductVisibilityInput } from './schemas/update-products.schema';\nimport { updateProducts } from './update-products';\n\nexport const setProductVisibility = (dtos: UpdateProductVisibilityInput[]) => {\n return updateProducts(dtos);\n};\n"],"mappings":";;;;;;;;;;;AAAA,SAAS,OAAO,QAAQ,cAAc;;;ACAtC,YAAY,OAAO;AACZ,IAAM,gCAAkC,QAAM;AAAA,EACjD,SAAO;AAAA,IACP,aAAe,MAAI;AAAA,IACnB,YAAc,MAAI;AAAA,IAClB,UAAY,MAAI,EAAE,IAAI,CAAC;AAAA,EACzB,CAAC;AAAA,EACC,SAAO;AAAA,IACP,aAAe,MAAI;AAAA,IACnB,KAAO,SAAO;AAAA,IACd,UAAY,MAAI,EAAE,IAAI,CAAC;AAAA,EACzB,CAAC;AACH,CAAC;AACM,IAAM,4BAA8B,SAAO;AAAA,EAChD,QAAU,SAAO;AAAA,EACjB,OAAS,QAAM,6BAA6B;AAC9C,CAAC;AACM,IAAM,6BAA+B,SAAO;AAAA,EACjD,gBAAkB,SAAO;AAC3B,CAAC;;;ADLM,IAAM,uBAAuB,CAAC,QAAgB,UAA0C;AAC7F,SAAO,OAAO,aAAa,KAAK,EAAE;AAAA,IAChC,OAAO,QAAQ,2BAA2B;AAAA,IAC1C,OAAO,UAAU,CAAC,UAAU,uBAAuB,QAAQ,KAAK,GAAG;AAAA,MACjE,aAAa;AAAA,IACf,CAAC;AAAA,IACD,OAAO;AAAA,IACP,OAAO,IAAI,MAAM,OAAO;AAAA,EAC1B;AACF;AAEA,IAAM,yBAAyB,CAC7B,QACA,UACG;AACH,SAAO,OAAO,IAAI,aAAa;AAC7B,UAAM,gBAAgB,OAAO,cAAc,2BAA2B;AAAA,MACpE;AAAA,MACA,OAAO,MAAM,QAAQ,KAAK;AAAA,IAC5B,CAAC;AACD,UAAM,UAAU,OAAO;AACvB,WAAO,OAAO,OAAO;AAAA,MACnB,QAAQ,MAAM;AAAA,QACZ,OAAO;AAAA,QACP,QAAQ;AAAA,QACR,MAAM;AAAA,QACN,SAAS;AAAA,QACT,MAAM;AAAA,QACN,cAAc;AAAA,MAChB,CAAC;AAAA,MACD;AAAA,IACF;AAAA,EACF,CAAC;AACH;;;AE/CA,SAAS,SAAAA,QAAO,UAAAC,SAAQ,UAAAC,eAAc;AACtC,YAAYC,QAAO;;;ACDnB,YAAYC,QAAO;AACZ,IAAM,gCAAkC,UAAO;AAAA,EACpD,IAAM,UAAO;AAAA,EACb,YAAc,WAAQ;AACxB,CAAC;AAEM,IAAM,sBAAwB,SAAM,CAAC,6BAA6B,CAAC;AAEnE,IAAM,8BAAgC,OAAI;;;ADMjD,IAAM,2BAA6B,SAAM,mBAAmB;AACrD,IAAM,iBAAiB,CAAC,SAA+B;AAC5D,SAAOC,QAAO,aAAa,IAAI,EAAE;AAAA,IAC/BA,QAAO,QAAQ,2BAA2B;AAAA,IAC1CA,QAAO,UAAU,CAAC,UAAU,mBAAmB,KAAK,GAAG;AAAA,MACrD,aAAa;AAAA,IACf,CAAC;AAAA,IACDA,QAAO;AAAA,IACPC,QAAO,IAAIC,OAAM,OAAO;AAAA,EAC1B;AACF;AAEA,IAAM,qBAAqB,CAAC,UAA2C;AACrE,SAAOD,QAAO,IAAI,aAAa;AAC7B,UAAM,gBAAgB,OAAO,cAAc,0BAA0BC,OAAM,QAAQ,KAAK,CAAC;AACzF,UAAM,UAAU,OAAO;AACvB,WAAO,OAAOD,QAAO;AAAA,MACnB,QAAQ,MAAM;AAAA,QACZ,OAAO;AAAA,QACP,QAAQ;AAAA,QACR,MAAM;AAAA,QACN,SAAS;AAAA,QACT,MAAM;AAAA,QACN,cAAc;AAAA,MAChB,CAAC;AAAA,MACD;AAAA,IACF;AAAA,EACF,CAAC;AACH;;;AEvCO,IAAM,uBAAuB,CAAC,SAAyC;AAC5E,SAAO,eAAe,IAAI;AAC5B;","names":["Chunk","Effect","Stream","z","z","Stream","Effect","Chunk"]}
@@ -0,0 +1,14 @@
1
+ import * as effect_Cause from 'effect/Cause';
2
+ import * as effect_Types from 'effect/Types';
3
+ import * as z from 'zod';
4
+
5
+ declare const InputValidationError_base: new <A extends Record<string, any> = {}>(args: effect_Types.Equals<A, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" ? never : P]: A[P]; }) => effect_Cause.YieldableError & {
6
+ readonly _tag: "InputValidationError";
7
+ } & Readonly<A>;
8
+ declare class InputValidationError extends InputValidationError_base<{
9
+ input: unknown;
10
+ error: z.ZodError;
11
+ }> {
12
+ }
13
+
14
+ export { InputValidationError as I };
@@ -0,0 +1,14 @@
1
+ import * as effect_Cause from 'effect/Cause';
2
+ import * as effect_Types from 'effect/Types';
3
+ import * as z from 'zod';
4
+
5
+ declare const InputValidationError_base: new <A extends Record<string, any> = {}>(args: effect_Types.Equals<A, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" ? never : P]: A[P]; }) => effect_Cause.YieldableError & {
6
+ readonly _tag: "InputValidationError";
7
+ } & Readonly<A>;
8
+ declare class InputValidationError extends InputValidationError_base<{
9
+ input: unknown;
10
+ error: z.ZodError;
11
+ }> {
12
+ }
13
+
14
+ export { InputValidationError as I };