@zapier/zapier-sdk 0.11.1 → 0.12.0

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/index.cjs CHANGED
@@ -298,6 +298,21 @@ var appsPlugin = ({ sdk }) => {
298
298
  apps: createAppsProxy({ sdk })
299
299
  };
300
300
  };
301
+ var FetchUrlSchema = zod.z.union([zod.z.string(), zod.z.instanceof(URL)]).describe("The URL to fetch");
302
+ var FetchInitSchema = zod.z.object({
303
+ method: zod.z.enum(["GET", "POST", "PUT", "DELETE", "PATCH", "HEAD", "OPTIONS"]).optional(),
304
+ headers: zod.z.record(zod.z.string()).optional(),
305
+ body: zod.z.union([
306
+ zod.z.string(),
307
+ zod.z.instanceof(FormData),
308
+ zod.z.instanceof(URLSearchParams)
309
+ ]).optional(),
310
+ authenticationId: zod.z.number().optional().describe("Zapier authentication ID to use for the request"),
311
+ callbackUrl: zod.z.string().optional().describe("URL to send async response to (makes request async)"),
312
+ authenticationTemplate: zod.z.string().optional().describe(
313
+ "Optional JSON string authentication template to bypass Notary lookup"
314
+ )
315
+ }).optional().describe("Fetch options including authentication");
301
316
 
302
317
  // src/plugins/fetch/index.ts
303
318
  var fetchPlugin = ({ sdk }) => {
@@ -318,6 +333,19 @@ var fetchPlugin = ({ sdk }) => {
318
333
  callbackUrl,
319
334
  authenticationTemplate
320
335
  });
336
+ },
337
+ context: {
338
+ meta: {
339
+ fetch: {
340
+ packages: ["sdk"],
341
+ categories: ["http"],
342
+ returnType: "Response",
343
+ inputParameters: [
344
+ { name: "url", schema: FetchUrlSchema },
345
+ { name: "init", schema: FetchInitSchema }
346
+ ]
347
+ }
348
+ }
321
349
  }
322
350
  };
323
351
  };
@@ -1851,7 +1879,9 @@ var ListAuthenticationsSchema = zod.z.object({
1851
1879
  search: zod.z.string().optional().describe("Search term to filter authentications by title"),
1852
1880
  title: zod.z.string().optional().describe("Filter authentications by exact title match"),
1853
1881
  accountId: zod.z.string().optional().describe("Filter by account ID"),
1854
- owner: zod.z.string().optional().describe("Filter by owner"),
1882
+ owner: zod.z.union([zod.z.string(), zod.z.literal("me")]).optional().describe(
1883
+ "Filter by owner, 'me' for your own authentications or a specific user ID"
1884
+ ),
1855
1885
  pageSize: zod.z.number().min(1).optional().describe("Number of authentications per page"),
1856
1886
  maxItems: zod.z.number().min(1).optional().describe("Maximum total items to return across all pages")
1857
1887
  }).describe("List available authentications with optional filtering");
@@ -3495,37 +3525,53 @@ var registryPlugin = ({ sdk, context }) => {
3495
3525
  itemType: meta.itemType,
3496
3526
  returnType: meta.returnType,
3497
3527
  inputSchema: meta.inputSchema,
3528
+ inputParameters: meta.inputParameters,
3498
3529
  outputSchema: meta.outputSchema,
3499
3530
  categories: meta.categories || [],
3500
- resolvers: meta.resolvers
3531
+ resolvers: meta.resolvers,
3532
+ packages: meta.packages
3501
3533
  };
3502
3534
  }).sort((a, b) => a.name.localeCompare(b.name));
3503
3535
  const knownCategories = Object.keys(categoryDefinitions);
