@roarkanalytics/sdk 0.1.0-alpha.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (246) hide show
  1. package/CHANGELOG.md +25 -0
  2. package/LICENSE +201 -0
  3. package/README.md +344 -0
  4. package/api-promise.d.mts +47 -0
  5. package/api-promise.d.mts.map +1 -0
  6. package/api-promise.d.ts +47 -0
  7. package/api-promise.d.ts.map +1 -0
  8. package/api-promise.js +84 -0
  9. package/api-promise.js.map +1 -0
  10. package/api-promise.mjs +80 -0
  11. package/api-promise.mjs.map +1 -0
  12. package/client.d.mts +186 -0
  13. package/client.d.mts.map +1 -0
  14. package/client.d.ts +186 -0
  15. package/client.d.ts.map +1 -0
  16. package/client.js +449 -0
  17. package/client.js.map +1 -0
  18. package/client.mjs +422 -0
  19. package/client.mjs.map +1 -0
  20. package/error.d.mts +47 -0
  21. package/error.d.mts.map +1 -0
  22. package/error.d.ts +47 -0
  23. package/error.d.ts.map +1 -0
  24. package/error.js +113 -0
  25. package/error.js.map +1 -0
  26. package/error.mjs +97 -0
  27. package/error.mjs.map +1 -0
  28. package/index.d.mts +6 -0
  29. package/index.d.mts.map +1 -0
  30. package/index.d.ts +6 -0
  31. package/index.d.ts.map +1 -0
  32. package/index.js +30 -0
  33. package/index.js.map +1 -0
  34. package/index.mjs +7 -0
  35. package/index.mjs.map +1 -0
  36. package/internal/builtin-types.d.mts +65 -0
  37. package/internal/builtin-types.d.mts.map +1 -0
  38. package/internal/builtin-types.d.ts +65 -0
  39. package/internal/builtin-types.d.ts.map +1 -0
  40. package/internal/builtin-types.js +4 -0
  41. package/internal/builtin-types.js.map +1 -0
  42. package/internal/builtin-types.mjs +3 -0
  43. package/internal/builtin-types.mjs.map +1 -0
  44. package/internal/detect-platform.d.mts +15 -0
  45. package/internal/detect-platform.d.mts.map +1 -0
  46. package/internal/detect-platform.d.ts +15 -0
  47. package/internal/detect-platform.d.ts.map +1 -0
  48. package/internal/detect-platform.js +162 -0
  49. package/internal/detect-platform.js.map +1 -0
  50. package/internal/detect-platform.mjs +157 -0
  51. package/internal/detect-platform.mjs.map +1 -0
  52. package/internal/errors.d.mts +3 -0
  53. package/internal/errors.d.mts.map +1 -0
  54. package/internal/errors.d.ts +3 -0
  55. package/internal/errors.d.ts.map +1 -0
  56. package/internal/errors.js +26 -0
  57. package/internal/errors.js.map +1 -0
  58. package/internal/errors.mjs +21 -0
  59. package/internal/errors.mjs.map +1 -0
  60. package/internal/headers.d.mts +21 -0
  61. package/internal/headers.d.mts.map +1 -0
  62. package/internal/headers.d.ts +21 -0
  63. package/internal/headers.d.ts.map +1 -0
  64. package/internal/headers.js +77 -0
  65. package/internal/headers.js.map +1 -0
  66. package/internal/headers.mjs +72 -0
  67. package/internal/headers.mjs.map +1 -0
  68. package/internal/parse.d.mts +10 -0
  69. package/internal/parse.d.mts.map +1 -0
  70. package/internal/parse.d.ts +10 -0
  71. package/internal/parse.d.ts.map +1 -0
  72. package/internal/parse.js +28 -0
  73. package/internal/parse.js.map +1 -0
  74. package/internal/parse.mjs +24 -0
  75. package/internal/parse.mjs.map +1 -0
  76. package/internal/polyfill/crypto.node.d.ts +10 -0
  77. package/internal/polyfill/crypto.node.js +11 -0
  78. package/internal/polyfill/crypto.node.mjs +2 -0
  79. package/internal/polyfill/file.node.d.ts +9 -0
  80. package/internal/polyfill/file.node.js +17 -0
  81. package/internal/polyfill/file.node.mjs +9 -0
  82. package/internal/request-options.d.mts +34 -0
  83. package/internal/request-options.d.mts.map +1 -0
  84. package/internal/request-options.d.ts +34 -0
  85. package/internal/request-options.d.ts.map +1 -0
  86. package/internal/request-options.js +39 -0
  87. package/internal/request-options.js.map +1 -0
  88. package/internal/request-options.mjs +34 -0
  89. package/internal/request-options.mjs.map +1 -0
  90. package/internal/shim-types.d.mts +28 -0
  91. package/internal/shim-types.d.ts +28 -0
  92. package/internal/shims.d.mts +61 -0
  93. package/internal/shims.d.mts.map +1 -0
  94. package/internal/shims.d.ts +61 -0
  95. package/internal/shims.d.ts.map +1 -0
  96. package/internal/shims.js +101 -0
  97. package/internal/shims.js.map +1 -0
  98. package/internal/shims.mjs +92 -0
  99. package/internal/shims.mjs.map +1 -0
  100. package/internal/types.d.mts +68 -0
  101. package/internal/types.d.mts.map +1 -0
  102. package/internal/types.d.ts +68 -0
  103. package/internal/types.d.ts.map +1 -0
  104. package/internal/types.js +4 -0
  105. package/internal/types.js.map +1 -0
  106. package/internal/types.mjs +3 -0
  107. package/internal/types.mjs.map +1 -0
  108. package/internal/uploads.d.mts +73 -0
  109. package/internal/uploads.d.mts.map +1 -0
  110. package/internal/uploads.d.ts +73 -0
  111. package/internal/uploads.d.ts.map +1 -0
  112. package/internal/uploads.js +208 -0
  113. package/internal/uploads.js.map +1 -0
  114. package/internal/uploads.mjs +200 -0
  115. package/internal/uploads.mjs.map +1 -0
  116. package/internal/utils/base64.d.mts +3 -0
  117. package/internal/utils/base64.d.mts.map +1 -0
  118. package/internal/utils/base64.d.ts +3 -0
  119. package/internal/utils/base64.d.ts.map +1 -0
  120. package/internal/utils/base64.js +33 -0
  121. package/internal/utils/base64.js.map +1 -0
  122. package/internal/utils/base64.mjs +28 -0
  123. package/internal/utils/base64.mjs.map +1 -0
  124. package/internal/utils/env.d.mts +9 -0
  125. package/internal/utils/env.d.mts.map +1 -0
  126. package/internal/utils/env.d.ts +9 -0
  127. package/internal/utils/env.d.ts.map +1 -0
  128. package/internal/utils/env.js +22 -0
  129. package/internal/utils/env.js.map +1 -0
  130. package/internal/utils/env.mjs +18 -0
  131. package/internal/utils/env.mjs.map +1 -0
  132. package/internal/utils/log.d.mts +4 -0
  133. package/internal/utils/log.d.mts.map +1 -0
  134. package/internal/utils/log.d.ts +4 -0
  135. package/internal/utils/log.d.ts.map +1 -0
  136. package/internal/utils/log.js +47 -0
  137. package/internal/utils/log.js.map +1 -0
  138. package/internal/utils/log.mjs +43 -0
  139. package/internal/utils/log.mjs.map +1 -0
  140. package/internal/utils/sleep.d.mts +2 -0
  141. package/internal/utils/sleep.d.mts.map +1 -0
  142. package/internal/utils/sleep.d.ts +2 -0
  143. package/internal/utils/sleep.d.ts.map +1 -0
  144. package/internal/utils/sleep.js +7 -0
  145. package/internal/utils/sleep.js.map +1 -0
  146. package/internal/utils/sleep.mjs +3 -0
  147. package/internal/utils/sleep.mjs.map +1 -0
  148. package/internal/utils/uuid.d.mts +5 -0
  149. package/internal/utils/uuid.d.mts.map +1 -0
  150. package/internal/utils/uuid.d.ts +5 -0
  151. package/internal/utils/uuid.d.ts.map +1 -0
  152. package/internal/utils/uuid.js +15 -0
  153. package/internal/utils/uuid.js.map +1 -0
  154. package/internal/utils/uuid.mjs +11 -0
  155. package/internal/utils/uuid.mjs.map +1 -0
  156. package/internal/utils/values.d.mts +15 -0
  157. package/internal/utils/values.d.mts.map +1 -0
  158. package/internal/utils/values.d.ts +15 -0
  159. package/internal/utils/values.d.ts.map +1 -0
  160. package/internal/utils/values.js +100 -0
  161. package/internal/utils/values.js.map +1 -0
  162. package/internal/utils/values.mjs +84 -0
  163. package/internal/utils/values.mjs.map +1 -0
  164. package/internal/utils.d.mts +7 -0
  165. package/internal/utils.d.mts.map +1 -0
  166. package/internal/utils.d.ts +7 -0
  167. package/internal/utils.d.ts.map +1 -0
  168. package/internal/utils.js +24 -0
  169. package/internal/utils.js.map +1 -0
  170. package/internal/utils.mjs +8 -0
  171. package/internal/utils.mjs.map +1 -0
  172. package/package.json +119 -0
  173. package/resource.d.mts +6 -0
  174. package/resource.d.mts.map +1 -0
  175. package/resource.d.ts +6 -0
  176. package/resource.d.ts.map +1 -0
  177. package/resource.js +11 -0
  178. package/resource.js.map +1 -0
  179. package/resource.mjs +7 -0
  180. package/resource.mjs.map +1 -0
  181. package/resources/calls.d.mts +85 -0
  182. package/resources/calls.d.mts.map +1 -0
  183. package/resources/calls.d.ts +85 -0
  184. package/resources/calls.d.ts.map +1 -0
  185. package/resources/calls.js +15 -0
  186. package/resources/calls.js.map +1 -0
  187. package/resources/calls.mjs +11 -0
  188. package/resources/calls.mjs.map +1 -0
  189. package/resources/index.d.mts +2 -0
  190. package/resources/index.d.mts.map +1 -0
  191. package/resources/index.d.ts +2 -0
  192. package/resources/index.d.ts.map +1 -0
  193. package/resources/index.js +7 -0
  194. package/resources/index.js.map +1 -0
  195. package/resources/index.mjs +3 -0
  196. package/resources/index.mjs.map +1 -0
  197. package/src/api-promise.ts +92 -0
  198. package/src/client.ts +646 -0
  199. package/src/error.ts +130 -0
  200. package/src/index.ts +22 -0
  201. package/src/internal/builtin-types.ts +79 -0
  202. package/src/internal/detect-platform.ts +196 -0
  203. package/src/internal/errors.ts +22 -0
  204. package/src/internal/headers.ts +96 -0
  205. package/src/internal/parse.ts +41 -0
  206. package/src/internal/polyfill/crypto.node.d.ts +10 -0
  207. package/src/internal/polyfill/crypto.node.js +11 -0
  208. package/src/internal/polyfill/crypto.node.mjs +2 -0
  209. package/src/internal/polyfill/file.node.d.ts +9 -0
  210. package/src/internal/polyfill/file.node.js +17 -0
  211. package/src/internal/polyfill/file.node.mjs +9 -0
  212. package/src/internal/request-options.ts +67 -0
  213. package/src/internal/shim-types.d.ts +28 -0
  214. package/src/internal/shims.ts +145 -0
  215. package/src/internal/types.ts +98 -0
  216. package/src/internal/uploads.ts +307 -0
  217. package/src/internal/utils/base64.ts +37 -0
  218. package/src/internal/utils/env.ts +18 -0
  219. package/src/internal/utils/log.ts +49 -0
  220. package/src/internal/utils/sleep.ts +3 -0
  221. package/src/internal/utils/uuid.ts +13 -0
  222. package/src/internal/utils/values.ts +94 -0
  223. package/src/internal/utils.ts +8 -0
  224. package/src/lib/.keep +4 -0
  225. package/src/resource.ts +11 -0
  226. package/src/resources/calls.ts +118 -0
  227. package/src/resources/index.ts +3 -0
  228. package/src/tsconfig.json +11 -0
  229. package/src/uploads.ts +1 -0
  230. package/src/version.ts +1 -0
  231. package/uploads.d.mts +2 -0
  232. package/uploads.d.mts.map +1 -0
  233. package/uploads.d.ts +2 -0
  234. package/uploads.d.ts.map +1 -0
  235. package/uploads.js +6 -0
  236. package/uploads.js.map +1 -0
  237. package/uploads.mjs +2 -0
  238. package/uploads.mjs.map +1 -0
  239. package/version.d.mts +2 -0
  240. package/version.d.mts.map +1 -0
  241. package/version.d.ts +2 -0
  242. package/version.d.ts.map +1 -0
  243. package/version.js +5 -0
  244. package/version.js.map +1 -0
  245. package/version.mjs +2 -0
  246. package/version.mjs.map +1 -0
