@appconda/sdk 1.0.552 → 1.0.555

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/client.d.ts CHANGED
@@ -32,6 +32,7 @@ declare class Client {
32
32
  forwardeduseragent: string;
33
33
  };
34
34
  headers: Headers;
35
+ private fetchImpl?;
35
36
  /**
36
37
  * Set Endpoint
37
38
  *
@@ -59,6 +60,13 @@ declare class Client {
59
60
  * @returns {this}
60
61
  */
61
62
  addHeader(header: string, value: string): this;
63
+ /**
64
+ * Set custom fetch implementation.
65
+ *
66
+ * Useful for Node.js versions without a global fetch.
67
+ */
68
+ setFetch(fetchImpl: typeof fetch): this;
69
+ private getFetch;
62
70
  /**
63
71
  * Set Project
64
72
  *
package/dist/client.js CHANGED
@@ -8,6 +8,44 @@ class AppcondaException extends Error {
8
8
  this.response = response;
9
9
  }
10
10
  }
11
+ function hasGlobalFileConstructor() {
12
+ return typeof globalThis !== 'undefined' && typeof globalThis.File !== 'undefined';
13
+ }
14
+ function isFileLike(value) {
15
+ if (!value || typeof value !== 'object') {
16
+ return false;
17
+ }
18
+ if (hasGlobalFileConstructor() && value instanceof globalThis.File) {
19
+ return true;
20
+ }
21
+ return typeof value.size === 'number' && typeof value.slice === 'function';
22
+ }
23
+ function getFileName(file, fallbackName = 'upload.bin') {
24
+ if (typeof file.name === 'string' && file.name.length > 0) {
25
+ return file.name;
26
+ }
27
+ return fallbackName;
28
+ }
29
+ function createChunkFile(chunk, filename) {
30
+ if (hasGlobalFileConstructor()) {
31
+ return new globalThis.File([chunk], filename, {
32
+ type: chunk.type || 'application/octet-stream',
33
+ });
34
+ }
35
+ const blob = new Blob([chunk], {
36
+ type: chunk.type || 'application/octet-stream',
37
+ });
38
+ try {
39
+ Object.defineProperty(blob, 'name', {
40
+ value: filename,
41
+ configurable: true,
42
+ });
43
+ }
44
+ catch {
45
+ // Fallback for runtimes where Blob is not extensible.
46
+ }
47
+ return blob;
48
+ }
11
49
  function getUserAgent() {
12
50
  let ua = 'AppcondaNodeJSSDK/14.1.0';
13
51
  // `process` is a global in Node.js, but not fully available in all runtimes.
@@ -101,6 +139,22 @@ class Client {
101
139
  this.headers[header.toLowerCase()] = value;
102
140
  return this;
103
141
  }
142
+ /**
143
+ * Set custom fetch implementation.
144
+ *
145
+ * Useful for Node.js versions without a global fetch.
146
+ */
147
+ setFetch(fetchImpl) {
148
+ this.fetchImpl = fetchImpl;
149
+ return this;
150
+ }
151
+ getFetch() {
152
+ const runtimeFetch = this.fetchImpl ?? (typeof globalThis !== 'undefined' ? globalThis.fetch : undefined);
153
+ if (!runtimeFetch) {
154
+ throw new AppcondaException('Fetch API is not available. Use Node.js 18+ or set a custom fetch with client.setFetch().');
155
+ }
156
+ return runtimeFetch.bind(globalThis);
157
+ }
104
158
  /**
105
159
  * Set Project
106
160
  *
@@ -229,12 +283,17 @@ class Client {
229
283
  case 'multipart/form-data':
230
284
  const formData = new FormData();
231
285
  for (const [key, value] of Object.entries(params)) {
232
- if (value instanceof File) {
233
- formData.append(key, value, value.name);
286
+ if (isFileLike(value)) {
287
+ formData.append(key, value, getFileName(value));
234
288
  }
235
289
  else if (Array.isArray(value)) {
236
290
  for (const nestedValue of value) {
237
- formData.append(`${key}[]`, nestedValue);
291
+ if (isFileLike(nestedValue)) {
292
+ formData.append(`${key}[]`, nestedValue, getFileName(nestedValue));
293
+ }
294
+ else {
295
+ formData.append(`${key}[]`, nestedValue);
296
+ }
238
297
  }
239
298
  }
240
299
  else {
@@ -249,7 +308,10 @@ class Client {
249
308
  return { uri: url.toString(), options };
250
309
  }
251
310
  async chunkedUpload(method, url, headers = {}, originalPayload = {}, onProgress) {
252
- const file = Object.values(originalPayload).find((value) => value instanceof File);
311
+ const file = Object.values(originalPayload).find((value) => isFileLike(value));
312
+ if (!file) {
313
+ return await this.call(method, url, headers, originalPayload);
314
+ }
253
315
  if (file.size <= Client.CHUNK_SIZE) {
254
316
  return await this.call(method, url, headers, originalPayload);
255
317
  }
@@ -262,7 +324,10 @@ class Client {
262
324
  }
263
325
  headers['content-range'] = `bytes ${start}-${end - 1}/${file.size}`;
264
326
  const chunk = file.slice(start, end);
265
- let payload = { ...originalPayload, file: new File([chunk], file.name) };
327
+ const payload = {
328
+ ...originalPayload,
329
+ file: createChunkFile(chunk, getFileName(file)),
330
+ };
266
331
  response = await this.call(method, url, headers, payload);
267
332
  if (onProgress && typeof onProgress === 'function') {
268
333
  onProgress({
@@ -282,7 +347,8 @@ class Client {
282
347
  }
283
348
  async redirect(method, url, headers = {}, params = {}) {
284
349
  const { uri, options } = this.prepareRequest(method, url, headers, params);
285
- const response = await fetch(uri, {
350
+ const runtimeFetch = this.getFetch();
351
+ const response = await runtimeFetch(uri, {
286
352
  ...options,
287
353
  redirect: 'manual'
288
354
  });
@@ -293,9 +359,10 @@ class Client {
293
359
  }
294
360
  async call(method, url, headers = {}, params = {}, responseType = 'json') {
295
361
  const { uri, options } = this.prepareRequest(method, url, headers, params);
362
+ const runtimeFetch = this.getFetch();
296
363
  let data = null;
297
364
  try {
298
- const response = await fetch(uri, options);
365
+ const response = await runtimeFetch(uri, options);
299
366
  const warnings = response.headers.get('x-appconda-warning');
300
367
  if (warnings) {
301
368
  warnings.split(';').forEach((warning) => console.warn('Warning: ' + warning));
@@ -338,4 +405,4 @@ class Client {
338
405
  Client.CHUNK_SIZE = 1024 * 1024 * 5;
339
406
  export { Client, AppcondaException };
340
407
  export { Query } from './query';
341
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client.js","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport { Models } from './models';\n\ntype Payload = {\n    [key: string]: any;\n}\n\ntype UploadProgress = {\n    $id: string;\n    progress: number;\n    sizeUploaded: number;\n    chunksTotal: number;\n    chunksUploaded: number;\n}\n\ntype Headers = {\n    [key: string]: string;\n}\n\nclass AppcondaException extends Error {\n    code: number;\n    response: string;\n    type: string;\n    constructor(message: string, code: number = 0, type: string = '', response: string = '') {\n        super(message);\n        this.name = 'AppcondaException';\n        this.message = message;\n        this.code = code;\n        this.type = type;\n        this.response = response;\n    }\n}\n\nfunction getUserAgent() {\n    let ua = 'AppcondaNodeJSSDK/14.1.0';\n\n    // `process` is a global in Node.js, but not fully available in all runtimes.\n    const platform: string[] = [];\n    if (typeof process !== 'undefined') {\n        if (typeof process.platform === 'string') platform.push(process.platform);\n        if (typeof process.arch === 'string') platform.push(process.arch);\n    }\n    if (platform.length > 0) {\n        ua += ` (${platform.join('; ')})`;\n    }\n\n    // `navigator.userAgent` is available in Node.js 21 and later.\n    // It's also part of the WinterCG spec, so many edge runtimes provide it.\n    // https://common-min-api.proposal.wintercg.org/#requirements-for-navigatoruseragent\n    // @ts-ignore\n    if (typeof navigator !== 'undefined' && typeof navigator.userAgent === 'string') {\n        // @ts-ignore\n        ua += ` ${navigator.userAgent}`;\n\n        // @ts-ignore\n    } else if (typeof globalThis.EdgeRuntime === 'string') {\n        ua += ` EdgeRuntime`;\n\n        // Older Node.js versions don't have `navigator.userAgent`, so we have to use `process.version`.\n    } else if (typeof process !== 'undefined' && typeof process.version === 'string') {\n        ua += ` Node.js/${process.version}`;\n    }\n\n    return ua;\n}\n\nclass Client {\n    static CHUNK_SIZE = 1024 * 1024 * 5;\n\n    config = {\n        endpoint: 'https://cloud.appconda.io/v1',\n        selfSigned: false,\n        project: '',\n        mode: '',\n        key: '',\n        jwt: '',\n        locale: '',\n        session: '',\n        forwardeduseragent: '',\n    };\n    headers: Headers = {\n        'x-sdk-name': 'Node.js',\n        'x-sdk-platform': 'server',\n        'x-sdk-language': 'nodejs',\n        'x-sdk-version': '14.1.0',\n        'user-agent': getUserAgent(),\n        'X-Appconda-Response-Format': '1.6.0',\n    };\n\n    /**\n     * Set Endpoint\n     *\n     * Your project endpoint\n     *\n     * @param {string} endpoint\n     *\n     * @returns {this}\n     */\n    setEndpoint(endpoint: string): this {\n        this.config.endpoint = endpoint;\n\n        return this;\n    }\n\n    /**\n     * Set self-signed\n     *\n     * @param {boolean} selfSigned\n     *\n     * @returns {this}\n     */\n    setSelfSigned(selfSigned: boolean): this {\n        // @ts-ignore\n        if (typeof globalThis.EdgeRuntime !== 'undefined') {\n            console.warn('setSelfSigned is not supported in edge runtimes.');\n        }\n\n        this.config.selfSigned = selfSigned;\n\n        return this;\n    }\n\n    /**\n     * Add header\n     *\n     * @param {string} header\n     * @param {string} value\n     *\n     * @returns {this}\n     */\n    addHeader(header: string, value: string): this {\n        this.headers[header.toLowerCase()] = value;\n\n        return this;\n    }\n\n    /**\n     * Set Project\n     *\n     * Your project ID\n     *\n     * @param value string\n     *\n     * @return {this}\n     */\n    setProject(value: string): this {\n        this.headers['X-Appconda-Project'] = value;\n        this.config.project = value;\n        return this;\n    }\n\n      /**\n     * Set Mode\n     *\n     * @param value string\n     *\n     * @return {this}\n     */\n      setMode(value: string): this {\n        this.headers['X-Appconda-Mode'] = value;\n        this.config.mode = value;\n        return this;\n    }\n\n    /**\n     * Set Key\n     *\n     * Your secret API key\n     *\n     * @param value string\n     *\n     * @return {this}\n     */\n    setKey(value: string): this {\n        this.headers['X-Appconda-Key'] = value;\n        this.config.key = value;\n        return this;\n    }\n    /**\n     * Set JWT\n     *\n     * Your secret JSON Web Token\n     *\n     * @param value string\n     *\n     * @return {this}\n     */\n    setJWT(value: string): this {\n        this.headers['X-Appconda-JWT'] = value;\n        this.config.jwt = value;\n        return this;\n    }\n    /**\n     * Set Locale\n     *\n     * @param value string\n     *\n     * @return {this}\n     */\n    setLocale(value: string): this {\n        this.headers['X-Appconda-Locale'] = value;\n        this.config.locale = value;\n        return this;\n    }\n    /**\n     * Set Session\n     *\n     * The user session to authenticate with\n     *\n     * @param value string\n     *\n     * @return {this}\n     */\n    setSession(value: string): this {\n        this.headers['X-Appconda-Session'] = value;\n        this.config.session = value;\n        return this;\n    }\n    /**\n     * Set ForwardedUserAgent\n     *\n     * The user agent string of the client that made the request\n     *\n     * @param value string\n     *\n     * @return {this}\n     */\n    setForwardedUserAgent(value: string): this {\n        this.headers['X-Forwarded-User-Agent'] = value;\n        this.config.forwardeduseragent = value;\n        return this;\n    }\n\n    setFallbackCookies(value: string): this {\n        this.headers['X-Fallback-Cookies'] = value;\n        //this.config.forwardeduseragent = value;\n        return this;\n    }\n\n    prepareRequest(method: string, url: URL, headers: Headers = {}, params: Payload = {}): { uri: string, options: RequestInit } {\n        method = method.toUpperCase();\n\n        headers = Object.assign({}, this.headers, headers);\n\n        if (typeof window !== 'undefined' && window.localStorage) {\n            const cookieFallback = window.localStorage.getItem('cookieFallback');\n            if (cookieFallback) {\n                headers['X-Fallback-Cookies'] = cookieFallback;\n            }\n        }\n\n        let options: RequestInit = {\n            method,\n            headers,\n        };\n\n        if (headers['X-Appconda-Dev-Key'] === undefined) {\n            options.credentials = 'include';\n        }\n\n        if (method === 'GET') {\n            for (const [key, value] of Object.entries(Client.flatten(params))) {\n                url.searchParams.append(key, value);\n            }\n        } else {\n            switch (headers['content-type']) {\n                case 'application/json':\n                    options.body = JSON.stringify(params);\n                    break;\n\n                case 'multipart/form-data':\n                    const formData = new FormData();\n\n                    for (const [key, value] of Object.entries(params)) {\n                        if (value instanceof File) {\n                            formData.append(key, value, value.name);\n                        } else if (Array.isArray(value)) {\n                            for (const nestedValue of value) {\n                                formData.append(`${key}[]`, nestedValue);\n                            }\n                        } else {\n                            formData.append(key, value);\n                        }\n                    }\n\n                    options.body = formData;\n                    delete headers['content-type'];\n                    break;\n            }\n        }\n\n        return { uri: url.toString(), options };\n    }\n\n    async chunkedUpload(method: string, url: URL, headers: Headers = {}, originalPayload: Payload = {}, onProgress: (progress: UploadProgress) => void) {\n        const file: any = Object.values(originalPayload).find((value) => value instanceof File);\n\n        if (file.size <= Client.CHUNK_SIZE) {\n            return await this.call(method, url, headers, originalPayload);\n        }\n\n        let start = 0;\n        let response: any = null;\n\n        while (start < file.size) {\n            let end = start + Client.CHUNK_SIZE; // Prepare end for the next chunk\n            if (end >= file.size) {\n                end = file.size; // Adjust for the last chunk to include the last byte\n            }\n\n            headers['content-range'] = `bytes ${start}-${end - 1}/${file.size}`;\n            const chunk = file.slice(start, end);\n\n            let payload = { ...originalPayload, file: new File([chunk], file.name) };\n\n            response = await this.call(method, url, headers, payload);\n\n            if (onProgress && typeof onProgress === 'function') {\n                onProgress({\n                    $id: response.$id,\n                    progress: Math.round((end / file.size) * 100),\n                    sizeUploaded: end,\n                    chunksTotal: Math.ceil(file.size / Client.CHUNK_SIZE),\n                    chunksUploaded: Math.ceil(end / Client.CHUNK_SIZE)\n                });\n            }\n\n            if (response && response.$id) {\n                headers['x-appconda-id'] = response.$id;\n            }\n\n            start = end;\n        }\n\n        return response;\n    }\n\n    async redirect(method: string, url: URL, headers: Headers = {}, params: Payload = {}): Promise<string> {\n        const { uri, options } = this.prepareRequest(method, url, headers, params);\n\n        const response = await fetch(uri, {\n            ...options,\n            redirect: 'manual'\n        });\n\n        if (response.status !== 301 && response.status !== 302) {\n            throw new AppcondaException('Invalid redirect', response.status);\n        }\n\n        return response.headers.get('location') || '';\n    }\n\n    async call(method: string, url: URL, headers: Headers = {}, params: Payload = {}, responseType = 'json'): Promise<any> {\n        const { uri, options } = this.prepareRequest(method, url, headers, params);\n\n        let data: any = null;\n\n        try {\n            const response = await fetch(uri, options);\n\n            const warnings = response.headers.get('x-appconda-warning');\n            if (warnings) {\n                warnings.split(';').forEach((warning: string) => console.warn('Warning: ' + warning));\n            }\n\n            if (response.headers.get('content-type')?.includes('application/json')) {\n                data = await response.json();\n            } else if (responseType === 'arrayBuffer') {\n                data = await response.arrayBuffer();\n            } else {\n                data = {\n                    message: await response.text()\n                };\n            }\n\n            if (400 <= response.status) {\n                throw new AppcondaException(data?.message, response.status, data?.type, data);\n            }\n\n            return data;\n        } catch (e) {\n            console.error(e);\n            throw e;\n        }\n    }\n\n    static flatten(data: Payload, prefix = ''): Payload {\n        let output: Payload = {};\n\n        for (const [key, value] of Object.entries(data)) {\n            let finalKey = prefix ? prefix + '[' + key + ']' : key;\n            if (Array.isArray(value)) {\n                output = { ...output, ...Client.flatten(value, finalKey) };\n            } else {\n                output[finalKey] = value;\n            }\n        }\n\n        return output;\n    }\n}\n\nexport { Client, AppcondaException };\nexport { Query } from './query';\nexport type { Models, Payload, UploadProgress };\nexport type { QueryTypes, QueryTypesList } from './query';\n"]}
408
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client.js","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport { Models } from './models';\n\ntype Payload = {\n    [key: string]: any;\n}\n\ntype UploadProgress = {\n    $id: string;\n    progress: number;\n    sizeUploaded: number;\n    chunksTotal: number;\n    chunksUploaded: number;\n}\n\ntype Headers = {\n    [key: string]: string;\n}\n\nclass AppcondaException extends Error {\n    code: number;\n    response: string;\n    type: string;\n    constructor(message: string, code: number = 0, type: string = '', response: string = '') {\n        super(message);\n        this.name = 'AppcondaException';\n        this.message = message;\n        this.code = code;\n        this.type = type;\n        this.response = response;\n    }\n}\n\ntype FileLike = {\n    size: number;\n    slice: (start?: number, end?: number) => Blob;\n    name?: string;\n    type?: string;\n}\n\nfunction hasGlobalFileConstructor(): boolean {\n    return typeof globalThis !== 'undefined' && typeof (globalThis as any).File !== 'undefined';\n}\n\nfunction isFileLike(value: unknown): value is FileLike {\n    if (!value || typeof value !== 'object') {\n        return false;\n    }\n\n    if (hasGlobalFileConstructor() && value instanceof (globalThis as any).File) {\n        return true;\n    }\n\n    return typeof (value as FileLike).size === 'number' && typeof (value as FileLike).slice === 'function';\n}\n\nfunction getFileName(file: FileLike, fallbackName = 'upload.bin'): string {\n    if (typeof file.name === 'string' && file.name.length > 0) {\n        return file.name;\n    }\n\n    return fallbackName;\n}\n\nfunction createChunkFile(chunk: Blob, filename: string): Blob | File {\n    if (hasGlobalFileConstructor()) {\n        return new (globalThis as any).File([chunk], filename, {\n            type: chunk.type || 'application/octet-stream',\n        });\n    }\n\n    const blob = new Blob([chunk], {\n        type: chunk.type || 'application/octet-stream',\n    }) as Blob & { name?: string };\n\n    try {\n        Object.defineProperty(blob, 'name', {\n            value: filename,\n            configurable: true,\n        });\n    } catch {\n        // Fallback for runtimes where Blob is not extensible.\n    }\n\n    return blob;\n}\n\nfunction getUserAgent() {\n    let ua = 'AppcondaNodeJSSDK/14.1.0';\n\n    // `process` is a global in Node.js, but not fully available in all runtimes.\n    const platform: string[] = [];\n    if (typeof process !== 'undefined') {\n        if (typeof process.platform === 'string') platform.push(process.platform);\n        if (typeof process.arch === 'string') platform.push(process.arch);\n    }\n    if (platform.length > 0) {\n        ua += ` (${platform.join('; ')})`;\n    }\n\n    // `navigator.userAgent` is available in Node.js 21 and later.\n    // It's also part of the WinterCG spec, so many edge runtimes provide it.\n    // https://common-min-api.proposal.wintercg.org/#requirements-for-navigatoruseragent\n    // @ts-ignore\n    if (typeof navigator !== 'undefined' && typeof navigator.userAgent === 'string') {\n        // @ts-ignore\n        ua += ` ${navigator.userAgent}`;\n\n        // @ts-ignore\n    } else if (typeof globalThis.EdgeRuntime === 'string') {\n        ua += ` EdgeRuntime`;\n\n        // Older Node.js versions don't have `navigator.userAgent`, so we have to use `process.version`.\n    } else if (typeof process !== 'undefined' && typeof process.version === 'string') {\n        ua += ` Node.js/${process.version}`;\n    }\n\n    return ua;\n}\n\nclass Client {\n    static CHUNK_SIZE = 1024 * 1024 * 5;\n\n    config = {\n        endpoint: 'https://cloud.appconda.io/v1',\n        selfSigned: false,\n        project: '',\n        mode: '',\n        key: '',\n        jwt: '',\n        locale: '',\n        session: '',\n        forwardeduseragent: '',\n    };\n    headers: Headers = {\n        'x-sdk-name': 'Node.js',\n        'x-sdk-platform': 'server',\n        'x-sdk-language': 'nodejs',\n        'x-sdk-version': '14.1.0',\n        'user-agent': getUserAgent(),\n        'X-Appconda-Response-Format': '1.6.0',\n    };\n    private fetchImpl?: typeof fetch;\n\n    /**\n     * Set Endpoint\n     *\n     * Your project endpoint\n     *\n     * @param {string} endpoint\n     *\n     * @returns {this}\n     */\n    setEndpoint(endpoint: string): this {\n        this.config.endpoint = endpoint;\n\n        return this;\n    }\n\n    /**\n     * Set self-signed\n     *\n     * @param {boolean} selfSigned\n     *\n     * @returns {this}\n     */\n    setSelfSigned(selfSigned: boolean): this {\n        // @ts-ignore\n        if (typeof globalThis.EdgeRuntime !== 'undefined') {\n            console.warn('setSelfSigned is not supported in edge runtimes.');\n        }\n\n        this.config.selfSigned = selfSigned;\n\n        return this;\n    }\n\n    /**\n     * Add header\n     *\n     * @param {string} header\n     * @param {string} value\n     *\n     * @returns {this}\n     */\n    addHeader(header: string, value: string): this {\n        this.headers[header.toLowerCase()] = value;\n\n        return this;\n    }\n\n    /**\n     * Set custom fetch implementation.\n     *\n     * Useful for Node.js versions without a global fetch.\n     */\n    setFetch(fetchImpl: typeof fetch): this {\n        this.fetchImpl = fetchImpl;\n        return this;\n    }\n\n    private getFetch(): typeof fetch {\n        const runtimeFetch = this.fetchImpl ?? (typeof globalThis !== 'undefined' ? globalThis.fetch : undefined);\n\n        if (!runtimeFetch) {\n            throw new AppcondaException('Fetch API is not available. Use Node.js 18+ or set a custom fetch with client.setFetch().');\n        }\n\n        return runtimeFetch.bind(globalThis);\n    }\n\n    /**\n     * Set Project\n     *\n     * Your project ID\n     *\n     * @param value string\n     *\n     * @return {this}\n     */\n    setProject(value: string): this {\n        this.headers['X-Appconda-Project'] = value;\n        this.config.project = value;\n        return this;\n    }\n\n      /**\n     * Set Mode\n     *\n     * @param value string\n     *\n     * @return {this}\n     */\n      setMode(value: string): this {\n        this.headers['X-Appconda-Mode'] = value;\n        this.config.mode = value;\n        return this;\n    }\n\n    /**\n     * Set Key\n     *\n     * Your secret API key\n     *\n     * @param value string\n     *\n     * @return {this}\n     */\n    setKey(value: string): this {\n        this.headers['X-Appconda-Key'] = value;\n        this.config.key = value;\n        return this;\n    }\n    /**\n     * Set JWT\n     *\n     * Your secret JSON Web Token\n     *\n     * @param value string\n     *\n     * @return {this}\n     */\n    setJWT(value: string): this {\n        this.headers['X-Appconda-JWT'] = value;\n        this.config.jwt = value;\n        return this;\n    }\n    /**\n     * Set Locale\n     *\n     * @param value string\n     *\n     * @return {this}\n     */\n    setLocale(value: string): this {\n        this.headers['X-Appconda-Locale'] = value;\n        this.config.locale = value;\n        return this;\n    }\n    /**\n     * Set Session\n     *\n     * The user session to authenticate with\n     *\n     * @param value string\n     *\n     * @return {this}\n     */\n    setSession(value: string): this {\n        this.headers['X-Appconda-Session'] = value;\n        this.config.session = value;\n        return this;\n    }\n    /**\n     * Set ForwardedUserAgent\n     *\n     * The user agent string of the client that made the request\n     *\n     * @param value string\n     *\n     * @return {this}\n     */\n    setForwardedUserAgent(value: string): this {\n        this.headers['X-Forwarded-User-Agent'] = value;\n        this.config.forwardeduseragent = value;\n        return this;\n    }\n\n    setFallbackCookies(value: string): this {\n        this.headers['X-Fallback-Cookies'] = value;\n        //this.config.forwardeduseragent = value;\n        return this;\n    }\n\n    prepareRequest(method: string, url: URL, headers: Headers = {}, params: Payload = {}): { uri: string, options: RequestInit } {\n        method = method.toUpperCase();\n\n        headers = Object.assign({}, this.headers, headers);\n\n        if (typeof window !== 'undefined' && window.localStorage) {\n            const cookieFallback = window.localStorage.getItem('cookieFallback');\n            if (cookieFallback) {\n                headers['X-Fallback-Cookies'] = cookieFallback;\n            }\n        }\n\n        let options: RequestInit = {\n            method,\n            headers,\n        };\n\n        if (headers['X-Appconda-Dev-Key'] === undefined) {\n            options.credentials = 'include';\n        }\n\n        if (method === 'GET') {\n            for (const [key, value] of Object.entries(Client.flatten(params))) {\n                url.searchParams.append(key, value);\n            }\n        } else {\n            switch (headers['content-type']) {\n                case 'application/json':\n                    options.body = JSON.stringify(params);\n                    break;\n\n                case 'multipart/form-data':\n                    const formData = new FormData();\n\n                    for (const [key, value] of Object.entries(params)) {\n                        if (isFileLike(value)) {\n                            formData.append(key, value as unknown as Blob, getFileName(value));\n                        } else if (Array.isArray(value)) {\n                            for (const nestedValue of value) {\n                                if (isFileLike(nestedValue)) {\n                                    formData.append(`${key}[]`, nestedValue as unknown as Blob, getFileName(nestedValue));\n                                } else {\n                                    formData.append(`${key}[]`, nestedValue as any);\n                                }\n                            }\n                        } else {\n                            formData.append(key, value as any);\n                        }\n                    }\n\n                    options.body = formData;\n                    delete headers['content-type'];\n                    break;\n            }\n        }\n\n        return { uri: url.toString(), options };\n    }\n\n    async chunkedUpload(method: string, url: URL, headers: Headers = {}, originalPayload: Payload = {}, onProgress: (progress: UploadProgress) => void) {\n        const file = Object.values(originalPayload).find((value) => isFileLike(value)) as FileLike | undefined;\n\n        if (!file) {\n            return await this.call(method, url, headers, originalPayload);\n        }\n\n        if (file.size <= Client.CHUNK_SIZE) {\n            return await this.call(method, url, headers, originalPayload);\n        }\n\n        let start = 0;\n        let response: any = null;\n\n        while (start < file.size) {\n            let end = start + Client.CHUNK_SIZE; // Prepare end for the next chunk\n            if (end >= file.size) {\n                end = file.size; // Adjust for the last chunk to include the last byte\n            }\n\n            headers['content-range'] = `bytes ${start}-${end - 1}/${file.size}`;\n            const chunk = file.slice(start, end);\n\n            const payload = {\n                ...originalPayload,\n                file: createChunkFile(chunk, getFileName(file)),\n            };\n\n            response = await this.call(method, url, headers, payload);\n\n            if (onProgress && typeof onProgress === 'function') {\n                onProgress({\n                    $id: response.$id,\n                    progress: Math.round((end / file.size) * 100),\n                    sizeUploaded: end,\n                    chunksTotal: Math.ceil(file.size / Client.CHUNK_SIZE),\n                    chunksUploaded: Math.ceil(end / Client.CHUNK_SIZE)\n                });\n            }\n\n            if (response && response.$id) {\n                headers['x-appconda-id'] = response.$id;\n            }\n\n            start = end;\n        }\n\n        return response;\n    }\n\n    async redirect(method: string, url: URL, headers: Headers = {}, params: Payload = {}): Promise<string> {\n        const { uri, options } = this.prepareRequest(method, url, headers, params);\n        const runtimeFetch = this.getFetch();\n\n        const response = await runtimeFetch(uri, {\n            ...options,\n            redirect: 'manual'\n        });\n\n        if (response.status !== 301 && response.status !== 302) {\n            throw new AppcondaException('Invalid redirect', response.status);\n        }\n\n        return response.headers.get('location') || '';\n    }\n\n    async call(method: string, url: URL, headers: Headers = {}, params: Payload = {}, responseType = 'json'): Promise<any> {\n        const { uri, options } = this.prepareRequest(method, url, headers, params);\n        const runtimeFetch = this.getFetch();\n\n        let data: any = null;\n\n        try {\n            const response = await runtimeFetch(uri, options);\n\n            const warnings = response.headers.get('x-appconda-warning');\n            if (warnings) {\n                warnings.split(';').forEach((warning: string) => console.warn('Warning: ' + warning));\n            }\n\n            if (response.headers.get('content-type')?.includes('application/json')) {\n                data = await response.json();\n            } else if (responseType === 'arrayBuffer') {\n                data = await response.arrayBuffer();\n            } else {\n                data = {\n                    message: await response.text()\n                };\n            }\n\n            if (400 <= response.status) {\n                throw new AppcondaException(data?.message, response.status, data?.type, data);\n            }\n\n            return data;\n        } catch (e) {\n            console.error(e);\n            throw e;\n        }\n    }\n\n    static flatten(data: Payload, prefix = ''): Payload {\n        let output: Payload = {};\n\n        for (const [key, value] of Object.entries(data)) {\n            let finalKey = prefix ? prefix + '[' + key + ']' : key;\n            if (Array.isArray(value)) {\n                output = { ...output, ...Client.flatten(value, finalKey) };\n            } else {\n                output[finalKey] = value;\n            }\n        }\n\n        return output;\n    }\n}\n\nexport { Client, AppcondaException };\nexport { Query } from './query';\nexport type { Models, Payload, UploadProgress };\nexport type { QueryTypes, QueryTypesList } from './query';\n"]}
@@ -1,3 +1,14 @@
1
- import { Client } from "./client";
2
- export declare function getAppcondaClient(): Client;
3
- export declare function getAppcondaClientSync(): Client;
1
+ import { Client } from './client';
2
+ export type AppcondaClientOptions = {
3
+ endpoint?: string;
4
+ project?: string;
5
+ mode?: string;
6
+ key?: string;
7
+ jwt?: string;
8
+ session?: string;
9
+ locale?: string;
10
+ forwardedUserAgent?: string;
11
+ headers?: Record<string, string>;
12
+ };
13
+ export declare function getAppcondaClient(options?: AppcondaClientOptions): Client;
14
+ export declare function getAppcondaClientSync(options?: AppcondaClientOptions): Client;
@@ -1,68 +1,60 @@
1
- import { Client } from "./client";
2
- function getPortAndHostname(urlString) {
3
- try {
4
- const url = new URL(urlString);
5
- return {
6
- hostname: url.hostname,
7
- port: url.port || (url.protocol === 'https:' ? '443' : '80'), // Default ports if not specified
8
- protocol: url.protocol
9
- };
1
+ import { Client } from './client';
2
+ const APPCONDA_DEFAULT_PATH = '/api/appconda/v1';
3
+ const APPCONDA_NODE_DEFAULT_ENDPOINT = 'http://localhost:3000/api/appconda/v1';
4
+ function normalizeEndpoint(endpoint) {
5
+ return endpoint.replace(/\/+$/, '');
6
+ }
7
+ function resolveEndpoint(overrideEndpoint) {
8
+ if (overrideEndpoint) {
9
+ return normalizeEndpoint(overrideEndpoint);
10
+ }
11
+ const envEndpoint = (typeof process !== 'undefined' && process?.env?.APPCONDA_ENDPOINT) ||
12
+ (typeof process !== 'undefined' && process?.env?.NEXT_PUBLIC_APPCONDA_ENDPOINT) ||
13
+ '';
14
+ if (envEndpoint) {
15
+ return normalizeEndpoint(envEndpoint);
10
16
  }
11
- catch (error) {
12
- console.error('Invalid URL:', error);
13
- return { hostname: '', port: '', protocol: '' };
17
+ if (typeof window !== 'undefined' && window?.location?.origin) {
18
+ return normalizeEndpoint(new URL(APPCONDA_DEFAULT_PATH, window.location.origin).toString());
14
19
  }
20
+ return APPCONDA_NODE_DEFAULT_ENDPOINT;
15
21
  }
16
- const APPCONDA_ENDPOINT = 'api/appconda/v1';
17
- export function getAppcondaClient() {
18
- let url;
19
- if (typeof window !== 'undefined') {
20
- const hostInfo = getPortAndHostname(window.location.href);
21
- if (hostInfo.port) {
22
- url = `${hostInfo.protocol}//${hostInfo.hostname}:${hostInfo.port}/${APPCONDA_ENDPOINT}`;
23
- }
24
- else {
25
- url = `${hostInfo.protocol}//${hostInfo.hostname}/${APPCONDA_ENDPOINT}`;
26
- }
22
+ function applyClientOptions(client, options) {
23
+ if (options.project) {
24
+ client.setProject(options.project);
27
25
  }
28
- else {
29
- url = APPCONDA_ENDPOINT || 'http://appconda/v1';
26
+ if (options.mode) {
27
+ client.setMode(options.mode);
30
28
  }
31
- /* if (ApplicationConfig.Port == null) {
32
- url = `${ApplicationConfig.Protocol}://${ApplicationConfig.Domain}:${ApplicationConfig.Port}/v1`
33
- } else {
34
- url = `${ApplicationConfig.Protocol}://${ApplicationConfig.Domain}/v1`
35
- } */
36
- const adminClient = new Client()
37
- .setEndpoint(url) // Your API Endpoint
38
- .setProject('console');
39
- return adminClient;
40
- }
41
- export function getAppcondaClientSync() {
42
- let url;
43
- if (APPCONDA_ENDPOINT) {
44
- url = APPCONDA_ENDPOINT;
29
+ if (options.key) {
30
+ client.setKey(options.key);
45
31
  }
46
- else if (typeof window !== 'undefined') {
47
- const hostInfo = getPortAndHostname(window.location.href);
48
- if (hostInfo.port) {
49
- url = `${hostInfo.protocol}//${hostInfo.hostname}:${hostInfo.port}/v1`;
50
- }
51
- else {
52
- url = `${hostInfo.protocol}//${hostInfo.hostname}/v1`;
53
- }
32
+ if (options.jwt) {
33
+ client.setJWT(options.jwt);
54
34
  }
55
- else {
56
- url = APPCONDA_ENDPOINT || 'http://appconda/v1';
35
+ if (options.session) {
36
+ client.setSession(options.session);
57
37
  }
58
- /* if (ApplicationConfig.Port == null) {
59
- url = `${ApplicationConfig.Protocol}://${ApplicationConfig.Domain}:${ApplicationConfig.Port}/v1`
60
- } else {
61
- url = `${ApplicationConfig.Protocol}://${ApplicationConfig.Domain}/v1`
62
- } */
63
- const adminClient = new Client()
64
- .setEndpoint(url) // Your API Endpoint
65
- .setProject('console');
66
- return adminClient;
38
+ if (options.locale) {
39
+ client.setLocale(options.locale);
40
+ }
41
+ if (options.forwardedUserAgent) {
42
+ client.setForwardedUserAgent(options.forwardedUserAgent);
43
+ }
44
+ if (options.headers) {
45
+ for (const [headerName, headerValue] of Object.entries(options.headers)) {
46
+ client.addHeader(headerName, headerValue);
47
+ }
48
+ }
49
+ return client;
50
+ }
51
+ export function getAppcondaClient(options = {}) {
52
+ const client = new Client()
53
+ .setEndpoint(resolveEndpoint(options.endpoint))
54
+ .setProject(options.project ?? 'console');
55
+ return applyClientOptions(client, options);
56
+ }
57
+ export function getAppcondaClientSync(options = {}) {
58
+ return getAppcondaClient(options);
67
59
  }
68
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0QXBwY29uZGFDbGllbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvZ2V0QXBwY29uZGFDbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUVsQyxTQUFTLGtCQUFrQixDQUFDLFNBQWlCO0lBQ3pDLElBQUksQ0FBQztRQUNELE1BQU0sR0FBRyxHQUFHLElBQUksR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQy9CLE9BQU87WUFDSCxRQUFRLEVBQUUsR0FBRyxDQUFDLFFBQVE7WUFDdEIsSUFBSSxFQUFFLEdBQUcsQ0FBQyxJQUFJLElBQUksQ0FBQyxHQUFHLENBQUMsUUFBUSxLQUFLLFFBQVEsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsRUFBRSxpQ0FBaUM7WUFDL0YsUUFBUSxFQUFFLEdBQUcsQ0FBQyxRQUFRO1NBQ3pCLENBQUM7SUFDTixDQUFDO0lBQUMsT0FBTyxLQUFLLEVBQUUsQ0FBQztRQUNiLE9BQU8sQ0FBQyxLQUFLLENBQUMsY0FBYyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ3JDLE9BQU8sRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFLElBQUksRUFBRSxFQUFFLEVBQUUsUUFBUSxFQUFFLEVBQUUsRUFBRSxDQUFDO0lBQ3BELENBQUM7QUFDTCxDQUFDO0FBRUQsTUFBTSxpQkFBaUIsR0FBRyxpQkFBaUIsQ0FBQztBQUU1QyxNQUFNLFVBQVUsaUJBQWlCO0lBRTdCLElBQUksR0FBRyxDQUFDO0lBQ1IsSUFBSSxPQUFPLE1BQU0sS0FBSyxXQUFXLEVBQUUsQ0FBQztRQUNoQyxNQUFNLFFBQVEsR0FBRyxrQkFBa0IsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzFELElBQUksUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ2hCLEdBQUcsR0FBRyxHQUFHLFFBQVEsQ0FBQyxRQUFRLEtBQUssUUFBUSxDQUFDLFFBQVEsSUFBSSxRQUFRLENBQUMsSUFBSSxJQUFJLGlCQUFpQixFQUFFLENBQUE7UUFDNUYsQ0FBQzthQUFNLENBQUM7WUFDSixHQUFHLEdBQUcsR0FBRyxRQUFRLENBQUMsUUFBUSxLQUFLLFFBQVEsQ0FBQyxRQUFRLElBQUksaUJBQWlCLEVBQUUsQ0FBQTtRQUMzRSxDQUFDO0lBQ0wsQ0FBQztTQUFNLENBQUM7UUFDSixHQUFHLEdBQUcsaUJBQWlCLElBQUksb0JBQW9CLENBQUE7SUFDbkQsQ0FBQztJQUVEOzs7O1VBSU07SUFDTixNQUFNLFdBQVcsR0FBRyxJQUFJLE1BQU0sRUFBRTtTQUMzQixXQUFXLENBQUMsR0FBRyxDQUFDLENBQUMsb0JBQW9CO1NBQ3JDLFVBQVUsQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUUzQixPQUFPLFdBQVcsQ0FBQTtBQUV0QixDQUFDO0FBRUQsTUFBTSxVQUFVLHFCQUFxQjtJQUVqQyxJQUFJLEdBQUcsQ0FBQztJQUNSLElBQUksaUJBQWlCLEVBQUUsQ0FBQztRQUNwQixHQUFHLEdBQUcsaUJBQWlCLENBQUM7SUFDNUIsQ0FBQztTQUFNLElBQUksT0FBTyxNQUFNLEtBQUssV0FBVyxFQUFFLENBQUM7UUFDdkMsTUFBTSxRQUFRLEdBQUcsa0JBQWtCLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMxRCxJQUFJLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNoQixHQUFHLEdBQUcsR0FBRyxRQUFRLENBQUMsUUFBUSxLQUFLLFFBQVEsQ0FBQyxRQUFRLElBQUksUUFBUSxDQUFDLElBQUksS0FBSyxDQUFBO1FBQzFFLENBQUM7YUFBTSxDQUFDO1lBQ0osR0FBRyxHQUFHLEdBQUcsUUFBUSxDQUFDLFFBQVEsS0FBSyxRQUFRLENBQUMsUUFBUSxLQUFLLENBQUE7UUFDekQsQ0FBQztJQUNMLENBQUM7U0FBTSxDQUFDO1FBQ0osR0FBRyxHQUFHLGlCQUFpQixJQUFJLG9CQUFvQixDQUFBO0lBQ25ELENBQUM7SUFFRDs7OztVQUlNO0lBQ04sTUFBTSxXQUFXLEdBQUcsSUFBSSxNQUFNLEVBQUU7U0FDM0IsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDLG9CQUFvQjtTQUNyQyxVQUFVLENBQUMsU0FBUyxDQUFDLENBQUM7SUFFM0IsT0FBTyxXQUFXLENBQUE7QUFFdEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENsaWVudCB9IGZyb20gXCIuL2NsaWVudFwiO1xuXG5mdW5jdGlvbiBnZXRQb3J0QW5kSG9zdG5hbWUodXJsU3RyaW5nOiBzdHJpbmcpOiB7IGhvc3RuYW1lOiBzdHJpbmc7IHBvcnQ6IHN0cmluZzsgcHJvdG9jb2w6IHN0cmluZyB9IHtcbiAgICB0cnkge1xuICAgICAgICBjb25zdCB1cmwgPSBuZXcgVVJMKHVybFN0cmluZyk7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICBob3N0bmFtZTogdXJsLmhvc3RuYW1lLFxuICAgICAgICAgICAgcG9ydDogdXJsLnBvcnQgfHwgKHVybC5wcm90b2NvbCA9PT0gJ2h0dHBzOicgPyAnNDQzJyA6ICc4MCcpLCAvLyBEZWZhdWx0IHBvcnRzIGlmIG5vdCBzcGVjaWZpZWRcbiAgICAgICAgICAgIHByb3RvY29sOiB1cmwucHJvdG9jb2xcbiAgICAgICAgfTtcbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgICBjb25zb2xlLmVycm9yKCdJbnZhbGlkIFVSTDonLCBlcnJvcik7XG4gICAgICAgIHJldHVybiB7IGhvc3RuYW1lOiAnJywgcG9ydDogJycsIHByb3RvY29sOiAnJyB9O1xuICAgIH1cbn1cblxuY29uc3QgQVBQQ09OREFfRU5EUE9JTlQgPSAnYXBpL2FwcGNvbmRhL3YxJztcblxuZXhwb3J0IGZ1bmN0aW9uIGdldEFwcGNvbmRhQ2xpZW50KCkge1xuXG4gICAgbGV0IHVybDtcbiAgICBpZiAodHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgICAgY29uc3QgaG9zdEluZm8gPSBnZXRQb3J0QW5kSG9zdG5hbWUod2luZG93LmxvY2F0aW9uLmhyZWYpO1xuICAgICAgICBpZiAoaG9zdEluZm8ucG9ydCkge1xuICAgICAgICAgICAgdXJsID0gYCR7aG9zdEluZm8ucHJvdG9jb2x9Ly8ke2hvc3RJbmZvLmhvc3RuYW1lfToke2hvc3RJbmZvLnBvcnR9LyR7QVBQQ09OREFfRU5EUE9JTlR9YFxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdXJsID0gYCR7aG9zdEluZm8ucHJvdG9jb2x9Ly8ke2hvc3RJbmZvLmhvc3RuYW1lfS8ke0FQUENPTkRBX0VORFBPSU5UfWBcbiAgICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICAgIHVybCA9IEFQUENPTkRBX0VORFBPSU5UIHx8ICdodHRwOi8vYXBwY29uZGEvdjEnXG4gICAgfVxuXG4gICAgLyogIGlmIChBcHBsaWNhdGlvbkNvbmZpZy5Qb3J0ID09IG51bGwpIHtcbiAgICAgICAgIHVybCA9IGAke0FwcGxpY2F0aW9uQ29uZmlnLlByb3RvY29sfTovLyR7QXBwbGljYXRpb25Db25maWcuRG9tYWlufToke0FwcGxpY2F0aW9uQ29uZmlnLlBvcnR9L3YxYFxuICAgICB9IGVsc2Uge1xuICAgICAgICAgICB1cmwgPSBgJHtBcHBsaWNhdGlvbkNvbmZpZy5Qcm90b2NvbH06Ly8ke0FwcGxpY2F0aW9uQ29uZmlnLkRvbWFpbn0vdjFgXG4gICAgIH0gICovXG4gICAgY29uc3QgYWRtaW5DbGllbnQgPSBuZXcgQ2xpZW50KClcbiAgICAgICAgLnNldEVuZHBvaW50KHVybCkgLy8gWW91ciBBUEkgRW5kcG9pbnRcbiAgICAgICAgLnNldFByb2plY3QoJ2NvbnNvbGUnKTtcblxuICAgIHJldHVybiBhZG1pbkNsaWVudFxuXG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRBcHBjb25kYUNsaWVudFN5bmMoKSB7XG5cbiAgICBsZXQgdXJsO1xuICAgIGlmIChBUFBDT05EQV9FTkRQT0lOVCkge1xuICAgICAgICB1cmwgPSBBUFBDT05EQV9FTkRQT0lOVDtcbiAgICB9IGVsc2UgaWYgKHR5cGVvZiB3aW5kb3cgIT09ICd1bmRlZmluZWQnKSB7XG4gICAgICAgIGNvbnN0IGhvc3RJbmZvID0gZ2V0UG9ydEFuZEhvc3RuYW1lKHdpbmRvdy5sb2NhdGlvbi5ocmVmKTtcbiAgICAgICAgaWYgKGhvc3RJbmZvLnBvcnQpIHtcbiAgICAgICAgICAgIHVybCA9IGAke2hvc3RJbmZvLnByb3RvY29sfS8vJHtob3N0SW5mby5ob3N0bmFtZX06JHtob3N0SW5mby5wb3J0fS92MWBcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHVybCA9IGAke2hvc3RJbmZvLnByb3RvY29sfS8vJHtob3N0SW5mby5ob3N0bmFtZX0vdjFgXG4gICAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgICB1cmwgPSBBUFBDT05EQV9FTkRQT0lOVCB8fCAnaHR0cDovL2FwcGNvbmRhL3YxJ1xuICAgIH1cblxuICAgIC8qICBpZiAoQXBwbGljYXRpb25Db25maWcuUG9ydCA9PSBudWxsKSB7XG4gICAgICAgICB1cmwgPSBgJHtBcHBsaWNhdGlvbkNvbmZpZy5Qcm90b2NvbH06Ly8ke0FwcGxpY2F0aW9uQ29uZmlnLkRvbWFpbn06JHtBcHBsaWNhdGlvbkNvbmZpZy5Qb3J0fS92MWBcbiAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgdXJsID0gYCR7QXBwbGljYXRpb25Db25maWcuUHJvdG9jb2x9Oi8vJHtBcHBsaWNhdGlvbkNvbmZpZy5Eb21haW59L3YxYFxuICAgICB9ICAqL1xuICAgIGNvbnN0IGFkbWluQ2xpZW50ID0gbmV3IENsaWVudCgpXG4gICAgICAgIC5zZXRFbmRwb2ludCh1cmwpIC8vIFlvdXIgQVBJIEVuZHBvaW50XG4gICAgICAgIC5zZXRQcm9qZWN0KCdjb25zb2xlJyk7XG5cbiAgICByZXR1cm4gYWRtaW5DbGllbnRcblxufSJdfQ==
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0QXBwY29uZGFDbGllbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvZ2V0QXBwY29uZGFDbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUVsQyxNQUFNLHFCQUFxQixHQUFHLGtCQUFrQixDQUFDO0FBQ2pELE1BQU0sOEJBQThCLEdBQUcsdUNBQXVDLENBQUM7QUFjL0UsU0FBUyxpQkFBaUIsQ0FBQyxRQUFnQjtJQUN2QyxPQUFPLFFBQVEsQ0FBQyxPQUFPLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0FBQ3hDLENBQUM7QUFFRCxTQUFTLGVBQWUsQ0FBQyxnQkFBeUI7SUFDOUMsSUFBSSxnQkFBZ0IsRUFBRSxDQUFDO1FBQ25CLE9BQU8saUJBQWlCLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUMvQyxDQUFDO0lBRUQsTUFBTSxXQUFXLEdBQ2IsQ0FBQyxPQUFPLE9BQU8sS0FBSyxXQUFXLElBQUksT0FBTyxFQUFFLEdBQUcsRUFBRSxpQkFBaUIsQ0FBQztRQUNuRSxDQUFDLE9BQU8sT0FBTyxLQUFLLFdBQVcsSUFBSSxPQUFPLEVBQUUsR0FBRyxFQUFFLDZCQUE2QixDQUFDO1FBQy9FLEVBQUUsQ0FBQztJQUVQLElBQUksV0FBVyxFQUFFLENBQUM7UUFDZCxPQUFPLGlCQUFpQixDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQzFDLENBQUM7SUFFRCxJQUFJLE9BQU8sTUFBTSxLQUFLLFdBQVcsSUFBSSxNQUFNLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxDQUFDO1FBQzVELE9BQU8saUJBQWlCLENBQUMsSUFBSSxHQUFHLENBQUMscUJBQXFCLEVBQUUsTUFBTSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO0lBQ2hHLENBQUM7SUFFRCxPQUFPLDhCQUE4QixDQUFDO0FBQzFDLENBQUM7QUFFRCxTQUFTLGtCQUFrQixDQUFDLE1BQWMsRUFBRSxPQUE4QjtJQUN0RSxJQUFJLE9BQU8sQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUNsQixNQUFNLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUN2QyxDQUFDO0lBQ0QsSUFBSSxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDZixNQUFNLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNqQyxDQUFDO0lBQ0QsSUFBSSxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDZCxNQUFNLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUMvQixDQUFDO0lBQ0QsSUFBSSxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDZCxNQUFNLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUMvQixDQUFDO0lBQ0QsSUFBSSxPQUFPLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDbEIsTUFBTSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUNELElBQUksT0FBTyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ2pCLE1BQU0sQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3JDLENBQUM7SUFDRCxJQUFJLE9BQU8sQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO1FBQzdCLE1BQU0sQ0FBQyxxQkFBcUIsQ0FBQyxPQUFPLENBQUMsa0JBQWtCLENBQUMsQ0FBQztJQUM3RCxDQUFDO0lBQ0QsSUFBSSxPQUFPLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDbEIsS0FBSyxNQUFNLENBQUMsVUFBVSxFQUFFLFdBQVcsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7WUFDdEUsTUFBTSxDQUFDLFNBQVMsQ0FBQyxVQUFVLEVBQUUsV0FBVyxDQUFDLENBQUM7UUFDOUMsQ0FBQztJQUNMLENBQUM7SUFFRCxPQUFPLE1BQU0sQ0FBQztBQUNsQixDQUFDO0FBRUQsTUFBTSxVQUFVLGlCQUFpQixDQUFDLFVBQWlDLEVBQUU7SUFDakUsTUFBTSxNQUFNLEdBQUcsSUFBSSxNQUFNLEVBQUU7U0FDdEIsV0FBVyxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUM7U0FDOUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxPQUFPLElBQUksU0FBUyxDQUFDLENBQUM7SUFFOUMsT0FBTyxrQkFBa0IsQ0FBQyxNQUFNLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFDL0MsQ0FBQztBQUVELE1BQU0sVUFBVSxxQkFBcUIsQ0FBQyxVQUFpQyxFQUFFO0lBQ3JFLE9BQU8saUJBQWlCLENBQUMsT0FBTyxDQUFDLENBQUM7QUFDdEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENsaWVudCB9IGZyb20gJy4vY2xpZW50JztcblxuY29uc3QgQVBQQ09OREFfREVGQVVMVF9QQVRIID0gJy9hcGkvYXBwY29uZGEvdjEnO1xuY29uc3QgQVBQQ09OREFfTk9ERV9ERUZBVUxUX0VORFBPSU5UID0gJ2h0dHA6Ly9sb2NhbGhvc3Q6MzAwMC9hcGkvYXBwY29uZGEvdjEnO1xuXG5leHBvcnQgdHlwZSBBcHBjb25kYUNsaWVudE9wdGlvbnMgPSB7XG4gICAgZW5kcG9pbnQ/OiBzdHJpbmc7XG4gICAgcHJvamVjdD86IHN0cmluZztcbiAgICBtb2RlPzogc3RyaW5nO1xuICAgIGtleT86IHN0cmluZztcbiAgICBqd3Q/OiBzdHJpbmc7XG4gICAgc2Vzc2lvbj86IHN0cmluZztcbiAgICBsb2NhbGU/OiBzdHJpbmc7XG4gICAgZm9yd2FyZGVkVXNlckFnZW50Pzogc3RyaW5nO1xuICAgIGhlYWRlcnM/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+O1xufVxuXG5mdW5jdGlvbiBub3JtYWxpemVFbmRwb2ludChlbmRwb2ludDogc3RyaW5nKTogc3RyaW5nIHtcbiAgICByZXR1cm4gZW5kcG9pbnQucmVwbGFjZSgvXFwvKyQvLCAnJyk7XG59XG5cbmZ1bmN0aW9uIHJlc29sdmVFbmRwb2ludChvdmVycmlkZUVuZHBvaW50Pzogc3RyaW5nKTogc3RyaW5nIHtcbiAgICBpZiAob3ZlcnJpZGVFbmRwb2ludCkge1xuICAgICAgICByZXR1cm4gbm9ybWFsaXplRW5kcG9pbnQob3ZlcnJpZGVFbmRwb2ludCk7XG4gICAgfVxuXG4gICAgY29uc3QgZW52RW5kcG9pbnQgPVxuICAgICAgICAodHlwZW9mIHByb2Nlc3MgIT09ICd1bmRlZmluZWQnICYmIHByb2Nlc3M/LmVudj8uQVBQQ09OREFfRU5EUE9JTlQpIHx8XG4gICAgICAgICh0eXBlb2YgcHJvY2VzcyAhPT0gJ3VuZGVmaW5lZCcgJiYgcHJvY2Vzcz8uZW52Py5ORVhUX1BVQkxJQ19BUFBDT05EQV9FTkRQT0lOVCkgfHxcbiAgICAgICAgJyc7XG5cbiAgICBpZiAoZW52RW5kcG9pbnQpIHtcbiAgICAgICAgcmV0dXJuIG5vcm1hbGl6ZUVuZHBvaW50KGVudkVuZHBvaW50KTtcbiAgICB9XG5cbiAgICBpZiAodHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCcgJiYgd2luZG93Py5sb2NhdGlvbj8ub3JpZ2luKSB7XG4gICAgICAgIHJldHVybiBub3JtYWxpemVFbmRwb2ludChuZXcgVVJMKEFQUENPTkRBX0RFRkFVTFRfUEFUSCwgd2luZG93LmxvY2F0aW9uLm9yaWdpbikudG9TdHJpbmcoKSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIEFQUENPTkRBX05PREVfREVGQVVMVF9FTkRQT0lOVDtcbn1cblxuZnVuY3Rpb24gYXBwbHlDbGllbnRPcHRpb25zKGNsaWVudDogQ2xpZW50LCBvcHRpb25zOiBBcHBjb25kYUNsaWVudE9wdGlvbnMpOiBDbGllbnQge1xuICAgIGlmIChvcHRpb25zLnByb2plY3QpIHtcbiAgICAgICAgY2xpZW50LnNldFByb2plY3Qob3B0aW9ucy5wcm9qZWN0KTtcbiAgICB9XG4gICAgaWYgKG9wdGlvbnMubW9kZSkge1xuICAgICAgICBjbGllbnQuc2V0TW9kZShvcHRpb25zLm1vZGUpO1xuICAgIH1cbiAgICBpZiAob3B0aW9ucy5rZXkpIHtcbiAgICAgICAgY2xpZW50LnNldEtleShvcHRpb25zLmtleSk7XG4gICAgfVxuICAgIGlmIChvcHRpb25zLmp3dCkge1xuICAgICAgICBjbGllbnQuc2V0SldUKG9wdGlvbnMuand0KTtcbiAgICB9XG4gICAgaWYgKG9wdGlvbnMuc2Vzc2lvbikge1xuICAgICAgICBjbGllbnQuc2V0U2Vzc2lvbihvcHRpb25zLnNlc3Npb24pO1xuICAgIH1cbiAgICBpZiAob3B0aW9ucy5sb2NhbGUpIHtcbiAgICAgICAgY2xpZW50LnNldExvY2FsZShvcHRpb25zLmxvY2FsZSk7XG4gICAgfVxuICAgIGlmIChvcHRpb25zLmZvcndhcmRlZFVzZXJBZ2VudCkge1xuICAgICAgICBjbGllbnQuc2V0Rm9yd2FyZGVkVXNlckFnZW50KG9wdGlvbnMuZm9yd2FyZGVkVXNlckFnZW50KTtcbiAgICB9XG4gICAgaWYgKG9wdGlvbnMuaGVhZGVycykge1xuICAgICAgICBmb3IgKGNvbnN0IFtoZWFkZXJOYW1lLCBoZWFkZXJWYWx1ZV0gb2YgT2JqZWN0LmVudHJpZXMob3B0aW9ucy5oZWFkZXJzKSkge1xuICAgICAgICAgICAgY2xpZW50LmFkZEhlYWRlcihoZWFkZXJOYW1lLCBoZWFkZXJWYWx1ZSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gY2xpZW50O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0QXBwY29uZGFDbGllbnQob3B0aW9uczogQXBwY29uZGFDbGllbnRPcHRpb25zID0ge30pOiBDbGllbnQge1xuICAgIGNvbnN0IGNsaWVudCA9IG5ldyBDbGllbnQoKVxuICAgICAgICAuc2V0RW5kcG9pbnQocmVzb2x2ZUVuZHBvaW50KG9wdGlvbnMuZW5kcG9pbnQpKVxuICAgICAgICAuc2V0UHJvamVjdChvcHRpb25zLnByb2plY3QgPz8gJ2NvbnNvbGUnKTtcblxuICAgIHJldHVybiBhcHBseUNsaWVudE9wdGlvbnMoY2xpZW50LCBvcHRpb25zKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEFwcGNvbmRhQ2xpZW50U3luYyhvcHRpb25zOiBBcHBjb25kYUNsaWVudE9wdGlvbnMgPSB7fSk6IENsaWVudCB7XG4gICAgcmV0dXJuIGdldEFwcGNvbmRhQ2xpZW50KG9wdGlvbnMpO1xufVxuIl19
@@ -1,3 +1,4 @@
1
+ import type { AppcondaClientOptions } from './getAppcondaClient';
1
2
  import { BuilderService, DataSourceService, ScrapflowService, WaitlistService } from "./modules";
2
3
  import { AccountService } from "./modules/accounv1";
3
4
  import { TenantService } from "./modules/tenant/service";
@@ -17,4 +18,5 @@ export type AppcondaSDK = {
17
18
  waitlist: WaitlistService;
18
19
  configuration: Configuration;
19
20
  };
20
- export declare function getSDKForService(token?: string): AppcondaSDK;
21
+ export type AppcondaSDKOptions = AppcondaClientOptions;
22
+ export declare function getSDKForService(token?: string, options?: AppcondaSDKOptions): AppcondaSDK;
@@ -1,4 +1,4 @@
1
- import { getAppcondaClient } from "./getAppcondaClient";
1
+ import { getAppcondaClient } from './getAppcondaClient';
2
2
  import { BuilderService, DataSourceService, ScrapflowService, WaitlistService } from "./modules";
3
3
  import { AccountService } from "./modules/accounv1";
4
4
  import { TenantService } from "./modules/tenant/service";
@@ -6,8 +6,8 @@ import { Configuration } from "./services/configuration";
6
6
  import { OrganizationService } from "./modules/organization/service";
7
7
  import { EmploidService } from "./modules/emploid/service";
8
8
  import { BpmService } from "./modules/bpm/service";
9
- export function getSDKForService(token) {
10
- const adminClient = getAppcondaClient();
9
+ export function getSDKForService(token, options = {}) {
10
+ const adminClient = getAppcondaClient(options);
11
11
  adminClient.addHeader('x-service-token', '');
12
12
  if (token) {
13
13
  adminClient.addHeader('Authorization', `Bearer ${token}`);
@@ -69,4 +69,4 @@ export function getSDKForService(token) {
69
69
  configuration
70
70
  };
71
71
  }
72
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0U0RLRm9yU2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9nZXRTREtGb3JTZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRXhELE9BQU8sRUFBVyxjQUFjLEVBQUUsaUJBQWlCLEVBQUUsZ0JBQWdCLEVBQUUsZUFBZSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQzFHLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNwRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUE2Qm5ELE1BQU0sVUFBVSxnQkFBZ0IsQ0FBQyxLQUFjO0lBQzdDLE1BQU0sV0FBVyxHQUFHLGlCQUFpQixFQUFFLENBQUM7SUFFeEMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxpQkFBaUIsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUM3QyxJQUFJLEtBQUssRUFBRSxDQUFDO1FBQ1YsV0FBVyxDQUFDLFNBQVMsQ0FBQyxlQUFlLEVBQUUsVUFBVSxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQzVELENBQUM7SUFFRCxNQUFNLFFBQVEsR0FBRyxJQUFJLGNBQWMsQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUNqRCxNQUFNLE9BQU8sR0FBRyxJQUFJLGFBQWEsQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUMvQyxNQUFNLFlBQVksR0FBRyxJQUFJLG1CQUFtQixDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQzFELE1BQU0sT0FBTyxHQUFHLElBQUksY0FBYyxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ2hELE1BQU0sR0FBRyxHQUFHLElBQUksVUFBVSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ3hDLE1BQU0sVUFBVSxHQUFHLElBQUksaUJBQWlCLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDdEQsTUFBTSxPQUFPLEdBQUcsSUFBSSxjQUFjLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDaEQsTUFBTSxTQUFTLEdBQUcsSUFBSSxnQkFBZ0IsQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUVwRDs7Ozs7Ozs7Ozs7Ozs7Ozs7OztvREFtQmdEO0lBQ2hELE1BQU0sUUFBUSxHQUFHLElBQUksZUFBZSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ2xELE1BQU0sYUFBYSxHQUFHLElBQUksYUFBYSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBRXJELE9BQU87UUFDTCxRQUFRO1FBQ1IsT0FBTztRQUNQLFlBQVk7UUFDWixPQUFPO1FBQ1AsR0FBRztRQUNILFVBQVU7UUFDVixPQUFPO1FBQ1AsU0FBUztRQUNUOzs7Ozs7Ozs7Ozs7O3FCQWFhO1FBQ2IsUUFBUTtRQUNSLGFBQWE7S0FDZCxDQUFBO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldEFwcGNvbmRhQ2xpZW50IH0gZnJvbSBcIi4vZ2V0QXBwY29uZGFDbGllbnRcIjtcblxuaW1wb3J0IHsgQWNjb3VudCwgQnVpbGRlclNlcnZpY2UsIERhdGFTb3VyY2VTZXJ2aWNlLCBTY3JhcGZsb3dTZXJ2aWNlLCBXYWl0bGlzdFNlcnZpY2UgfSBmcm9tIFwiLi9tb2R1bGVzXCI7XG5pbXBvcnQgeyBBY2NvdW50U2VydmljZSB9IGZyb20gXCIuL21vZHVsZXMvYWNjb3VudjFcIjtcbmltcG9ydCB7IFRlbmFudFNlcnZpY2UgfSBmcm9tIFwiLi9tb2R1bGVzL3RlbmFudC9zZXJ2aWNlXCI7XG5pbXBvcnQgeyBDb25maWd1cmF0aW9uIH0gZnJvbSBcIi4vc2VydmljZXMvY29uZmlndXJhdGlvblwiO1xuaW1wb3J0IHsgT3JnYW5pemF0aW9uU2VydmljZSB9IGZyb20gXCIuL21vZHVsZXMvb3JnYW5pemF0aW9uL3NlcnZpY2VcIjtcbmltcG9ydCB7IEVtcGxvaWRTZXJ2aWNlIH0gZnJvbSBcIi4vbW9kdWxlcy9lbXBsb2lkL3NlcnZpY2VcIjtcbmltcG9ydCB7IEJwbVNlcnZpY2UgfSBmcm9tIFwiLi9tb2R1bGVzL2JwbS9zZXJ2aWNlXCI7XG5cbmV4cG9ydCB0eXBlIEFwcGNvbmRhU0RLID0ge1xuICBhY2NvdW50czogQWNjb3VudFNlcnZpY2UsXG4gIHRlbmFudHM6IFRlbmFudFNlcnZpY2UsXG4gIG9yZ2FuaXphdGlvbjogT3JnYW5pemF0aW9uU2VydmljZSxcbiAgZW1wbG9pZDogRW1wbG9pZFNlcnZpY2UsXG4gIGJwbTogQnBtU2VydmljZSxcbiAgZGF0YXNvdXJjZTogRGF0YVNvdXJjZVNlcnZpY2UsXG4gIGJ1aWxkZXI6IEJ1aWxkZXJTZXJ2aWNlLFxuICBzY3JhcGZsb3c6IFNjcmFwZmxvd1NlcnZpY2UsXG4gIC8qICAgY3VycmVudFVzZXIsXG4gICAgYWNjb3VudHMsXG4gICAgZGF0YWJhc2VzLFxuICAgIHByb2plY3RzLFxuICAgIHVzZXJzLFxuICAgIHRlYW1zLFxuICAgIHRlbmFudHMsXG4gICAgcm9sZXMsXG4gICAgcGVybWlzc2lvbnMsXG4gICAgc2NoZW1hcyxcbiAgICBjb21tdW5pdHksXG4gICAgdGVuYW50U3Vic2NyaXB0aW9ucyxcbiAgICBzdWJzY3JpcHRpb24sXG4gICAgcHJpY2luZywgKi9cbiAgd2FpdGxpc3Q6IFdhaXRsaXN0U2VydmljZSxcbiAgY29uZmlndXJhdGlvbjogQ29uZmlndXJhdGlvblxufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0U0RLRm9yU2VydmljZSh0b2tlbj86IHN0cmluZyk6IEFwcGNvbmRhU0RLIHtcbiAgY29uc3QgYWRtaW5DbGllbnQgPSBnZXRBcHBjb25kYUNsaWVudCgpO1xuXG4gIGFkbWluQ2xpZW50LmFkZEhlYWRlcigneC1zZXJ2aWNlLXRva2VuJywgJycpO1xuICBpZiAodG9rZW4pIHtcbiAgICBhZG1pbkNsaWVudC5hZGRIZWFkZXIoJ0F1dGhvcml6YXRpb24nLCBgQmVhcmVyICR7dG9rZW59YCk7XG4gIH1cblxuICBjb25zdCBhY2NvdW50cyA9IG5ldyBBY2NvdW50U2VydmljZShhZG1pbkNsaWVudCk7XG4gIGNvbnN0IHRlbmFudHMgPSBuZXcgVGVuYW50U2VydmljZShhZG1pbkNsaWVudCk7XG4gIGNvbnN0IG9yZ2FuaXphdGlvbiA9IG5ldyBPcmdhbml6YXRpb25TZXJ2aWNlKGFkbWluQ2xpZW50KTtcbiAgY29uc3QgZW1wbG9pZCA9IG5ldyBFbXBsb2lkU2VydmljZShhZG1pbkNsaWVudCk7XG4gIGNvbnN0IGJwbSA9IG5ldyBCcG1TZXJ2aWNlKGFkbWluQ2xpZW50KTtcbiAgY29uc3QgZGF0YXNvdXJjZSA9IG5ldyBEYXRhU291cmNlU2VydmljZShhZG1pbkNsaWVudCk7XG4gIGNvbnN0IGJ1aWxkZXIgPSBuZXcgQnVpbGRlclNlcnZpY2UoYWRtaW5DbGllbnQpO1xuICBjb25zdCBzY3JhcGZsb3cgPSBuZXcgU2NyYXBmbG93U2VydmljZShhZG1pbkNsaWVudCk7XG5cbiAgLyogICAgIGNvbnN0IGRhdGFiYXNlcyA9IG5ldyBEYXRhYmFzZXMoYWRtaW5DbGllbnQpO1xuICBcbiAgICAgIGNvbnN0IHByb2plY3RzID0gbmV3IFByb2plY3RzKGFkbWluQ2xpZW50KTtcbiAgXG4gICAgICBjb25zdCBjdXJyZW50VXNlciA9IGF3YWl0IGFjY291bnRzLmdldCgpO1xuICBcbiAgICAgIGNvbnN0IHVzZXJzID0gbmV3IFVzZXJzKGFkbWluQ2xpZW50KTtcbiAgICAgIGNvbnN0IHRlYW1zID0gbmV3IFRlYW1zKGFkbWluQ2xpZW50KTtcbiAgXG4gICAgIFxuICAgICAgY29uc3Qgcm9sZXMgPSBuZXcgUm9sZXMoYWRtaW5DbGllbnQpO1xuICAgICAgY29uc3QgcGVybWlzc2lvbnMgPSBuZXcgUGVybWlzc2lvbnMoYWRtaW5DbGllbnQpO1xuICAgICAgY29uc3Qgc2NoZW1hcyA9IG5ldyBTY2hlbWFzKGFkbWluQ2xpZW50KTtcbiAgXG4gICAgICBjb25zdCBjb21tdW5pdHkgPSBuZXcgQ29tbXVuaXR5KGFkbWluQ2xpZW50KTtcbiAgXG4gICAgICBjb25zdCB0ZW5hbnRTdWJzY3JpcHRpb25zID0gbmV3IFRlbmFudFN1YnNjcmlwdGlvbihhZG1pbkNsaWVudCk7XG4gIFxuICAgICAgY29uc3Qgc3Vic2NyaXB0aW9uID0gbmV3IFN1YnNjcmlwdGlvbihhZG1pbkNsaWVudCk7XG4gICAgICBjb25zdCBwcmljaW5nID0gbmV3IFByaWNpbmcoYWRtaW5DbGllbnQpOyAqL1xuICBjb25zdCB3YWl0bGlzdCA9IG5ldyBXYWl0bGlzdFNlcnZpY2UoYWRtaW5DbGllbnQpO1xuICBjb25zdCBjb25maWd1cmF0aW9uID0gbmV3IENvbmZpZ3VyYXRpb24oYWRtaW5DbGllbnQpO1xuXG4gIHJldHVybiB7XG4gICAgYWNjb3VudHMsXG4gICAgdGVuYW50cyxcbiAgICBvcmdhbml6YXRpb24sXG4gICAgZW1wbG9pZCxcbiAgICBicG0sXG4gICAgZGF0YXNvdXJjZSxcbiAgICBidWlsZGVyLFxuICAgIHNjcmFwZmxvdyxcbiAgICAvKiAgIGN1cnJlbnRVc2VyLFxuICAgICAgYWNjb3VudHMsXG4gICAgICBkYXRhYmFzZXMsXG4gICAgICBwcm9qZWN0cyxcbiAgICAgIHVzZXJzLFxuICAgICAgdGVhbXMsXG4gICAgICB0ZW5hbnRzLFxuICAgICAgcm9sZXMsXG4gICAgICBwZXJtaXNzaW9ucyxcbiAgICAgIHNjaGVtYXMsXG4gICAgICBjb21tdW5pdHksXG4gICAgICB0ZW5hbnRTdWJzY3JpcHRpb25zLFxuICAgICAgc3Vic2NyaXB0aW9uLFxuICAgICAgcHJpY2luZywgKi9cbiAgICB3YWl0bGlzdCxcbiAgICBjb25maWd1cmF0aW9uXG4gIH1cbn0iXX0=
72
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0U0RLRm9yU2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9nZXRTREtGb3JTZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBR3hELE9BQU8sRUFBVyxjQUFjLEVBQUUsaUJBQWlCLEVBQUUsZ0JBQWdCLEVBQUUsZUFBZSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQzFHLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNwRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUErQm5ELE1BQU0sVUFBVSxnQkFBZ0IsQ0FBQyxLQUFjLEVBQUUsVUFBOEIsRUFBRTtJQUMvRSxNQUFNLFdBQVcsR0FBRyxpQkFBaUIsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUUvQyxXQUFXLENBQUMsU0FBUyxDQUFDLGlCQUFpQixFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQzdDLElBQUksS0FBSyxFQUFFLENBQUM7UUFDVixXQUFXLENBQUMsU0FBUyxDQUFDLGVBQWUsRUFBRSxVQUFVLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDNUQsQ0FBQztJQUVELE1BQU0sUUFBUSxHQUFHLElBQUksY0FBYyxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ2pELE1BQU0sT0FBTyxHQUFHLElBQUksYUFBYSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQy9DLE1BQU0sWUFBWSxHQUFHLElBQUksbUJBQW1CLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDMUQsTUFBTSxPQUFPLEdBQUcsSUFBSSxjQUFjLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDaEQsTUFBTSxHQUFHLEdBQUcsSUFBSSxVQUFVLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDeEMsTUFBTSxVQUFVLEdBQUcsSUFBSSxpQkFBaUIsQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUN0RCxNQUFNLE9BQU8sR0FBRyxJQUFJLGNBQWMsQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUNoRCxNQUFNLFNBQVMsR0FBRyxJQUFJLGdCQUFnQixDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBRXBEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7O29EQW1CZ0Q7SUFDaEQsTUFBTSxRQUFRLEdBQUcsSUFBSSxlQUFlLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDbEQsTUFBTSxhQUFhLEdBQUcsSUFBSSxhQUFhLENBQUMsV0FBVyxDQUFDLENBQUM7SUFFckQsT0FBTztRQUNMLFFBQVE7UUFDUixPQUFPO1FBQ1AsWUFBWTtRQUNaLE9BQU87UUFDUCxHQUFHO1FBQ0gsVUFBVTtRQUNWLE9BQU87UUFDUCxTQUFTO1FBQ1Q7Ozs7Ozs7Ozs7Ozs7cUJBYWE7UUFDYixRQUFRO1FBQ1IsYUFBYTtLQUNkLENBQUE7QUFDSCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0QXBwY29uZGFDbGllbnQgfSBmcm9tICcuL2dldEFwcGNvbmRhQ2xpZW50JztcbmltcG9ydCB0eXBlIHsgQXBwY29uZGFDbGllbnRPcHRpb25zIH0gZnJvbSAnLi9nZXRBcHBjb25kYUNsaWVudCc7XG5cbmltcG9ydCB7IEFjY291bnQsIEJ1aWxkZXJTZXJ2aWNlLCBEYXRhU291cmNlU2VydmljZSwgU2NyYXBmbG93U2VydmljZSwgV2FpdGxpc3RTZXJ2aWNlIH0gZnJvbSBcIi4vbW9kdWxlc1wiO1xuaW1wb3J0IHsgQWNjb3VudFNlcnZpY2UgfSBmcm9tIFwiLi9tb2R1bGVzL2FjY291bnYxXCI7XG5pbXBvcnQgeyBUZW5hbnRTZXJ2aWNlIH0gZnJvbSBcIi4vbW9kdWxlcy90ZW5hbnQvc2VydmljZVwiO1xuaW1wb3J0IHsgQ29uZmlndXJhdGlvbiB9IGZyb20gXCIuL3NlcnZpY2VzL2NvbmZpZ3VyYXRpb25cIjtcbmltcG9ydCB7IE9yZ2FuaXphdGlvblNlcnZpY2UgfSBmcm9tIFwiLi9tb2R1bGVzL29yZ2FuaXphdGlvbi9zZXJ2aWNlXCI7XG5pbXBvcnQgeyBFbXBsb2lkU2VydmljZSB9IGZyb20gXCIuL21vZHVsZXMvZW1wbG9pZC9zZXJ2aWNlXCI7XG5pbXBvcnQgeyBCcG1TZXJ2aWNlIH0gZnJvbSBcIi4vbW9kdWxlcy9icG0vc2VydmljZVwiO1xuXG5leHBvcnQgdHlwZSBBcHBjb25kYVNESyA9IHtcbiAgYWNjb3VudHM6IEFjY291bnRTZXJ2aWNlLFxuICB0ZW5hbnRzOiBUZW5hbnRTZXJ2aWNlLFxuICBvcmdhbml6YXRpb246IE9yZ2FuaXphdGlvblNlcnZpY2UsXG4gIGVtcGxvaWQ6IEVtcGxvaWRTZXJ2aWNlLFxuICBicG06IEJwbVNlcnZpY2UsXG4gIGRhdGFzb3VyY2U6IERhdGFTb3VyY2VTZXJ2aWNlLFxuICBidWlsZGVyOiBCdWlsZGVyU2VydmljZSxcbiAgc2NyYXBmbG93OiBTY3JhcGZsb3dTZXJ2aWNlLFxuICAvKiAgIGN1cnJlbnRVc2VyLFxuICAgIGFjY291bnRzLFxuICAgIGRhdGFiYXNlcyxcbiAgICBwcm9qZWN0cyxcbiAgICB1c2VycyxcbiAgICB0ZWFtcyxcbiAgICB0ZW5hbnRzLFxuICAgIHJvbGVzLFxuICAgIHBlcm1pc3Npb25zLFxuICAgIHNjaGVtYXMsXG4gICAgY29tbXVuaXR5LFxuICAgIHRlbmFudFN1YnNjcmlwdGlvbnMsXG4gICAgc3Vic2NyaXB0aW9uLFxuICAgIHByaWNpbmcsICovXG4gIHdhaXRsaXN0OiBXYWl0bGlzdFNlcnZpY2UsXG4gIGNvbmZpZ3VyYXRpb246IENvbmZpZ3VyYXRpb25cbn1cblxuZXhwb3J0IHR5cGUgQXBwY29uZGFTREtPcHRpb25zID0gQXBwY29uZGFDbGllbnRPcHRpb25zO1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0U0RLRm9yU2VydmljZSh0b2tlbj86IHN0cmluZywgb3B0aW9uczogQXBwY29uZGFTREtPcHRpb25zID0ge30pOiBBcHBjb25kYVNESyB7XG4gIGNvbnN0IGFkbWluQ2xpZW50ID0gZ2V0QXBwY29uZGFDbGllbnQob3B0aW9ucyk7XG5cbiAgYWRtaW5DbGllbnQuYWRkSGVhZGVyKCd4LXNlcnZpY2UtdG9rZW4nLCAnJyk7XG4gIGlmICh0b2tlbikge1xuICAgIGFkbWluQ2xpZW50LmFkZEhlYWRlcignQXV0aG9yaXphdGlvbicsIGBCZWFyZXIgJHt0b2tlbn1gKTtcbiAgfVxuXG4gIGNvbnN0IGFjY291bnRzID0gbmV3IEFjY291bnRTZXJ2aWNlKGFkbWluQ2xpZW50KTtcbiAgY29uc3QgdGVuYW50cyA9IG5ldyBUZW5hbnRTZXJ2aWNlKGFkbWluQ2xpZW50KTtcbiAgY29uc3Qgb3JnYW5pemF0aW9uID0gbmV3IE9yZ2FuaXphdGlvblNlcnZpY2UoYWRtaW5DbGllbnQpO1xuICBjb25zdCBlbXBsb2lkID0gbmV3IEVtcGxvaWRTZXJ2aWNlKGFkbWluQ2xpZW50KTtcbiAgY29uc3QgYnBtID0gbmV3IEJwbVNlcnZpY2UoYWRtaW5DbGllbnQpO1xuICBjb25zdCBkYXRhc291cmNlID0gbmV3IERhdGFTb3VyY2VTZXJ2aWNlKGFkbWluQ2xpZW50KTtcbiAgY29uc3QgYnVpbGRlciA9IG5ldyBCdWlsZGVyU2VydmljZShhZG1pbkNsaWVudCk7XG4gIGNvbnN0IHNjcmFwZmxvdyA9IG5ldyBTY3JhcGZsb3dTZXJ2aWNlKGFkbWluQ2xpZW50KTtcblxuICAvKiAgICAgY29uc3QgZGF0YWJhc2VzID0gbmV3IERhdGFiYXNlcyhhZG1pbkNsaWVudCk7XG4gIFxuICAgICAgY29uc3QgcHJvamVjdHMgPSBuZXcgUHJvamVjdHMoYWRtaW5DbGllbnQpO1xuICBcbiAgICAgIGNvbnN0IGN1cnJlbnRVc2VyID0gYXdhaXQgYWNjb3VudHMuZ2V0KCk7XG4gIFxuICAgICAgY29uc3QgdXNlcnMgPSBuZXcgVXNlcnMoYWRtaW5DbGllbnQpO1xuICAgICAgY29uc3QgdGVhbXMgPSBuZXcgVGVhbXMoYWRtaW5DbGllbnQpO1xuICBcbiAgICAgXG4gICAgICBjb25zdCByb2xlcyA9IG5ldyBSb2xlcyhhZG1pbkNsaWVudCk7XG4gICAgICBjb25zdCBwZXJtaXNzaW9ucyA9IG5ldyBQZXJtaXNzaW9ucyhhZG1pbkNsaWVudCk7XG4gICAgICBjb25zdCBzY2hlbWFzID0gbmV3IFNjaGVtYXMoYWRtaW5DbGllbnQpO1xuICBcbiAgICAgIGNvbnN0IGNvbW11bml0eSA9IG5ldyBDb21tdW5pdHkoYWRtaW5DbGllbnQpO1xuICBcbiAgICAgIGNvbnN0IHRlbmFudFN1YnNjcmlwdGlvbnMgPSBuZXcgVGVuYW50U3Vic2NyaXB0aW9uKGFkbWluQ2xpZW50KTtcbiAgXG4gICAgICBjb25zdCBzdWJzY3JpcHRpb24gPSBuZXcgU3Vic2NyaXB0aW9uKGFkbWluQ2xpZW50KTtcbiAgICAgIGNvbnN0IHByaWNpbmcgPSBuZXcgUHJpY2luZyhhZG1pbkNsaWVudCk7ICovXG4gIGNvbnN0IHdhaXRsaXN0ID0gbmV3IFdhaXRsaXN0U2VydmljZShhZG1pbkNsaWVudCk7XG4gIGNvbnN0IGNvbmZpZ3VyYXRpb24gPSBuZXcgQ29uZmlndXJhdGlvbihhZG1pbkNsaWVudCk7XG5cbiAgcmV0dXJuIHtcbiAgICBhY2NvdW50cyxcbiAgICB0ZW5hbnRzLFxuICAgIG9yZ2FuaXphdGlvbixcbiAgICBlbXBsb2lkLFxuICAgIGJwbSxcbiAgICBkYXRhc291cmNlLFxuICAgIGJ1aWxkZXIsXG4gICAgc2NyYXBmbG93LFxuICAgIC8qICAgY3VycmVudFVzZXIsXG4gICAgICBhY2NvdW50cyxcbiAgICAgIGRhdGFiYXNlcyxcbiAgICAgIHByb2plY3RzLFxuICAgICAgdXNlcnMsXG4gICAgICB0ZWFtcyxcbiAgICAgIHRlbmFudHMsXG4gICAgICByb2xlcyxcbiAgICAgIHBlcm1pc3Npb25zLFxuICAgICAgc2NoZW1hcyxcbiAgICAgIGNvbW11bml0eSxcbiAgICAgIHRlbmFudFN1YnNjcmlwdGlvbnMsXG4gICAgICBzdWJzY3JpcHRpb24sXG4gICAgICBwcmljaW5nLCAqL1xuICAgIHdhaXRsaXN0LFxuICAgIGNvbmZpZ3VyYXRpb25cbiAgfVxufVxuIl19
package/dist/index.d.ts CHANGED
@@ -1,3 +1,7 @@
1
1
  export * from './modules';
2
- export { getSDKForService, AppcondaSDK } from './getSDKForService';
2
+ export { getSDKForService } from './getSDKForService';
3
+ export type { AppcondaSDK, AppcondaSDKOptions } from './getSDKForService';
3
4
  export * from './EmploidClient';
5
+ export { getAppcondaClient, getAppcondaClientSync } from './getAppcondaClient';
6
+ export type { AppcondaClientOptions } from './getAppcondaClient';
7
+ export { Client, AppcondaException, Query } from './client';
package/dist/index.js CHANGED
@@ -1,4 +1,6 @@
1
1
  export * from './modules';
2
2
  export { getSDKForService } from './getSDKForService';
3
3
  export * from './EmploidClient';
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxXQUFXLENBQUM7QUFDMUIsT0FBTyxFQUFFLGdCQUFnQixFQUFlLE1BQU0sb0JBQW9CLENBQUM7QUFDbkUsY0FBYyxpQkFBaUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbW9kdWxlcyc7XG5leHBvcnQgeyBnZXRTREtGb3JTZXJ2aWNlLCBBcHBjb25kYVNESyB9IGZyb20gJy4vZ2V0U0RLRm9yU2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL0VtcGxvaWRDbGllbnQnO1xuXG4iXX0=
4
+ export { getAppcondaClient, getAppcondaClientSync } from './getAppcondaClient';
5
+ export { Client, AppcondaException, Query } from './client';
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxXQUFXLENBQUM7QUFDMUIsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFdEQsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUUvRSxPQUFPLEVBQUUsTUFBTSxFQUFFLGlCQUFpQixFQUFFLEtBQUssRUFBRSxNQUFNLFVBQVUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbW9kdWxlcyc7XG5leHBvcnQgeyBnZXRTREtGb3JTZXJ2aWNlIH0gZnJvbSAnLi9nZXRTREtGb3JTZXJ2aWNlJztcbmV4cG9ydCB0eXBlIHsgQXBwY29uZGFTREssIEFwcGNvbmRhU0RLT3B0aW9ucyB9IGZyb20gJy4vZ2V0U0RLRm9yU2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL0VtcGxvaWRDbGllbnQnO1xuZXhwb3J0IHsgZ2V0QXBwY29uZGFDbGllbnQsIGdldEFwcGNvbmRhQ2xpZW50U3luYyB9IGZyb20gJy4vZ2V0QXBwY29uZGFDbGllbnQnO1xuZXhwb3J0IHR5cGUgeyBBcHBjb25kYUNsaWVudE9wdGlvbnMgfSBmcm9tICcuL2dldEFwcGNvbmRhQ2xpZW50JztcbmV4cG9ydCB7IENsaWVudCwgQXBwY29uZGFFeGNlcHRpb24sIFF1ZXJ5IH0gZnJvbSAnLi9jbGllbnQnO1xuIl19
@@ -1017,9 +1017,13 @@ export declare const ListWorkerTopicsSchema: z.ZodObject<{
1017
1017
  workerId: z.ZodOptional<z.ZodString>;
1018
1018
  }, z.core.$strip>;
1019
1019
  export declare const CreateTopicSchema: z.ZodObject<{
1020
- entityName: z.ZodString;
1021
- entityDescription: z.ZodString;
1022
- categories: z.ZodOptional<z.ZodArray<z.ZodString>>;
1020
+ tenantId: z.ZodString;
1021
+ entityId: z.ZodString;
1022
+ entityType: z.ZodString;
1023
+ title: z.ZodString;
1024
+ prompt: z.ZodOptional<z.ZodString>;
1025
+ instructions: z.ZodOptional<z.ZodArray<z.ZodString>>;
1026
+ category: z.ZodString;
1023
1027
  }, z.core.$strip>;
1024
1028
  export declare const UpdateTopicSchema: z.ZodObject<{
1025
1029
  id: z.ZodString;
@@ -1047,6 +1051,7 @@ export declare const PublishWorkerSchema: z.ZodObject<{
1047
1051
  workerId: z.ZodString;
1048
1052
  }, z.core.$strip>;
1049
1053
  export declare const EnhanceTopicSchema: z.ZodObject<{
1050
- tenantId: z.ZodString;
1051
- entityId: z.ZodOptional<z.ZodString>;
1054
+ entityName: z.ZodString;
1055
+ entityDescription: z.ZodString;
1056
+ categories: z.ZodOptional<z.ZodArray<z.ZodString>>;
1052
1057
  }, z.core.$strip>;