@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.
- package/dist/esm/core/commons.external-connectors-models.schemas.d.ts +195 -0
- package/dist/esm/core/commons.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/core/commons.external-connectors-models.schemas.js +96 -0
- package/dist/esm/core/commons.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/core/lazy-loading.external-connectors-models.schemas.d.ts +127 -0
- package/dist/esm/core/lazy-loading.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/core/lazy-loading.external-connectors-models.schemas.js +22 -0
- package/dist/esm/core/lazy-loading.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/core/oauth2.enums.d.ts +125 -0
- package/dist/esm/core/oauth2.enums.d.ts.map +1 -0
- package/dist/esm/core/oauth2.enums.js +134 -0
- package/dist/esm/core/oauth2.enums.js.map +1 -0
- package/dist/esm/core/operations.external-connectors-models.schemas.d.ts +46 -0
- package/dist/esm/core/operations.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/core/operations.external-connectors-models.schemas.js +10 -0
- package/dist/esm/core/operations.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/core/protocols.external-connectors-models.schemas.d.ts +84 -0
- package/dist/esm/core/protocols.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/core/protocols.external-connectors-models.schemas.js +1 -0
- package/dist/esm/core/protocols.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/core/providers.external-connectors-models.schemas.d.ts +80 -0
- package/dist/esm/core/providers.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/core/providers.external-connectors-models.schemas.js +55 -0
- package/dist/esm/core/providers.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/core/security.external-connectors-models.schemas.d.ts +187 -0
- package/dist/esm/core/security.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/core/security.external-connectors-models.schemas.js +233 -0
- package/dist/esm/core/security.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/features/core.external-connectors-models.schemas.d.ts +63 -0
- package/dist/esm/features/core.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/features/core.external-connectors-models.schemas.js +101 -0
- package/dist/esm/features/core.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/features/email.external-connectors-models.schemas.d.ts +181 -0
- package/dist/esm/features/email.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/features/email.external-connectors-models.schemas.js +34 -0
- package/dist/esm/features/email.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/features/hooks.external-connectors-models.schemas.d.ts +101 -0
- package/dist/esm/features/hooks.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/features/hooks.external-connectors-models.schemas.js +11 -0
- package/dist/esm/features/hooks.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/features/sms.external-connectors-models.schemas.d.ts +21 -0
- package/dist/esm/features/sms.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/features/sms.external-connectors-models.schemas.js +8 -0
- package/dist/esm/features/sms.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/index.d.ts +28 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +31 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/protocols/a2a.external-connectors-models.schemas.d.ts +57 -0
- package/dist/esm/protocols/a2a.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/protocols/a2a.external-connectors-models.schemas.js +73 -0
- package/dist/esm/protocols/a2a.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/protocols/billing.standard-interface.schemas.d.ts +315 -0
- package/dist/esm/protocols/billing.standard-interface.schemas.d.ts.map +1 -0
- package/dist/esm/protocols/billing.standard-interface.schemas.js +104 -0
- package/dist/esm/protocols/billing.standard-interface.schemas.js.map +1 -0
- package/dist/esm/protocols/cli-runtime.external-connectors-models.schemas.d.ts +214 -0
- package/dist/esm/protocols/cli-runtime.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/protocols/cli-runtime.external-connectors-models.schemas.js +188 -0
- package/dist/esm/protocols/cli-runtime.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/protocols/email.external-connectors-models.schemas.d.ts +370 -0
- package/dist/esm/protocols/email.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/protocols/email.external-connectors-models.schemas.js +368 -0
- package/dist/esm/protocols/email.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/protocols/email.standard-interface.schemas.d.ts +330 -0
- package/dist/esm/protocols/email.standard-interface.schemas.d.ts.map +1 -0
- package/dist/esm/protocols/email.standard-interface.schemas.js +275 -0
- package/dist/esm/protocols/email.standard-interface.schemas.js.map +1 -0
- package/dist/esm/protocols/frontend.external-connectors-models.schemas.d.ts +16 -0
- package/dist/esm/protocols/frontend.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/protocols/frontend.external-connectors-models.schemas.js +10 -0
- package/dist/esm/protocols/frontend.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/protocols/git.external-connectors-models.schemas.d.ts +14 -0
- package/dist/esm/protocols/git.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/protocols/git.external-connectors-models.schemas.js +9 -0
- package/dist/esm/protocols/git.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/protocols/grpc.external-connectors-models.schemas.d.ts +14 -0
- package/dist/esm/protocols/grpc.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/protocols/grpc.external-connectors-models.schemas.js +9 -0
- package/dist/esm/protocols/grpc.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/protocols/hooks.external-connectors-models.schemas.d.ts +192 -0
- package/dist/esm/protocols/hooks.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/protocols/hooks.external-connectors-models.schemas.js +103 -0
- package/dist/esm/protocols/hooks.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/protocols/llm.external-connectors-models.schemas.d.ts +499 -0
- package/dist/esm/protocols/llm.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/protocols/llm.external-connectors-models.schemas.js +351 -0
- package/dist/esm/protocols/llm.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/protocols/mcp.external-connectors-models.schemas.d.ts +60 -0
- package/dist/esm/protocols/mcp.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/protocols/mcp.external-connectors-models.schemas.js +35 -0
- package/dist/esm/protocols/mcp.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/protocols/oauth2.external-connectors-models.schemas.d.ts +570 -0
- package/dist/esm/protocols/oauth2.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/protocols/oauth2.external-connectors-models.schemas.js +401 -0
- package/dist/esm/protocols/oauth2.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/protocols/rest-api.external-connectors-models.schemas.d.ts +125 -0
- package/dist/esm/protocols/rest-api.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/protocols/rest-api.external-connectors-models.schemas.js +92 -0
- package/dist/esm/protocols/rest-api.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/protocols/saml.external-connectors-models.schemas.d.ts +135 -0
- package/dist/esm/protocols/saml.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/protocols/saml.external-connectors-models.schemas.js +9 -0
- package/dist/esm/protocols/saml.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/protocols/sms.external-connectors-models.schemas.d.ts +55 -0
- package/dist/esm/protocols/sms.external-connectors-models.schemas.d.ts.map +1 -0
- package/dist/esm/protocols/sms.external-connectors-models.schemas.js +46 -0
- package/dist/esm/protocols/sms.external-connectors-models.schemas.js.map +1 -0
- package/dist/esm/protocols/sms.standard-interface.schemas.d.ts +35 -0
- package/dist/esm/protocols/sms.standard-interface.schemas.d.ts.map +1 -0
- package/dist/esm/protocols/sms.standard-interface.schemas.js +54 -0
- package/dist/esm/protocols/sms.standard-interface.schemas.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -0
- package/package.json +47 -0
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
import { ExternalProvider_Auth_Kind } from "./security.external-connectors-models.schemas.js";
|
|
3
|
+
export declare enum ExternalProvider_ExchangeProtocol_Kind {
|
|
4
|
+
REST_API = "rest_api",
|
|
5
|
+
WEBHOOK_ORIGINATOR = "webhook_originator",
|
|
6
|
+
LLM_PROVIDER = "llm_provider",
|
|
7
|
+
CLI_RUNTIME = "cli_runtime",
|
|
8
|
+
MCP_CONNECTOR = "mcp_connector",
|
|
9
|
+
A2A_CONNECTOR = "a2a_connector",
|
|
10
|
+
EMAIL_PROVIDER = "email_provider",
|
|
11
|
+
GIT_PROVIDER = "git_provider",
|
|
12
|
+
GRPC = "grpc",
|
|
13
|
+
SSO_OAUTH2 = "sso_oauth2",
|
|
14
|
+
SSO_SAML = "sso_saml",
|
|
15
|
+
BILLING_PROVIDER = "billing_provider",
|
|
16
|
+
SMS_PROVIDER = "sms_provider",
|
|
17
|
+
FRONTEND_INTEGRATION = "frontend_integration"
|
|
18
|
+
}
|
|
19
|
+
export declare enum APPLICATION_ENVIRONMENT {
|
|
20
|
+
DEVELOPMENT = "development",
|
|
21
|
+
STAGING = "staging",
|
|
22
|
+
PRODUCTION = "production"
|
|
23
|
+
}
|
|
24
|
+
export declare enum ExternalProvider_Status {
|
|
25
|
+
ACTIVE = "active",
|
|
26
|
+
INACTIVE = "inactive",
|
|
27
|
+
BUZY = "busy",
|
|
28
|
+
OFFLINE = "offline",
|
|
29
|
+
DEPRECATED = "deprecated"
|
|
30
|
+
}
|
|
31
|
+
export declare enum API_HttpMethod {
|
|
32
|
+
GET = "GET",
|
|
33
|
+
POST = "POST",
|
|
34
|
+
PUT = "PUT",
|
|
35
|
+
PATCH = "PATCH",
|
|
36
|
+
DELETE = "DELETE",
|
|
37
|
+
HEAD = "HEAD",
|
|
38
|
+
OPTIONS = "OPTIONS"
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Shared protocol profile fields.
|
|
42
|
+
*
|
|
43
|
+
* These fields are transport-oriented hints that many protocols use, but they
|
|
44
|
+
* are not universally meaningful. Execution-oriented protocols such as a local
|
|
45
|
+
* CLI runtime should not need to invent fake HTTP endpoints or auth profiles
|
|
46
|
+
* just to satisfy the shared contract.
|
|
47
|
+
*/
|
|
48
|
+
export declare const ExternalProvider_ExchangeProtocol_Profile_BaseSchema: z.ZodObject<{
|
|
49
|
+
endpoints: z.ZodOptional<z.ZodRecord<z.ZodEnum<typeof APPLICATION_ENVIRONMENT>, z.ZodString>>;
|
|
50
|
+
availableAuthMethods: z.ZodOptional<z.ZodArray<z.ZodEnum<typeof ExternalProvider_Auth_Kind>>>;
|
|
51
|
+
authProfiles: z.ZodOptional<z.ZodArray<z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
52
|
+
ref: z.ZodOptional<z.ZodString>;
|
|
53
|
+
isDefault: z.ZodDefault<z.ZodBoolean>;
|
|
54
|
+
location: z.ZodDefault<z.ZodEnum<typeof import("./security.external-connectors-models.schemas.js").ExternalProvider_Auth_ApiKey_Location>>;
|
|
55
|
+
kind: z.ZodLiteral<ExternalProvider_Auth_Kind.API_KEY>;
|
|
56
|
+
locationField: z.ZodDefault<z.ZodString>;
|
|
57
|
+
prefix: z.ZodOptional<z.ZodString>;
|
|
58
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
59
|
+
ref: z.ZodOptional<z.ZodString>;
|
|
60
|
+
isDefault: z.ZodDefault<z.ZodBoolean>;
|
|
61
|
+
location: z.ZodDefault<z.ZodEnum<typeof import("./security.external-connectors-models.schemas.js").ExternalProvider_Auth_ApiKey_Location>>;
|
|
62
|
+
kind: z.ZodLiteral<ExternalProvider_Auth_Kind.HMAC_SIGNATURE>;
|
|
63
|
+
locationField: z.ZodDefault<z.ZodString>;
|
|
64
|
+
algorithm: z.ZodDefault<z.ZodEnum<typeof import("./security.external-connectors-models.schemas.js").ExternalProvider_Auth_HMAC_Signature_Algorithm>>;
|
|
65
|
+
signaturePayload: z.ZodOptional<z.ZodEnum<{
|
|
66
|
+
custom: "custom";
|
|
67
|
+
body: "body";
|
|
68
|
+
timestamp: "timestamp";
|
|
69
|
+
}>>;
|
|
70
|
+
timestampHeader: z.ZodOptional<z.ZodString>;
|
|
71
|
+
nonceHeader: z.ZodOptional<z.ZodString>;
|
|
72
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
73
|
+
ref: z.ZodOptional<z.ZodString>;
|
|
74
|
+
isDefault: z.ZodDefault<z.ZodBoolean>;
|
|
75
|
+
kind: z.ZodLiteral<ExternalProvider_Auth_Kind.BEARER>;
|
|
76
|
+
location: z.ZodDefault<z.ZodEnum<typeof import("./security.external-connectors-models.schemas.js").ExternalProvider_Auth_ApiKey_Location>>;
|
|
77
|
+
locationField: z.ZodDefault<z.ZodString>;
|
|
78
|
+
prefix: z.ZodDefault<z.ZodString>;
|
|
79
|
+
format: z.ZodDefault<z.ZodEnum<typeof import("./security.external-connectors-models.schemas.js").ExternalProvider_Auth_Bearer_Format>>;
|
|
80
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
81
|
+
ref: z.ZodOptional<z.ZodString>;
|
|
82
|
+
isDefault: z.ZodDefault<z.ZodBoolean>;
|
|
83
|
+
location: z.ZodDefault<z.ZodEnum<typeof import("./security.external-connectors-models.schemas.js").ExternalProvider_Auth_ApiKey_Location>>;
|
|
84
|
+
locationField: z.ZodDefault<z.ZodString>;
|
|
85
|
+
kind: z.ZodLiteral<ExternalProvider_Auth_Kind.OPENID_CONNECT>;
|
|
86
|
+
discoveryUrl: z.ZodOptional<z.ZodURL>;
|
|
87
|
+
issuer: z.ZodOptional<z.ZodString>;
|
|
88
|
+
audience: z.ZodOptional<z.ZodString>;
|
|
89
|
+
validationMode: z.ZodOptional<z.ZodEnum<{
|
|
90
|
+
jwks: "jwks";
|
|
91
|
+
introspection: "introspection";
|
|
92
|
+
local: "local";
|
|
93
|
+
}>>;
|
|
94
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
95
|
+
ref: z.ZodOptional<z.ZodString>;
|
|
96
|
+
isDefault: z.ZodDefault<z.ZodBoolean>;
|
|
97
|
+
location: z.ZodDefault<z.ZodEnum<typeof import("./security.external-connectors-models.schemas.js").ExternalProvider_Auth_ApiKey_Location>>;
|
|
98
|
+
locationField: z.ZodDefault<z.ZodString>;
|
|
99
|
+
kind: z.ZodLiteral<ExternalProvider_Auth_Kind.OAUTH2>;
|
|
100
|
+
oauth2ProviderRef: z.ZodOptional<z.ZodString>;
|
|
101
|
+
authUrl: z.ZodOptional<z.ZodURL>;
|
|
102
|
+
tokenUrl: z.ZodOptional<z.ZodURL>;
|
|
103
|
+
refreshUrl: z.ZodOptional<z.ZodURL>;
|
|
104
|
+
scopes: z.ZodOptional<z.ZodArray<z.ZodString>>;
|
|
105
|
+
grantType: z.ZodOptional<z.ZodEnum<typeof import("./oauth2.enums.js").OAuth2_GrantType>>;
|
|
106
|
+
tokenEndpointAuthMethod: z.ZodOptional<z.ZodEnum<typeof import("./oauth2.enums.js").OAuth2_TokenEndpoint_AuthMethod>>;
|
|
107
|
+
pkce: z.ZodOptional<z.ZodBoolean>;
|
|
108
|
+
pkceMethod: z.ZodOptional<z.ZodEnum<typeof import("./oauth2.enums.js").OAuth2_PKCE_Method>>;
|
|
109
|
+
prompt: z.ZodOptional<z.ZodEnum<typeof import("./oauth2.enums.js").OAuth2_Prompt>>;
|
|
110
|
+
accessType: z.ZodOptional<z.ZodEnum<typeof import("./oauth2.enums.js").OAuth2_AccessType>>;
|
|
111
|
+
extraAuthParams: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
|
|
112
|
+
extraTokenParams: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
|
|
113
|
+
tokenFormat: z.ZodDefault<z.ZodEnum<{
|
|
114
|
+
token: "token";
|
|
115
|
+
bearer: "bearer";
|
|
116
|
+
oauth: "oauth";
|
|
117
|
+
custom: "custom";
|
|
118
|
+
}>>;
|
|
119
|
+
customTokenPrefix: z.ZodOptional<z.ZodString>;
|
|
120
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
121
|
+
ref: z.ZodOptional<z.ZodString>;
|
|
122
|
+
isDefault: z.ZodDefault<z.ZodBoolean>;
|
|
123
|
+
location: z.ZodDefault<z.ZodEnum<typeof import("./security.external-connectors-models.schemas.js").ExternalProvider_Auth_ApiKey_Location>>;
|
|
124
|
+
locationField: z.ZodDefault<z.ZodString>;
|
|
125
|
+
kind: z.ZodLiteral<ExternalProvider_Auth_Kind.BASIC>;
|
|
126
|
+
usernameRef: z.ZodOptional<z.ZodString>;
|
|
127
|
+
passwordRef: z.ZodOptional<z.ZodString>;
|
|
128
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
129
|
+
ref: z.ZodOptional<z.ZodString>;
|
|
130
|
+
isDefault: z.ZodDefault<z.ZodBoolean>;
|
|
131
|
+
location: z.ZodDefault<z.ZodEnum<typeof import("./security.external-connectors-models.schemas.js").ExternalProvider_Auth_ApiKey_Location>>;
|
|
132
|
+
locationField: z.ZodDefault<z.ZodString>;
|
|
133
|
+
kind: z.ZodLiteral<ExternalProvider_Auth_Kind.NONE>;
|
|
134
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
135
|
+
ref: z.ZodOptional<z.ZodString>;
|
|
136
|
+
isDefault: z.ZodDefault<z.ZodBoolean>;
|
|
137
|
+
location: z.ZodDefault<z.ZodEnum<typeof import("./security.external-connectors-models.schemas.js").ExternalProvider_Auth_ApiKey_Location>>;
|
|
138
|
+
locationField: z.ZodDefault<z.ZodString>;
|
|
139
|
+
kind: z.ZodLiteral<ExternalProvider_Auth_Kind.FRONTEND_SECRET>;
|
|
140
|
+
frontendOnly: z.ZodDefault<z.ZodBoolean>;
|
|
141
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
142
|
+
ref: z.ZodOptional<z.ZodString>;
|
|
143
|
+
isDefault: z.ZodDefault<z.ZodBoolean>;
|
|
144
|
+
location: z.ZodDefault<z.ZodEnum<typeof import("./security.external-connectors-models.schemas.js").ExternalProvider_Auth_ApiKey_Location>>;
|
|
145
|
+
locationField: z.ZodDefault<z.ZodString>;
|
|
146
|
+
kind: z.ZodLiteral<ExternalProvider_Auth_Kind.MUTUAL_TLS>;
|
|
147
|
+
certificateRef: z.ZodOptional<z.ZodString>;
|
|
148
|
+
privateKeyRef: z.ZodOptional<z.ZodString>;
|
|
149
|
+
caRef: z.ZodOptional<z.ZodString>;
|
|
150
|
+
}, z.core.$strip>], "kind">>>;
|
|
151
|
+
}, z.core.$strip>;
|
|
152
|
+
/**
|
|
153
|
+
* Shared protocol configuration fields.
|
|
154
|
+
*
|
|
155
|
+
* `authConfig` remains available for protocols that resolve secrets through the
|
|
156
|
+
* generic provider auth model, but it is optional because execution-oriented
|
|
157
|
+
* protocols can own their own auth/runtime policy contract.
|
|
158
|
+
*/
|
|
159
|
+
export declare const ExternalProvider_ExchangeProtocol_Configuration_BaseSchema: z.ZodObject<{
|
|
160
|
+
enabled: z.ZodBoolean;
|
|
161
|
+
authConfig: z.ZodOptional<z.ZodObject<{
|
|
162
|
+
authKind: z.ZodEnum<typeof ExternalProvider_Auth_Kind>;
|
|
163
|
+
profileRefs: z.ZodOptional<z.ZodArray<z.ZodString>>;
|
|
164
|
+
isDefault: z.ZodOptional<z.ZodBoolean>;
|
|
165
|
+
secretRef: z.ZodString;
|
|
166
|
+
}, z.core.$strip>>;
|
|
167
|
+
rateLimitConfig: z.ZodOptional<z.ZodObject<{
|
|
168
|
+
maxConcurrent: z.ZodDefault<z.ZodOptional<z.ZodNumber>>;
|
|
169
|
+
minTime: z.ZodOptional<z.ZodNumber>;
|
|
170
|
+
reservoir: z.ZodOptional<z.ZodNumber>;
|
|
171
|
+
reservoirRefreshInterval: z.ZodOptional<z.ZodNumber>;
|
|
172
|
+
reservoirRefreshAmount: z.ZodOptional<z.ZodNumber>;
|
|
173
|
+
priority: z.ZodDefault<z.ZodOptional<z.ZodNumber>>;
|
|
174
|
+
}, z.core.$strip>>;
|
|
175
|
+
}, z.core.$strip>;
|
|
176
|
+
export declare const ExternalProvider_ExchangeProtocol_Status_BaseSchema: z.ZodObject<{
|
|
177
|
+
protocolKind: z.ZodEnum<typeof ExternalProvider_ExchangeProtocol_Kind>;
|
|
178
|
+
status: z.ZodEnum<typeof ExternalProvider_Status>;
|
|
179
|
+
lastCheckedAt: z.ZodString;
|
|
180
|
+
errorReason: z.ZodOptional<z.ZodString>;
|
|
181
|
+
}, z.core.$strip>;
|
|
182
|
+
export type ExternalProvider_ExchangeProtocol_Profile_Base = z.infer<typeof ExternalProvider_ExchangeProtocol_Profile_BaseSchema>;
|
|
183
|
+
export type ExternalProvider_ExchangeProtocol_Configuration_Base = z.infer<typeof ExternalProvider_ExchangeProtocol_Configuration_BaseSchema>;
|
|
184
|
+
export type ExternalProvider_ExchangeProtocol_Status_Base = z.infer<typeof ExternalProvider_ExchangeProtocol_Status_BaseSchema>;
|
|
185
|
+
export declare enum ExternalProvider_IO_Direction {
|
|
186
|
+
INBOUND = "inbound",
|
|
187
|
+
OUTBOUND = "outbound",
|
|
188
|
+
BIDIRECTIONAL = "bidirectional"
|
|
189
|
+
}
|
|
190
|
+
export declare enum ExternalProvider_IO_InteractionPattern {
|
|
191
|
+
REQUEST_RESPONSE = "request_response",
|
|
192
|
+
EVENT_BASED = "event_based",
|
|
193
|
+
STREAMING = "stream"
|
|
194
|
+
}
|
|
195
|
+
//# sourceMappingURL=commons.external-connectors-models.schemas.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"commons.external-connectors-models.schemas.d.ts","sourceRoot":"","sources":["../../../src/core/commons.external-connectors-models.schemas.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAA6C,0BAA0B,EAAsF,MAAM,+CAA+C,CAAC;AAG1N,oBAAY,sCAAsC;IAEhD,QAAQ,aAAa;IACrB,kBAAkB,uBAAuB;IAIzC,YAAY,iBAAiB;IAC7B,WAAW,gBAAgB;IAC3B,aAAa,kBAAkB;IAC/B,aAAa,kBAAkB;IAG/B,cAAc,mBAAmB;IACjC,YAAY,iBAAiB;IAC7B,IAAI,SAAS;IAGb,UAAU,eAAe;IACzB,QAAQ,aAAa;IAIrB,gBAAgB,qBAAqB;IAGrC,YAAY,iBAAiB;IAG7B,oBAAoB,yBAAyB;CAC9C;AAED,oBAAY,uBAAuB;IACjC,WAAW,gBAAgB;IAC3B,OAAO,YAAY;IACnB,UAAU,eAAe;CAC1B;AAED,oBAAY,uBAAuB;IACjC,MAAM,WAAW;IACjB,QAAQ,aAAa;IACrB,IAAI,SAAS;IACb,OAAO,YAAY;IACnB,UAAU,eAAe;CAC1B;AAGD,oBAAY,cAAc;IACxB,GAAG,QAAQ;IACX,IAAI,SAAS;IACb,GAAG,QAAQ;IACX,KAAK,UAAU;IACf,MAAM,WAAW;IACjB,IAAI,SAAS;IACb,OAAO,YAAY;CACpB;AAED;;;;;;;GAOG;AACH,eAAO,MAAM,oDAAoD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAI/D,CAAC;AAEH;;;;;;GAMG;AACH,eAAO,MAAM,0DAA0D;;;;;;;;;;;;;;;;iBAIrE,CAAC;AAEH,eAAO,MAAM,mDAAmD;;;;;iBAK9D,CAAC;AAEH,MAAM,MAAM,8CAA8C,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,oDAAoD,CAAC,CAAC;AAClI,MAAM,MAAM,oDAAoD,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,0DAA0D,CAAC,CAAC;AAC9I,MAAM,MAAM,6CAA6C,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,mDAAmD,CAAC,CAAC;AAEhI,oBAAY,6BAA6B;IACvC,OAAO,YAAY;IACnB,QAAQ,aAAa;IACrB,aAAa,kBAAkB;CAChC;AAED,oBAAY,sCAAsC;IAChD,gBAAgB,qBAAqB;IACrC,WAAW,gBAAgB;IAC3B,SAAS,WAAW;CACrB"}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
import { ExternalProvider_Auth_ConfigurationSchema, ExternalProvider_Auth_Kind, ExternalProvider_AuthProfile_Schema, ExternalProvider_RateLimitConfigurationSchema } from "./security.external-connectors-models.schemas.js";
|
|
3
|
+
export var ExternalProvider_ExchangeProtocol_Kind;
|
|
4
|
+
(function (ExternalProvider_ExchangeProtocol_Kind) {
|
|
5
|
+
// WEB
|
|
6
|
+
ExternalProvider_ExchangeProtocol_Kind["REST_API"] = "rest_api";
|
|
7
|
+
ExternalProvider_ExchangeProtocol_Kind["WEBHOOK_ORIGINATOR"] = "webhook_originator";
|
|
8
|
+
// SOAP ?
|
|
9
|
+
// AI
|
|
10
|
+
ExternalProvider_ExchangeProtocol_Kind["LLM_PROVIDER"] = "llm_provider";
|
|
11
|
+
ExternalProvider_ExchangeProtocol_Kind["CLI_RUNTIME"] = "cli_runtime";
|
|
12
|
+
ExternalProvider_ExchangeProtocol_Kind["MCP_CONNECTOR"] = "mcp_connector";
|
|
13
|
+
ExternalProvider_ExchangeProtocol_Kind["A2A_CONNECTOR"] = "a2a_connector";
|
|
14
|
+
// INFRA
|
|
15
|
+
ExternalProvider_ExchangeProtocol_Kind["EMAIL_PROVIDER"] = "email_provider";
|
|
16
|
+
ExternalProvider_ExchangeProtocol_Kind["GIT_PROVIDER"] = "git_provider";
|
|
17
|
+
ExternalProvider_ExchangeProtocol_Kind["GRPC"] = "grpc";
|
|
18
|
+
// AUTH
|
|
19
|
+
ExternalProvider_ExchangeProtocol_Kind["SSO_OAUTH2"] = "sso_oauth2";
|
|
20
|
+
ExternalProvider_ExchangeProtocol_Kind["SSO_SAML"] = "sso_saml";
|
|
21
|
+
// OPENID_CONNECT ?
|
|
22
|
+
// BILLING
|
|
23
|
+
ExternalProvider_ExchangeProtocol_Kind["BILLING_PROVIDER"] = "billing_provider";
|
|
24
|
+
// SMS (Phase G2)
|
|
25
|
+
ExternalProvider_ExchangeProtocol_Kind["SMS_PROVIDER"] = "sms_provider";
|
|
26
|
+
// FRONTEND
|
|
27
|
+
ExternalProvider_ExchangeProtocol_Kind["FRONTEND_INTEGRATION"] = "frontend_integration";
|
|
28
|
+
})(ExternalProvider_ExchangeProtocol_Kind || (ExternalProvider_ExchangeProtocol_Kind = {}));
|
|
29
|
+
export var APPLICATION_ENVIRONMENT;
|
|
30
|
+
(function (APPLICATION_ENVIRONMENT) {
|
|
31
|
+
APPLICATION_ENVIRONMENT["DEVELOPMENT"] = "development";
|
|
32
|
+
APPLICATION_ENVIRONMENT["STAGING"] = "staging";
|
|
33
|
+
APPLICATION_ENVIRONMENT["PRODUCTION"] = "production";
|
|
34
|
+
})(APPLICATION_ENVIRONMENT || (APPLICATION_ENVIRONMENT = {}));
|
|
35
|
+
export var ExternalProvider_Status;
|
|
36
|
+
(function (ExternalProvider_Status) {
|
|
37
|
+
ExternalProvider_Status["ACTIVE"] = "active";
|
|
38
|
+
ExternalProvider_Status["INACTIVE"] = "inactive";
|
|
39
|
+
ExternalProvider_Status["BUZY"] = "busy";
|
|
40
|
+
ExternalProvider_Status["OFFLINE"] = "offline";
|
|
41
|
+
ExternalProvider_Status["DEPRECATED"] = "deprecated";
|
|
42
|
+
})(ExternalProvider_Status || (ExternalProvider_Status = {}));
|
|
43
|
+
export var API_HttpMethod;
|
|
44
|
+
(function (API_HttpMethod) {
|
|
45
|
+
API_HttpMethod["GET"] = "GET";
|
|
46
|
+
API_HttpMethod["POST"] = "POST";
|
|
47
|
+
API_HttpMethod["PUT"] = "PUT";
|
|
48
|
+
API_HttpMethod["PATCH"] = "PATCH";
|
|
49
|
+
API_HttpMethod["DELETE"] = "DELETE";
|
|
50
|
+
API_HttpMethod["HEAD"] = "HEAD";
|
|
51
|
+
API_HttpMethod["OPTIONS"] = "OPTIONS";
|
|
52
|
+
})(API_HttpMethod || (API_HttpMethod = {}));
|
|
53
|
+
/**
|
|
54
|
+
* Shared protocol profile fields.
|
|
55
|
+
*
|
|
56
|
+
* These fields are transport-oriented hints that many protocols use, but they
|
|
57
|
+
* are not universally meaningful. Execution-oriented protocols such as a local
|
|
58
|
+
* CLI runtime should not need to invent fake HTTP endpoints or auth profiles
|
|
59
|
+
* just to satisfy the shared contract.
|
|
60
|
+
*/
|
|
61
|
+
export const ExternalProvider_ExchangeProtocol_Profile_BaseSchema = z.object({
|
|
62
|
+
endpoints: z.record(z.enum(APPLICATION_ENVIRONMENT), z.string()).optional(),
|
|
63
|
+
availableAuthMethods: z.array(z.enum(ExternalProvider_Auth_Kind)).optional(),
|
|
64
|
+
authProfiles: z.array(ExternalProvider_AuthProfile_Schema).optional(),
|
|
65
|
+
});
|
|
66
|
+
/**
|
|
67
|
+
* Shared protocol configuration fields.
|
|
68
|
+
*
|
|
69
|
+
* `authConfig` remains available for protocols that resolve secrets through the
|
|
70
|
+
* generic provider auth model, but it is optional because execution-oriented
|
|
71
|
+
* protocols can own their own auth/runtime policy contract.
|
|
72
|
+
*/
|
|
73
|
+
export const ExternalProvider_ExchangeProtocol_Configuration_BaseSchema = z.object({
|
|
74
|
+
enabled: z.boolean(),
|
|
75
|
+
authConfig: ExternalProvider_Auth_ConfigurationSchema.optional(),
|
|
76
|
+
rateLimitConfig: ExternalProvider_RateLimitConfigurationSchema.optional(),
|
|
77
|
+
});
|
|
78
|
+
export const ExternalProvider_ExchangeProtocol_Status_BaseSchema = z.object({
|
|
79
|
+
protocolKind: z.enum(ExternalProvider_ExchangeProtocol_Kind),
|
|
80
|
+
status: z.enum(ExternalProvider_Status),
|
|
81
|
+
lastCheckedAt: z.string(),
|
|
82
|
+
errorReason: z.string().optional(),
|
|
83
|
+
});
|
|
84
|
+
export var ExternalProvider_IO_Direction;
|
|
85
|
+
(function (ExternalProvider_IO_Direction) {
|
|
86
|
+
ExternalProvider_IO_Direction["INBOUND"] = "inbound";
|
|
87
|
+
ExternalProvider_IO_Direction["OUTBOUND"] = "outbound";
|
|
88
|
+
ExternalProvider_IO_Direction["BIDIRECTIONAL"] = "bidirectional";
|
|
89
|
+
})(ExternalProvider_IO_Direction || (ExternalProvider_IO_Direction = {}));
|
|
90
|
+
export var ExternalProvider_IO_InteractionPattern;
|
|
91
|
+
(function (ExternalProvider_IO_InteractionPattern) {
|
|
92
|
+
ExternalProvider_IO_InteractionPattern["REQUEST_RESPONSE"] = "request_response";
|
|
93
|
+
ExternalProvider_IO_InteractionPattern["EVENT_BASED"] = "event_based";
|
|
94
|
+
ExternalProvider_IO_InteractionPattern["STREAMING"] = "stream";
|
|
95
|
+
})(ExternalProvider_IO_InteractionPattern || (ExternalProvider_IO_InteractionPattern = {}));
|
|
96
|
+
//# sourceMappingURL=commons.external-connectors-models.schemas.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"commons.external-connectors-models.schemas.js","sourceRoot":"","sources":["../../../src/core/commons.external-connectors-models.schemas.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Lazy Loading Types for External Connectors
|
|
3
|
+
*
|
|
4
|
+
* Enables on-demand loading of provider definitions at:
|
|
5
|
+
* - Protocol level (REST_API, WEBHOOK, LLM, etc.)
|
|
6
|
+
* - Domain level (customers, invoices, etc.)
|
|
7
|
+
*
|
|
8
|
+
* This dramatically reduces memory usage from 1GB+ to ~100KB at startup.
|
|
9
|
+
*/
|
|
10
|
+
import { ExternalProvider_ExchangeProtocol_Kind } from "./commons.external-connectors-models.schemas.js";
|
|
11
|
+
import { ExternalProvider_OperationDefinition_Base } from "./operations.external-connectors-models.schemas.js";
|
|
12
|
+
import { ExternalProvider_ExchangeProtocol_Base } from "./protocols.external-connectors-models.schemas.js";
|
|
13
|
+
import { ExternalProvider_Capability } from "../features/core.external-connectors-models.schemas.js";
|
|
14
|
+
/**
|
|
15
|
+
* Map of operation key to operation definition
|
|
16
|
+
*/
|
|
17
|
+
export type OperationsMap = Record<string, ExternalProvider_OperationDefinition_Base>;
|
|
18
|
+
/**
|
|
19
|
+
* Lazy loader for operations within a protocol
|
|
20
|
+
* @param domain - Optional domain name (required for REST_API with domains)
|
|
21
|
+
*/
|
|
22
|
+
export type OperationsLoader = (domain?: string) => Promise<OperationsMap>;
|
|
23
|
+
/**
|
|
24
|
+
* Lazy loader for a protocol definition (without operations)
|
|
25
|
+
*/
|
|
26
|
+
export type ProtocolLoader = () => Promise<Omit<ExternalProvider_ExchangeProtocol_Base, 'operations'>>;
|
|
27
|
+
/**
|
|
28
|
+
* Catalog entry for a single protocol within a provider
|
|
29
|
+
* Contains metadata and lazy loaders for the protocol and its operations
|
|
30
|
+
*/
|
|
31
|
+
export interface ProtocolCatalogEntry {
|
|
32
|
+
/** Protocol kind (REST_API, LLM_PROVIDER, etc.) */
|
|
33
|
+
kind: ExternalProvider_ExchangeProtocol_Kind;
|
|
34
|
+
/**
|
|
35
|
+
* Available domains within this protocol (for REST_API)
|
|
36
|
+
* undefined for protocols without domain-level splitting
|
|
37
|
+
*/
|
|
38
|
+
domains?: string[];
|
|
39
|
+
/**
|
|
40
|
+
* Load the protocol definition (profile, config, status schema)
|
|
41
|
+
* Does NOT include operations - those are loaded separately
|
|
42
|
+
*/
|
|
43
|
+
loadProtocol: ProtocolLoader;
|
|
44
|
+
/**
|
|
45
|
+
* Load operations for this protocol
|
|
46
|
+
* @param domain - Domain name (required if domains is defined)
|
|
47
|
+
*/
|
|
48
|
+
loadOperations: OperationsLoader;
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Catalog entry for a provider
|
|
52
|
+
* Contains lightweight metadata and protocol loaders
|
|
53
|
+
*
|
|
54
|
+
* Total size: ~200-500 bytes per provider
|
|
55
|
+
* For 400 providers: ~100-200 KB (vs 1GB+ for full definitions)
|
|
56
|
+
*/
|
|
57
|
+
export interface ProviderCatalogEntry {
|
|
58
|
+
/** Provider reference (e.g., "stripe", "google", "openai") */
|
|
59
|
+
ref: string;
|
|
60
|
+
/** Human-readable name */
|
|
61
|
+
displayName: string;
|
|
62
|
+
/** Provider description */
|
|
63
|
+
description?: string;
|
|
64
|
+
/** Default base URL */
|
|
65
|
+
baseUrl?: string;
|
|
66
|
+
/** Available protocols with their loaders */
|
|
67
|
+
protocols: ProtocolCatalogEntry[];
|
|
68
|
+
/**
|
|
69
|
+
* Capabilities this provider implements (with transformers available).
|
|
70
|
+
* Lightweight array of capability enums - used for transformer availability checking.
|
|
71
|
+
* If a capability is listed here, its transformer is guaranteed to exist.
|
|
72
|
+
*/
|
|
73
|
+
capabilities?: ExternalProvider_Capability[];
|
|
74
|
+
/**
|
|
75
|
+
* NPM packages required at runtime by this provider's transformers.
|
|
76
|
+
*
|
|
77
|
+
* Copied from `ExternalProvider_Definition.requiredPackages` during catalog building.
|
|
78
|
+
* The engine uses this to check SDK availability at startup before attempting
|
|
79
|
+
* to use the provider, avoiding cryptic MODULE_NOT_FOUND errors at runtime.
|
|
80
|
+
*
|
|
81
|
+
* @example ['stripe'] for the Stripe billing provider
|
|
82
|
+
*/
|
|
83
|
+
requiredPackages?: string[];
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Complete catalog of all providers
|
|
87
|
+
* Loaded at startup (~100-200 KB)
|
|
88
|
+
*
|
|
89
|
+
* Individual providers/protocols/domains loaded on demand
|
|
90
|
+
*/
|
|
91
|
+
export type ProviderCatalog = Record<string, ProviderCatalogEntry>;
|
|
92
|
+
/**
|
|
93
|
+
* A provider definition with lazy-loadable protocols
|
|
94
|
+
* Used as the return type when loading a provider from catalog
|
|
95
|
+
*/
|
|
96
|
+
export interface LazyProviderDefinition {
|
|
97
|
+
ref: string;
|
|
98
|
+
displayName: string;
|
|
99
|
+
description?: string;
|
|
100
|
+
baseUrl?: string;
|
|
101
|
+
/** Loaded protocols (populated as they're accessed) */
|
|
102
|
+
protocols: Map<ExternalProvider_ExchangeProtocol_Kind, ExternalProvider_ExchangeProtocol_Base>;
|
|
103
|
+
/** Protocol catalog entries for lazy loading */
|
|
104
|
+
protocolCatalog: ProtocolCatalogEntry[];
|
|
105
|
+
/**
|
|
106
|
+
* NPM packages required at runtime by this provider's transformers.
|
|
107
|
+
* Copied from the catalog entry for convenience when working with loaded definitions.
|
|
108
|
+
*/
|
|
109
|
+
requiredPackages?: string[];
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* Cache key for protocol cache
|
|
113
|
+
*/
|
|
114
|
+
export type ProtocolCacheKey = `${string}:${ExternalProvider_ExchangeProtocol_Kind}`;
|
|
115
|
+
/**
|
|
116
|
+
* Cache key for operations cache
|
|
117
|
+
*/
|
|
118
|
+
export type OperationsCacheKey = `${string}:${ExternalProvider_ExchangeProtocol_Kind}:${string}`;
|
|
119
|
+
/**
|
|
120
|
+
* Build protocol cache key
|
|
121
|
+
*/
|
|
122
|
+
export declare function buildProtocolCacheKey(providerRef: string, protocolKind: ExternalProvider_ExchangeProtocol_Kind): ProtocolCacheKey;
|
|
123
|
+
/**
|
|
124
|
+
* Build operations cache key
|
|
125
|
+
*/
|
|
126
|
+
export declare function buildOperationsCacheKey(providerRef: string, protocolKind: ExternalProvider_ExchangeProtocol_Kind, domain?: string): OperationsCacheKey;
|
|
127
|
+
//# sourceMappingURL=lazy-loading.external-connectors-models.schemas.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lazy-loading.external-connectors-models.schemas.d.ts","sourceRoot":"","sources":["../../../src/core/lazy-loading.external-connectors-models.schemas.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EAAE,sCAAsC,EAAE,MAAM,8CAA8C,CAAC;AACtG,OAAO,EAAE,yCAAyC,EAAE,MAAM,iDAAiD,CAAC;AAC5G,OAAO,EAAE,sCAAsC,EAAE,MAAM,gDAAgD,CAAC;AACxG,OAAO,EAAE,2BAA2B,EAAE,MAAM,2EAA2E,CAAC;AAIxH;;GAEG;AACH,MAAM,MAAM,aAAa,GAAG,MAAM,CAAC,MAAM,EAAE,yCAAyC,CAAC,CAAC;AAEtF;;;GAGG;AACH,MAAM,MAAM,gBAAgB,GAAG,CAAC,MAAM,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,aAAa,CAAC,CAAC;AAE3E;;GAEG;AACH,MAAM,MAAM,cAAc,GAAG,MAAM,OAAO,CAAC,IAAI,CAAC,sCAAsC,EAAE,YAAY,CAAC,CAAC,CAAC;AAIvG;;;GAGG;AACH,MAAM,WAAW,oBAAoB;IACnC,mDAAmD;IACnD,IAAI,EAAE,sCAAsC,CAAC;IAE7C;;;OAGG;IACH,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IAEnB;;;OAGG;IACH,YAAY,EAAE,cAAc,CAAC;IAE7B;;;OAGG;IACH,cAAc,EAAE,gBAAgB,CAAC;CAClC;AAID;;;;;;GAMG;AACH,MAAM,WAAW,oBAAoB;IACnC,8DAA8D;IAC9D,GAAG,EAAE,MAAM,CAAC;IAEZ,0BAA0B;IAC1B,WAAW,EAAE,MAAM,CAAC;IAEpB,2BAA2B;IAC3B,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB,uBAAuB;IACvB,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB,6CAA6C;IAC7C,SAAS,EAAE,oBAAoB,EAAE,CAAC;IAElC;;;;OAIG;IACH,YAAY,CAAC,EAAE,2BAA2B,EAAE,CAAC;IAE7C;;;;;;;;OAQG;IACH,gBAAgB,CAAC,EAAE,MAAM,EAAE,CAAC;CAC7B;AAID;;;;;GAKG;AACH,MAAM,MAAM,eAAe,GAAG,MAAM,CAAC,MAAM,EAAE,oBAAoB,CAAC,CAAC;AAInE;;;GAGG;AACH,MAAM,WAAW,sBAAsB;IACrC,GAAG,EAAE,MAAM,CAAC;IACZ,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB,uDAAuD;IACvD,SAAS,EAAE,GAAG,CAAC,sCAAsC,EAAE,sCAAsC,CAAC,CAAC;IAE/F,gDAAgD;IAChD,eAAe,EAAE,oBAAoB,EAAE,CAAC;IAExC;;;OAGG;IACH,gBAAgB,CAAC,EAAE,MAAM,EAAE,CAAC;CAC7B;AAID;;GAEG;AACH,MAAM,MAAM,gBAAgB,GAAG,GAAG,MAAM,IAAI,sCAAsC,EAAE,CAAC;AAErF;;GAEG;AACH,MAAM,MAAM,kBAAkB,GAAG,GAAG,MAAM,IAAI,sCAAsC,IAAI,MAAM,EAAE,CAAC;AAEjG;;GAEG;AACH,wBAAgB,qBAAqB,CACnC,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,sCAAsC,GACnD,gBAAgB,CAElB;AAED;;GAEG;AACH,wBAAgB,uBAAuB,CACrC,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,sCAAsC,EACpD,MAAM,CAAC,EAAE,MAAM,GACd,kBAAkB,CAEpB"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Lazy Loading Types for External Connectors
|
|
3
|
+
*
|
|
4
|
+
* Enables on-demand loading of provider definitions at:
|
|
5
|
+
* - Protocol level (REST_API, WEBHOOK, LLM, etc.)
|
|
6
|
+
* - Domain level (customers, invoices, etc.)
|
|
7
|
+
*
|
|
8
|
+
* This dramatically reduces memory usage from 1GB+ to ~100KB at startup.
|
|
9
|
+
*/
|
|
10
|
+
/**
|
|
11
|
+
* Build protocol cache key
|
|
12
|
+
*/
|
|
13
|
+
export function buildProtocolCacheKey(providerRef, protocolKind) {
|
|
14
|
+
return `${providerRef}:${protocolKind}`;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Build operations cache key
|
|
18
|
+
*/
|
|
19
|
+
export function buildOperationsCacheKey(providerRef, protocolKind, domain) {
|
|
20
|
+
return `${providerRef}:${protocolKind}:${domain ?? '_all'}`;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=lazy-loading.external-connectors-models.schemas.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lazy-loading.external-connectors-models.schemas.js","sourceRoot":"","sources":["../../../src/core/lazy-loading.external-connectors-models.schemas.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAiJH;;GAEG;AACH,MAAM,UAAU,qBAAqB,CACnC,WAAmB,EACnB,YAAoD;IAEpD,OAAO,GAAG,WAAW,IAAI,YAAY,EAAE,CAAC;AAC1C,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,uBAAuB,CACrC,WAAmB,EACnB,YAAoD,EACpD,MAAe;IAEf,OAAO,GAAG,WAAW,IAAI,YAAY,IAAI,MAAM,IAAI,MAAM,EAAE,CAAC;AAC9D,CAAC"}
|
|
@@ -0,0 +1,125 @@
|
|
|
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 declare enum OAuth2_GrantType {
|
|
17
|
+
/** Authorization Code Grant (RFC 6749 §4.1) - For server-side apps with secure client secrets */
|
|
18
|
+
AUTHORIZATION_CODE = "authorization_code",
|
|
19
|
+
/** Client Credentials Grant (RFC 6749 §4.4) - For machine-to-machine / S2S authentication */
|
|
20
|
+
CLIENT_CREDENTIALS = "client_credentials",
|
|
21
|
+
/** Refresh Token Grant (RFC 6749 §6) - For obtaining new access tokens */
|
|
22
|
+
REFRESH_TOKEN = "refresh_token",
|
|
23
|
+
/** Implicit Grant (RFC 6749 §4.2) - DEPRECATED, use PKCE instead */
|
|
24
|
+
IMPLICIT = "implicit",
|
|
25
|
+
/** Resource Owner Password Credentials (RFC 6749 §4.3) - DEPRECATED */
|
|
26
|
+
PASSWORD = "password",
|
|
27
|
+
/** Device Authorization Grant (RFC 8628) - For input-constrained devices */
|
|
28
|
+
DEVICE_CODE = "urn:ietf:params:oauth:grant-type:device_code",
|
|
29
|
+
/** JWT Bearer Assertion (RFC 7523) - For service accounts */
|
|
30
|
+
JWT_BEARER = "urn:ietf:params:oauth:grant-type:jwt-bearer"
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* OAuth2 Response Types for Authorization Endpoint
|
|
34
|
+
*/
|
|
35
|
+
export declare enum OAuth2_ResponseType {
|
|
36
|
+
CODE = "code",
|
|
37
|
+
TOKEN = "token",
|
|
38
|
+
ID_TOKEN = "id_token",
|
|
39
|
+
CODE_ID_TOKEN = "code id_token",
|
|
40
|
+
CODE_TOKEN = "code token",
|
|
41
|
+
ID_TOKEN_TOKEN = "id_token token",
|
|
42
|
+
CODE_ID_TOKEN_TOKEN = "code id_token token"
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* PKCE Code Challenge Methods (RFC 7636)
|
|
46
|
+
*/
|
|
47
|
+
export declare enum OAuth2_PKCE_Method {
|
|
48
|
+
PLAIN = "plain",
|
|
49
|
+
S256 = "S256"
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Token Endpoint Authentication Methods
|
|
53
|
+
* How credentials are sent to the token endpoint
|
|
54
|
+
*/
|
|
55
|
+
export declare enum OAuth2_TokenEndpoint_AuthMethod {
|
|
56
|
+
/** Credentials in Authorization header as Basic auth */
|
|
57
|
+
CLIENT_SECRET_BASIC = "client_secret_basic",
|
|
58
|
+
/** Credentials in request body */
|
|
59
|
+
CLIENT_SECRET_POST = "client_secret_post",
|
|
60
|
+
/** JWT assertion signed with client secret (HMAC) */
|
|
61
|
+
CLIENT_SECRET_JWT = "client_secret_jwt",
|
|
62
|
+
/** JWT assertion signed with private key (RSA/EC) */
|
|
63
|
+
PRIVATE_KEY_JWT = "private_key_jwt",
|
|
64
|
+
/** No authentication (public clients) */
|
|
65
|
+
NONE = "none"
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* OpenID Connect Prompt Values
|
|
69
|
+
* Controls how the authorization server prompts the user
|
|
70
|
+
*/
|
|
71
|
+
export declare enum OAuth2_Prompt {
|
|
72
|
+
/** No prompt - silent auth only */
|
|
73
|
+
NONE = "none",
|
|
74
|
+
/** Force login even if session exists */
|
|
75
|
+
LOGIN = "login",
|
|
76
|
+
/** Require user consent even if previously granted */
|
|
77
|
+
CONSENT = "consent",
|
|
78
|
+
/** Prompt for account selection */
|
|
79
|
+
SELECT_ACCOUNT = "select_account"
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Access Type - whether to request refresh tokens
|
|
83
|
+
*/
|
|
84
|
+
export declare enum OAuth2_AccessType {
|
|
85
|
+
/** Only access token, no refresh capability */
|
|
86
|
+
ONLINE = "online",
|
|
87
|
+
/** Request refresh token for offline access */
|
|
88
|
+
OFFLINE = "offline"
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* OAuth2 Provider Purpose - what the OAuth2 is used for
|
|
92
|
+
*/
|
|
93
|
+
export declare enum OAuth2_Purpose {
|
|
94
|
+
/** API access only - for making API calls to the provider */
|
|
95
|
+
API_ACCESS = "api_access",
|
|
96
|
+
/** User SSO - for authenticating users into our application */
|
|
97
|
+
USER_SSO = "user_sso",
|
|
98
|
+
/** Both API access and user SSO */
|
|
99
|
+
HYBRID = "hybrid"
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* OAuth2 Token Format - How to format the token for API calls
|
|
103
|
+
*/
|
|
104
|
+
export declare enum OAuth2_TokenFormat {
|
|
105
|
+
/** Authorization: Bearer <token> */
|
|
106
|
+
BEARER = "bearer",
|
|
107
|
+
/** Authorization: token <token> */
|
|
108
|
+
TOKEN = "token",
|
|
109
|
+
/** Authorization: OAuth <token> */
|
|
110
|
+
OAUTH = "oauth",
|
|
111
|
+
/** Custom header specified separately */
|
|
112
|
+
CUSTOM_HEADER = "custom_header",
|
|
113
|
+
/** Token in query parameter */
|
|
114
|
+
QUERY_PARAM = "query_param"
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* OAuth2 Token Location - Where to send the access token
|
|
118
|
+
*/
|
|
119
|
+
export declare enum OAuth2_TokenLocation {
|
|
120
|
+
/** In Authorization header */
|
|
121
|
+
HEADER = "header",
|
|
122
|
+
/** As query parameter */
|
|
123
|
+
QUERY = "query"
|
|
124
|
+
}
|
|
125
|
+
//# sourceMappingURL=oauth2.enums.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"oauth2.enums.d.ts","sourceRoot":"","sources":["../../../src/core/oauth2.enums.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH;;;GAGG;AACH,oBAAY,gBAAgB;IAC1B,iGAAiG;IACjG,kBAAkB,uBAAuB;IAEzC,6FAA6F;IAC7F,kBAAkB,uBAAuB;IAEzC,0EAA0E;IAC1E,aAAa,kBAAkB;IAE/B,oEAAoE;IACpE,QAAQ,aAAa;IAErB,uEAAuE;IACvE,QAAQ,aAAa;IAErB,4EAA4E;IAC5E,WAAW,iDAAiD;IAE5D,6DAA6D;IAC7D,UAAU,gDAAgD;CAC3D;AAED;;GAEG;AACH,oBAAY,mBAAmB;IAC7B,IAAI,SAAS;IACb,KAAK,UAAU;IACf,QAAQ,aAAa;IACrB,aAAa,kBAAkB;IAC/B,UAAU,eAAe;IACzB,cAAc,mBAAmB;IACjC,mBAAmB,wBAAwB;CAC5C;AAED;;GAEG;AACH,oBAAY,kBAAkB;IAC5B,KAAK,UAAU;IACf,IAAI,SAAS;CACd;AAED;;;GAGG;AACH,oBAAY,+BAA+B;IACzC,wDAAwD;IACxD,mBAAmB,wBAAwB;IAE3C,kCAAkC;IAClC,kBAAkB,uBAAuB;IAEzC,qDAAqD;IACrD,iBAAiB,sBAAsB;IAEvC,qDAAqD;IACrD,eAAe,oBAAoB;IAEnC,yCAAyC;IACzC,IAAI,SAAS;CACd;AAED;;;GAGG;AACH,oBAAY,aAAa;IACvB,mCAAmC;IACnC,IAAI,SAAS;IAEb,yCAAyC;IACzC,KAAK,UAAU;IAEf,sDAAsD;IACtD,OAAO,YAAY;IAEnB,mCAAmC;IACnC,cAAc,mBAAmB;CAClC;AAED;;GAEG;AACH,oBAAY,iBAAiB;IAC3B,+CAA+C;IAC/C,MAAM,WAAW;IAEjB,+CAA+C;IAC/C,OAAO,YAAY;CACpB;AAED;;GAEG;AACH,oBAAY,cAAc;IACxB,6DAA6D;IAC7D,UAAU,eAAe;IAEzB,+DAA+D;IAC/D,QAAQ,aAAa;IAErB,mCAAmC;IACnC,MAAM,WAAW;CAClB;AAED;;GAEG;AACH,oBAAY,kBAAkB;IAC5B,oCAAoC;IACpC,MAAM,WAAW;IACjB,mCAAmC;IACnC,KAAK,UAAU;IACf,mCAAmC;IACnC,KAAK,UAAU;IACf,yCAAyC;IACzC,aAAa,kBAAkB;IAC/B,+BAA+B;IAC/B,WAAW,gBAAgB;CAC5B;AAED;;GAEG;AACH,oBAAY,oBAAoB;IAC9B,8BAA8B;IAC9B,MAAM,WAAW;IACjB,yBAAyB;IACzB,KAAK,UAAU;CAChB"}
|