partnermax 0.2.0 → 0.2.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 (74) hide show
  1. package/CHANGELOG.md +60 -47
  2. package/LICENSE +201 -201
  3. package/README.md +370 -370
  4. package/api-promise.js +1 -1
  5. package/client.js +1 -1
  6. package/client.mjs +1 -1
  7. package/core/api-promise.js +1 -1
  8. package/core/api-promise.mjs +1 -1
  9. package/error.js +1 -1
  10. package/package.json +9 -15
  11. package/resource.js +1 -1
  12. package/resources/dealers/dealers.js +1 -1
  13. package/resources/dealers/nlt/nlt.js +1 -1
  14. package/resources/dealers/nlt.js +1 -1
  15. package/resources/dealers/vehicles/vehicles.js +1 -1
  16. package/resources/dealers/vehicles.js +1 -1
  17. package/resources/dealers.js +1 -1
  18. package/resources.js +1 -1
  19. package/src/api-promise.ts +2 -2
  20. package/src/client.ts +841 -841
  21. package/src/core/README.md +3 -3
  22. package/src/core/api-promise.ts +92 -92
  23. package/src/core/error.ts +130 -130
  24. package/src/core/resource.ts +11 -11
  25. package/src/core/uploads.ts +2 -2
  26. package/src/error.ts +2 -2
  27. package/src/index.ts +22 -22
  28. package/src/internal/README.md +3 -3
  29. package/src/internal/builtin-types.ts +93 -93
  30. package/src/internal/detect-platform.ts +196 -196
  31. package/src/internal/errors.ts +33 -33
  32. package/src/internal/headers.ts +97 -97
  33. package/src/internal/parse.ts +56 -56
  34. package/src/internal/request-options.ts +91 -91
  35. package/src/internal/shim-types.ts +26 -26
  36. package/src/internal/shims.ts +107 -107
  37. package/src/internal/to-file.ts +154 -154
  38. package/src/internal/types.ts +93 -93
  39. package/src/internal/uploads.ts +187 -187
  40. package/src/internal/utils/base64.ts +40 -40
  41. package/src/internal/utils/bytes.ts +32 -32
  42. package/src/internal/utils/env.ts +18 -18
  43. package/src/internal/utils/log.ts +128 -128
  44. package/src/internal/utils/path.ts +88 -88
  45. package/src/internal/utils/query.ts +23 -23
  46. package/src/internal/utils/sleep.ts +3 -3
  47. package/src/internal/utils/uuid.ts +17 -17
  48. package/src/internal/utils/values.ts +105 -105
  49. package/src/internal/utils.ts +9 -9
  50. package/src/lib/.keep +4 -4
  51. package/src/resource.ts +2 -2
  52. package/src/resources/dealers/dealers.ts +348 -348
  53. package/src/resources/dealers/index.ts +28 -28
  54. package/src/resources/dealers/nlt/index.ts +11 -11
  55. package/src/resources/dealers/nlt/nlt.ts +29 -29
  56. package/src/resources/dealers/nlt/offers.ts +427 -427
  57. package/src/resources/dealers/nlt-settings.ts +269 -269
  58. package/src/resources/dealers/nlt.ts +3 -3
  59. package/src/resources/dealers/vehicles/images.ts +153 -153
  60. package/src/resources/dealers/vehicles/index.ts +25 -25
  61. package/src/resources/dealers/vehicles/vehicles.ts +796 -796
  62. package/src/resources/dealers/vehicles.ts +3 -3
  63. package/src/resources/dealers.ts +3 -3
  64. package/src/resources/index.ts +12 -12
  65. package/src/resources/keys.ts +128 -128
  66. package/src/resources.ts +1 -1
  67. package/src/tsconfig.json +11 -11
  68. package/src/uploads.ts +2 -2
  69. package/src/version.ts +1 -1
  70. package/uploads.js +1 -1
  71. package/version.d.mts +1 -1
  72. package/version.d.ts +1 -1
  73. package/version.js +1 -1
  74. package/version.mjs +1 -1
