@wildo-ai/external-connectors-models 1.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (114) hide show
  1. package/dist/esm/core/commons.external-connectors-models.schemas.d.ts +195 -0
  2. package/dist/esm/core/commons.external-connectors-models.schemas.d.ts.map +1 -0
  3. package/dist/esm/core/commons.external-connectors-models.schemas.js +96 -0
  4. package/dist/esm/core/commons.external-connectors-models.schemas.js.map +1 -0
  5. package/dist/esm/core/lazy-loading.external-connectors-models.schemas.d.ts +127 -0
  6. package/dist/esm/core/lazy-loading.external-connectors-models.schemas.d.ts.map +1 -0
  7. package/dist/esm/core/lazy-loading.external-connectors-models.schemas.js +22 -0
  8. package/dist/esm/core/lazy-loading.external-connectors-models.schemas.js.map +1 -0
  9. package/dist/esm/core/oauth2.enums.d.ts +125 -0
  10. package/dist/esm/core/oauth2.enums.d.ts.map +1 -0
  11. package/dist/esm/core/oauth2.enums.js +134 -0
  12. package/dist/esm/core/oauth2.enums.js.map +1 -0
  13. package/dist/esm/core/operations.external-connectors-models.schemas.d.ts +46 -0
  14. package/dist/esm/core/operations.external-connectors-models.schemas.d.ts.map +1 -0
  15. package/dist/esm/core/operations.external-connectors-models.schemas.js +10 -0
  16. package/dist/esm/core/operations.external-connectors-models.schemas.js.map +1 -0
  17. package/dist/esm/core/protocols.external-connectors-models.schemas.d.ts +84 -0
  18. package/dist/esm/core/protocols.external-connectors-models.schemas.d.ts.map +1 -0
  19. package/dist/esm/core/protocols.external-connectors-models.schemas.js +1 -0
  20. package/dist/esm/core/protocols.external-connectors-models.schemas.js.map +1 -0
  21. package/dist/esm/core/providers.external-connectors-models.schemas.d.ts +80 -0
  22. package/dist/esm/core/providers.external-connectors-models.schemas.d.ts.map +1 -0
  23. package/dist/esm/core/providers.external-connectors-models.schemas.js +55 -0
  24. package/dist/esm/core/providers.external-connectors-models.schemas.js.map +1 -0
  25. package/dist/esm/core/security.external-connectors-models.schemas.d.ts +187 -0
  26. package/dist/esm/core/security.external-connectors-models.schemas.d.ts.map +1 -0
  27. package/dist/esm/core/security.external-connectors-models.schemas.js +233 -0
  28. package/dist/esm/core/security.external-connectors-models.schemas.js.map +1 -0
  29. package/dist/esm/features/core.external-connectors-models.schemas.d.ts +63 -0
  30. package/dist/esm/features/core.external-connectors-models.schemas.d.ts.map +1 -0
  31. package/dist/esm/features/core.external-connectors-models.schemas.js +101 -0
  32. package/dist/esm/features/core.external-connectors-models.schemas.js.map +1 -0
  33. package/dist/esm/features/email.external-connectors-models.schemas.d.ts +181 -0
  34. package/dist/esm/features/email.external-connectors-models.schemas.d.ts.map +1 -0
  35. package/dist/esm/features/email.external-connectors-models.schemas.js +34 -0
  36. package/dist/esm/features/email.external-connectors-models.schemas.js.map +1 -0
  37. package/dist/esm/features/hooks.external-connectors-models.schemas.d.ts +101 -0
  38. package/dist/esm/features/hooks.external-connectors-models.schemas.d.ts.map +1 -0
  39. package/dist/esm/features/hooks.external-connectors-models.schemas.js +11 -0
  40. package/dist/esm/features/hooks.external-connectors-models.schemas.js.map +1 -0
  41. package/dist/esm/features/sms.external-connectors-models.schemas.d.ts +21 -0
  42. package/dist/esm/features/sms.external-connectors-models.schemas.d.ts.map +1 -0
  43. package/dist/esm/features/sms.external-connectors-models.schemas.js +8 -0
  44. package/dist/esm/features/sms.external-connectors-models.schemas.js.map +1 -0
  45. package/dist/esm/index.d.ts +28 -0
  46. package/dist/esm/index.d.ts.map +1 -0
  47. package/dist/esm/index.js +31 -0
  48. package/dist/esm/index.js.map +1 -0
  49. package/dist/esm/protocols/a2a.external-connectors-models.schemas.d.ts +57 -0
  50. package/dist/esm/protocols/a2a.external-connectors-models.schemas.d.ts.map +1 -0
  51. package/dist/esm/protocols/a2a.external-connectors-models.schemas.js +73 -0
  52. package/dist/esm/protocols/a2a.external-connectors-models.schemas.js.map +1 -0
  53. package/dist/esm/protocols/billing.standard-interface.schemas.d.ts +315 -0
  54. package/dist/esm/protocols/billing.standard-interface.schemas.d.ts.map +1 -0
  55. package/dist/esm/protocols/billing.standard-interface.schemas.js +104 -0
  56. package/dist/esm/protocols/billing.standard-interface.schemas.js.map +1 -0
  57. package/dist/esm/protocols/cli-runtime.external-connectors-models.schemas.d.ts +214 -0
  58. package/dist/esm/protocols/cli-runtime.external-connectors-models.schemas.d.ts.map +1 -0
  59. package/dist/esm/protocols/cli-runtime.external-connectors-models.schemas.js +188 -0
  60. package/dist/esm/protocols/cli-runtime.external-connectors-models.schemas.js.map +1 -0
  61. package/dist/esm/protocols/email.external-connectors-models.schemas.d.ts +370 -0
  62. package/dist/esm/protocols/email.external-connectors-models.schemas.d.ts.map +1 -0
  63. package/dist/esm/protocols/email.external-connectors-models.schemas.js +368 -0
  64. package/dist/esm/protocols/email.external-connectors-models.schemas.js.map +1 -0
  65. package/dist/esm/protocols/email.standard-interface.schemas.d.ts +330 -0
  66. package/dist/esm/protocols/email.standard-interface.schemas.d.ts.map +1 -0
  67. package/dist/esm/protocols/email.standard-interface.schemas.js +275 -0
  68. package/dist/esm/protocols/email.standard-interface.schemas.js.map +1 -0
  69. package/dist/esm/protocols/frontend.external-connectors-models.schemas.d.ts +16 -0
  70. package/dist/esm/protocols/frontend.external-connectors-models.schemas.d.ts.map +1 -0
  71. package/dist/esm/protocols/frontend.external-connectors-models.schemas.js +10 -0
  72. package/dist/esm/protocols/frontend.external-connectors-models.schemas.js.map +1 -0
  73. package/dist/esm/protocols/git.external-connectors-models.schemas.d.ts +14 -0
  74. package/dist/esm/protocols/git.external-connectors-models.schemas.d.ts.map +1 -0
  75. package/dist/esm/protocols/git.external-connectors-models.schemas.js +9 -0
  76. package/dist/esm/protocols/git.external-connectors-models.schemas.js.map +1 -0
  77. package/dist/esm/protocols/grpc.external-connectors-models.schemas.d.ts +14 -0
  78. package/dist/esm/protocols/grpc.external-connectors-models.schemas.d.ts.map +1 -0
  79. package/dist/esm/protocols/grpc.external-connectors-models.schemas.js +9 -0
  80. package/dist/esm/protocols/grpc.external-connectors-models.schemas.js.map +1 -0
  81. package/dist/esm/protocols/hooks.external-connectors-models.schemas.d.ts +192 -0
  82. package/dist/esm/protocols/hooks.external-connectors-models.schemas.d.ts.map +1 -0
  83. package/dist/esm/protocols/hooks.external-connectors-models.schemas.js +103 -0
  84. package/dist/esm/protocols/hooks.external-connectors-models.schemas.js.map +1 -0
  85. package/dist/esm/protocols/llm.external-connectors-models.schemas.d.ts +499 -0
  86. package/dist/esm/protocols/llm.external-connectors-models.schemas.d.ts.map +1 -0
  87. package/dist/esm/protocols/llm.external-connectors-models.schemas.js +351 -0
  88. package/dist/esm/protocols/llm.external-connectors-models.schemas.js.map +1 -0
  89. package/dist/esm/protocols/mcp.external-connectors-models.schemas.d.ts +60 -0
  90. package/dist/esm/protocols/mcp.external-connectors-models.schemas.d.ts.map +1 -0
  91. package/dist/esm/protocols/mcp.external-connectors-models.schemas.js +35 -0
  92. package/dist/esm/protocols/mcp.external-connectors-models.schemas.js.map +1 -0
  93. package/dist/esm/protocols/oauth2.external-connectors-models.schemas.d.ts +570 -0
  94. package/dist/esm/protocols/oauth2.external-connectors-models.schemas.d.ts.map +1 -0
  95. package/dist/esm/protocols/oauth2.external-connectors-models.schemas.js +401 -0
  96. package/dist/esm/protocols/oauth2.external-connectors-models.schemas.js.map +1 -0
  97. package/dist/esm/protocols/rest-api.external-connectors-models.schemas.d.ts +125 -0
  98. package/dist/esm/protocols/rest-api.external-connectors-models.schemas.d.ts.map +1 -0
  99. package/dist/esm/protocols/rest-api.external-connectors-models.schemas.js +92 -0
  100. package/dist/esm/protocols/rest-api.external-connectors-models.schemas.js.map +1 -0
  101. package/dist/esm/protocols/saml.external-connectors-models.schemas.d.ts +135 -0
  102. package/dist/esm/protocols/saml.external-connectors-models.schemas.d.ts.map +1 -0
  103. package/dist/esm/protocols/saml.external-connectors-models.schemas.js +9 -0
  104. package/dist/esm/protocols/saml.external-connectors-models.schemas.js.map +1 -0
  105. package/dist/esm/protocols/sms.external-connectors-models.schemas.d.ts +55 -0
  106. package/dist/esm/protocols/sms.external-connectors-models.schemas.d.ts.map +1 -0
  107. package/dist/esm/protocols/sms.external-connectors-models.schemas.js +46 -0
  108. package/dist/esm/protocols/sms.external-connectors-models.schemas.js.map +1 -0
  109. package/dist/esm/protocols/sms.standard-interface.schemas.d.ts +35 -0
  110. package/dist/esm/protocols/sms.standard-interface.schemas.d.ts.map +1 -0
  111. package/dist/esm/protocols/sms.standard-interface.schemas.js +54 -0
  112. package/dist/esm/protocols/sms.standard-interface.schemas.js.map +1 -0
  113. package/dist/tsconfig.build.tsbuildinfo +1 -0
  114. package/package.json +47 -0