package/src/error.ts ADDED
@@ -0,0 +1,130 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ import { castToError } from './internal/errors';
4
+
5
+ export class PetstoreError extends Error {}
6
+
7
+ export class APIError<
8
+ TStatus extends number | undefined = number | undefined,
9
+ THeaders extends Headers | undefined = Headers | undefined,
10
+ TError extends Object | undefined = Object | undefined,
11
+ > extends PetstoreError {
12
+ /** HTTP status for the response that caused the error */
13
+ readonly status: TStatus;
14
+ /** HTTP headers for the response that caused the error */
15
+ readonly headers: THeaders;
16
+ /** JSON body of the response that caused the error */
17
+ readonly error: TError;
18
+
19
+ constructor(status: TStatus, error: TError, message: string | undefined, headers: THeaders) {
20
+ super(`${APIError.makeMessage(status, error, message)}`);
21
+ this.status = status;
22
+ this.headers = headers;
23
+ this.error = error;
24
+ }
25
+
26
+ private static makeMessage(status: number | undefined, error: any, message: string | undefined) {
27
+ const msg =
28
+ error?.message ?
29
+ typeof error.message === 'string' ?
30
+ error.message
31
+ : JSON.stringify(error.message)
32
+ : error ? JSON.stringify(error)
33
+ : message;
34
+
35
+ if (status && msg) {
36
+ return `${status} ${msg}`;
37
+ }
38
+ if (status) {
39
+ return `${status} status code (no body)`;
40
+ }
41
+ if (msg) {
42
+ return msg;
43
+ }
44
+ return '(no status code or body)';
45
+ }
46
+
47
+ static generate(
48
+ status: number | undefined,
49
+ errorResponse: Object | undefined,
50
+ message: string | undefined,
51
+ headers: Headers | undefined,
52
+ ): APIError {
53
+ if (!status || !headers) {
54
+ return new APIConnectionError({ message, cause: castToError(errorResponse) });
55
+ }
56
+
57
+ const error = errorResponse as Record<string, any>;
58
+
59
+ if (status === 400) {
60
+ return new BadRequestError(status, error, message, headers);
61
+ }
62
+
63
+ if (status === 401) {
64
+ return new AuthenticationError(status, error, message, headers);
65
+ }
66
+
67
+ if (status === 403) {
68
+ return new PermissionDeniedError(status, error, message, headers);
69
+ }
70
+
71
+ if (status === 404) {
72
+ return new NotFoundError(status, error, message, headers);
73
+ }
74
+
75
+ if (status === 409) {
76
+ return new ConflictError(status, error, message, headers);
77
+ }
78
+
79
+ if (status === 422) {
80
+ return new UnprocessableEntityError(status, error, message, headers);
81
+ }
82
+
83
+ if (status === 429) {
84
+ return new RateLimitError(status, error, message, headers);
85
+ }
86
+
87
+ if (status >= 500) {
88
+ return new InternalServerError(status, error, message, headers);
89
+ }
90
+
91
+ return new APIError(status, error, message, headers);
92
+ }
93
+ }
94
+
95
+ export class APIUserAbortError extends APIError<undefined, undefined, undefined> {
96
+ constructor({ message }: { message?: string } = {}) {
97
+ super(undefined, undefined, message || 'Request was aborted.', undefined);
98
+ }
99
+ }
100
+
101
+ export class APIConnectionError extends APIError<undefined, undefined, undefined> {
102
+ constructor({ message, cause }: { message?: string | undefined; cause?: Error | undefined }) {
103
+ super(undefined, undefined, message || 'Connection error.', undefined);
104
+ // in some environments the 'cause' property is already declared
105
+ // @ts-ignore
106
+ if (cause) this.cause = cause;
107
+ }
108
+ }
109
+
110
+ export class APIConnectionTimeoutError extends APIConnectionError {
111
+ constructor({ message }: { message?: string } = {}) {
112
+ super({ message: message ?? 'Request timed out.' });
113
+ }
114
+ }
115
+
116
+ export class BadRequestError extends APIError<400, Headers> {}
117
+
118
+ export class AuthenticationError extends APIError<401, Headers> {}
119
+
120
+ export class PermissionDeniedError extends APIError<403, Headers> {}
121
+
122
+ export class NotFoundError extends APIError<404, Headers> {}
123
+
124
+ export class ConflictError extends APIError<409, Headers> {}
125
+
126
+ export class UnprocessableEntityError extends APIError<422, Headers> {}
127
+
128
+ export class RateLimitError extends APIError<429, Headers> {}
129
+
130
+ export class InternalServerError extends APIError<number, Headers> {}
package/src/index.ts ADDED
@@ -0,0 +1,22 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ export { Petstore as default } from './client';
4
+
5
+ export { type Uploadable, toFile } from './uploads';
6
+ export { APIPromise } from './api-promise';
7
+ export { Petstore, type ClientOptions } from './client';
8
+ export {
9
+ PetstoreError,
10
+ APIError,
11
+ APIConnectionError,
12
+ APIConnectionTimeoutError,
13
+ APIUserAbortError,
14
+ NotFoundError,
15
+ ConflictError,
16
+ RateLimitError,
17
+ BadRequestError,
18
+ AuthenticationError,
19
+ InternalServerError,
20
+ PermissionDeniedError,
21
+ UnprocessableEntityError,
22
+ } from './error';
@@ -0,0 +1,79 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ export type Fetch = (input: string | URL | Request, init?: RequestInit) => Promise<Response>;
4
+
5
+ /**
6
+ * An alias to the builtin `RequestInit` type so we can
7
+ * easily alias it in import statements if there are name clashes.
8
+ *
9
+ * https://developer.mozilla.org/docs/Web/API/RequestInit
10
+ */
11
+ type _RequestInit = RequestInit;
12
+
13
+ /**
14
+ * An alias to the builtin `Response` type so we can
15
+ * easily alias it in import statements if there are name clashes.
16
+ *
17
+ * https://developer.mozilla.org/docs/Web/API/Response
18
+ */
19
+ type _Response = Response;
20
+
21
+ /**
22
+ * The type for the first argument to `fetch`.
23
+ *
24
+ * https://developer.mozilla.org/docs/Web/API/Window/fetch#resource
25
+ */
26
+ type _RequestInfo = Request | URL | string;
27
+
28
+ /**
29
+ * The type for constructing `RequestInit` Headers.
30
+ *
31
+ * https://developer.mozilla.org/docs/Web/API/RequestInit#setting_headers
32
+ */
33
+ type _HeadersInit = RequestInit['headers'];
34
+
35
+ /**
36
+ * The type for constructing `RequestInit` body.
37
+ *
38
+ * https://developer.mozilla.org/docs/Web/API/RequestInit#body
39
+ */
40
+ type _BodyInit = RequestInit['body'];
41
+
42
+ export type {
43
+ _BodyInit as BodyInit,
44
+ _HeadersInit as HeadersInit,
45
+ _RequestInfo as RequestInfo,
46
+ _RequestInit as RequestInit,
47
+ _Response as Response,
48
+ };
49
+
50
+ /**
51
+ * A copy of the builtin `EndingType` type as it isn't fully supported in certain
52
+ * environments and attempting to reference the global version will error.
53
+ *
54
+ * https://github.com/microsoft/TypeScript/blob/49ad1a3917a0ea57f5ff248159256e12bb1cb705/src/lib/dom.generated.d.ts#L27941
55
+ */
56
+ type EndingType = 'native' | 'transparent';
57
+
58
+ /**
59
+ * A copy of the builtin `BlobPropertyBag` type as it isn't fully supported in certain
60
+ * environments and attempting to reference the global version will error.
61
+ *
62
+ * https://github.com/microsoft/TypeScript/blob/49ad1a3917a0ea57f5ff248159256e12bb1cb705/src/lib/dom.generated.d.ts#L154
63
+ * https://developer.mozilla.org/en-US/docs/Web/API/Blob/Blob#options
64
+ */
65
+ export interface BlobPropertyBag {
66
+ endings?: EndingType;
67
+ type?: string;
68
+ }
69
+
70
+ /**
71
+ * A copy of the builtin `FilePropertyBag` type as it isn't fully supported in certain
72
+ * environments and attempting to reference the global version will error.
73
+ *
74
+ * https://github.com/microsoft/TypeScript/blob/49ad1a3917a0ea57f5ff248159256e12bb1cb705/src/lib/dom.generated.d.ts#L503
75
+ * https://developer.mozilla.org/en-US/docs/Web/API/File/File#options
76
+ */
77
+ export interface FilePropertyBag extends BlobPropertyBag {
78
+ lastModified?: number;
79
+ }
@@ -0,0 +1,196 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ import { VERSION } from '../version';
4
+
5
+ export const isRunningInBrowser = () => {
6
+ return (
7
+ // @ts-ignore
8
+ typeof window !== 'undefined' &&
9
+ // @ts-ignore
10
+ typeof window.document !== 'undefined' &&
11
+ // @ts-ignore
12
+ typeof navigator !== 'undefined'
13
+ );
14
+ };
15
+
16
+ type DetectedPlatform = 'deno' | 'node' | 'edge' | 'unknown';
17
+
18
+ /**
19
+ * Note this does not detect 'browser'; for that, use getBrowserInfo().
20
+ */
21
+ function getDetectedPlatform(): DetectedPlatform {
22
+ if (typeof Deno !== 'undefined' && Deno.build != null) {
23
+ return 'deno';
24
+ }
25
+ if (typeof EdgeRuntime !== 'undefined') {
26
+ return 'edge';
27
+ }
28
+ if (
29
+ Object.prototype.toString.call(
30
+ typeof (globalThis as any).process !== 'undefined' ? (globalThis as any).process : 0,
31
+ ) === '[object process]'
32
+ ) {
33
+ return 'node';
34
+ }
35
+ return 'unknown';
36
+ }
37
+
38
+ declare const Deno: any;
39
+ declare const EdgeRuntime: any;
40
+ type Arch = 'x32' | 'x64' | 'arm' | 'arm64' | `other:${string}` | 'unknown';
41
+ type PlatformName =
42
+ | 'MacOS'
43
+ | 'Linux'
44
+ | 'Windows'
45
+ | 'FreeBSD'
46
+ | 'OpenBSD'
47
+ | 'iOS'
48
+ | 'Android'
49
+ | `Other:${string}`
50
+ | 'Unknown';
51
+ type Browser = 'ie' | 'edge' | 'chrome' | 'firefox' | 'safari';
52
+ type PlatformProperties = {
53
+ 'X-Stainless-Lang': 'js';
54
+ 'X-Stainless-Package-Version': string;
55
+ 'X-Stainless-OS': PlatformName;
56
+ 'X-Stainless-Arch': Arch;
57
+ 'X-Stainless-Runtime': 'node' | 'deno' | 'edge' | `browser:${Browser}` | 'unknown';
58
+ 'X-Stainless-Runtime-Version': string;
59
+ };
60
+ const getPlatformProperties = (): PlatformProperties => {
61
+ const detectedPlatform = getDetectedPlatform();
62
+ if (detectedPlatform === 'deno') {
63
+ return {
64
+ 'X-Stainless-Lang': 'js',
65
+ 'X-Stainless-Package-Version': VERSION,
66
+ 'X-Stainless-OS': normalizePlatform(Deno.build.os),
67
+ 'X-Stainless-Arch': normalizeArch(Deno.build.arch),
68
+ 'X-Stainless-Runtime': 'deno',
69
+ 'X-Stainless-Runtime-Version':
70
+ typeof Deno.version === 'string' ? Deno.version : Deno.version?.deno ?? 'unknown',
71
+ };
72
+ }
73
+ if (typeof EdgeRuntime !== 'undefined') {
74
+ return {
75
+ 'X-Stainless-Lang': 'js',
76
+ 'X-Stainless-Package-Version': VERSION,
77
+ 'X-Stainless-OS': 'Unknown',
78
+ 'X-Stainless-Arch': `other:${EdgeRuntime}`,
79
+ 'X-Stainless-Runtime': 'edge',
80
+ 'X-Stainless-Runtime-Version': (globalThis as any).process.version,
81
+ };
82
+ }
83
+ // Check if Node.js
84
+ if (detectedPlatform === 'node') {
85
+ return {
86
+ 'X-Stainless-Lang': 'js',
87
+ 'X-Stainless-Package-Version': VERSION,
88
+ 'X-Stainless-OS': normalizePlatform((globalThis as any).process.platform),
89
+ 'X-Stainless-Arch': normalizeArch((globalThis as any).process.arch),
90
+ 'X-Stainless-Runtime': 'node',
91
+ 'X-Stainless-Runtime-Version': (globalThis as any).process.version,
92
+ };
93
+ }
94
+
95
+ const browserInfo = getBrowserInfo();
96
+ if (browserInfo) {
97
+ return {
98
+ 'X-Stainless-Lang': 'js',
99
+ 'X-Stainless-Package-Version': VERSION,
100
+ 'X-Stainless-OS': 'Unknown',
101
+ 'X-Stainless-Arch': 'unknown',
102
+ 'X-Stainless-Runtime': `browser:${browserInfo.browser}`,
103
+ 'X-Stainless-Runtime-Version': browserInfo.version,
104
+ };
105
+ }
106
+
107
+ // TODO add support for Cloudflare workers, etc.
108
+ return {
109
+ 'X-Stainless-Lang': 'js',
110
+ 'X-Stainless-Package-Version': VERSION,
111
+ 'X-Stainless-OS': 'Unknown',
112
+ 'X-Stainless-Arch': 'unknown',
113
+ 'X-Stainless-Runtime': 'unknown',
114
+ 'X-Stainless-Runtime-Version': 'unknown',
115
+ };
116
+ };
117
+
118
+ type BrowserInfo = {
119
+ browser: Browser;
120
+ version: string;
121
+ };
122
+
123
+ declare const navigator: { userAgent: string } | undefined;
124
+
125
+ // Note: modified from https://github.com/JS-DevTools/host-environment/blob/b1ab79ecde37db5d6e163c050e54fe7d287d7c92/src/isomorphic.browser.ts
126
+ function getBrowserInfo(): BrowserInfo | null {
127
+ if (typeof navigator === 'undefined' || !navigator) {
128
+ return null;
129
+ }
130
+
131
+ // NOTE: The order matters here!
132
+ const browserPatterns = [
133
+ { key: 'edge' as const, pattern: /Edge(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/ },
134
+ { key: 'ie' as const, pattern: /MSIE(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/ },
135
+ { key: 'ie' as const, pattern: /Trident(?:.*rv\:(\d+)\.(\d+)(?:\.(\d+))?)?/ },
136
+ { key: 'chrome' as const, pattern: /Chrome(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/ },
137
+ { key: 'firefox' as const, pattern: /Firefox(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/ },
138
+ { key: 'safari' as const, pattern: /(?:Version\W+(\d+)\.(\d+)(?:\.(\d+))?)?(?:\W+Mobile\S*)?\W+Safari/ },
139
+ ];
140
+
141
+ // Find the FIRST matching browser
142
+ for (const { key, pattern } of browserPatterns) {
143
+ const match = pattern.exec(navigator.userAgent);
144
+ if (match) {
145
+ const major = match[1] || 0;
146
+ const minor = match[2] || 0;
147
+ const patch = match[3] || 0;
148
+
149
+ return { browser: key, version: `${major}.${minor}.${patch}` };
150
+ }
151
+ }
152
+
153
+ return null;
154
+ }
155
+
156
+ const normalizeArch = (arch: string): Arch => {
157
+ // Node docs:
158
+ // - https://nodejs.org/api/process.html#processarch
159
+ // Deno docs:
160
+ // - https://doc.deno.land/deno/stable/~/Deno.build
161
+ if (arch === 'x32') return 'x32';
162
+ if (arch === 'x86_64' || arch === 'x64') return 'x64';
163
+ if (arch === 'arm') return 'arm';
164
+ if (arch === 'aarch64' || arch === 'arm64') return 'arm64';
165
+ if (arch) return `other:${arch}`;
166
+ return 'unknown';
167
+ };
168
+
169
+ const normalizePlatform = (platform: string): PlatformName => {
170
+ // Node platforms:
171
+ // - https://nodejs.org/api/process.html#processplatform
172
+ // Deno platforms:
173
+ // - https://doc.deno.land/deno/stable/~/Deno.build
174
+ // - https://github.com/denoland/deno/issues/14799
175
+
176
+ platform = platform.toLowerCase();
177
+
178
+ // NOTE: this iOS check is untested and may not work
179
+ // Node does not work natively on IOS, there is a fork at
180
+ // https://github.com/nodejs-mobile/nodejs-mobile
181
+ // however it is unknown at the time of writing how to detect if it is running
182
+ if (platform.includes('ios')) return 'iOS';
183
+ if (platform === 'android') return 'Android';
184
+ if (platform === 'darwin') return 'MacOS';
185
+ if (platform === 'win32') return 'Windows';
186
+ if (platform === 'freebsd') return 'FreeBSD';
187
+ if (platform === 'openbsd') return 'OpenBSD';
188
+ if (platform === 'linux') return 'Linux';
189
+ if (platform) return `Other:${platform}`;
190
+ return 'Unknown';
191
+ };
192
+
193
+ let _platformHeaders: PlatformProperties;
194
+ export const getPlatformHeaders = () => {
195
+ return (_platformHeaders ??= getPlatformProperties());
196
+ };
@@ -0,0 +1,22 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ export function isAbortError(err: unknown) {
4
+ return (
5
+ typeof err === 'object' &&
6
+ err !== null &&
7
+ // Spec-compliant fetch implementations
8
+ (('name' in err && (err as any).name === 'AbortError') ||
9
+ // Expo fetch
10
+ ('message' in err && String((err as any).message).includes('FetchRequestCanceledException')))
11
+ );
12
+ }
13
+
14
+ export const castToError = (err: any): Error => {
15
+ if (err instanceof Error) return err;
16
+ if (typeof err === 'object' && err !== null) {
17
+ try {
18
+ return new Error(JSON.stringify(err));
19
+ } catch {}
20
+ }
21
+ return new Error(err);
22
+ };
@@ -0,0 +1,96 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ type HeaderValue = string | undefined | null;
4
+ export type HeadersLike =
5
+ | Headers
6
+ | readonly [string, HeaderValue][]
7
+ | Record<string, HeaderValue | readonly HeaderValue[]>
8
+ | undefined
9
+ | null
10
+ | NullableHeaders;
11
+
12
+ const brand_privateNullableHeaders = Symbol('brand.privateNullableHeaders');
13
+
14
+ /**
15
+ * @internal
16
+ * Users can pass explicit nulls to unset default headers. When we parse them
17
+ * into a standard headers type we need to preserve that information.
18
+ */
19
+ export type NullableHeaders = {
20
+ /** Brand check, prevent users from creating a NullableHeaders. */
21
+ [brand_privateNullableHeaders]: true;
22
+ /** Parsed headers. */
23
+ values: Headers;
24
+ /** Set of lowercase header names explicitly set to null. */
25
+ nulls: Set<string>;
26
+ };
27
+
28
+ const isArray = Array.isArray as (val: unknown) => val is readonly unknown[];
29
+
30
+ function* iterateHeaders(headers: HeadersLike): IterableIterator<readonly [string, string | null]> {
31
+ if (!headers) return;
32
+
33
+ if (brand_privateNullableHeaders in headers) {
34
+ const { values, nulls } = headers;
35
+ yield* values.entries();
36
+ for (const name of nulls) {
37
+ yield [name, null];
38
+ }
39
+ return;
40
+ }
41
+
42
+ let shouldClear = false;
43
+ let iter: Iterable<readonly [string, HeaderValue | readonly HeaderValue[]]>;
44
+ if (headers instanceof Headers) {
45
+ iter = headers.entries();
46
+ } else if (isArray(headers)) {
47
+ iter = headers;
48
+ } else {
49
+ shouldClear = true;
50
+ iter = Object.entries(headers ?? {});
51
+ }
52
+ for (let row of iter) {
53
+ const name = row[0];
54
+ const values = isArray(row[1]) ? row[1] : [row[1]];
55
+ let didClear = false;
56
+ for (const value of values) {
57
+ if (value === undefined) continue;
58
+
59
+ // Objects keys always overwrite older headers, they never append.
60
+ // Yield a null to clear the header before adding the new values.
61
+ if (shouldClear && !didClear) {
62
+ didClear = true;
63
+ yield [name, null];
64
+ }
65
+ yield [name, value];
66
+ }
67
+ }
68
+ }
69
+
70
+ export const buildHeaders = (newHeaders: HeadersLike[]): NullableHeaders => {
71
+ const targetHeaders = new Headers();
72
+ const nullHeaders = new Set<string>();
73
+ const seenHeaders = new Set<string>();
74
+ for (const headers of newHeaders) {
75
+ for (const [name, value] of iterateHeaders(headers)) {
76
+ const lowerName = name.toLowerCase();
77
+ if (!seenHeaders.has(lowerName)) {
78
+ targetHeaders.delete(name);
79
+ seenHeaders.add(lowerName);
80
+ }
81
+ if (value === null) {
82
+ targetHeaders.delete(name);
83
+ nullHeaders.add(lowerName);
84
+ } else {
85
+ targetHeaders.append(name, value);
86
+ nullHeaders.delete(lowerName);
87
+ }
88
+ }
89
+ }
90
+ return { [brand_privateNullableHeaders]: true, values: targetHeaders, nulls: nullHeaders };
91
+ };
92
+
93
+ export const isEmptyHeaders = (headers: HeadersLike) => {
94
+ for (const _ of iterateHeaders(headers)) return false;
95
+ return true;
96
+ };
@@ -0,0 +1,41 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ import type { FinalRequestOptions } from './request-options';
4
+ import { type Petstore } from '../client';
5
+ import { logger } from './utils/log';
6
+
7
+ export type APIResponseProps = {
8
+ response: Response;
9
+ options: FinalRequestOptions;
10
+ controller: AbortController;
11
+ };
12
+
13
+ export async function defaultParseResponse<T>(client: Petstore, props: APIResponseProps): Promise<T> {
14
+ const { response } = props;
15
+
16
+ // fetch refuses to read the body when the status code is 204.
17
+ if (response.status === 204) {
18
+ return null as T;
19
+ }
20
+
21
+ if (props.options.__binaryResponse) {
22
+ return response as unknown as T;
23
+ }
24
+
25
+ const contentType = response.headers.get('content-type');
26
+ const isJSON =
27
+ contentType?.includes('application/json') || contentType?.includes('application/vnd.api+json');
28
+ if (isJSON) {
29
+ const json = await response.json();
30
+
31
+ logger(client).debug('response', response.status, response.url, response.headers, json);
32
+
33
+ return json as T;
34
+ }
35
+
36
+ const text = await response.text();
37
+ logger(client).debug('response', response.status, response.url, response.headers, text);
38
+
39
+ // TODO handle blob, arraybuffer, other content types, etc.
40
+ return text as unknown as T;
41
+ }
@@ -0,0 +1,10 @@
1
+ export declare const crypto: {
2
+ /** [MDN Reference](https://developer.mozilla.org/docs/Web/API/Crypto/getRandomValues) */
3
+ getRandomValues<T extends ArrayBufferView | null>(array: T): T;
4
+ /**
5
+ * Available only in secure contexts.
6
+ *
7
+ * [MDN Reference](https://developer.mozilla.org/docs/Web/API/Crypto/randomUUID)
8
+ */
9
+ randomUUID?: () => string;
10
+ };
@@ -0,0 +1,11 @@
1
+ if (typeof require !== 'undefined') {
2
+ if (globalThis.crypto) {
3
+ exports.crypto = globalThis.crypto;
4
+ } else {
5
+ try {
6
+ // Use [require][0](...) and not require(...) so bundlers don't try to bundle the
7
+ // crypto module.
8
+ exports.crypto = [require][0]('node:crypto').webcrypto;
9
+ } catch (e) {}
10
+ }
11
+ }
@@ -0,0 +1,2 @@
1
+ import * as mod from './crypto.node.js';
2
+ export const crypto = globalThis.crypto || mod.crypto;
@@ -0,0 +1,9 @@
1
+ /**
2
+ * This file polyfills the global `File` object for you if it's not already defined
3
+ * when running on Node.js
4
+ *
5
+ * This is only needed on Node.js v18 & v19. Newer versions already define `File`
6
+ * as a global.
7
+ */
8
+
9
+ export {};
@@ -0,0 +1,17 @@
1
+ /**
2
+ * This file polyfills the global `File` object for you if it's not already defined
3
+ * when running on Node.js
4
+ *
5
+ * This is only needed on Node.js v18 & v19. Newer versions already define `File`
6
+ * as a global.
7
+ */
8
+
9
+ if (typeof require !== 'undefined') {
10
+ if (!globalThis.File) {
11
+ try {
12
+ // Use [require][0](...) and not require(...) so bundlers don't try to bundle the
13
+ // buffer module.
14
+ globalThis.File = [require][0]('node:buffer').File;
15
+ } catch (e) {}
16
+ }
17
+ }
@@ -0,0 +1,9 @@
1
+ /**
2
+ * This file polyfills the global `File` object for you if it's not already defined
3
+ * when running on Node.js
4
+ *
5
+ * This is only needed on Node.js v18 & v19. Newer versions already define `File`
6
+ * as a global.
7
+ */
8
+
9
+ import './file.node.js';