@@ -1,97 +1,97 @@
1
- // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
-
3
- import { isReadonlyArray } from './utils/values';
4
-
5
- type HeaderValue = string | undefined | null;
6
- export type HeadersLike =
7
- | Headers
8
- | readonly HeaderValue[][]
9
- | Record<string, HeaderValue | readonly HeaderValue[]>
10
- | undefined
11
- | null
12
- | NullableHeaders;
13
-
14
- const brand_privateNullableHeaders = /* @__PURE__ */ Symbol('brand.privateNullableHeaders');
15
-
16
- /**
17
- * @internal
18
- * Users can pass explicit nulls to unset default headers. When we parse them
19
- * into a standard headers type we need to preserve that information.
20
- */
21
- export type NullableHeaders = {
22
- /** Brand check, prevent users from creating a NullableHeaders. */
23
- [brand_privateNullableHeaders]: true;
24
- /** Parsed headers. */
25
- values: Headers;
26
- /** Set of lowercase header names explicitly set to null. */
27
- nulls: Set<string>;
28
- };
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 (HeaderValue | readonly HeaderValue[])[]>;
44
- if (headers instanceof Headers) {
45
- iter = headers.entries();
46
- } else if (isReadonlyArray(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
- if (typeof name !== 'string') throw new TypeError('expected header name to be a string');
55
- const values = isReadonlyArray(row[1]) ? row[1] : [row[1]];
56
- let didClear = false;
57
- for (const value of values) {
58
- if (value === undefined) continue;
59
-
60
- // Objects keys always overwrite older headers, they never append.
61
- // Yield a null to clear the header before adding the new values.
62
- if (shouldClear && !didClear) {
63
- didClear = true;
64
- yield [name, null];
65
- }
66
- yield [name, value];
67
- }
68
- }
69
- }
70
-
71
- export const buildHeaders = (newHeaders: HeadersLike[]): NullableHeaders => {
72
- const targetHeaders = new Headers();
73
- const nullHeaders = new Set<string>();
74
- for (const headers of newHeaders) {
75
- const seenHeaders = new Set<string>();
76
- for (const [name, value] of iterateHeaders(headers)) {
77
- const lowerName = name.toLowerCase();
78
- if (!seenHeaders.has(lowerName)) {
79
- targetHeaders.delete(name);
80
- seenHeaders.add(lowerName);
81
- }
82
- if (value === null) {
83
- targetHeaders.delete(name);
84
- nullHeaders.add(lowerName);
85
- } else {
86
- targetHeaders.append(name, value);
87
- nullHeaders.delete(lowerName);
88
- }
89
- }
90
- }
91
- return { [brand_privateNullableHeaders]: true, values: targetHeaders, nulls: nullHeaders };
92
- };
93
-
94
- export const isEmptyHeaders = (headers: HeadersLike) => {
95
- for (const _ of iterateHeaders(headers)) return false;
96
- return true;
97
- };
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ import { isReadonlyArray } from './utils/values';
4
+
5
+ type HeaderValue = string | undefined | null;
6
+ export type HeadersLike =
7
+ | Headers
8
+ | readonly HeaderValue[][]
9
+ | Record<string, HeaderValue | readonly HeaderValue[]>
10
+ | undefined
11
+ | null
12
+ | NullableHeaders;
13
+
14
+ const brand_privateNullableHeaders = /* @__PURE__ */ Symbol('brand.privateNullableHeaders');
15
+
16
+ /**
17
+ * @internal
18
+ * Users can pass explicit nulls to unset default headers. When we parse them
19
+ * into a standard headers type we need to preserve that information.
20
+ */
21
+ export type NullableHeaders = {
22
+ /** Brand check, prevent users from creating a NullableHeaders. */
23
+ [brand_privateNullableHeaders]: true;
24
+ /** Parsed headers. */
25
+ values: Headers;
26
+ /** Set of lowercase header names explicitly set to null. */
27
+ nulls: Set<string>;
28
+ };
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 (HeaderValue | readonly HeaderValue[])[]>;
44
+ if (headers instanceof Headers) {
45
+ iter = headers.entries();
46
+ } else if (isReadonlyArray(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
+ if (typeof name !== 'string') throw new TypeError('expected header name to be a string');
55
+ const values = isReadonlyArray(row[1]) ? row[1] : [row[1]];
56
+ let didClear = false;
57
+ for (const value of values) {
58
+ if (value === undefined) continue;
59
+
60
+ // Objects keys always overwrite older headers, they never append.
61
+ // Yield a null to clear the header before adding the new values.
62
+ if (shouldClear && !didClear) {
63
+ didClear = true;
64
+ yield [name, null];
65
+ }
66
+ yield [name, value];
67
+ }
68
+ }
69
+ }
70
+
71
+ export const buildHeaders = (newHeaders: HeadersLike[]): NullableHeaders => {
72
+ const targetHeaders = new Headers();
73
+ const nullHeaders = new Set<string>();
74
+ for (const headers of newHeaders) {
75
+ const seenHeaders = new Set<string>();
76
+ for (const [name, value] of iterateHeaders(headers)) {
77
+ const lowerName = name.toLowerCase();
78
+ if (!seenHeaders.has(lowerName)) {
79
+ targetHeaders.delete(name);
80
+ seenHeaders.add(lowerName);
81
+ }
82
+ if (value === null) {
83
+ targetHeaders.delete(name);
84
+ nullHeaders.add(lowerName);
85
+ } else {
86
+ targetHeaders.append(name, value);
87
+ nullHeaders.delete(lowerName);
88
+ }
89
+ }
90
+ }
91
+ return { [brand_privateNullableHeaders]: true, values: targetHeaders, nulls: nullHeaders };
92
+ };
93
+
94
+ export const isEmptyHeaders = (headers: HeadersLike) => {
95
+ for (const _ of iterateHeaders(headers)) return false;
96
+ return true;
97
+ };
@@ -1,56 +1,56 @@
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 Partnermax } from '../client';
5
- import { formatRequestDetails, loggerFor } from './utils/log';
6
-
7
- export type APIResponseProps = {
8
- response: Response;
9
- options: FinalRequestOptions;
10
- controller: AbortController;
11
- requestLogID: string;
12
- retryOfRequestLogID: string | undefined;
13
- startTime: number;
14
- };
15
-
16
- export async function defaultParseResponse<T>(client: Partnermax, props: APIResponseProps): Promise<T> {
17
- const { response, requestLogID, retryOfRequestLogID, startTime } = props;
18
- const body = await (async () => {
19
- // fetch refuses to read the body when the status code is 204.
20
- if (response.status === 204) {
21
- return null as T;
22
- }
23
-
24
- if (props.options.__binaryResponse) {
25
- return response as unknown as T;
26
- }
27
-
28
- const contentType = response.headers.get('content-type');
29
- const mediaType = contentType?.split(';')[0]?.trim();
30
- const isJSON = mediaType?.includes('application/json') || mediaType?.endsWith('+json');
31
- if (isJSON) {
32
- const contentLength = response.headers.get('content-length');
33
- if (contentLength === '0') {
34
- // if there is no content we can't do anything
35
- return undefined as T;
36
- }
37
-
38
- const json = await response.json();
39
- return json as T;
40
- }
41
-
42
- const text = await response.text();
43
- return text as unknown as T;
44
- })();
45
- loggerFor(client).debug(
46
- `[${requestLogID}] response parsed`,
47
- formatRequestDetails({
48
- retryOfRequestLogID,
49
- url: response.url,
50
- status: response.status,
51
- body,
52
- durationMs: Date.now() - startTime,
53
- }),
54
- );
55
- return body;
56
- }
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 Partnermax } from '../client';
5
+ import { formatRequestDetails, loggerFor } from './utils/log';
6
+
7
+ export type APIResponseProps = {
8
+ response: Response;
9
+ options: FinalRequestOptions;
10
+ controller: AbortController;
11
+ requestLogID: string;
12
+ retryOfRequestLogID: string | undefined;
13
+ startTime: number;
14
+ };
15
+
16
+ export async function defaultParseResponse<T>(client: Partnermax, props: APIResponseProps): Promise<T> {
17
+ const { response, requestLogID, retryOfRequestLogID, startTime } = props;
18
+ const body = await (async () => {
19
+ // fetch refuses to read the body when the status code is 204.
20
+ if (response.status === 204) {
21
+ return null as T;
22
+ }
23
+
24
+ if (props.options.__binaryResponse) {
25
+ return response as unknown as T;
26
+ }
27
+
28
+ const contentType = response.headers.get('content-type');
29
+ const mediaType = contentType?.split(';')[0]?.trim();
30
+ const isJSON = mediaType?.includes('application/json') || mediaType?.endsWith('+json');
31
+ if (isJSON) {
32
+ const contentLength = response.headers.get('content-length');
33
+ if (contentLength === '0') {
34
+ // if there is no content we can't do anything
35
+ return undefined as T;
36
+ }
37
+
38
+ const json = await response.json();
39
+ return json as T;
40
+ }
41
+
42
+ const text = await response.text();
43
+ return text as unknown as T;
44
+ })();
45
+ loggerFor(client).debug(
46
+ `[${requestLogID}] response parsed`,
47
+ formatRequestDetails({
48
+ retryOfRequestLogID,
49
+ url: response.url,
50
+ status: response.status,
51
+ body,
52
+ durationMs: Date.now() - startTime,
53
+ }),
54
+ );
55
+ return body;
56
+ }
@@ -1,91 +1,91 @@
1
- // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
-
3
- import { NullableHeaders } from './headers';
4
-
5
- import type { BodyInit } from './builtin-types';
6
- import type { HTTPMethod, MergedRequestInit } from './types';
7
- import { type HeadersLike } from './headers';
8
-
9
- export type FinalRequestOptions = RequestOptions & { method: HTTPMethod; path: string };
10
-
11
- export type RequestOptions = {
12
- /**
13
- * The HTTP method for the request (e.g., 'get', 'post', 'put', 'delete').
14
- */
15
- method?: HTTPMethod;
16
-
17
- /**
18
- * The URL path for the request.
19
- *
20
- * @example "/v1/foo"
21
- */
22
- path?: string;
23
-
24
- /**
25
- * Query parameters to include in the request URL.
26
- */
27
- query?: object | undefined | null;
28
-
29
- /**
30
- * The request body. Can be a string, JSON object, FormData, or other supported types.
31
- */
32
- body?: unknown;
33
-
34
- /**
35
- * HTTP headers to include with the request. Can be a Headers object, plain object, or array of tuples.
36
- */
37
- headers?: HeadersLike;
38
-
39
- /**
40
- * The maximum number of times that the client will retry a request in case of a
41
- * temporary failure, like a network error or a 5XX error from the server.
42
- *
43
- * @default 2
44
- */
45
- maxRetries?: number;
46
-
47
- stream?: boolean | undefined;
48
-
49
- /**
50
- * The maximum amount of time (in milliseconds) that the client should wait for a response
51
- * from the server before timing out a single request.
52
- *
53
- * @unit milliseconds
54
- */
55
- timeout?: number;
56
-
57
- /**
58
- * Additional `RequestInit` options to be passed to the underlying `fetch` call.
59
- * These options will be merged with the client's default fetch options.
60
- */
61
- fetchOptions?: MergedRequestInit;
62
-
63
- /**
64
- * An AbortSignal that can be used to cancel the request.
65
- */
66
- signal?: AbortSignal | undefined | null;
67
-
68
- /**
69
- * A unique key for this request to enable idempotency.
70
- */
71
- idempotencyKey?: string;
72
-
73
- /**
74
- * Override the default base URL for this specific request.
75
- */
76
- defaultBaseURL?: string | undefined;
77
-
78
- __binaryResponse?: boolean | undefined;
79
- };
80
-
81
- export type EncodedContent = { bodyHeaders: HeadersLike; body: BodyInit };
82
- export type RequestEncoder = (request: { headers: NullableHeaders; body: unknown }) => EncodedContent;
83
-
84
- export const FallbackEncoder: RequestEncoder = ({ headers, body }) => {
85
- return {
86
- bodyHeaders: {
87
- 'content-type': 'application/json',
88
- },
89
- body: JSON.stringify(body),
90
- };
91
- };
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ import { NullableHeaders } from './headers';
4
+
5
+ import type { BodyInit } from './builtin-types';
6
+ import type { HTTPMethod, MergedRequestInit } from './types';
7
+ import { type HeadersLike } from './headers';
8
+
9
+ export type FinalRequestOptions = RequestOptions & { method: HTTPMethod; path: string };
10
+
11
+ export type RequestOptions = {
12
+ /**
13
+ * The HTTP method for the request (e.g., 'get', 'post', 'put', 'delete').
14
+ */
15
+ method?: HTTPMethod;
16
+
17
+ /**
18
+ * The URL path for the request.
19
+ *
20
+ * @example "/v1/foo"
21
+ */
22
+ path?: string;
23
+
24
+ /**
25
+ * Query parameters to include in the request URL.
26
+ */
27
+ query?: object | undefined | null;
28
+
29
+ /**
30
+ * The request body. Can be a string, JSON object, FormData, or other supported types.
31
+ */
32
+ body?: unknown;
33
+
34
+ /**
35
+ * HTTP headers to include with the request. Can be a Headers object, plain object, or array of tuples.
36
+ */
37
+ headers?: HeadersLike;
38
+
39
+ /**
40
+ * The maximum number of times that the client will retry a request in case of a
41
+ * temporary failure, like a network error or a 5XX error from the server.
42
+ *
43
+ * @default 2
44
+ */
45
+ maxRetries?: number;
46
+
47
+ stream?: boolean | undefined;
48
+
49
+ /**
50
+ * The maximum amount of time (in milliseconds) that the client should wait for a response
51
+ * from the server before timing out a single request.
52
+ *
53
+ * @unit milliseconds
54
+ */
55
+ timeout?: number;
56
+
57
+ /**
58
+ * Additional `RequestInit` options to be passed to the underlying `fetch` call.
59
+ * These options will be merged with the client's default fetch options.
60
+ */
61
+ fetchOptions?: MergedRequestInit;
62
+
63
+ /**
64
+ * An AbortSignal that can be used to cancel the request.
65
+ */
66
+ signal?: AbortSignal | undefined | null;
67
+
68
+ /**
69
+ * A unique key for this request to enable idempotency.
70
+ */
71
+ idempotencyKey?: string;
72
+
73
+ /**
74
+ * Override the default base URL for this specific request.
75
+ */
76
+ defaultBaseURL?: string | undefined;
77
+
78
+ __binaryResponse?: boolean | undefined;
79
+ };
80
+
81
+ export type EncodedContent = { bodyHeaders: HeadersLike; body: BodyInit };
82
+ export type RequestEncoder = (request: { headers: NullableHeaders; body: unknown }) => EncodedContent;
83
+
84
+ export const FallbackEncoder: RequestEncoder = ({ headers, body }) => {
85
+ return {
86
+ bodyHeaders: {
87
+ 'content-type': 'application/json',
88
+ },
89
+ body: JSON.stringify(body),
90
+ };
91
+ };
@@ -1,26 +1,26 @@
1
- // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
-
3
- /**
4
- * Shims for types that we can't always rely on being available globally.
5
- *
6
- * Note: these only exist at the type-level, there is no corresponding runtime
7
- * version for any of these symbols.
8
- */
9
-
10
- type NeverToAny<T> = T extends never ? any : T;
11
-
12
- /** @ts-ignore */
13
- type _DOMReadableStream<R = any> = globalThis.ReadableStream<R>;
14
-
15
- /** @ts-ignore */
16
- type _NodeReadableStream<R = any> = import('stream/web').ReadableStream<R>;
17
-
18
- type _ConditionalNodeReadableStream<R = any> =
19
- typeof globalThis extends { ReadableStream: any } ? never : _NodeReadableStream<R>;
20
-
21
- type _ReadableStream<R = any> = NeverToAny<
22
- | ([0] extends [1 & _DOMReadableStream<R>] ? never : _DOMReadableStream<R>)
23
- | ([0] extends [1 & _ConditionalNodeReadableStream<R>] ? never : _ConditionalNodeReadableStream<R>)
24
- >;
25
-
26
- export type { _ReadableStream as ReadableStream };
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ /**
4
+ * Shims for types that we can't always rely on being available globally.
5
+ *
6
+ * Note: these only exist at the type-level, there is no corresponding runtime
7
+ * version for any of these symbols.
8
+ */
9
+
10
+ type NeverToAny<T> = T extends never ? any : T;
11
+
12
+ /** @ts-ignore */
13
+ type _DOMReadableStream<R = any> = globalThis.ReadableStream<R>;
14
+
15
+ /** @ts-ignore */
16
+ type _NodeReadableStream<R = any> = import('stream/web').ReadableStream<R>;
17
+
18
+ type _ConditionalNodeReadableStream<R = any> =
19
+ typeof globalThis extends { ReadableStream: any } ? never : _NodeReadableStream<R>;
20
+
21
+ type _ReadableStream<R = any> = NeverToAny<
22
+ | ([0] extends [1 & _DOMReadableStream<R>] ? never : _DOMReadableStream<R>)
23
+ | ([0] extends [1 & _ConditionalNodeReadableStream<R>] ? never : _ConditionalNodeReadableStream<R>)
24
+ >;
25
+
26
+ export type { _ReadableStream as ReadableStream };