3504
- const categories = knownCategories.sort((a, b) => {
3505
- if (a === "other") return 1;
3506
- if (b === "other") return -1;
3507
- const titleA = categoryDefinitions[a].title;
3508
- const titleB = categoryDefinitions[b].title;
3509
- return titleA.localeCompare(titleB);
3510
- }).map((categoryKey) => {
3511
- const categoryFunctions = functions.filter(
3512
- (f) => f.categories.includes(categoryKey) || // If the category is "other" and the function is not in any other category, include it
3513
- categoryKey === "other" && !f.categories.some((c) => knownCategories.includes(c))
3514
- ).map((f) => f.name).sort();
3515
- const definition = categoryDefinitions[categoryKey];
3516
- const title = definition.title;
3517
- return {
3518
- key: categoryKey,
3519
- title,
3520
- titlePlural: definition.titlePlural ?? `${title}s`,
3521
- functions: categoryFunctions
3522
- };
3523
- });
3524
- function getRegistry() {
3525
- return {
3526
- functions,
3527
- categories
3536
+ const registryCache = /* @__PURE__ */ new Map();
3537
+ function getRegistry(options) {
3538
+ const packageFilter = options?.package;
3539
+ const cacheKey = packageFilter || "__all__";
3540
+ if (registryCache.has(cacheKey)) {
3541
+ return registryCache.get(cacheKey);
3542
+ }
3543
+ const filteredFunctions = packageFilter ? functions.filter(
3544
+ (f) => (
3545
+ // Include if packages is undefined (belongs to all packages) or includes the specified package
3546
+ !f.packages || f.packages.includes(packageFilter)
3547
+ )
3548
+ ) : functions;
3549
+ const filteredCategories = knownCategories.sort((a, b) => {
3550
+ if (a === "other") return 1;
3551
+ if (b === "other") return -1;
3552
+ const titleA = categoryDefinitions[a].title;
3553
+ const titleB = categoryDefinitions[b].title;
3554
+ return titleA.localeCompare(titleB);
3555
+ }).map((categoryKey) => {
3556
+ const categoryFunctions = filteredFunctions.filter(
3557
+ (f) => f.categories.includes(categoryKey) || // If the category is "other" and the function is not in any other category, include it
3558
+ categoryKey === "other" && !f.categories.some((c) => knownCategories.includes(c))
3559
+ ).map((f) => f.name).sort();
3560
+ const definition = categoryDefinitions[categoryKey];
3561
+ const title = definition.title;
3562
+ return {
3563
+ key: categoryKey,
3564
+ title,
3565
+ titlePlural: definition.titlePlural ?? `${title}s`,
3566
+ functions: categoryFunctions
3567
+ };
3568
+ }).filter((category) => category.functions.length > 0);
3569
+ const result = {
3570
+ functions: filteredFunctions,
3571
+ categories: filteredCategories
3528
3572
  };
3573
+ registryCache.set(cacheKey, result);
3574
+ return result;
3529
3575
  }
3530
3576
  return {
3531
3577
  getRegistry
package/dist/index.d.mts CHANGED
@@ -1,3 +1,4 @@
1
+ import * as zod from 'zod';
1
2
  import { z } from 'zod';
2
3
 
3
4
  /**
@@ -1575,7 +1576,9 @@ type Sdk<TCurrentSdk = {}, TCurrentContext = {
1575
1576
  };
1576
1577
 
1577
1578
  interface RegistryPluginProvides {
1578
- getRegistry: () => {
1579
+ getRegistry: (options?: {
1580
+ package?: string;
1581
+ }) => {
1579
1582
  functions: FunctionRegistryEntry[];
1580
1583
  categories: {
1581
1584
  key: string;
@@ -1661,6 +1664,19 @@ interface FetchPluginProvides {
1661
1664
  callbackUrl?: string;
1662
1665
  authenticationTemplate?: string;
1663
1666
  }) => Promise<Response>;
1667
+ context: {
1668
+ meta: {
1669
+ fetch: {
1670
+ packages: string[];
1671
+ categories: string[];
1672
+ returnType: string;
1673
+ inputParameters: Array<{
1674
+ name: string;
1675
+ schema: z.ZodSchema;
1676
+ }>;
1677
+ };
1678
+ };
1679
+ };
1664
1680
  }
1665
1681
  /**
1666
1682
  * Direct plugin function - takes options + sdk + context in one object
@@ -1981,7 +1997,7 @@ declare const ListAuthenticationsSchema: z.ZodObject<{
1981
1997
  search: z.ZodOptional<z.ZodString>;
1982
1998
  title: z.ZodOptional<z.ZodString>;
1983
1999
  accountId: z.ZodOptional<z.ZodString>;
1984
- owner: z.ZodOptional<z.ZodString>;
2000
+ owner: z.ZodOptional<z.ZodUnion<[z.ZodString, z.ZodLiteral<"me">]>>;
1985
2001
  pageSize: z.ZodOptional<z.ZodNumber>;
1986
2002
  maxItems: z.ZodOptional<z.ZodNumber>;
1987
2003
  }, "strip", z.ZodTypeAny, {
@@ -2198,10 +2214,15 @@ interface FunctionRegistryEntry {
2198
2214
  type?: "list" | "item";
2199
2215
  itemType?: string;
2200
2216
  returnType?: string;
2201
- inputSchema: z.ZodSchema;
2217
+ inputSchema?: z.ZodSchema;
2218
+ inputParameters?: Array<{
2219
+ name: string;
2220
+ schema: z.ZodSchema;
2221
+ }>;
2202
2222
  outputSchema?: z.ZodSchema;
2203
2223
  categories: string[];
2204
2224
  resolvers?: Record<string, any>;
2225
+ packages?: string[];
2205
2226
  }
2206
2227
  interface ZapierSdk extends GetSdkType<RegistryPluginProvides & FetchPluginProvides & AppsPluginProvides & ListAppsPluginProvides & ManifestPluginProvides & GetAppPluginProvides & ListActionsPluginProvides & GetActionPluginProvides & RunActionPluginProvides & ListAuthenticationsPluginProvides & GetAuthenticationPluginProvides & FindFirstAuthenticationPluginProvides & FindUniqueAuthenticationPluginProvides & ListInputFieldsPluginProvides & ListInputFieldChoicesPluginProvides & RequestPluginProvides & GetProfilePluginProvides> {
2207
2228
  apps: ActionProxy & ZapierSdkApps;
@@ -3385,6 +3406,18 @@ declare function createZapierSdkWithoutRegistry(options?: ZapierSdkOptions): Sdk
3385
3406
  inputSchema: typeof RelayRequestSchema;
3386
3407
  };
3387
3408
  };
3409
+ } & {
3410
+ meta: {
3411
+ fetch: {
3412
+ packages: string[];
3413
+ categories: string[];
3414
+ returnType: string;
3415
+ inputParameters: Array<{
3416
+ name: string;
3417
+ schema: zod.ZodType;
3418
+ }>;
3419
+ };
3420
+ };
3388
3421
  } & {
3389
3422
  meta: {
3390
3423
  getProfile: {
package/dist/index.mjs CHANGED
@@ -296,6 +296,21 @@ var appsPlugin = ({ sdk }) => {
296
296
  apps: createAppsProxy({ sdk })
297
297
  };
298
298
  };
299
+ var FetchUrlSchema = z.union([z.string(), z.instanceof(URL)]).describe("The URL to fetch");
300
+ var FetchInitSchema = z.object({
301
+ method: z.enum(["GET", "POST", "PUT", "DELETE", "PATCH", "HEAD", "OPTIONS"]).optional(),
302
+ headers: z.record(z.string()).optional(),
303
+ body: z.union([
304
+ z.string(),
305
+ z.instanceof(FormData),
306
+ z.instanceof(URLSearchParams)
307
+ ]).optional(),
308
+ authenticationId: z.number().optional().describe("Zapier authentication ID to use for the request"),
309
+ callbackUrl: z.string().optional().describe("URL to send async response to (makes request async)"),
310
+ authenticationTemplate: z.string().optional().describe(
311
+ "Optional JSON string authentication template to bypass Notary lookup"
312
+ )
313
+ }).optional().describe("Fetch options including authentication");
299
314
 
300
315
  // src/plugins/fetch/index.ts
301
316
  var fetchPlugin = ({ sdk }) => {
@@ -316,6 +331,19 @@ var fetchPlugin = ({ sdk }) => {
316
331
  callbackUrl,
317
332
  authenticationTemplate
318
333
  });
334
+ },
335
+ context: {
336
+ meta: {
337
+ fetch: {
338
+ packages: ["sdk"],
339
+ categories: ["http"],
340
+ returnType: "Response",
341
+ inputParameters: [
342
+ { name: "url", schema: FetchUrlSchema },
343
+ { name: "init", schema: FetchInitSchema }
344
+ ]
345
+ }
346
+ }
319
347
  }
320
348
  };
321
349
  };
@@ -1849,7 +1877,9 @@ var ListAuthenticationsSchema = z.object({
1849
1877
  search: z.string().optional().describe("Search term to filter authentications by title"),
1850
1878
  title: z.string().optional().describe("Filter authentications by exact title match"),
1851
1879
  accountId: z.string().optional().describe("Filter by account ID"),
1852
- owner: z.string().optional().describe("Filter by owner"),
1880
+ owner: z.union([z.string(), z.literal("me")]).optional().describe(
1881
+ "Filter by owner, 'me' for your own authentications or a specific user ID"
1882
+ ),
1853
1883
  pageSize: z.number().min(1).optional().describe("Number of authentications per page"),
1854
1884
  maxItems: z.number().min(1).optional().describe("Maximum total items to return across all pages")
1855
1885
  }).describe("List available authentications with optional filtering");
@@ -3493,37 +3523,53 @@ var registryPlugin = ({ sdk, context }) => {
3493
3523
  itemType: meta.itemType,
3494
3524
  returnType: meta.returnType,
3495
3525
  inputSchema: meta.inputSchema,
3526
+ inputParameters: meta.inputParameters,
3496
3527
  outputSchema: meta.outputSchema,
3497
3528
  categories: meta.categories || [],
3498
- resolvers: meta.resolvers
3529
+ resolvers: meta.resolvers,
3530
+ packages: meta.packages
3499
3531
  };
3500
3532
  }).sort((a, b) => a.name.localeCompare(b.name));
3501
3533
  const knownCategories = Object.keys(categoryDefinitions);
3502
- const categories = knownCategories.sort((a, b) => {
3503
- if (a === "other") return 1;
3504
- if (b === "other") return -1;
3505
- const titleA = categoryDefinitions[a].title;
3506
- const titleB = categoryDefinitions[b].title;
3507
- return titleA.localeCompare(titleB);
3508
- }).map((categoryKey) => {
3509
- const categoryFunctions = functions.filter(
3510
- (f) => f.categories.includes(categoryKey) || // If the category is "other" and the function is not in any other category, include it
3511
- categoryKey === "other" && !f.categories.some((c) => knownCategories.includes(c))
3512
- ).map((f) => f.name).sort();
3513
- const definition = categoryDefinitions[categoryKey];
3514
- const title = definition.title;
3515
- return {
3516
- key: categoryKey,
3517
- title,
3518
- titlePlural: definition.titlePlural ?? `${title}s`,
3519
- functions: categoryFunctions
3520
- };
3521
- });
3522
- function getRegistry() {
3523
- return {
3524
- functions,
3525
- categories
3534
+ const registryCache = /* @__PURE__ */ new Map();
3535
+ function getRegistry(options) {
3536
+ const packageFilter = options?.package;
3537
+ const cacheKey = packageFilter || "__all__";
3538
+ if (registryCache.has(cacheKey)) {
3539
+ return registryCache.get(cacheKey);
3540
+ }
3541
+ const filteredFunctions = packageFilter ? functions.filter(
3542
+ (f) => (
3543
+ // Include if packages is undefined (belongs to all packages) or includes the specified package
3544
+ !f.packages || f.packages.includes(packageFilter)
3545
+ )
3546
+ ) : functions;
3547
+ const filteredCategories = knownCategories.sort((a, b) => {
3548
+ if (a === "other") return 1;
3549
+ if (b === "other") return -1;
3550
+ const titleA = categoryDefinitions[a].title;
3551
+ const titleB = categoryDefinitions[b].title;
3552
+ return titleA.localeCompare(titleB);
3553
+ }).map((categoryKey) => {
3554
+ const categoryFunctions = filteredFunctions.filter(
3555
+ (f) => f.categories.includes(categoryKey) || // If the category is "other" and the function is not in any other category, include it
3556
+ categoryKey === "other" && !f.categories.some((c) => knownCategories.includes(c))
3557
+ ).map((f) => f.name).sort();
3558
+ const definition = categoryDefinitions[categoryKey];
3559
+ const title = definition.title;
3560
+ return {
3561
+ key: categoryKey,
3562
+ title,
3563
+ titlePlural: definition.titlePlural ?? `${title}s`,
3564
+ functions: categoryFunctions
3565
+ };
3566
+ }).filter((category) => category.functions.length > 0);
3567
+ const result = {
3568
+ functions: filteredFunctions,
3569
+ categories: filteredCategories
3526
3570
  };
3571
+ registryCache.set(cacheKey, result);
3572
+ return result;
3527
3573
  }
3528
3574
  return {
3529
3575
  getRegistry
@@ -1,11 +1,25 @@
1
1
  import type { Plugin, GetSdkType } from "../../types/plugin";
2
2
  import type { RequestPluginProvides } from "../request";
3
+ import type { z } from "zod";
3
4
  export interface FetchPluginProvides {
4
5
  fetch: (url: string | URL, init?: RequestInit & {
5
6
  authenticationId?: number;
6
7
  callbackUrl?: string;
7
8
  authenticationTemplate?: string;
8
9
  }) => Promise<Response>;
10
+ context: {
11
+ meta: {
12
+ fetch: {
13
+ packages: string[];
14
+ categories: string[];
15
+ returnType: string;
16
+ inputParameters: Array<{
17
+ name: string;
18
+ schema: z.ZodSchema;
19
+ }>;
20
+ };
21
+ };
22
+ };
9
23
  }
10
24
  /**
11
25
  * Direct plugin function - takes options + sdk + context in one object
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/plugins/fetch/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAC7D,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAExD,MAAM,WAAW,mBAAmB;IAClC,KAAK,EAAE,CACL,GAAG,EAAE,MAAM,GAAG,GAAG,EACjB,IAAI,CAAC,EAAE,WAAW,GAAG;QACnB,gBAAgB,CAAC,EAAE,MAAM,CAAC;QAC1B,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,sBAAsB,CAAC,EAAE,MAAM,CAAC;KACjC,KACE,OAAO,CAAC,QAAQ,CAAC,CAAC;CACxB;AAED;;GAEG;AACH,eAAO,MAAM,WAAW,EAAE,MAAM,CAC9B,UAAU,CAAC,qBAAqB,CAAC,EAAE,0BAA0B;AAC7D,EAAE,EAAE,yCAAyC;AAC7C,mBAAmB,CA8BpB,CAAC;AAEF,MAAM,MAAM,sBAAsB,GAAG,WAAW,GAAG;IACjD,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,sBAAsB,CAAC,EAAE,MAAM,CAAC;CACjC,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/plugins/fetch/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAC7D,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAExD,OAAO,KAAK,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAE7B,MAAM,WAAW,mBAAmB;IAClC,KAAK,EAAE,CACL,GAAG,EAAE,MAAM,GAAG,GAAG,EACjB,IAAI,CAAC,EAAE,WAAW,GAAG;QACnB,gBAAgB,CAAC,EAAE,MAAM,CAAC;QAC1B,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,sBAAsB,CAAC,EAAE,MAAM,CAAC;KACjC,KACE,OAAO,CAAC,QAAQ,CAAC,CAAC;IACvB,OAAO,EAAE;QACP,IAAI,EAAE;YACJ,KAAK,EAAE;gBACL,QAAQ,EAAE,MAAM,EAAE,CAAC;gBACnB,UAAU,EAAE,MAAM,EAAE,CAAC;gBACrB,UAAU,EAAE,MAAM,CAAC;gBACnB,eAAe,EAAE,KAAK,CAAC;oBAAE,IAAI,EAAE,MAAM,CAAC;oBAAC,MAAM,EAAE,CAAC,CAAC,SAAS,CAAA;iBAAE,CAAC,CAAC;aAC/D,CAAC;SACH,CAAC;KACH,CAAC;CACH;AAED;;GAEG;AACH,eAAO,MAAM,WAAW,EAAE,MAAM,CAC9B,UAAU,CAAC,qBAAqB,CAAC,EAAE,0BAA0B;AAC7D,EAAE,EAAE,yCAAyC;AAC7C,mBAAmB,CA2CpB,CAAC;AAEF,MAAM,MAAM,sBAAsB,GAAG,WAAW,GAAG;IACjD,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,sBAAsB,CAAC,EAAE,MAAM,CAAC;CACjC,CAAC"}
@@ -1,3 +1,4 @@
1
+ import { FetchUrlSchema, FetchInitSchema } from "./schemas";
1
2
  /**
2
3
  * Direct plugin function - takes options + sdk + context in one object
3
4
  */
@@ -16,5 +17,18 @@ export const fetchPlugin = ({ sdk }) => {
16
17
  authenticationTemplate,
17
18
  });
18
19
  },
20
+ context: {
21
+ meta: {
22
+ fetch: {
23
+ packages: ["sdk"],
24
+ categories: ["http"],
25
+ returnType: "Response",
26
+ inputParameters: [
27
+ { name: "url", schema: FetchUrlSchema },
28
+ { name: "init", schema: FetchInitSchema },
29
+ ],
30
+ },
31
+ },
32
+ },
19
33
  };
20
34
  };