@@ -0,0 +1,134 @@
1
+ /**
2
+ * OAuth2 Enums - Shared OAuth2 type definitions
3
+ *
4
+ * These enums are extracted to avoid circular dependencies between
5
+ * security schemas and oauth2 protocol schemas.
6
+ *
7
+ * Based on:
8
+ * - RFC 6749: The OAuth 2.0 Authorization Framework
9
+ * - RFC 7636: Proof Key for Code Exchange (PKCE)
10
+ * - OpenID Connect Core 1.0
11
+ */
12
+ /**
13
+ * OAuth2 Grant Types as defined in RFC 6749
14
+ * @see https://datatracker.ietf.org/doc/html/rfc6749#section-4
15
+ */
16
+ export var OAuth2_GrantType;
17
+ (function (OAuth2_GrantType) {
18
+ /** Authorization Code Grant (RFC 6749 §4.1) - For server-side apps with secure client secrets */
19
+ OAuth2_GrantType["AUTHORIZATION_CODE"] = "authorization_code";
20
+ /** Client Credentials Grant (RFC 6749 §4.4) - For machine-to-machine / S2S authentication */
21
+ OAuth2_GrantType["CLIENT_CREDENTIALS"] = "client_credentials";
22
+ /** Refresh Token Grant (RFC 6749 §6) - For obtaining new access tokens */
23
+ OAuth2_GrantType["REFRESH_TOKEN"] = "refresh_token";
24
+ /** Implicit Grant (RFC 6749 §4.2) - DEPRECATED, use PKCE instead */
25
+ OAuth2_GrantType["IMPLICIT"] = "implicit";
26
+ /** Resource Owner Password Credentials (RFC 6749 §4.3) - DEPRECATED */
27
+ OAuth2_GrantType["PASSWORD"] = "password";
28
+ /** Device Authorization Grant (RFC 8628) - For input-constrained devices */
29
+ OAuth2_GrantType["DEVICE_CODE"] = "urn:ietf:params:oauth:grant-type:device_code";
30
+ /** JWT Bearer Assertion (RFC 7523) - For service accounts */
31
+ OAuth2_GrantType["JWT_BEARER"] = "urn:ietf:params:oauth:grant-type:jwt-bearer";
32
+ })(OAuth2_GrantType || (OAuth2_GrantType = {}));
33
+ /**
34
+ * OAuth2 Response Types for Authorization Endpoint
35
+ */
36
+ export var OAuth2_ResponseType;
37
+ (function (OAuth2_ResponseType) {
38
+ OAuth2_ResponseType["CODE"] = "code";
39
+ OAuth2_ResponseType["TOKEN"] = "token";
40
+ OAuth2_ResponseType["ID_TOKEN"] = "id_token";
41
+ OAuth2_ResponseType["CODE_ID_TOKEN"] = "code id_token";
42
+ OAuth2_ResponseType["CODE_TOKEN"] = "code token";
43
+ OAuth2_ResponseType["ID_TOKEN_TOKEN"] = "id_token token";
44
+ OAuth2_ResponseType["CODE_ID_TOKEN_TOKEN"] = "code id_token token";
45
+ })(OAuth2_ResponseType || (OAuth2_ResponseType = {}));
46
+ /**
47
+ * PKCE Code Challenge Methods (RFC 7636)
48
+ */
49
+ export var OAuth2_PKCE_Method;
50
+ (function (OAuth2_PKCE_Method) {
51
+ OAuth2_PKCE_Method["PLAIN"] = "plain";
52
+ OAuth2_PKCE_Method["S256"] = "S256";
53
+ })(OAuth2_PKCE_Method || (OAuth2_PKCE_Method = {}));
54
+ /**
55
+ * Token Endpoint Authentication Methods
56
+ * How credentials are sent to the token endpoint
57
+ */
58
+ export var OAuth2_TokenEndpoint_AuthMethod;
59
+ (function (OAuth2_TokenEndpoint_AuthMethod) {
60
+ /** Credentials in Authorization header as Basic auth */
61
+ OAuth2_TokenEndpoint_AuthMethod["CLIENT_SECRET_BASIC"] = "client_secret_basic";
62
+ /** Credentials in request body */
63
+ OAuth2_TokenEndpoint_AuthMethod["CLIENT_SECRET_POST"] = "client_secret_post";
64
+ /** JWT assertion signed with client secret (HMAC) */
65
+ OAuth2_TokenEndpoint_AuthMethod["CLIENT_SECRET_JWT"] = "client_secret_jwt";
66
+ /** JWT assertion signed with private key (RSA/EC) */
67
+ OAuth2_TokenEndpoint_AuthMethod["PRIVATE_KEY_JWT"] = "private_key_jwt";
68
+ /** No authentication (public clients) */
69
+ OAuth2_TokenEndpoint_AuthMethod["NONE"] = "none";
70
+ })(OAuth2_TokenEndpoint_AuthMethod || (OAuth2_TokenEndpoint_AuthMethod = {}));
71
+ /**
72
+ * OpenID Connect Prompt Values
73
+ * Controls how the authorization server prompts the user
74
+ */
75
+ export var OAuth2_Prompt;
76
+ (function (OAuth2_Prompt) {
77
+ /** No prompt - silent auth only */
78
+ OAuth2_Prompt["NONE"] = "none";
79
+ /** Force login even if session exists */
80
+ OAuth2_Prompt["LOGIN"] = "login";
81
+ /** Require user consent even if previously granted */
82
+ OAuth2_Prompt["CONSENT"] = "consent";
83
+ /** Prompt for account selection */
84
+ OAuth2_Prompt["SELECT_ACCOUNT"] = "select_account";
85
+ })(OAuth2_Prompt || (OAuth2_Prompt = {}));
86
+ /**
87
+ * Access Type - whether to request refresh tokens
88
+ */
89
+ export var OAuth2_AccessType;
90
+ (function (OAuth2_AccessType) {
91
+ /** Only access token, no refresh capability */
92
+ OAuth2_AccessType["ONLINE"] = "online";
93
+ /** Request refresh token for offline access */
94
+ OAuth2_AccessType["OFFLINE"] = "offline";
95
+ })(OAuth2_AccessType || (OAuth2_AccessType = {}));
96
+ /**
97
+ * OAuth2 Provider Purpose - what the OAuth2 is used for
98
+ */
99
+ export var OAuth2_Purpose;
100
+ (function (OAuth2_Purpose) {
101
+ /** API access only - for making API calls to the provider */
102
+ OAuth2_Purpose["API_ACCESS"] = "api_access";
103
+ /** User SSO - for authenticating users into our application */
104
+ OAuth2_Purpose["USER_SSO"] = "user_sso";
105
+ /** Both API access and user SSO */
106
+ OAuth2_Purpose["HYBRID"] = "hybrid";
107
+ })(OAuth2_Purpose || (OAuth2_Purpose = {}));
108
+ /**
109
+ * OAuth2 Token Format - How to format the token for API calls
110
+ */
111
+ export var OAuth2_TokenFormat;
112
+ (function (OAuth2_TokenFormat) {
113
+ /** Authorization: Bearer <token> */
114
+ OAuth2_TokenFormat["BEARER"] = "bearer";
115
+ /** Authorization: token <token> */
116
+ OAuth2_TokenFormat["TOKEN"] = "token";
117
+ /** Authorization: OAuth <token> */
118
+ OAuth2_TokenFormat["OAUTH"] = "oauth";
119
+ /** Custom header specified separately */
120
+ OAuth2_TokenFormat["CUSTOM_HEADER"] = "custom_header";
121
+ /** Token in query parameter */
122
+ OAuth2_TokenFormat["QUERY_PARAM"] = "query_param";
123
+ })(OAuth2_TokenFormat || (OAuth2_TokenFormat = {}));
124
+ /**
125
+ * OAuth2 Token Location - Where to send the access token
126
+ */
127
+ export var OAuth2_TokenLocation;
128
+ (function (OAuth2_TokenLocation) {
129
+ /** In Authorization header */
130
+ OAuth2_TokenLocation["HEADER"] = "header";
131
+ /** As query parameter */
132
+ OAuth2_TokenLocation["QUERY"] = "query";
133
+ })(OAuth2_TokenLocation || (OAuth2_TokenLocation = {}));
134
+ //# sourceMappingURL=oauth2.enums.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"oauth2.enums.js","sourceRoot":"","sources":["../../../src/core/oauth2.enums.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH;;;GAGG;AACH,MAAM,CAAN,IAAY,gBAqBX;AArBD,WAAY,gBAAgB;IAC1B,iGAAiG;IACjG,6DAAyC,CAAA;IAEzC,6FAA6F;IAC7F,6DAAyC,CAAA;IAEzC,0EAA0E;IAC1E,mDAA+B,CAAA;IAE/B,oEAAoE;IACpE,yCAAqB,CAAA;IAErB,uEAAuE;IACvE,yCAAqB,CAAA;IAErB,4EAA4E;IAC5E,gFAA4D,CAAA;IAE5D,6DAA6D;IAC7D,8EAA0D,CAAA;AAC5D,CAAC,EArBW,gBAAgB,KAAhB,gBAAgB,QAqB3B;AAED;;GAEG;AACH,MAAM,CAAN,IAAY,mBAQX;AARD,WAAY,mBAAmB;IAC7B,oCAAa,CAAA;IACb,sCAAe,CAAA;IACf,4CAAqB,CAAA;IACrB,sDAA+B,CAAA;IAC/B,gDAAyB,CAAA;IACzB,wDAAiC,CAAA;IACjC,kEAA2C,CAAA;AAC7C,CAAC,EARW,mBAAmB,KAAnB,mBAAmB,QAQ9B;AAED;;GAEG;AACH,MAAM,CAAN,IAAY,kBAGX;AAHD,WAAY,kBAAkB;IAC5B,qCAAe,CAAA;IACf,mCAAa,CAAA;AACf,CAAC,EAHW,kBAAkB,KAAlB,kBAAkB,QAG7B;AAED;;;GAGG;AACH,MAAM,CAAN,IAAY,+BAeX;AAfD,WAAY,+BAA+B;IACzC,wDAAwD;IACxD,8EAA2C,CAAA;IAE3C,kCAAkC;IAClC,4EAAyC,CAAA;IAEzC,qDAAqD;IACrD,0EAAuC,CAAA;IAEvC,qDAAqD;IACrD,sEAAmC,CAAA;IAEnC,yCAAyC;IACzC,gDAAa,CAAA;AACf,CAAC,EAfW,+BAA+B,KAA/B,+BAA+B,QAe1C;AAED;;;GAGG;AACH,MAAM,CAAN,IAAY,aAYX;AAZD,WAAY,aAAa;IACvB,mCAAmC;IACnC,8BAAa,CAAA;IAEb,yCAAyC;IACzC,gCAAe,CAAA;IAEf,sDAAsD;IACtD,oCAAmB,CAAA;IAEnB,mCAAmC;IACnC,kDAAiC,CAAA;AACnC,CAAC,EAZW,aAAa,KAAb,aAAa,QAYxB;AAED;;GAEG;AACH,MAAM,CAAN,IAAY,iBAMX;AAND,WAAY,iBAAiB;IAC3B,+CAA+C;IAC/C,sCAAiB,CAAA;IAEjB,+CAA+C;IAC/C,wCAAmB,CAAA;AACrB,CAAC,EANW,iBAAiB,KAAjB,iBAAiB,QAM5B;AAED;;GAEG;AACH,MAAM,CAAN,IAAY,cASX;AATD,WAAY,cAAc;IACxB,6DAA6D;IAC7D,2CAAyB,CAAA;IAEzB,+DAA+D;IAC/D,uCAAqB,CAAA;IAErB,mCAAmC;IACnC,mCAAiB,CAAA;AACnB,CAAC,EATW,cAAc,KAAd,cAAc,QASzB;AAED;;GAEG;AACH,MAAM,CAAN,IAAY,kBAWX;AAXD,WAAY,kBAAkB;IAC5B,oCAAoC;IACpC,uCAAiB,CAAA;IACjB,mCAAmC;IACnC,qCAAe,CAAA;IACf,mCAAmC;IACnC,qCAAe,CAAA;IACf,yCAAyC;IACzC,qDAA+B,CAAA;IAC/B,+BAA+B;IAC/B,iDAA2B,CAAA;AAC7B,CAAC,EAXW,kBAAkB,KAAlB,kBAAkB,QAW7B;AAED;;GAEG;AACH,MAAM,CAAN,IAAY,oBAKX;AALD,WAAY,oBAAoB;IAC9B,8BAA8B;IAC9B,yCAAiB,CAAA;IACjB,yBAAyB;IACzB,uCAAe,CAAA;AACjB,CAAC,EALW,oBAAoB,KAApB,oBAAoB,QAK/B"}
@@ -0,0 +1,46 @@
1
+ import { z } from "zod";
2
+ /** ──────────────────────────────────────────────────────────────
3
+ * Internal Schemas (concrete, for method access)
4
+ * ────────────────────────────────────────────────────────────── */
5
+ export declare const ExternalProvider_OperationContextSchema: z.ZodObject<{
6
+ callTimestamp: z.ZodISODateTime;
7
+ callDuration: z.ZodOptional<z.ZodNumber>;
8
+ errorReason: z.ZodOptional<z.ZodString>;
9
+ }, z.core.$strip>;
10
+ export type ExternalProvider_OperationContext = z.infer<typeof ExternalProvider_OperationContextSchema>;
11
+ export type ExternalProvider_OperationDefinition_Base = {
12
+ /**
13
+ * Unique operation identifier
14
+ * Format: {provider}-{domain}-{action} e.g., "stripe-customers-create"
15
+ */
16
+ operationKey: string;
17
+ /** Provider reference (e.g., "google", "slack", "stripe") */
18
+ providerRef: string;
19
+ /**
20
+ * Domains this operation belongs to (can span multiple domains)
21
+ * e.g., ["customers"] or ["sheets", "drive"] for cross-domain operations
22
+ * Empty/undefined for providers without explicit domains
23
+ */
24
+ domains?: string[];
25
+ /**
26
+ * Capabilities/features this operation uses
27
+ * e.g., ["storage", "file-upload"] for a file creation operation
28
+ */
29
+ features?: string[];
30
+ /** Human-readable name */
31
+ displayName?: string;
32
+ /** Operation description */
33
+ description?: string;
34
+ /** Input schema (Zod) */
35
+ inputSchema: z.ZodSchema<any>;
36
+ /** Output schema (Zod) */
37
+ outputSchema: z.ZodSchema<any>;
38
+ /** Operation-specific metadata */
39
+ metadata?: Record<string, any>;
40
+ /**
41
+ * OAuth2 scopes required specifically for this operation
42
+ * System unions all required scopes from selected operations at auth time
43
+ */
44
+ requiredScopes?: string[];
45
+ };
46
+ //# sourceMappingURL=operations.external-connectors-models.schemas.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"operations.external-connectors-models.schemas.d.ts","sourceRoot":"","sources":["../../../src/core/operations.external-connectors-models.schemas.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB;;oEAEoE;AAEpE,eAAO,MAAM,uCAAuC;;;;iBAIlD,CAAC;AACH,MAAM,MAAM,iCAAiC,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,uCAAuC,CAAC,CAAC;AAExG,MAAM,MAAM,yCAAyC,GAAG;IACtD;;;OAGG;IACH,YAAY,EAAE,MAAM,CAAC;IAErB,6DAA6D;IAC7D,WAAW,EAAE,MAAM,CAAC;IAEpB;;;;OAIG;IACH,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IAEnB;;;OAGG;IACH,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IAEpB,0BAA0B;IAC1B,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB,4BAA4B;IAC5B,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB,yBAAyB;IACzB,WAAW,EAAE,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IAE9B,0BAA0B;IAC1B,YAAY,EAAE,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IAE/B,kCAAkC;IAClC,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAE/B;;;OAGG;IACH,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;CAC3B,CAAA"}
@@ -0,0 +1,10 @@
1
+ import { z } from "zod";
2
+ /** ──────────────────────────────────────────────────────────────
3
+ * Internal Schemas (concrete, for method access)
4
+ * ────────────────────────────────────────────────────────────── */
5
+ export const ExternalProvider_OperationContextSchema = z.object({
6
+ callTimestamp: z.iso.datetime(),
7
+ callDuration: z.number().optional(),
8
+ errorReason: z.string().optional(),
9
+ });
10
+ //# sourceMappingURL=operations.external-connectors-models.schemas.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"operations.external-connectors-models.schemas.js","sourceRoot":"","sources":["../../../src/core/operations.external-connectors-models.schemas.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB;;oEAEoE;AAEpE,MAAM,CAAC,MAAM,uCAAuC,GAAG,CAAC,CAAC,MAAM,CAAC;IAC9D,aAAa,EAAE,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE;IAC/B,YAAY,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACnC,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CACnC,CAAC,CAAC"}
@@ -0,0 +1,84 @@
1
+ import { z } from "zod";
2
+ import { A2A_AgentProfile, A2A_Configuration } from "../protocols/a2a.external-connectors-models.schemas.js";
3
+ import { CLIRuntime_Configuration, CLIRuntime_Profile } from "../protocols/cli-runtime.external-connectors-models.schemas.js";
4
+ import { EmailProvider_Configuration, EmailProvider_Profile } from "../protocols/email.external-connectors-models.schemas.js";
5
+ import { FrontendProvider_Configuration, FrontendProvider_Profile } from "../protocols/frontend.external-connectors-models.schemas.js";
6
+ import { GitProvider_Configuration, GitProvider_Profile } from "../protocols/git.external-connectors-models.schemas.js";
7
+ import { GrpcProvider_Configuration, GrpcProvider_Profile } from "../protocols/grpc.external-connectors-models.schemas.js";
8
+ import { HookInitiatorProvider_Configuration, HookInitiatorProvider_Profile } from "../protocols/hooks.external-connectors-models.schemas.js";
9
+ import { LLMProvider_Configuration, LLMProvider_Profile } from "../protocols/llm.external-connectors-models.schemas.js";
10
+ import { MCPProvider_Configuration, MCPProvider_Profile } from "../protocols/mcp.external-connectors-models.schemas.js";
11
+ import { ExternalProvider_OAuth2_Config, OAuth2Provider_Profile } from "../protocols/oauth2.external-connectors-models.schemas.js";
12
+ import { REST_API_Provider_Configuration, REST_API_Provider_Profile } from "../protocols/rest-api.external-connectors-models.schemas.js";
13
+ import { SAMLProvider_Configuration, SAMLProvider_Profile } from "../protocols/saml.external-connectors-models.schemas.js";
14
+ import type { SMSProvider_Configuration, SMSProvider_Profile } from "../protocols/sms.external-connectors-models.schemas.js";
15
+ import { ExternalProvider_ExchangeProtocol_Configuration_Base, ExternalProvider_ExchangeProtocol_Kind, ExternalProvider_ExchangeProtocol_Profile_Base, ExternalProvider_IO_Direction, ExternalProvider_IO_InteractionPattern } from "./commons.external-connectors-models.schemas.js";
16
+ import { ExternalProvider_OperationDefinition_Base } from "./operations.external-connectors-models.schemas.js";
17
+ export type ExternalProvider_ExchangeProtocol_Base = {
18
+ kind: ExternalProvider_ExchangeProtocol_Kind;
19
+ providerRef: string;
20
+ direction: ExternalProvider_IO_Direction;
21
+ interactionPattern: ExternalProvider_IO_InteractionPattern;
22
+ profile: ExternalProvider_ExchangeProtocol_Profile_Base;
23
+ defaultConfiguration: ExternalProvider_ExchangeProtocol_Configuration_Base;
24
+ statusSchema: z.ZodSchema<any>;
25
+ operations: Record<string, ExternalProvider_OperationDefinition_Base>;
26
+ };
27
+ export type ExternalProvider_ExchangeProtocol = (ExternalProvider_ExchangeProtocol_Base & {
28
+ kind: ExternalProvider_ExchangeProtocol_Kind.REST_API;
29
+ profile: REST_API_Provider_Profile;
30
+ defaultConfiguration: REST_API_Provider_Configuration;
31
+ }) | (ExternalProvider_ExchangeProtocol_Base & {
32
+ kind: ExternalProvider_ExchangeProtocol_Kind.WEBHOOK_ORIGINATOR;
33
+ profile: HookInitiatorProvider_Profile;
34
+ defaultConfiguration: HookInitiatorProvider_Configuration;
35
+ }) | (ExternalProvider_ExchangeProtocol_Base & {
36
+ kind: ExternalProvider_ExchangeProtocol_Kind.LLM_PROVIDER;
37
+ profile: LLMProvider_Profile;
38
+ defaultConfiguration: LLMProvider_Configuration;
39
+ }) | (ExternalProvider_ExchangeProtocol_Base & {
40
+ kind: ExternalProvider_ExchangeProtocol_Kind.CLI_RUNTIME;
41
+ profile: CLIRuntime_Profile;
42
+ defaultConfiguration: CLIRuntime_Configuration;
43
+ }) | (ExternalProvider_ExchangeProtocol_Base & {
44
+ kind: ExternalProvider_ExchangeProtocol_Kind.MCP_CONNECTOR;
45
+ profile: MCPProvider_Profile;
46
+ defaultConfiguration: MCPProvider_Configuration;
47
+ }) | (ExternalProvider_ExchangeProtocol_Base & {
48
+ kind: ExternalProvider_ExchangeProtocol_Kind.A2A_CONNECTOR;
49
+ profile: A2A_AgentProfile;
50
+ defaultConfiguration: A2A_Configuration;
51
+ }) | (ExternalProvider_ExchangeProtocol_Base & {
52
+ kind: ExternalProvider_ExchangeProtocol_Kind.EMAIL_PROVIDER;
53
+ profile: EmailProvider_Profile;
54
+ defaultConfiguration: EmailProvider_Configuration;
55
+ }) | (ExternalProvider_ExchangeProtocol_Base & {
56
+ kind: ExternalProvider_ExchangeProtocol_Kind.GIT_PROVIDER;
57
+ profile: GitProvider_Profile;
58
+ defaultConfiguration: GitProvider_Configuration;
59
+ }) | (ExternalProvider_ExchangeProtocol_Base & {
60
+ kind: ExternalProvider_ExchangeProtocol_Kind.GRPC;
61
+ profile: GrpcProvider_Profile;
62
+ defaultConfiguration: GrpcProvider_Configuration;
63
+ }) | (ExternalProvider_ExchangeProtocol_Base & {
64
+ kind: ExternalProvider_ExchangeProtocol_Kind.SSO_OAUTH2;
65
+ profile: OAuth2Provider_Profile;
66
+ defaultConfiguration: ExternalProvider_OAuth2_Config;
67
+ }) | (ExternalProvider_ExchangeProtocol_Base & {
68
+ kind: ExternalProvider_ExchangeProtocol_Kind.SSO_SAML;
69
+ profile: SAMLProvider_Profile;
70
+ defaultConfiguration: SAMLProvider_Configuration;
71
+ }) | (ExternalProvider_ExchangeProtocol_Base & {
72
+ kind: ExternalProvider_ExchangeProtocol_Kind.FRONTEND_INTEGRATION;
73
+ profile: FrontendProvider_Profile;
74
+ defaultConfiguration: FrontendProvider_Configuration;
75
+ }) | (ExternalProvider_ExchangeProtocol_Base & {
76
+ kind: ExternalProvider_ExchangeProtocol_Kind.BILLING_PROVIDER;
77
+ profile: ExternalProvider_ExchangeProtocol_Profile_Base;
78
+ defaultConfiguration: ExternalProvider_ExchangeProtocol_Configuration_Base;
79
+ }) | (ExternalProvider_ExchangeProtocol_Base & {
80
+ kind: ExternalProvider_ExchangeProtocol_Kind.SMS_PROVIDER;
81
+ profile: SMSProvider_Profile;
82
+ defaultConfiguration: SMSProvider_Configuration;
83
+ });
84
+ //# sourceMappingURL=protocols.external-connectors-models.schemas.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"protocols.external-connectors-models.schemas.d.ts","sourceRoot":"","sources":["../../../src/core/protocols.external-connectors-models.schemas.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ //# sourceMappingURL=protocols.external-connectors-models.schemas.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"protocols.external-connectors-models.schemas.js","sourceRoot":"","sources":["../../../src/core/protocols.external-connectors-models.schemas.ts"],"names":[],"mappings":""}
@@ -0,0 +1,80 @@
1
+ import { z } from "zod";
2
+ import { ExternalProvider_ExchangeProtocol } from "./protocols.external-connectors-models.schemas.js";
3
+ import { ExternalProvider_Capability } from "../features/core.external-connectors-models.schemas.js";
4
+ import { ProviderCapabilityTransformers } from "../features/email.external-connectors-models.schemas.js";
5
+ /** ──────────────────────────────────────────────────────────────
6
+ * Domain Schema
7
+ * A domain is a logical grouping of related API operations within a provider
8
+ * e.g., Stripe has domains: customers, payments, subscriptions, invoices
9
+ * e.g., Google has domains: sheets, drive, calendar, gmail
10
+ * ────────────────────────────────────────────────────────────── */
11
+ export declare const ExternalProvider_DomainSchema: z.ZodObject<{
12
+ ref: z.ZodString;
13
+ displayName: z.ZodString;
14
+ description: z.ZodOptional<z.ZodString>;
15
+ baseUrl: z.ZodOptional<z.ZodURL>;
16
+ version: z.ZodOptional<z.ZodString>;
17
+ metadata: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnknown>>;
18
+ }, z.core.$strip>;
19
+ /** ──────────────────────────────────────────────────────────────
20
+ * Provider Definition Schema
21
+ * Represents an external service provider (e.g., Google, Microsoft, Slack)
22
+ * ────────────────────────────────────────────────────────────── */
23
+ export declare const ExternalProvider_DefinitionBaseSchema: z.ZodObject<{
24
+ ref: z.ZodString;
25
+ displayName: z.ZodString;
26
+ description: z.ZodOptional<z.ZodString>;
27
+ baseUrl: z.ZodOptional<z.ZodURL>;
28
+ domains: z.ZodDefault<z.ZodArray<z.ZodObject<{
29
+ ref: z.ZodString;
30
+ displayName: z.ZodString;
31
+ description: z.ZodOptional<z.ZodString>;
32
+ baseUrl: z.ZodOptional<z.ZodURL>;
33
+ version: z.ZodOptional<z.ZodString>;
34
+ metadata: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnknown>>;
35
+ }, z.core.$strip>>>;
36
+ metadata: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnknown>>;
37
+ }, z.core.$strip>;
38
+ /** ──────────────────────────────────────────────────────────────
39
+ * Inferred Types (from schemas - no interface duplication)
40
+ * ────────────────────────────────────────────────────────────── */
41
+ export type ExternalProvider_Domain = z.infer<typeof ExternalProvider_DomainSchema>;
42
+ export type ExternalProvider_DefinitionBase = z.infer<typeof ExternalProvider_DefinitionBaseSchema>;
43
+ /**
44
+ * Complete provider definition including protocols, capabilities, and transformers.
45
+ *
46
+ * Capabilities and their transformers are defined at the PROVIDER level, not protocol level.
47
+ * Each capability (EMAIL_TRANSACTIONAL, EMAIL_MARKETING, etc.) is fully independent.
48
+ */
49
+ export type ExternalProvider_Definition = ExternalProvider_DefinitionBase & {
50
+ /** Exchange protocols this provider supports (EMAIL_PROVIDER, LLM_PROVIDER, etc.) */
51
+ protocols: ExternalProvider_ExchangeProtocol[];
52
+ /**
53
+ * Standard capabilities this provider implements.
54
+ * Each capability is fully independent even if related (e.g., EMAIL_TRANSACTIONAL vs EMAIL_MARKETING).
55
+ */
56
+ capabilities?: ExternalProvider_Capability[];
57
+ /**
58
+ * Capability transformers for ETL operations.
59
+ * Each capability has its own transformer with fully segregated logic.
60
+ * Used by the backend to interact with providers in a standardized way.
61
+ */
62
+ capabilityTransformers?: ProviderCapabilityTransformers;
63
+ /**
64
+ * NPM packages required at runtime by this provider's transformers.
65
+ *
66
+ * Provider SDK packages (e.g., 'stripe', 'resend') are optional dependencies
67
+ * of the external-connectors package. The consuming app (apps-custom) must
68
+ * explicitly add the required packages to its own dependencies.
69
+ *
70
+ * The engine uses this list to:
71
+ * - Check SDK availability at startup before attempting to use the provider
72
+ * - Provide actionable error messages when a required package is missing
73
+ * - Filter available providers in admin UIs and configuration surfaces
74
+ *
75
+ * @example ['stripe'] for Stripe billing provider
76
+ * @example ['resend'] for Resend email provider
77
+ */
78
+ requiredPackages?: string[];
79
+ };
80
+ //# sourceMappingURL=providers.external-connectors-models.schemas.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"providers.external-connectors-models.schemas.d.ts","sourceRoot":"","sources":["../../../src/core/providers.external-connectors-models.schemas.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,iCAAiC,EAAE,MAAM,gDAAgD,CAAC;AACnG,OAAO,EAAE,2BAA2B,EAAE,MAAM,2EAA2E,CAAC;AACxH,OAAO,EAAE,8BAA8B,EAAE,MAAM,4EAA4E,CAAC;AAE5H;;;;;oEAKoE;AAEpE,eAAO,MAAM,6BAA6B;;;;;;;iBAyBxC,CAAC;AAEH;;;oEAGoE;AAEpE,eAAO,MAAM,qCAAqC;;;;;;;;;;;;;;iBA0BhD,CAAC;AAEH;;oEAEoE;AAEpE,MAAM,MAAM,uBAAuB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,6BAA6B,CAAC,CAAC;AACpF,MAAM,MAAM,+BAA+B,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,qCAAqC,CAAC,CAAC;AAEpG;;;;;GAKG;AACH,MAAM,MAAM,2BAA2B,GAAG,+BAA+B,GAAG;IAC1E,qFAAqF;IACrF,SAAS,EAAE,iCAAiC,EAAE,CAAC;IAE/C;;;OAGG;IACH,YAAY,CAAC,EAAE,2BAA2B,EAAE,CAAC;IAE7C;;;;OAIG;IACH,sBAAsB,CAAC,EAAE,8BAA8B,CAAC;IAExD;;;;;;;;;;;;;;OAcG;IACH,gBAAgB,CAAC,EAAE,MAAM,EAAE,CAAC;CAC7B,CAAC"}
@@ -0,0 +1,55 @@
1
+ import { z } from "zod";
2
+ /** ──────────────────────────────────────────────────────────────
3
+ * Domain Schema
4
+ * A domain is a logical grouping of related API operations within a provider
5
+ * e.g., Stripe has domains: customers, payments, subscriptions, invoices
6
+ * e.g., Google has domains: sheets, drive, calendar, gmail
7
+ * ────────────────────────────────────────────────────────────── */
8
+ export const ExternalProvider_DomainSchema = z.object({
9
+ /** Unique identifier within the provider (e.g., "customers", "sheets") */
10
+ ref: z.string().min(1),
11
+ /** Human-readable name (e.g., "Customers", "Google Sheets") */
12
+ displayName: z.string().min(1),
13
+ /** Domain description */
14
+ description: z.string().optional(),
15
+ /**
16
+ * Base URL override for this domain
17
+ * If not specified, uses provider's baseUrl
18
+ * e.g., "https://sheets.googleapis.com/v4" overrides "https://www.googleapis.com"
19
+ */
20
+ baseUrl: z.url().optional(),
21
+ /**
22
+ * API version for this domain (e.g., "v4", "2025-03-31")
23
+ * If not specified, uses protocol-level version
24
+ */
25
+ version: z.string().optional(),
26
+ /** Domain-specific metadata */
27
+ metadata: z.record(z.string(), z.unknown()).optional(),
28
+ });
29
+ /** ──────────────────────────────────────────────────────────────
30
+ * Provider Definition Schema
31
+ * Represents an external service provider (e.g., Google, Microsoft, Slack)
32
+ * ────────────────────────────────────────────────────────────── */
33
+ export const ExternalProvider_DefinitionBaseSchema = z.object({
34
+ /** Unique identifier (e.g., "google", "microsoft", "slack") */
35
+ ref: z.string().min(1),
36
+ /** Human-readable name (e.g., "Google", "Microsoft", "Slack") */
37
+ displayName: z.string().min(1),
38
+ /** Provider description */
39
+ description: z.string().optional(),
40
+ /**
41
+ * Default base URL for the provider
42
+ * Can be overridden at domain level
43
+ */
44
+ baseUrl: z.url().optional(),
45
+ /**
46
+ * Domains/API groupings within this provider
47
+ * Empty array for providers without explicit domains
48
+ * e.g., Stripe has: [{ ref: "customers" }, { ref: "payments" }, { ref: "subscriptions" }]
49
+ * e.g., Google has: [{ ref: "sheets" }, { ref: "drive" }, { ref: "calendar" }]
50
+ */
51
+ domains: z.array(ExternalProvider_DomainSchema).default([]),
52
+ /** Provider-specific metadata */
53
+ metadata: z.record(z.string(), z.unknown()).optional(),
54
+ });
55
+ //# sourceMappingURL=providers.external-connectors-models.schemas.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"providers.external-connectors-models.schemas.js","sourceRoot":"","sources":["../../../src/core/providers.external-connectors-models.schemas.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAKxB;;;;;oEAKoE;AAEpE,MAAM,CAAC,MAAM,6BAA6B,GAAG,CAAC,CAAC,MAAM,CAAC;IACpD,0EAA0E;IAC1E,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAEtB,+DAA+D;IAC/D,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAE9B,yBAAyB;IACzB,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAElC;;;;OAIG;IACH,OAAO,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE;IAE3B;;;OAGG;IACH,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAE9B,+BAA+B;IAC/B,QAAQ,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,QAAQ,EAAE;CACvD,CAAC,CAAC;AAEH;;;oEAGoE;AAEpE,MAAM,CAAC,MAAM,qCAAqC,GAAG,CAAC,CAAC,MAAM,CAAC;IAC5D,+DAA+D;IAC/D,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAEtB,iEAAiE;IACjE,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAE9B,2BAA2B;IAC3B,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAElC;;;OAGG;IACH,OAAO,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE;IAE3B;;;;;OAKG;IACH,OAAO,EAAE,CAAC,CAAC,KAAK,CAAC,6BAA6B,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC;IAE3D,iCAAiC;IACjC,QAAQ,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,QAAQ,EAAE;CACvD,CAAC,CAAC"}
@@ -0,0 +1,187 @@
1
+ /**
2
+ * Security and Authentication Schemas for External Connectors
3
+ *
4
+ * This module defines authentication profiles that can be used across protocols.
5
+ * It integrates with OAuth2 to avoid duplication between API auth and OAuth2 config.
6
+ *
7
+ * Architecture:
8
+ * - ExternalProvider_Auth_Kind: The type of authentication
9
+ * - ExternalProvider_AuthProfile: How to authenticate with an API
10
+ * - OAuth2-linked profiles: Reference OAuth2 config instead of duplicating
11
+ *
12
+ * @see https://swagger.io/docs/specification/v3_0/authentication/
13
+ */
14
+ import { z } from "zod";
15
+ import { OAuth2_GrantType, OAuth2_TokenEndpoint_AuthMethod, OAuth2_PKCE_Method, OAuth2_Prompt, OAuth2_AccessType } from './oauth2.enums.js';
16
+ /**
17
+ * Authentication types supported by external providers
18
+ * Follows OpenAPI 3.0 Security Schemes with extensions
19
+ */
20
+ export declare enum ExternalProvider_Auth_Kind {
21
+ /** No authentication required */
22
+ NONE = "none",
23
+ /** API Key in header, query, or cookie */
24
+ API_KEY = "api_key",
25
+ /** Bearer token (OAuth2 access token or JWT) */
26
+ BEARER = "bearer",
27
+ /** HTTP Basic authentication */
28
+ BASIC = "basic",
29
+ /** OAuth2 authentication - links to OAuth2 provider definition */
30
+ OAUTH2 = "oauth2",
31
+ /** HMAC signature-based authentication */
32
+ HMAC_SIGNATURE = "hmac_signature",
33
+ /** OpenID Connect (OAuth2 + identity layer) */
34
+ OPENID_CONNECT = "openid_connect",
35
+ /** Mutual TLS (client certificates) */
36
+ MUTUAL_TLS = "mutual_tls",
37
+ /** Frontend-specific secret (not exposed to user) */
38
+ FRONTEND_SECRET = "frontend_secret"
39
+ }
40
+ export declare enum ExternalProvider_Auth_ApiKey_Location {
41
+ HEADER = "header",
42
+ QUERY = "query",
43
+ COOKIE = "cookie"
44
+ }
45
+ export declare enum ExternalProvider_Auth_HMAC_Signature_Algorithm {
46
+ SHA256 = "sha256",
47
+ SHA512 = "sha512"
48
+ }
49
+ export declare enum ExternalProvider_Auth_Bearer_Format {
50
+ JWT = "jwt",
51
+ API_KEY = "api_key",
52
+ OAUTH2_ACCESS_TOKEN = "oauth2_access_token"
53
+ }
54
+ /**
55
+ * Auth Configuration - references a secret
56
+ * This is the runtime configuration that specifies which secret to use
57
+ */
58
+ export declare const ExternalProvider_Auth_ConfigurationSchema: z.ZodObject<{
59
+ authKind: z.ZodEnum<typeof ExternalProvider_Auth_Kind>;
60
+ profileRefs: z.ZodOptional<z.ZodArray<z.ZodString>>;
61
+ isDefault: z.ZodOptional<z.ZodBoolean>;
62
+ secretRef: z.ZodString;
63
+ }, z.core.$strip>;
64
+ export declare const ExternalProvider_RateLimitConfigurationSchema: z.ZodObject<{
65
+ maxConcurrent: z.ZodDefault<z.ZodOptional<z.ZodNumber>>;
66
+ minTime: z.ZodOptional<z.ZodNumber>;
67
+ reservoir: z.ZodOptional<z.ZodNumber>;
68
+ reservoirRefreshInterval: z.ZodOptional<z.ZodNumber>;
69
+ reservoirRefreshAmount: z.ZodOptional<z.ZodNumber>;
70
+ priority: z.ZodDefault<z.ZodOptional<z.ZodNumber>>;
71
+ }, z.core.$strip>;
72
+ export declare const ExternalProvider_AuthProfile_BaseSchema: z.ZodObject<{
73
+ kind: z.ZodEnum<typeof ExternalProvider_Auth_Kind>;
74
+ ref: z.ZodOptional<z.ZodString>;
75
+ isDefault: z.ZodDefault<z.ZodBoolean>;
76
+ location: z.ZodDefault<z.ZodEnum<typeof ExternalProvider_Auth_ApiKey_Location>>;
77
+ locationField: z.ZodDefault<z.ZodString>;
78
+ }, z.core.$strip>;
79
+ export type ExternalProvider_Auth_Configuration = z.infer<typeof ExternalProvider_Auth_ConfigurationSchema>;
80
+ export type ExternalProvider_RateLimitConfiguration = z.infer<typeof ExternalProvider_RateLimitConfigurationSchema>;
81
+ export type ExternalProvider_AuthProfile_Base = z.infer<typeof ExternalProvider_AuthProfile_BaseSchema>;
82
+ /**
83
+ * Complete Auth Profile Schema - discriminated union by kind
84
+ * Each kind has specific configuration fields
85
+ */
86
+ export declare const ExternalProvider_AuthProfile_Schema: z.ZodDiscriminatedUnion<[z.ZodObject<{
87
+ ref: z.ZodOptional<z.ZodString>;
88
+ isDefault: z.ZodDefault<z.ZodBoolean>;
89
+ location: z.ZodDefault<z.ZodEnum<typeof ExternalProvider_Auth_ApiKey_Location>>;
90
+ kind: z.ZodLiteral<ExternalProvider_Auth_Kind.API_KEY>;
91
+ locationField: z.ZodDefault<z.ZodString>;
92
+ prefix: z.ZodOptional<z.ZodString>;
93
+ }, z.core.$strip>, z.ZodObject<{
94
+ ref: z.ZodOptional<z.ZodString>;
95
+ isDefault: z.ZodDefault<z.ZodBoolean>;
96
+ location: z.ZodDefault<z.ZodEnum<typeof ExternalProvider_Auth_ApiKey_Location>>;
97
+ kind: z.ZodLiteral<ExternalProvider_Auth_Kind.HMAC_SIGNATURE>;
98
+ locationField: z.ZodDefault<z.ZodString>;
99
+ algorithm: z.ZodDefault<z.ZodEnum<typeof ExternalProvider_Auth_HMAC_Signature_Algorithm>>;
100
+ signaturePayload: z.ZodOptional<z.ZodEnum<{
101
+ custom: "custom";
102
+ body: "body";
103
+ timestamp: "timestamp";
104
+ }>>;
105
+ timestampHeader: z.ZodOptional<z.ZodString>;
106
+ nonceHeader: z.ZodOptional<z.ZodString>;
107
+ }, z.core.$strip>, z.ZodObject<{
108
+ ref: z.ZodOptional<z.ZodString>;
109
+ isDefault: z.ZodDefault<z.ZodBoolean>;
110
+ kind: z.ZodLiteral<ExternalProvider_Auth_Kind.BEARER>;
111
+ location: z.ZodDefault<z.ZodEnum<typeof ExternalProvider_Auth_ApiKey_Location>>;
112
+ locationField: z.ZodDefault<z.ZodString>;
113
+ prefix: z.ZodDefault<z.ZodString>;
114
+ format: z.ZodDefault<z.ZodEnum<typeof ExternalProvider_Auth_Bearer_Format>>;
115
+ }, z.core.$strip>, z.ZodObject<{
116
+ ref: z.ZodOptional<z.ZodString>;
117
+ isDefault: z.ZodDefault<z.ZodBoolean>;
118
+ location: z.ZodDefault<z.ZodEnum<typeof ExternalProvider_Auth_ApiKey_Location>>;
119
+ locationField: z.ZodDefault<z.ZodString>;
120
+ kind: z.ZodLiteral<ExternalProvider_Auth_Kind.OPENID_CONNECT>;
121
+ discoveryUrl: z.ZodOptional<z.ZodURL>;
122
+ issuer: z.ZodOptional<z.ZodString>;
123
+ audience: z.ZodOptional<z.ZodString>;
124
+ validationMode: z.ZodOptional<z.ZodEnum<{
125
+ jwks: "jwks";
126
+ introspection: "introspection";
127
+ local: "local";
128
+ }>>;
129
+ }, z.core.$strip>, z.ZodObject<{
130
+ ref: z.ZodOptional<z.ZodString>;
131
+ isDefault: z.ZodDefault<z.ZodBoolean>;
132
+ location: z.ZodDefault<z.ZodEnum<typeof ExternalProvider_Auth_ApiKey_Location>>;
133
+ locationField: z.ZodDefault<z.ZodString>;
134
+ kind: z.ZodLiteral<ExternalProvider_Auth_Kind.OAUTH2>;
135
+ oauth2ProviderRef: z.ZodOptional<z.ZodString>;
136
+ authUrl: z.ZodOptional<z.ZodURL>;
137
+ tokenUrl: z.ZodOptional<z.ZodURL>;
138
+ refreshUrl: z.ZodOptional<z.ZodURL>;
139
+ scopes: z.ZodOptional<z.ZodArray<z.ZodString>>;
140
+ grantType: z.ZodOptional<z.ZodEnum<typeof OAuth2_GrantType>>;
141
+ tokenEndpointAuthMethod: z.ZodOptional<z.ZodEnum<typeof OAuth2_TokenEndpoint_AuthMethod>>;
142
+ pkce: z.ZodOptional<z.ZodBoolean>;
143
+ pkceMethod: z.ZodOptional<z.ZodEnum<typeof OAuth2_PKCE_Method>>;
144
+ prompt: z.ZodOptional<z.ZodEnum<typeof OAuth2_Prompt>>;
145
+ accessType: z.ZodOptional<z.ZodEnum<typeof OAuth2_AccessType>>;
146
+ extraAuthParams: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
147
+ extraTokenParams: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
148
+ tokenFormat: z.ZodDefault<z.ZodEnum<{
149
+ token: "token";
150
+ bearer: "bearer";
151
+ oauth: "oauth";
152
+ custom: "custom";
153
+ }>>;
154
+ customTokenPrefix: z.ZodOptional<z.ZodString>;
155
+ }, z.core.$strip>, z.ZodObject<{
156
+ ref: z.ZodOptional<z.ZodString>;
157
+ isDefault: z.ZodDefault<z.ZodBoolean>;
158
+ location: z.ZodDefault<z.ZodEnum<typeof ExternalProvider_Auth_ApiKey_Location>>;
159
+ locationField: z.ZodDefault<z.ZodString>;
160
+ kind: z.ZodLiteral<ExternalProvider_Auth_Kind.BASIC>;
161
+ usernameRef: z.ZodOptional<z.ZodString>;
162
+ passwordRef: z.ZodOptional<z.ZodString>;
163
+ }, z.core.$strip>, z.ZodObject<{
164
+ ref: z.ZodOptional<z.ZodString>;
165
+ isDefault: z.ZodDefault<z.ZodBoolean>;
166
+ location: z.ZodDefault<z.ZodEnum<typeof ExternalProvider_Auth_ApiKey_Location>>;
167
+ locationField: z.ZodDefault<z.ZodString>;
168
+ kind: z.ZodLiteral<ExternalProvider_Auth_Kind.NONE>;
169
+ }, z.core.$strip>, z.ZodObject<{
170
+ ref: z.ZodOptional<z.ZodString>;
171
+ isDefault: z.ZodDefault<z.ZodBoolean>;
172
+ location: z.ZodDefault<z.ZodEnum<typeof ExternalProvider_Auth_ApiKey_Location>>;
173
+ locationField: z.ZodDefault<z.ZodString>;
174
+ kind: z.ZodLiteral<ExternalProvider_Auth_Kind.FRONTEND_SECRET>;
175
+ frontendOnly: z.ZodDefault<z.ZodBoolean>;
176
+ }, z.core.$strip>, z.ZodObject<{
177
+ ref: z.ZodOptional<z.ZodString>;
178
+ isDefault: z.ZodDefault<z.ZodBoolean>;
179
+ location: z.ZodDefault<z.ZodEnum<typeof ExternalProvider_Auth_ApiKey_Location>>;
180
+ locationField: z.ZodDefault<z.ZodString>;
181
+ kind: z.ZodLiteral<ExternalProvider_Auth_Kind.MUTUAL_TLS>;
182
+ certificateRef: z.ZodOptional<z.ZodString>;
183
+ privateKeyRef: z.ZodOptional<z.ZodString>;
184
+ caRef: z.ZodOptional<z.ZodString>;
185
+ }, z.core.$strip>], "kind">;
186
+ export type ExternalProvider_AuthProfile = z.infer<typeof ExternalProvider_AuthProfile_Schema>;
187
+ //# sourceMappingURL=security.external-connectors-models.schemas.d.ts.map