@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,29 @@
1
+ import { B as BigCommerceFetcher } from './bigcommerce.fetcher-D1TyK4y4.js';
2
+ export { e as BigCommerceConflictError, f as BigCommerceConnectionError, k as BigCommerceFetchMethods, l as BigCommerceFetchParams, c as BigCommerceForbiddenError, i as BigCommerceInvalidRequestError, h as BigCommerceInvalidResponseError, d as BigCommerceNotFoundError, j as BigCommerceParseResponseError, b as BigCommerceUnauthorizedError, g as BigCommerceUnknownError, a as BigCommerceUnprocessableEntityError, S as SomeBigCommerceError } from './bigcommerce.fetcher-D1TyK4y4.js';
3
+ import * as effect_Cause from 'effect/Cause';
4
+ import * as effect_Types from 'effect/Types';
5
+ import { Context, Effect, Layer } from 'effect';
6
+ import 'zod';
7
+
8
+ declare const NoBigCommerceConfigError_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 & {
9
+ readonly _tag: "NoBigCommerceConfigError";
10
+ } & Readonly<A>;
11
+ declare class NoBigCommerceConfigError extends NoBigCommerceConfigError_base<{
12
+ readonly key: string;
13
+ }> {
14
+ }
15
+ declare const BigCommerceConfig_base: Context.TagClass<BigCommerceConfig, "BigCommerceConfig", {
16
+ readonly getStoreHash: Effect.Effect<string, NoBigCommerceConfigError, string>;
17
+ readonly getClientId: Effect.Effect<string, NoBigCommerceConfigError, string>;
18
+ readonly getClientSecret: Effect.Effect<string, NoBigCommerceConfigError, string>;
19
+ readonly getAccessToken: Effect.Effect<string, NoBigCommerceConfigError, string>;
20
+ readonly getTimeout: Effect.Effect<number, NoBigCommerceConfigError, string>;
21
+ }>;
22
+ declare class BigCommerceConfig extends BigCommerceConfig_base {
23
+ }
24
+ declare const BigCommerceConfigLive: Layer.Layer<BigCommerceConfig, NoBigCommerceConfigError, never>;
25
+ declare const BigCommerceConfigTest: Layer.Layer<BigCommerceConfig, never, never>;
26
+
27
+ declare const BigCommerceFetcherLive: Layer.Layer<BigCommerceFetcher, NoBigCommerceConfigError, string | BigCommerceConfig>;
28
+
29
+ export { BigCommerceConfig, BigCommerceConfigLive, BigCommerceConfigTest, BigCommerceFetcher, BigCommerceFetcherLive, NoBigCommerceConfigError };
package/dist/index.js ADDED
@@ -0,0 +1,304 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/core/index.ts
21
+ var core_exports = {};
22
+ __export(core_exports, {
23
+ BigCommerceConfig: () => BigCommerceConfig,
24
+ BigCommerceConfigLive: () => BigCommerceConfigLive,
25
+ BigCommerceConfigTest: () => BigCommerceConfigTest,
26
+ BigCommerceConflictError: () => BigCommerceConflictError,
27
+ BigCommerceConnectionError: () => BigCommerceConnectionError,
28
+ BigCommerceFetcher: () => BigCommerceFetcher,
29
+ BigCommerceFetcherLive: () => BigCommerceFetcherLive,
30
+ BigCommerceForbiddenError: () => BigCommerceForbiddenError,
31
+ BigCommerceInvalidRequestError: () => BigCommerceInvalidRequestError,
32
+ BigCommerceInvalidResponseError: () => BigCommerceInvalidResponseError,
33
+ BigCommerceNotFoundError: () => BigCommerceNotFoundError,
34
+ BigCommerceParseResponseError: () => BigCommerceParseResponseError,
35
+ BigCommerceUnauthorizedError: () => BigCommerceUnauthorizedError,
36
+ BigCommerceUnknownError: () => BigCommerceUnknownError,
37
+ BigCommerceUnprocessableEntityError: () => BigCommerceUnprocessableEntityError,
38
+ NoBigCommerceConfigError: () => NoBigCommerceConfigError
39
+ });
40
+ module.exports = __toCommonJS(core_exports);
41
+
42
+ // src/core/bigcommerce.error.ts
43
+ var import_effect = require("effect");
44
+ var BigCommerceUnprocessableEntityError = class extends import_effect.Data.TaggedError(
45
+ "BigCommerceUnprocessableEntityError"
46
+ ) {
47
+ };
48
+ var BigCommerceUnauthorizedError = class extends import_effect.Data.TaggedError(
49
+ "BigCommerceUnauthorizedError"
50
+ ) {
51
+ };
52
+ var BigCommerceForbiddenError = class extends import_effect.Data.TaggedError("BigCommerceForbiddenError") {
53
+ };
54
+ var BigCommerceNotFoundError = class extends import_effect.Data.TaggedError("BigCommerceNotFoundError") {
55
+ };
56
+ var BigCommerceConflictError = class extends import_effect.Data.TaggedError("BigCommerceConflictError") {
57
+ };
58
+ var BigCommerceConnectionError = class extends import_effect.Data.TaggedError("BigCommerceConnectionError") {
59
+ };
60
+ var BigCommerceUnknownError = class extends import_effect.Data.TaggedError("BigCommerceUnknownError") {
61
+ };
62
+ var BigCommerceInvalidResponseError = class extends import_effect.Data.TaggedError(
63
+ "BigCommerceInvalidResponseError"
64
+ ) {
65
+ };
66
+ var BigCommerceInvalidRequestError = class extends import_effect.Data.TaggedError(
67
+ "BigCommerceInvalidRequestError"
68
+ ) {
69
+ };
70
+ var BigCommerceParseResponseError = class extends import_effect.Data.TaggedError(
71
+ "BigCommerceParseResponseError"
72
+ ) {
73
+ };
74
+
75
+ // src/core/bigcommerce.fetcher.ts
76
+ var import_effect2 = require("effect");
77
+ var BigCommerceFetcher = class extends import_effect2.Context.Tag("BigCommerceFetcher")() {
78
+ };
79
+
80
+ // src/core/bigcommerce.fetcher.live.ts
81
+ var import_effect5 = require("effect");
82
+
83
+ // src/constants.ts
84
+ var import_effect3 = require("effect");
85
+ var DEFAULT_TIMEOUT_MS = 3e4;
86
+ var API_BASE_URLS = {
87
+ B2B: "https://api-b2b.bigcommerce.com/api",
88
+ REGULAR: "https://api.bigcommerce.com/stores"
89
+ };
90
+ var DEFAULT_RETRY_TIMES = 2;
91
+ var DEFAULT_RETRY_WAIT = 200;
92
+ var DEFAULT_RETRY_SCHEDULE = import_effect3.Schedule.exponential(import_effect3.Duration.millis(DEFAULT_RETRY_WAIT));
93
+ var RETRY_POLICY_WITH_BACKOFF = import_effect3.Schedule.exponential(
94
+ import_effect3.Duration.millis(DEFAULT_RETRY_WAIT),
95
+ 2
96
+ ).pipe(import_effect3.Schedule.intersect(import_effect3.Schedule.recurs(DEFAULT_RETRY_TIMES)));
97
+
98
+ // src/core/config.ts
99
+ var import_effect4 = require("effect");
100
+ var NoBigCommerceConfigError = class extends import_effect4.Data.TaggedError("NoBigCommerceConfigError") {
101
+ };
102
+ var BigCommerceConfig = class extends import_effect4.Context.Tag("BigCommerceConfig")() {
103
+ };
104
+ var getBigCommerceConfig = (key) => {
105
+ return import_effect4.Config.nested(import_effect4.Config.string(key), "BIGCOMMERCE").pipe(
106
+ import_effect4.Effect.mapError(() => new NoBigCommerceConfigError({ key }))
107
+ );
108
+ };
109
+ var getBigCommerceTimeout = () => {
110
+ return import_effect4.Config.nested(import_effect4.Config.number("TIMEOUT"), "BIGCOMMERCE").pipe(
111
+ import_effect4.Effect.mapError(() => new NoBigCommerceConfigError({ key: "TIMEOUT" })),
112
+ // Default to 30 seconds if not configured
113
+ import_effect4.Effect.orElse(() => import_effect4.Effect.succeed(DEFAULT_TIMEOUT_MS))
114
+ );
115
+ };
116
+ var BigCommerceConfigLive = import_effect4.Layer.effect(
117
+ BigCommerceConfig,
118
+ import_effect4.Effect.gen(function* () {
119
+ const [storeHash, clientId, clientSecret, accessToken, timeout] = yield* import_effect4.Effect.all([
120
+ getBigCommerceConfig("STORE_HASH"),
121
+ getBigCommerceConfig("CLIENT_ID"),
122
+ getBigCommerceConfig("CLIENT_SECRET"),
123
+ getBigCommerceConfig("ACCESS_TOKEN"),
124
+ getBigCommerceTimeout()
125
+ ]);
126
+ return {
127
+ getStoreHash: import_effect4.Effect.succeed(storeHash),
128
+ getClientId: import_effect4.Effect.succeed(clientId),
129
+ getClientSecret: import_effect4.Effect.succeed(clientSecret),
130
+ getAccessToken: import_effect4.Effect.succeed(accessToken),
131
+ getTimeout: import_effect4.Effect.succeed(timeout)
132
+ };
133
+ })
134
+ );
135
+ var BigCommerceConfigTest = import_effect4.Layer.succeed(BigCommerceConfig, {
136
+ getAccessToken: import_effect4.Effect.succeed("test"),
137
+ getClientId: import_effect4.Effect.succeed("test"),
138
+ getClientSecret: import_effect4.Effect.succeed("test"),
139
+ getStoreHash: import_effect4.Effect.succeed("test"),
140
+ getTimeout: import_effect4.Effect.succeed(DEFAULT_TIMEOUT_MS)
141
+ });
142
+
143
+ // src/core/bigcommerce.fetcher.live.ts
144
+ var BigCommerceStatusCodes = {
145
+ UNAUTHORIZED: 401,
146
+ CONFLICT: 409,
147
+ FORBIDDEN: 403,
148
+ NOT_FOUND: 404,
149
+ UNPROCESSABLE_ENTITY: 422,
150
+ INTERNAL_SERVER_ERROR: 500,
151
+ BAD_GATEWAY: 502,
152
+ SERVICE_UNAVAILABLE: 503,
153
+ GATEWAY_TIMEOUT: 504,
154
+ INVALID_REQUEST: 400
155
+ };
156
+ var BigCommerceFetcherLive = import_effect5.Layer.effect(
157
+ BigCommerceFetcher,
158
+ import_effect5.Effect.gen(function* () {
159
+ const config = yield* BigCommerceConfig;
160
+ const storeHash = yield* config.getStoreHash;
161
+ const accessToken = yield* config.getAccessToken;
162
+ const timeout = yield* config.getTimeout;
163
+ return {
164
+ fetch: (params) => {
165
+ const base = getBase(params);
166
+ const headers = {
167
+ Accept: "application/json",
168
+ "Content-Type": "application/json",
169
+ "x-auth-token": accessToken
170
+ };
171
+ if (params.isB2B) {
172
+ headers["x-store-hash"] = storeHash;
173
+ }
174
+ const url = applyParams(base.replace("[storeHash]", storeHash), params.query);
175
+ return import_effect5.Effect.tryPromise({
176
+ try: () => fetch(url, {
177
+ headers,
178
+ signal: AbortSignal.timeout(timeout),
179
+ method: params.method,
180
+ ...params.body && { body: JSON.stringify(params.body) }
181
+ }),
182
+ catch: (error) => {
183
+ if (error instanceof Error && error.name === "TimeoutError") {
184
+ return new BigCommerceConnectionError({
185
+ message: `Request timeout after ${timeout}ms`,
186
+ type: "timeout"
187
+ });
188
+ }
189
+ if (error instanceof Error && error.name === "AbortError") {
190
+ return new BigCommerceConnectionError({
191
+ message: `Request timeout after ${timeout}ms`,
192
+ type: "timeout"
193
+ });
194
+ }
195
+ return new BigCommerceUnknownError({ cause: error });
196
+ }
197
+ }).pipe(
198
+ import_effect5.Effect.tapError(
199
+ (error) => import_effect5.Effect.logError("Failed to fetch from BigCommerce API", error.cause)
200
+ ),
201
+ import_effect5.Effect.flatMap((response) => transformResponse(response, params.resultSchema))
202
+ );
203
+ }
204
+ };
205
+ })
206
+ );
207
+ var applyParams = (url, params) => {
208
+ const base = new URL(url);
209
+ if (!params) {
210
+ return base;
211
+ }
212
+ for (const [key, value] of Object.entries(params)) {
213
+ base.searchParams.append(key, `${value}`);
214
+ }
215
+ return base;
216
+ };
217
+ var getBase = ({
218
+ isB2B,
219
+ path,
220
+ version
221
+ }) => {
222
+ if (isB2B) {
223
+ return `${API_BASE_URLS.B2B}/${version}/io/${path}`;
224
+ }
225
+ return `${API_BASE_URLS.REGULAR}/[storeHash]/${version}/${path}`;
226
+ };
227
+ function processSuccessResponse(response, schema) {
228
+ return import_effect5.Effect.tryPromise({
229
+ try: () => response.json(),
230
+ catch: (error) => new BigCommerceInvalidResponseError({ cause: error })
231
+ }).pipe(
232
+ import_effect5.Effect.tapError(
233
+ (error) => import_effect5.Effect.logError("Error parsing response from BigCommerce API", error.cause)
234
+ ),
235
+ import_effect5.Effect.tryMap({
236
+ try: (json) => schema.parse(json),
237
+ catch: (error) => new BigCommerceParseResponseError({ error })
238
+ })
239
+ );
240
+ }
241
+ var processErrorResponse = (response) => {
242
+ const code = response.status;
243
+ return import_effect5.Effect.tryPromise({
244
+ try: () => response.json(),
245
+ catch: (error) => new BigCommerceInvalidResponseError({ cause: error })
246
+ }).pipe(
247
+ import_effect5.Effect.tapError((error) => import_effect5.Effect.logError("Error parsing error response", error.cause)),
248
+ import_effect5.Effect.flatMap(
249
+ (errorDetails) => import_effect5.Effect.fail(
250
+ import_effect5.Match.value(code).pipe(
251
+ import_effect5.Match.when(
252
+ BigCommerceStatusCodes.INVALID_REQUEST,
253
+ () => new BigCommerceInvalidRequestError({ errorDetails })
254
+ ),
255
+ import_effect5.Match.when(BigCommerceStatusCodes.UNAUTHORIZED, () => new BigCommerceUnauthorizedError()),
256
+ import_effect5.Match.when(BigCommerceStatusCodes.FORBIDDEN, () => new BigCommerceForbiddenError()),
257
+ import_effect5.Match.when(BigCommerceStatusCodes.NOT_FOUND, () => new BigCommerceNotFoundError()),
258
+ import_effect5.Match.when(
259
+ BigCommerceStatusCodes.CONFLICT,
260
+ () => new BigCommerceConflictError({ details: errorDetails })
261
+ ),
262
+ import_effect5.Match.when(
263
+ BigCommerceStatusCodes.UNPROCESSABLE_ENTITY,
264
+ () => new BigCommerceUnprocessableEntityError({ errorDetails })
265
+ ),
266
+ import_effect5.Match.when(
267
+ (code2) => code2 >= 500,
268
+ () => new BigCommerceConnectionError({
269
+ message: `Server error: ${code}`,
270
+ type: code === BigCommerceStatusCodes.INTERNAL_SERVER_ERROR ? "internalError" : code === BigCommerceStatusCodes.BAD_GATEWAY || code === BigCommerceStatusCodes.GATEWAY_TIMEOUT ? "timeout" : "internalError"
271
+ })
272
+ ),
273
+ import_effect5.Match.orElse(() => new BigCommerceUnknownError({ cause: errorDetails }))
274
+ )
275
+ )
276
+ )
277
+ );
278
+ };
279
+ var transformResponse = (response, schema) => {
280
+ if (response.ok) {
281
+ return processSuccessResponse(response, schema);
282
+ }
283
+ return processErrorResponse(response);
284
+ };
285
+ // Annotate the CommonJS export names for ESM import in node:
286
+ 0 && (module.exports = {
287
+ BigCommerceConfig,
288
+ BigCommerceConfigLive,
289
+ BigCommerceConfigTest,
290
+ BigCommerceConflictError,
291
+ BigCommerceConnectionError,
292
+ BigCommerceFetcher,
293
+ BigCommerceFetcherLive,
294
+ BigCommerceForbiddenError,
295
+ BigCommerceInvalidRequestError,
296
+ BigCommerceInvalidResponseError,
297
+ BigCommerceNotFoundError,
298
+ BigCommerceParseResponseError,
299
+ BigCommerceUnauthorizedError,
300
+ BigCommerceUnknownError,
301
+ BigCommerceUnprocessableEntityError,
302
+ NoBigCommerceConfigError
303
+ });
304
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/core/index.ts","../src/core/bigcommerce.error.ts","../src/core/bigcommerce.fetcher.ts","../src/core/bigcommerce.fetcher.live.ts","../src/constants.ts","../src/core/config.ts"],"sourcesContent":["export * from './bigcommerce.error';\nexport * from './bigcommerce.fetcher';\nexport * from './bigcommerce.fetcher.live';\nexport * from './config';\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 { 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 { 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"],"mappings":"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","names":["import_effect","import_effect","import_effect","import_effect","code"]}
package/dist/index.mjs ADDED
@@ -0,0 +1,37 @@
1
+ import {
2
+ BigCommerceConfig,
3
+ BigCommerceConfigLive,
4
+ BigCommerceConfigTest,
5
+ BigCommerceConflictError,
6
+ BigCommerceConnectionError,
7
+ BigCommerceFetcher,
8
+ BigCommerceFetcherLive,
9
+ BigCommerceForbiddenError,
10
+ BigCommerceInvalidRequestError,
11
+ BigCommerceInvalidResponseError,
12
+ BigCommerceNotFoundError,
13
+ BigCommerceParseResponseError,
14
+ BigCommerceUnauthorizedError,
15
+ BigCommerceUnknownError,
16
+ BigCommerceUnprocessableEntityError,
17
+ NoBigCommerceConfigError
18
+ } from "./chunk-7GBRYAQG.mjs";
19
+ export {
20
+ BigCommerceConfig,
21
+ BigCommerceConfigLive,
22
+ BigCommerceConfigTest,
23
+ BigCommerceConflictError,
24
+ BigCommerceConnectionError,
25
+ BigCommerceFetcher,
26
+ BigCommerceFetcherLive,
27
+ BigCommerceForbiddenError,
28
+ BigCommerceInvalidRequestError,
29
+ BigCommerceInvalidResponseError,
30
+ BigCommerceNotFoundError,
31
+ BigCommerceParseResponseError,
32
+ BigCommerceUnauthorizedError,
33
+ BigCommerceUnknownError,
34
+ BigCommerceUnprocessableEntityError,
35
+ NoBigCommerceConfigError
36
+ };
37
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}