@@ -0,0 +1,25 @@
1
+ import { z } from "zod";
2
+ export declare const FetchUrlSchema: z.ZodUnion<[z.ZodString, z.ZodType<URL, z.ZodTypeDef, URL>]>;
3
+ export declare const FetchInitSchema: z.ZodOptional<z.ZodObject<{
4
+ method: z.ZodOptional<z.ZodEnum<["GET", "POST", "PUT", "DELETE", "PATCH", "HEAD", "OPTIONS"]>>;
5
+ headers: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
6
+ body: z.ZodOptional<z.ZodUnion<[z.ZodString, z.ZodType<FormData, z.ZodTypeDef, FormData>, z.ZodType<URLSearchParams, z.ZodTypeDef, URLSearchParams>]>>;
7
+ authenticationId: z.ZodOptional<z.ZodNumber>;
8
+ callbackUrl: z.ZodOptional<z.ZodString>;
9
+ authenticationTemplate: z.ZodOptional<z.ZodString>;
10
+ }, "strip", z.ZodTypeAny, {
11
+ method?: "GET" | "POST" | "PUT" | "DELETE" | "PATCH" | "HEAD" | "OPTIONS" | undefined;
12
+ authenticationId?: number | undefined;
13
+ body?: string | URLSearchParams | FormData | undefined;
14
+ callbackUrl?: string | undefined;
15
+ authenticationTemplate?: string | undefined;
16
+ headers?: Record<string, string> | undefined;
17
+ }, {
18
+ method?: "GET" | "POST" | "PUT" | "DELETE" | "PATCH" | "HEAD" | "OPTIONS" | undefined;
19
+ authenticationId?: number | undefined;
20
+ body?: string | URLSearchParams | FormData | undefined;
21
+ callbackUrl?: string | undefined;
22
+ authenticationTemplate?: string | undefined;
23
+ headers?: Record<string, string> | undefined;
24
+ }>>;
25
+ //# sourceMappingURL=schemas.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schemas.d.ts","sourceRoot":"","sources":["../../../src/plugins/fetch/schemas.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAGxB,eAAO,MAAM,cAAc,8DAEI,CAAC;AAEhC,eAAO,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;GA6ByB,CAAC"}
@@ -0,0 +1,33 @@
1
+ import { z } from "zod";
2
+ // Schemas for fetch function parameters
3
+ export const FetchUrlSchema = z
4
+ .union([z.string(), z.instanceof(URL)])
5
+ .describe("The URL to fetch");
6
+ export const FetchInitSchema = z
7
+ .object({
8
+ method: z
9
+ .enum(["GET", "POST", "PUT", "DELETE", "PATCH", "HEAD", "OPTIONS"])
10
+ .optional(),
11
+ headers: z.record(z.string()).optional(),
12
+ body: z
13
+ .union([
14
+ z.string(),
15
+ z.instanceof(FormData),
16
+ z.instanceof(URLSearchParams),
17
+ ])
18
+ .optional(),
19
+ authenticationId: z
20
+ .number()
21
+ .optional()
22
+ .describe("Zapier authentication ID to use for the request"),
23
+ callbackUrl: z
24
+ .string()
25
+ .optional()
26
+ .describe("URL to send async response to (makes request async)"),
27
+ authenticationTemplate: z
28
+ .string()
29
+ .optional()
30
+ .describe("Optional JSON string authentication template to bypass Notary lookup"),
31
+ })
32
+ .optional()
33
+ .describe("Fetch options including authentication");
@@ -10,7 +10,7 @@ export declare const ListAuthenticationsSchema: z.ZodObject<{
10
10
  search: z.ZodOptional<z.ZodString>;
11
11
  title: z.ZodOptional<z.ZodString>;
12
12
  accountId: z.ZodOptional<z.ZodString>;
13
- owner: z.ZodOptional<z.ZodString>;
13
+ owner: z.ZodOptional<z.ZodUnion<[z.ZodString, z.ZodLiteral<"me">]>>;
14
14
  pageSize: z.ZodOptional<z.ZodNumber>;
15
15
  maxItems: z.ZodOptional<z.ZodNumber>;
16
16
  }, "strip", z.ZodTypeAny, {
@@ -1 +1 @@
1
- {"version":3,"file":"schemas.d.ts","sourceRoot":"","sources":["../../../src/plugins/listAuthentications/schemas.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AAClE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAC7D,OAAO,KAAK,EACV,yBAAyB,EACzB,cAAc,EACd,sBAAsB,EACtB,qBAAqB,EACrB,kBAAkB,EACnB,MAAM,oBAAoB,CAAC;AAG5B,eAAO,MAAM,yBAAyB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA8B+B,CAAC;AAGtE,MAAM,MAAM,0BAA0B,GAAG,CAAC,CAAC,KAAK,CAC9C,OAAO,yBAAyB,CACjC,CAAC;AAGF,MAAM,WAAW,uBAAuB;IACtC,IAAI,EAAE,kBAAkB,EAAE,CAAC;IAC3B,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAGD,MAAM,MAAM,wBAAwB,GAChC,yBAAyB,GACzB,cAAc,GACd,sBAAsB,GACtB,qBAAqB,GACrB,kBAAkB,CAAC;AAGvB,MAAM,WAAW,8BAA8B;IAC7C,mBAAmB,EAAE,oBAAoB,CACvC,0BAA0B,EAC1B,kBAAkB,CACnB,CAAC;CACH"}
1
+ {"version":3,"file":"schemas.d.ts","sourceRoot":"","sources":["../../../src/plugins/listAuthentications/schemas.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AAClE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAC7D,OAAO,KAAK,EACV,yBAAyB,EACzB,cAAc,EACd,sBAAsB,EACtB,qBAAqB,EACrB,kBAAkB,EACnB,MAAM,oBAAoB,CAAC;AAG5B,eAAO,MAAM,yBAAyB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAmC+B,CAAC;AAGtE,MAAM,MAAM,0BAA0B,GAAG,CAAC,CAAC,KAAK,CAC9C,OAAO,yBAAyB,CACjC,CAAC;AAGF,MAAM,WAAW,uBAAuB;IACtC,IAAI,EAAE,kBAAkB,EAAE,CAAC;IAC3B,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAGD,MAAM,MAAM,wBAAwB,GAChC,yBAAyB,GACzB,cAAc,GACd,sBAAsB,GACtB,qBAAqB,GACrB,kBAAkB,CAAC;AAGvB,MAAM,WAAW,8BAA8B;IAC7C,mBAAmB,EAAE,oBAAoB,CACvC,0BAA0B,EAC1B,kBAAkB,CACnB,CAAC;CACH"}
@@ -17,7 +17,10 @@ export const ListAuthenticationsSchema = z
17
17
  .optional()
18
18
  .describe("Filter authentications by exact title match"),
19
19
  accountId: z.string().optional().describe("Filter by account ID"),
20
- owner: z.string().optional().describe("Filter by owner"),
20
+ owner: z
21
+ .union([z.string(), z.literal("me")])
22
+ .optional()
23
+ .describe("Filter by owner, 'me' for your own authentications or a specific user ID"),
21
24
  pageSize: z
22
25
  .number()
23
26
  .min(1)
@@ -3,7 +3,9 @@ import type { FunctionRegistryEntry } from "../../types/sdk";
3
3
  export interface RegisterPluginFunctionOptions {
4
4
  }
5
5
  export interface RegistryPluginProvides {
6
- getRegistry: () => {
6
+ getRegistry: (options?: {
7
+ package?: string;
8
+ }) => {
7
9
  functions: FunctionRegistryEntry[];
8
10
  categories: {
9
11
  key: string;
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/plugins/registry/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAC;AAE7D,MAAM,WAAW,6BAA6B;CAAG;AAEjD,MAAM,WAAW,sBAAsB;IACrC,WAAW,EAAE,MAAM;QACjB,SAAS,EAAE,qBAAqB,EAAE,CAAC;QACnC,UAAU,EAAE;YACV,GAAG,EAAE,MAAM,CAAC;YACZ,KAAK,EAAE,MAAM,CAAC;YACd,WAAW,EAAE,MAAM,CAAC;YACpB,SAAS,EAAE,MAAM,EAAE,CAAC;SACrB,EAAE,CAAC;KACL,CAAC;CACH;AAGD,eAAO,MAAM,cAAc,EAAE,MAAM,CACjC,EAAE,EAAE,wBAAwB;AAC5B,EAAE,EAAE,sBAAsB;AAC1B,sBAAsB,CA+FvB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/plugins/registry/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAC;AAE7D,MAAM,WAAW,6BAA6B;CAAG;AAEjD,MAAM,WAAW,sBAAsB;IACrC,WAAW,EAAE,CAAC,OAAO,CAAC,EAAE;QAAE,OAAO,CAAC,EAAE,MAAM,CAAA;KAAE,KAAK;QAC/C,SAAS,EAAE,qBAAqB,EAAE,CAAC;QACnC,UAAU,EAAE;YACV,GAAG,EAAE,MAAM,CAAC;YACZ,KAAK,EAAE,MAAM,CAAC;YACd,WAAW,EAAE,MAAM,CAAC;YACpB,SAAS,EAAE,MAAM,EAAE,CAAC;SACrB,EAAE,CAAC;KACL,CAAC;CACH;AAGD,eAAO,MAAM,cAAc,EAAE,MAAM,CACjC,EAAE,EAAE,wBAAwB;AAC5B,EAAE,EAAE,sBAAsB;AAC1B,sBAAsB,CA+HvB,CAAC"}
@@ -36,48 +36,69 @@ export const registryPlugin = ({ sdk, context }) => {
36
36
  itemType: meta.itemType,
37
37
  returnType: meta.returnType,
38
38
  inputSchema: meta.inputSchema,
39
+ inputParameters: meta.inputParameters,
39
40
  outputSchema: meta.outputSchema,
40
41
  categories: meta.categories || [],
41
42
  resolvers: meta.resolvers,
43
+ packages: meta.packages,
42
44
  };
43
45
  })
44
46
  .sort((a, b) => a.name.localeCompare(b.name));
45
47
  const knownCategories = Object.keys(categoryDefinitions);
46
- const categories = knownCategories
47
- .sort((a, b) => {
48
- // Keep "other" category last
49
- if (a === "other")
50
- return 1;
51
- if (b === "other")
52
- return -1;
53
- // Alphabetize by title, not key
54
- const titleA = categoryDefinitions[a].title;
55
- const titleB = categoryDefinitions[b].title;
56
- return titleA.localeCompare(titleB);
57
- })
58
- .map((categoryKey) => {
59
- // Find the functions that are in this category
60
- const categoryFunctions = functions
61
- .filter((f) => f.categories.includes(categoryKey) ||
62
- // If the category is "other" and the function is not in any other category, include it
63
- (categoryKey === "other" &&
64
- !f.categories.some((c) => knownCategories.includes(c))))
65
- .map((f) => f.name)
66
- .sort(); // Alphabetize functions within each category
67
- const definition = categoryDefinitions[categoryKey];
68
- const title = definition.title;
69
- return {
70
- key: categoryKey,
71
- title,
72
- titlePlural: definition.titlePlural ?? `${title}s`,
73
- functions: categoryFunctions,
74
- };
75
- });
76
- function getRegistry() {
77
- return {
78
- functions,
79
- categories,
48
+ // Cache the entire registry result for each package
49
+ const registryCache = new Map();
50
+ function getRegistry(options) {
51
+ const packageFilter = options?.package;
52
+ const cacheKey = packageFilter || "__all__";
53
+ // Return cached result if available
54
+ if (registryCache.has(cacheKey)) {
55
+ return registryCache.get(cacheKey);
56
+ }
57
+ // Filter functions by package if specified
58
+ const filteredFunctions = packageFilter
59
+ ? functions.filter((f) =>
60
+ // Include if packages is undefined (belongs to all packages) or includes the specified package
61
+ !f.packages || f.packages.includes(packageFilter))
62
+ : functions;
63
+ // Build categories with filtered functions
64
+ const filteredCategories = knownCategories
65
+ .sort((a, b) => {
66
+ // Keep "other" category last
67
+ if (a === "other")
68
+ return 1;
69
+ if (b === "other")
70
+ return -1;
71
+ // Alphabetize by title, not key
72
+ const titleA = categoryDefinitions[a].title;
73
+ const titleB = categoryDefinitions[b].title;
74
+ return titleA.localeCompare(titleB);
75
+ })
76
+ .map((categoryKey) => {
77
+ // Find the functions that are in this category and match the package filter
78
+ const categoryFunctions = filteredFunctions
79
+ .filter((f) => f.categories.includes(categoryKey) ||
80
+ // If the category is "other" and the function is not in any other category, include it
81
+ (categoryKey === "other" &&
82
+ !f.categories.some((c) => knownCategories.includes(c))))
83
+ .map((f) => f.name)
84
+ .sort(); // Alphabetize functions within each category
85
+ const definition = categoryDefinitions[categoryKey];
86
+ const title = definition.title;
87
+ return {
88
+ key: categoryKey,
89
+ title,
90
+ titlePlural: definition.titlePlural ?? `${title}s`,
91
+ functions: categoryFunctions,
92
+ };
93
+ })
94
+ .filter((category) => category.functions.length > 0); // Only include categories with functions
95
+ const result = {
96
+ functions: filteredFunctions,
97
+ categories: filteredCategories,
80
98
  };
99
+ // Cache the result
100
+ registryCache.set(cacheKey, result);
101
+ return result;
81
102
  }
82
103
  return {
83
104
  getRegistry,
package/dist/sdk.d.ts CHANGED
@@ -93,6 +93,18 @@ export declare function createZapierSdkWithoutRegistry(options?: ZapierSdkOption
93
93
  inputSchema: typeof import(".").RelayRequestSchema;
94
94
  };
95
95
  };
96
+ } & {
97
+ meta: {
98
+ fetch: {
99
+ packages: string[];
100
+ categories: string[];
101
+ returnType: string;
102
+ inputParameters: Array<{
103
+ name: string;
104
+ schema: import("zod").ZodType;
105
+ }>;
106
+ };
107
+ };
96
108
  } & {
97
109
  meta: {
98
110
  getProfile: {
package/dist/sdk.d.ts.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"sdk.d.ts","sourceRoot":"","sources":["../src/sdk.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAMlD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,KAAK,EACV,GAAG,EACH,MAAM,EACN,wBAAwB,EACxB,oBAAoB,EACpB,cAAc,EACd,UAAU,EACX,MAAM,gBAAgB,CAAC;AAyBxB,MAAM,WAAW,gBAAiB,SAAQ,cAAc;CAAG;AAG3D,wBAAgB,SAAS,CACvB,WAAW,GAAG,EAAE,EAChB,eAAe,SAAS;IAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,CAAA;CAAE,GAAG;IAC7D,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;CAClC,EAED,OAAO,GAAE,gBAAqB,EAC9B,UAAU,GAAE,WAA+B,EAC3C,cAAc,GAAE,eAAiD;;cAKrD,gBAAgB,EAAE,SAAS,SAAS,cAAc,UAClD,MAAM,CACZ,WAAW,GAAG;QAAE,UAAU,IAAI,eAAe,CAAA;KAAE,EAC/C,gBAAgB,EAChB,SAAS,CACV,qBACiB,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GACxC,GAAG,CACJ,WAAW,GAAG,oBAAoB,CAAC,SAAS,CAAC,EAC7C,eAAe,GAAG,WAAW,CAAC,wBAAwB,CAAC,SAAS,CAAC,CAAC,CACnE;EA8DJ;AAED,wBAAgB,8BAA8B,CAAC,OAAO,GAAE,gBAAqB;UApFnE,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC;;;;;;+GAf2B,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuI/D;AAED,wBAAgB,eAAe,CAAC,OAAO,GAAE,gBAAqB,GAAG,SAAS,CAMzE"}
1
+ {"version":3,"file":"sdk.d.ts","sourceRoot":"","sources":["../src/sdk.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAMlD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,KAAK,EACV,GAAG,EACH,MAAM,EACN,wBAAwB,EACxB,oBAAoB,EACpB,cAAc,EACd,UAAU,EACX,MAAM,gBAAgB,CAAC;AAyBxB,MAAM,WAAW,gBAAiB,SAAQ,cAAc;CAAG;AAG3D,wBAAgB,SAAS,CACvB,WAAW,GAAG,EAAE,EAChB,eAAe,SAAS;IAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,CAAA;CAAE,GAAG;IAC7D,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;CAClC,EAED,OAAO,GAAE,gBAAqB,EAC9B,UAAU,GAAE,WAA+B,EAC3C,cAAc,GAAE,eAAiD;;cAKrD,gBAAgB,EAAE,SAAS,SAAS,cAAc,UAClD,MAAM,CACZ,WAAW,GAAG;QAAE,UAAU,IAAI,eAAe,CAAA;KAAE,EAC/C,gBAAgB,EAChB,SAAS,CACV,qBACiB,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GACxC,GAAG,CACJ,WAAW,GAAG,oBAAoB,CAAC,SAAS,CAAC,EAC7C,eAAe,GAAG,WAAW,CAAC,wBAAwB,CAAC,SAAS,CAAC,CAAC,CACnE;EA8DJ;AAED,wBAAgB,8BAA8B,CAAC,OAAO,GAAE,gBAAqB;UApFnE,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC;;;;;;+GAf2B,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuI/D;AAED,wBAAgB,eAAe,CAAC,OAAO,GAAE,gBAAqB,GAAG,SAAS,CAMzE"}