@super-repo/envx-plugins 0.2.3-b.4
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/README.md +380 -0
- package/dist/.tsbuildinfo +1 -0
- package/dist/auto-preload.d.ts +50 -0
- package/dist/auto-preload.d.ts.map +1 -0
- package/dist/auto-preload.js +81 -0
- package/dist/auto-preload.js.map +1 -0
- package/dist/aws.d.ts +52 -0
- package/dist/aws.d.ts.map +1 -0
- package/dist/aws.js +68 -0
- package/dist/aws.js.map +1 -0
- package/dist/azure.d.ts +46 -0
- package/dist/azure.d.ts.map +1 -0
- package/dist/azure.js +64 -0
- package/dist/azure.js.map +1 -0
- package/dist/doppler.d.ts +36 -0
- package/dist/doppler.d.ts.map +1 -0
- package/dist/doppler.js +48 -0
- package/dist/doppler.js.map +1 -0
- package/dist/gcp.d.ts +48 -0
- package/dist/gcp.d.ts.map +1 -0
- package/dist/gcp.js +56 -0
- package/dist/gcp.js.map +1 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +18 -0
- package/dist/index.js.map +1 -0
- package/dist/infisical.d.ts +51 -0
- package/dist/infisical.d.ts.map +1 -0
- package/dist/infisical.js +59 -0
- package/dist/infisical.js.map +1 -0
- package/dist/op.d.ts +52 -0
- package/dist/op.d.ts.map +1 -0
- package/dist/op.js +85 -0
- package/dist/op.js.map +1 -0
- package/dist/runtime.d.ts +95 -0
- package/dist/runtime.d.ts.map +1 -0
- package/dist/runtime.js +124 -0
- package/dist/runtime.js.map +1 -0
- package/dist/types.d.ts +54 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +64 -0
- package/dist/types.js.map +1 -0
- package/dist/vault.d.ts +47 -0
- package/dist/vault.d.ts.map +1 -0
- package/dist/vault.js +63 -0
- package/dist/vault.js.map +1 -0
- package/package.json +79 -0
package/README.md
ADDED
|
@@ -0,0 +1,380 @@
|
|
|
1
|
+
# @super-repo/envx-plugins
|
|
2
|
+
|
|
3
|
+
Secret-provider plugins for [envx](https://www.npmjs.com/package/@super-repo/envx). Each plugin returns a `SecretProvider` you wire into envx's `resolvers:` config so values like `${aws-secrets:my-db}` and `${vault:prod/api}` resolve at load time from the matching backend.
|
|
4
|
+
|
|
5
|
+
```sh
|
|
6
|
+
pnpm add @super-repo/envx-plugins
|
|
7
|
+
```
|
|
8
|
+
|
|
9
|
+
The plugins package itself has zero runtime SDK dependencies. Each plugin lazy-loads its provider's SDK on first use; install only the SDKs you actually need:
|
|
10
|
+
|
|
11
|
+
| provider | install |
|
|
12
|
+
| ------------------ | --------------------------------------------------------------------------- |
|
|
13
|
+
| AWS Secrets Manager | `pnpm add @aws-sdk/client-secrets-manager` |
|
|
14
|
+
| GCP Secret Manager | `pnpm add @google-cloud/secret-manager` |
|
|
15
|
+
| Azure Key Vault | `pnpm add @azure/keyvault-secrets @azure/identity` |
|
|
16
|
+
| HashiCorp Vault | _(no SDK — uses native `fetch`)_ |
|
|
17
|
+
| 1Password (SDK) | `pnpm add @1password/sdk` |
|
|
18
|
+
| 1Password (CLI) | install `op` via [1Password's docs](https://developer.1password.com/docs/cli) |
|
|
19
|
+
| Doppler | _(no SDK — uses native `fetch`)_ |
|
|
20
|
+
| Infisical | _(no SDK — uses native `fetch`)_ |
|
|
21
|
+
|
|
22
|
+
## How it composes with envx
|
|
23
|
+
|
|
24
|
+
envx's `resolvers:` config takes a **synchronous** function (`(id) => string | undefined`). All real secret-store SDKs are async, so plugins split the concern in two:
|
|
25
|
+
|
|
26
|
+
1. **`preload(ids)`** — async batch fetch, populates an in-memory cache.
|
|
27
|
+
2. **`resolve(id)`** — sync cache read. This is what envx calls during load.
|
|
28
|
+
|
|
29
|
+
You call `preload` in your bootstrap (top-level `await` in an async entry, or inside a small `await main()` wrapper), then hand `resolve` to envx. The cache is per-provider-instance — one `awsSecrets({...})` call yields one shared cache.
|
|
30
|
+
|
|
31
|
+
## One-shot example — all 7 providers
|
|
32
|
+
|
|
33
|
+
```ts
|
|
34
|
+
// bootstrap.ts
|
|
35
|
+
import envx from "@super-repo/envx";
|
|
36
|
+
import {
|
|
37
|
+
awsSecrets,
|
|
38
|
+
gcpSecrets,
|
|
39
|
+
azureKeyVault,
|
|
40
|
+
hcVault,
|
|
41
|
+
onePassword,
|
|
42
|
+
doppler,
|
|
43
|
+
infisical,
|
|
44
|
+
autoPreload,
|
|
45
|
+
asResolvers,
|
|
46
|
+
} from "@super-repo/envx-plugins";
|
|
47
|
+
|
|
48
|
+
const aws = awsSecrets({ region: "us-east-1" });
|
|
49
|
+
const gcp = gcpSecrets({ projectId: "acme-prod" });
|
|
50
|
+
const azure = azureKeyVault({ vaultUrl: "https://acme.vault.azure.net" });
|
|
51
|
+
const vault = hcVault({
|
|
52
|
+
endpoint: process.env.VAULT_ADDR!,
|
|
53
|
+
token: process.env.VAULT_TOKEN!,
|
|
54
|
+
});
|
|
55
|
+
const op = onePassword({ token: process.env.OP_SERVICE_ACCOUNT_TOKEN });
|
|
56
|
+
const dop = doppler({ token: process.env.DOPPLER_TOKEN! });
|
|
57
|
+
const inf = infisical({
|
|
58
|
+
token: process.env.INFISICAL_TOKEN!,
|
|
59
|
+
projectId: "proj-1",
|
|
60
|
+
environment: "prod",
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
// One call, per-file scan, parallel resolution.
|
|
64
|
+
await autoPreload([aws, gcp, azure, vault, op, dop, inf], {
|
|
65
|
+
envFiles: [".env", "vault/.env.prod"],
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
envx({
|
|
69
|
+
// `asResolvers([...])` builds the { name → resolve } map for you.
|
|
70
|
+
resolvers: asResolvers([aws, gcp, azure, vault, op, dop, inf]),
|
|
71
|
+
});
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
In your `.env*` files:
|
|
75
|
+
|
|
76
|
+
```
|
|
77
|
+
DATABASE_URL=${aws-secrets:prod/db}
|
|
78
|
+
CACHE_URL=${gcp-secrets:cache-host}
|
|
79
|
+
JWT_SECRET=${azure-keyvault:prod-jwt-signing@v3}
|
|
80
|
+
ROOT_TOKEN=${vault:prod/admin#token}
|
|
81
|
+
GITHUB_PAT=${op:op://prod/GitHub/personal-access-token}
|
|
82
|
+
SENDGRID_KEY=${doppler:SENDGRID_KEY}
|
|
83
|
+
STRIPE_KEY=${infisical:STRIPE_LIVE_KEY}
|
|
84
|
+
```
|
|
85
|
+
|
|
86
|
+
Only the providers actually referenced in those files get pre-loaded — `autoPreload` scans the files first and skips providers with zero hits.
|
|
87
|
+
|
|
88
|
+
## Per-provider usage
|
|
89
|
+
|
|
90
|
+
### AWS Secrets Manager
|
|
91
|
+
|
|
92
|
+
```ts
|
|
93
|
+
import { awsSecrets } from "@super-repo/envx-plugins/aws";
|
|
94
|
+
|
|
95
|
+
const aws = awsSecrets({ region: "us-east-1" });
|
|
96
|
+
await aws.preload(["prod/db", "prod/api-key"]);
|
|
97
|
+
```
|
|
98
|
+
|
|
99
|
+
```
|
|
100
|
+
DATABASE_URL=${aws-secrets:prod/db}
|
|
101
|
+
API_KEY=${aws-secrets:prod/api-key}
|
|
102
|
+
```
|
|
103
|
+
|
|
104
|
+
Multiple regions? Give each its own provider name and reference accordingly:
|
|
105
|
+
|
|
106
|
+
```ts
|
|
107
|
+
const awsUs = awsSecrets({ region: "us-east-1", name: "aws-us" });
|
|
108
|
+
const awsEu = awsSecrets({ region: "eu-west-1", name: "aws-eu" });
|
|
109
|
+
```
|
|
110
|
+
|
|
111
|
+
```
|
|
112
|
+
DB_US=${aws-us:prod/db}
|
|
113
|
+
DB_EU=${aws-eu:prod/db}
|
|
114
|
+
```
|
|
115
|
+
|
|
116
|
+
### GCP Secret Manager
|
|
117
|
+
|
|
118
|
+
```ts
|
|
119
|
+
import { gcpSecrets } from "@super-repo/envx-plugins/gcp";
|
|
120
|
+
|
|
121
|
+
const gcp = gcpSecrets({ projectId: "acme-prod" });
|
|
122
|
+
await gcp.preload(["prod-db", "prod-api"]);
|
|
123
|
+
```
|
|
124
|
+
|
|
125
|
+
```
|
|
126
|
+
DB_URL=${gcp-secrets:prod-db}
|
|
127
|
+
API_KEY=${gcp-secrets:prod-api@3} # pin to version 3
|
|
128
|
+
```
|
|
129
|
+
|
|
130
|
+
### Azure Key Vault
|
|
131
|
+
|
|
132
|
+
```ts
|
|
133
|
+
import { azureKeyVault } from "@super-repo/envx-plugins/azure";
|
|
134
|
+
|
|
135
|
+
const az = azureKeyVault({
|
|
136
|
+
vaultUrl: "https://my-vault.vault.azure.net",
|
|
137
|
+
});
|
|
138
|
+
await az.preload(["prod-db", "prod-jwt-signing"]);
|
|
139
|
+
```
|
|
140
|
+
|
|
141
|
+
```
|
|
142
|
+
DB_URL=${azure-keyvault:prod-db}
|
|
143
|
+
JWT_SECRET=${azure-keyvault:prod-jwt-signing@<version>}
|
|
144
|
+
```
|
|
145
|
+
|
|
146
|
+
Credentials come from `DefaultAzureCredential` by default (env vars → managed identity → Azure CLI → VS Code, in that order). Pass `credential:` to override.
|
|
147
|
+
|
|
148
|
+
### HashiCorp Vault (KV v1 / v2)
|
|
149
|
+
|
|
150
|
+
```ts
|
|
151
|
+
import { hcVault } from "@super-repo/envx-plugins/vault";
|
|
152
|
+
|
|
153
|
+
const vault = hcVault({
|
|
154
|
+
endpoint: process.env.VAULT_ADDR!,
|
|
155
|
+
token: process.env.VAULT_TOKEN!,
|
|
156
|
+
mount: "secret",
|
|
157
|
+
});
|
|
158
|
+
await vault.preload(["prod/db", "prod/api"]);
|
|
159
|
+
```
|
|
160
|
+
|
|
161
|
+
```
|
|
162
|
+
DB_URL=${vault:prod/db} # reads `data.value` field by default
|
|
163
|
+
USERNAME=${vault:prod/db#username} # specific JSON field
|
|
164
|
+
```
|
|
165
|
+
|
|
166
|
+
KV v1? Pass `kvVersion: 1`.
|
|
167
|
+
|
|
168
|
+
### 1Password — CLI mode (developer machines)
|
|
169
|
+
|
|
170
|
+
If `op` is signed in on your machine, no token / SDK is required:
|
|
171
|
+
|
|
172
|
+
```ts
|
|
173
|
+
import { onePassword } from "@super-repo/envx-plugins/op";
|
|
174
|
+
|
|
175
|
+
const op = onePassword();
|
|
176
|
+
await op.preload([
|
|
177
|
+
"op://prod/Database/url",
|
|
178
|
+
"op://prod/API/key",
|
|
179
|
+
]);
|
|
180
|
+
```
|
|
181
|
+
|
|
182
|
+
```
|
|
183
|
+
DB_URL=${op:op://prod/Database/url}
|
|
184
|
+
API_KEY=${op:op://prod/API/key}
|
|
185
|
+
```
|
|
186
|
+
|
|
187
|
+
### 1Password — SDK mode (CI / containers)
|
|
188
|
+
|
|
189
|
+
Use a service-account token in environments without an interactive `op signin`:
|
|
190
|
+
|
|
191
|
+
```ts
|
|
192
|
+
const op = onePassword({
|
|
193
|
+
token: process.env.OP_SERVICE_ACCOUNT_TOKEN!,
|
|
194
|
+
});
|
|
195
|
+
```
|
|
196
|
+
|
|
197
|
+
The plugin lazy-loads `@1password/sdk` only in this mode.
|
|
198
|
+
|
|
199
|
+
### Doppler
|
|
200
|
+
|
|
201
|
+
```ts
|
|
202
|
+
import { doppler } from "@super-repo/envx-plugins/doppler";
|
|
203
|
+
|
|
204
|
+
const dop = doppler({ token: process.env.DOPPLER_TOKEN! });
|
|
205
|
+
await dop.preload(["DATABASE_URL", "API_KEY"]);
|
|
206
|
+
```
|
|
207
|
+
|
|
208
|
+
```
|
|
209
|
+
DATABASE_URL=${doppler:DATABASE_URL}
|
|
210
|
+
API_KEY=${doppler:API_KEY}
|
|
211
|
+
```
|
|
212
|
+
|
|
213
|
+
Service tokens scope to one project + config, so you typically don't pass project/config explicitly.
|
|
214
|
+
|
|
215
|
+
### Infisical
|
|
216
|
+
|
|
217
|
+
```ts
|
|
218
|
+
import { infisical } from "@super-repo/envx-plugins/infisical";
|
|
219
|
+
|
|
220
|
+
const inf = infisical({
|
|
221
|
+
token: process.env.INFISICAL_TOKEN!,
|
|
222
|
+
projectId: "proj-1",
|
|
223
|
+
environment: "prod",
|
|
224
|
+
secretPath: "/services/api", // optional
|
|
225
|
+
});
|
|
226
|
+
await inf.preload(["DATABASE_URL", "API_KEY"]);
|
|
227
|
+
```
|
|
228
|
+
|
|
229
|
+
```
|
|
230
|
+
DATABASE_URL=${infisical:DATABASE_URL}
|
|
231
|
+
API_KEY=${infisical:API_KEY}
|
|
232
|
+
```
|
|
233
|
+
|
|
234
|
+
Self-hosted? Pass `endpoint: "https://infisical.example.com"`.
|
|
235
|
+
|
|
236
|
+
## Runtime / edge — secrets that never leave the source
|
|
237
|
+
|
|
238
|
+
For the "secrets never touch disk, fetched on demand" model, use `createSecretRuntime` from the `/runtime` subpath. Async-first, TTL-cached, V8-isolate-safe — works in Cloudflare Workers, Vercel Edge, Deno Deploy, AWS Lambda, Bun, Node.
|
|
239
|
+
|
|
240
|
+
```ts
|
|
241
|
+
// src/secrets.ts — module-level singleton, one instance per worker / process
|
|
242
|
+
import { createSecretRuntime } from "@super-repo/envx-plugins/runtime";
|
|
243
|
+
import { hcVault } from "@super-repo/envx-plugins/vault";
|
|
244
|
+
|
|
245
|
+
export const secrets = createSecretRuntime({
|
|
246
|
+
providers: [
|
|
247
|
+
hcVault({
|
|
248
|
+
endpoint: env.VAULT_ADDR,
|
|
249
|
+
token: env.VAULT_TOKEN,
|
|
250
|
+
}),
|
|
251
|
+
],
|
|
252
|
+
ttl: 300, // refresh after 5 min
|
|
253
|
+
onFailure: "cache-stale", // serve stale on transient backend failures
|
|
254
|
+
});
|
|
255
|
+
```
|
|
256
|
+
|
|
257
|
+
```ts
|
|
258
|
+
// Cloudflare Worker, Vercel Edge, Lambda, Deno Deploy — same handler shape
|
|
259
|
+
import { secrets } from "./secrets";
|
|
260
|
+
|
|
261
|
+
export default async function handler(req: Request): Promise<Response> {
|
|
262
|
+
const dbUrl = await secrets.get("vault:prod/db");
|
|
263
|
+
const apiKey = await secrets.get("vault:prod/api");
|
|
264
|
+
return new Response(JSON.stringify({ dbUrl, apiKey }));
|
|
265
|
+
}
|
|
266
|
+
```
|
|
267
|
+
|
|
268
|
+
### Behavior
|
|
269
|
+
|
|
270
|
+
- **Lazy fetch** — first read triggers the network call. Subsequent reads inside the TTL window hit the in-memory cache.
|
|
271
|
+
- **Single-flight** — N concurrent reads of the same ref coalesce to one fetch. Edge functions handling a request burst don't fan out N parallel calls to your secret store.
|
|
272
|
+
- **TTL refresh** — values older than `ttl` seconds are refetched on next read.
|
|
273
|
+
- **Failure modes** — `"throw"` (default), `"cache-stale"` (serve previous value, log warn), `"cache-error"` (cache the failure for `errorTtl` seconds so a flaky backend doesn't get hammered).
|
|
274
|
+
- **No fs / child_process imports** — the runtime entry is V8-isolate-safe.
|
|
275
|
+
|
|
276
|
+
### API
|
|
277
|
+
|
|
278
|
+
```ts
|
|
279
|
+
interface SecretRuntime {
|
|
280
|
+
get(ref: string): Promise<string>; // throws on miss / unknown provider / failed fetch
|
|
281
|
+
tryGet(ref: string): Promise<string | undefined>; // never throws
|
|
282
|
+
invalidate(ref: string): Promise<string>; // force-refresh a specific ref
|
|
283
|
+
clear(): void; // drop all cached entries
|
|
284
|
+
readonly stats: () => { cached: number; inflight: number; errors: number };
|
|
285
|
+
}
|
|
286
|
+
|
|
287
|
+
interface SecretRuntimeOptions {
|
|
288
|
+
readonly providers: readonly SecretProvider[];
|
|
289
|
+
readonly ttl?: number; // default 300 (5min). 0 = no cache. Infinity = forever.
|
|
290
|
+
readonly onFailure?: "throw" | "cache-stale" | "cache-error";
|
|
291
|
+
readonly errorTtl?: number; // for "cache-error" mode. default 30
|
|
292
|
+
readonly logger?: { warn(msg: string): void };
|
|
293
|
+
}
|
|
294
|
+
```
|
|
295
|
+
|
|
296
|
+
### Edge-runtime compatibility per provider
|
|
297
|
+
|
|
298
|
+
| provider | Cloudflare Workers / Vercel Edge / Deno | Lambda / Cloud Run / Node | reason |
|
|
299
|
+
| --------------------- | --------------------------------------- | ------------------------- | ---------------------------- |
|
|
300
|
+
| `hcVault` | ✓ | ✓ | native `fetch` |
|
|
301
|
+
| `doppler` | ✓ | ✓ | native `fetch` |
|
|
302
|
+
| `infisical` | ✓ | ✓ | native `fetch` |
|
|
303
|
+
| `awsSecrets` | ⚠ | ✓ | Node streams in the SDK |
|
|
304
|
+
| `gcpSecrets` | ⚠ | ✓ | gRPC in the SDK |
|
|
305
|
+
| `azureKeyVault` | ⚠ | ✓ | `@azure/identity` token chain |
|
|
306
|
+
| `onePassword` (CLI) | ✗ | ✓ (with `op` on PATH) | spawns a child process |
|
|
307
|
+
| `onePassword` (SDK) | depends on `@1password/sdk` | ✓ | SDK's own constraints |
|
|
308
|
+
| custom `buildProvider`| depends on what your fetcher does | ✓ | usually fine if you use `fetch` |
|
|
309
|
+
|
|
310
|
+
For maximum portability across edges, prefer Vault / Doppler / Infisical, or write your own provider with `buildProvider`:
|
|
311
|
+
|
|
312
|
+
```ts
|
|
313
|
+
import { buildProvider } from "@super-repo/envx-plugins";
|
|
314
|
+
|
|
315
|
+
const myProvider = buildProvider("internal", async (id) => {
|
|
316
|
+
const r = await fetch(`https://internal.example.com/secrets/${id}`, {
|
|
317
|
+
headers: { Authorization: `Bearer ${env.MY_TOKEN}` },
|
|
318
|
+
});
|
|
319
|
+
return (await r.json()).value;
|
|
320
|
+
});
|
|
321
|
+
```
|
|
322
|
+
|
|
323
|
+
That single-file plugin works in every JS runtime that has `fetch`.
|
|
324
|
+
|
|
325
|
+
## Custom providers
|
|
326
|
+
|
|
327
|
+
The same `SecretProvider` shape works for any backend — wrap it with `buildProvider`:
|
|
328
|
+
|
|
329
|
+
```ts
|
|
330
|
+
import { buildProvider, type SecretProvider } from "@super-repo/envx-plugins";
|
|
331
|
+
|
|
332
|
+
const myProvider: SecretProvider = buildProvider("my-backend", async (id) => {
|
|
333
|
+
const r = await fetch(`https://internal.example.com/secrets/${id}`, {
|
|
334
|
+
headers: { Authorization: `Bearer ${process.env.MY_TOKEN}` },
|
|
335
|
+
});
|
|
336
|
+
if (!r.ok) throw new Error(`fetch ${id}: ${r.status}`);
|
|
337
|
+
const body = await r.json() as { value: string };
|
|
338
|
+
return body.value;
|
|
339
|
+
});
|
|
340
|
+
|
|
341
|
+
await myProvider.preload(["a", "b"]);
|
|
342
|
+
envx({ resolvers: { [myProvider.name]: myProvider.resolve } });
|
|
343
|
+
```
|
|
344
|
+
|
|
345
|
+
```
|
|
346
|
+
SOMETHING=${my-backend:a}
|
|
347
|
+
ELSE=${my-backend:b}
|
|
348
|
+
```
|
|
349
|
+
|
|
350
|
+
## API
|
|
351
|
+
|
|
352
|
+
```ts
|
|
353
|
+
interface SecretProvider {
|
|
354
|
+
readonly name: string;
|
|
355
|
+
preload(ids: readonly string[]): Promise<void>; // batch fetch + cache
|
|
356
|
+
fetch(id: string): Promise<string>; // single fetch, bypasses cache (for runtime use)
|
|
357
|
+
resolve(id: string): string | undefined; // sync cache read (for envx resolvers)
|
|
358
|
+
readonly cache: ReadonlyMap<string, string>;
|
|
359
|
+
}
|
|
360
|
+
|
|
361
|
+
function autoPreload(
|
|
362
|
+
providers: readonly SecretProvider[],
|
|
363
|
+
opts: { envFiles: string[]; cwd?: string },
|
|
364
|
+
): Promise<{ preloaded: Record<string, string[]> }>;
|
|
365
|
+
|
|
366
|
+
function asResolvers(
|
|
367
|
+
providers: readonly SecretProvider[],
|
|
368
|
+
): Record<string, (id: string) => string | undefined>;
|
|
369
|
+
|
|
370
|
+
function buildProvider(
|
|
371
|
+
name: string,
|
|
372
|
+
fetchOne: (id: string) => Promise<string>,
|
|
373
|
+
): SecretProvider;
|
|
374
|
+
|
|
375
|
+
class MissingSdkError extends Error { /* … */ }
|
|
376
|
+
```
|
|
377
|
+
|
|
378
|
+
## License
|
|
379
|
+
|
|
380
|
+
MIT
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"fileNames":["../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es5.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2015.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2016.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2017.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2018.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2019.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2020.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2021.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2022.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2023.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2024.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2025.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.esnext.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2015.core.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2015.collection.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2015.generator.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2015.iterable.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2015.promise.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2015.proxy.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2015.reflect.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2015.symbol.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2015.symbol.wellknown.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2016.array.include.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2016.intl.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2017.arraybuffer.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2017.date.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2017.object.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2017.sharedmemory.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2017.string.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2017.intl.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2017.typedarrays.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2018.asyncgenerator.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2018.asynciterable.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2018.intl.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2018.promise.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2018.regexp.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2019.array.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2019.object.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2019.string.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2019.symbol.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2019.intl.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2020.bigint.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2020.date.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2020.promise.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2020.sharedmemory.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2020.string.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2020.symbol.wellknown.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2020.intl.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2020.number.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2021.promise.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2021.string.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2021.weakref.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2021.intl.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2022.array.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2022.error.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2022.intl.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2022.object.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2022.string.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2022.regexp.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2023.array.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2023.collection.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2023.intl.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2024.arraybuffer.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2024.collection.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2024.object.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2024.promise.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2024.regexp.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2024.sharedmemory.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2024.string.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2025.collection.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2025.float16.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2025.intl.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2025.iterator.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2025.promise.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.es2025.regexp.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.esnext.array.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.esnext.collection.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.esnext.date.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.esnext.decorators.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.esnext.disposable.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.esnext.error.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.esnext.intl.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.esnext.sharedmemory.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.esnext.temporal.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.esnext.typedarrays.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.decorators.d.ts","../../../../node_modules/.pnpm/typescript@6.0.3/node_modules/typescript/lib/lib.decorators.legacy.d.ts","../src/types.ts","../src/auto-preload.ts","../src/aws.ts","../src/azure.ts","../src/doppler.ts","../src/gcp.ts","../src/runtime.ts","../src/vault.ts","../src/op.ts","../src/infisical.ts","../src/index.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/compatibility/disposable.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/compatibility/indexable.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/compatibility/iterators.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/compatibility/index.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/globals.typedarray.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/buffer.buffer.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/globals.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/web-globals/abortcontroller.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/web-globals/domexception.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/web-globals/events.d.ts","../../../../node_modules/.pnpm/buffer@5.7.1/node_modules/buffer/index.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/header.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/readable.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/file.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/fetch.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/formdata.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/connector.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/client.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/errors.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/dispatcher.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/global-dispatcher.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/global-origin.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/pool-stats.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/pool.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/handlers.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/balanced-pool.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/agent.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-interceptor.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-agent.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-client.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-pool.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-errors.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/proxy-agent.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/env-http-proxy-agent.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/retry-handler.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/retry-agent.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/api.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/interceptors.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/util.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/cookies.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/patch.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/websocket.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/eventsource.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/filereader.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/diagnostics-channel.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/content-type.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/cache.d.ts","../../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/index.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/web-globals/fetch.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/web-globals/navigator.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/web-globals/storage.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/assert.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/assert/strict.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/async_hooks.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/buffer.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/child_process.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/cluster.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/console.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/constants.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/crypto.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/dgram.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/diagnostics_channel.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/dns.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/dns/promises.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/domain.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/events.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/fs.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/fs/promises.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/http.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/http2.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/https.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/inspector.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/inspector.generated.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/module.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/net.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/os.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/path.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/perf_hooks.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/process.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/punycode.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/querystring.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/readline.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/readline/promises.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/repl.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/sea.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/sqlite.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/stream.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/stream/promises.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/stream/consumers.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/stream/web.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/string_decoder.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/test.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/timers.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/timers/promises.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/tls.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/trace_events.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/tty.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/url.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/util.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/v8.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/vm.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/wasi.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/worker_threads.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/zlib.d.ts","../../../../node_modules/.pnpm/@types+node@22.19.17/node_modules/@types/node/index.d.ts"],"fileIdsList":[[104,150,151,153,170,171],[104,152,153,170,171],[153,170,171],[104,153,158,170,171,188],[104,153,154,159,164,170,171,173,185,196],[104,153,154,155,164,170,171,173],[104,153,170,171],[99,100,101,104,153,170,171],[104,153,156,170,171,197],[104,153,157,158,165,170,171,174],[104,153,158,170,171,185,193],[104,153,159,161,164,170,171,173],[104,152,153,160,170,171],[104,153,161,162,170,171],[104,153,163,164,170,171],[104,152,153,164,170,171],[104,153,164,165,166,170,171,185,196],[104,153,164,165,166,170,171,180,185,188],[104,146,153,161,164,167,170,171,173,185,196],[104,153,164,165,167,168,170,171,173,185,193,196],[104,153,167,169,170,171,185,193,196],[102,103,104,105,106,107,108,147,148,149,150,151,152,153,154,155,156,157,158,159,160,161,162,163,164,165,166,167,168,169,170,171,172,173,174,175,176,177,178,179,180,181,182,183,184,185,186,187,188,189,190,191,192,193,194,195,196,197,198,199,200,201,202],[104,153,164,170,171],[104,153,170,171,172,196],[104,153,161,164,170,171,173,185],[104,153,170,171,174],[104,153,170,171,175],[104,152,153,170,171,176],[104,150,151,152,153,154,155,156,157,158,159,160,161,162,163,164,165,166,167,168,169,170,171,172,173,174,175,176,177,178,179,180,181,182,183,184,185,186,187,188,189,190,191,192,193,194,195,196,197,198,199,200,201,202],[104,153,170,171,178],[104,153,170,171,179],[104,153,164,170,171,180,181],[104,153,170,171,180,182,197,199],[104,153,165,170,171],[104,153,164,170,171,185,186,188],[104,153,170,171,187,188],[104,153,170,171,185,186],[104,153,170,171,188],[104,153,170,171,189],[104,150,153,170,171,185,190,196],[104,153,164,170,171,191,192],[104,153,170,171,191,192],[104,153,158,170,171,173,185,193],[104,153,170,171,194],[104,153,170,171,173,195],[104,153,167,170,171,179,196],[104,153,158,170,171,197],[104,153,170,171,185,198],[104,153,170,171,172,199],[104,153,170,171,200],[104,146,153,170,171],[104,146,153,164,166,170,171,176,185,188,196,198,199,201],[104,153,170,171,185,202],[104,118,122,153,170,171,196],[104,118,153,170,171,185,196],[104,113,153,170,171],[104,115,118,153,170,171,193,196],[104,153,170,171,173,193],[104,153,170,171,203],[104,113,153,170,171,203],[104,115,118,153,170,171,173,196],[104,110,111,114,117,153,164,170,171,185,196],[104,118,125,153,170,171],[104,110,116,153,170,171],[104,118,139,140,153,170,171],[104,114,118,153,170,171,188,196,203],[104,139,153,170,171,203],[104,112,113,153,170,171,203],[104,118,153,170,171],[104,112,113,114,115,116,117,118,119,120,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,140,141,142,143,144,145,153,170,171],[104,118,133,153,170,171],[104,118,125,126,153,170,171],[104,116,118,126,127,153,170,171],[104,117,153,170,171],[104,110,113,118,153,170,171],[104,118,122,126,127,153,170,171],[104,122,153,170,171],[104,116,118,121,153,170,171,196],[104,110,115,118,125,153,170,171],[104,153,170,171,185],[104,113,118,139,153,170,171,201,203],[88,104,153,165,170,171,175],[88,104,153,170,171],[88,89,90,91,92,93,94,95,96,97,104,153,170,171],[88,104,153,154,170,171,197]],"fileInfos":[{"version":"bcd24271a113971ba9eb71ff8cb01bc6b0f872a85c23fdbe5d93065b375933cd","affectsGlobalScope":true,"impliedFormat":1},{"version":"3f88bedbeb09c6f5a6645cb24c7c55f1aa22d19ae96c8e6959cbd8b85a707bc6","impliedFormat":1},{"version":"7fe93b39b810eadd916be8db880dd7f0f7012a5cc6ffb62de8f62a2117fa6f1f","impliedFormat":1},{"version":"bb0074cc08b84a2374af33d8bf044b80851ccc9e719a5e202eacf40db2c31600","impliedFormat":1},{"version":"1a7daebe4f45fb03d9ec53d60008fbf9ac45a697fdc89e4ce218bc94b94f94d6","impliedFormat":1},{"version":"f94b133a3cb14a288803be545ac2683e0d0ff6661bcd37e31aaaec54fc382aed","impliedFormat":1},{"version":"f59d0650799f8782fd74cf73c19223730c6d1b9198671b1c5b3a38e1188b5953","impliedFormat":1},{"version":"8a15b4607d9a499e2dbeed9ec0d3c0d7372c850b2d5f1fb259e8f6d41d468a84","impliedFormat":1},{"version":"26e0fe14baee4e127f4365d1ae0b276f400562e45e19e35fd2d4c296684715e6","impliedFormat":1},{"version":"1e9332c23e9a907175e0ffc6a49e236f97b48838cc8aec9ce7e4cec21e544b65","impliedFormat":1},{"version":"3753fbc1113dc511214802a2342280a8b284ab9094f6420e7aa171e868679f91","impliedFormat":1},{"version":"999ca32883495a866aa5737fe1babc764a469e4cde6ee6b136a4b9ae68853e4b","impliedFormat":1},{"version":"17f13ecb98cbc39243f2eee1f16d45cd8ec4706b03ee314f1915f1a8b42f6984","impliedFormat":1},{"version":"eadcffda2aa84802c73938e589b9e58248d74c59cb7fcbca6474e3435ac15504","affectsGlobalScope":true,"impliedFormat":1},{"version":"105ba8ff7ba746404fe1a2e189d1d3d2e0eb29a08c18dded791af02f29fb4711","affectsGlobalScope":true,"impliedFormat":1},{"version":"00343ca5b2e3d48fa5df1db6e32ea2a59afab09590274a6cccb1dbae82e60c7c","affectsGlobalScope":true,"impliedFormat":1},{"version":"ebd9f816d4002697cb2864bea1f0b70a103124e18a8cd9645eeccc09bdf80ab4","affectsGlobalScope":true,"impliedFormat":1},{"version":"2c1afac30a01772cd2a9a298a7ce7706b5892e447bb46bdbeef720f7b5da77ad","affectsGlobalScope":true,"impliedFormat":1},{"version":"7b0225f483e4fa685625ebe43dd584bb7973bbd84e66a6ba7bbe175ee1048b4f","affectsGlobalScope":true,"impliedFormat":1},{"version":"c0a4b8ac6ce74679c1da2b3795296f5896e31c38e888469a8e0f99dc3305de60","affectsGlobalScope":true,"impliedFormat":1},{"version":"3084a7b5f569088e0146533a00830e206565de65cae2239509168b11434cd84f","affectsGlobalScope":true,"impliedFormat":1},{"version":"c5079c53f0f141a0698faa903e76cb41cd664e3efb01cc17a5c46ec2eb0bef42","affectsGlobalScope":true,"impliedFormat":1},{"version":"32cafbc484dea6b0ab62cf8473182bbcb23020d70845b406f80b7526f38ae862","affectsGlobalScope":true,"impliedFormat":1},{"version":"fca4cdcb6d6c5ef18a869003d02c9f0fd95df8cfaf6eb431cd3376bc034cad36","affectsGlobalScope":true,"impliedFormat":1},{"version":"b93ec88115de9a9dc1b602291b85baf825c85666bf25985cc5f698073892b467","affectsGlobalScope":true,"impliedFormat":1},{"version":"f5c06dcc3fe849fcb297c247865a161f995cc29de7aa823afdd75aaaddc1419b","affectsGlobalScope":true,"impliedFormat":1},{"version":"b77e16112127a4b169ef0b8c3a4d730edf459c5f25fe52d5e436a6919206c4d7","affectsGlobalScope":true,"impliedFormat":1},{"version":"fbffd9337146eff822c7c00acbb78b01ea7ea23987f6c961eba689349e744f8c","affectsGlobalScope":true,"impliedFormat":1},{"version":"a995c0e49b721312f74fdfb89e4ba29bd9824c770bbb4021d74d2bf560e4c6bd","affectsGlobalScope":true,"impliedFormat":1},{"version":"c7b3542146734342e440a84b213384bfa188835537ddbda50d30766f0593aff9","affectsGlobalScope":true,"impliedFormat":1},{"version":"ce6180fa19b1cccd07ee7f7dbb9a367ac19c0ed160573e4686425060b6df7f57","affectsGlobalScope":true,"impliedFormat":1},{"version":"3f02e2476bccb9dbe21280d6090f0df17d2f66b74711489415a8aa4df73c9675","affectsGlobalScope":true,"impliedFormat":1},{"version":"45e3ab34c1c013c8ab2dc1ba4c80c780744b13b5676800ae2e3be27ae862c40c","affectsGlobalScope":true,"impliedFormat":1},{"version":"805c86f6cca8d7702a62a844856dbaa2a3fd2abef0536e65d48732441dde5b5b","affectsGlobalScope":true,"impliedFormat":1},{"version":"e42e397f1a5a77994f0185fd1466520691456c772d06bf843e5084ceb879a0ad","affectsGlobalScope":true,"impliedFormat":1},{"version":"f4c2b41f90c95b1c532ecc874bd3c111865793b23aebcc1c3cbbabcd5d76ffb0","affectsGlobalScope":true,"impliedFormat":1},{"version":"ab26191cfad5b66afa11b8bf935ef1cd88fabfcb28d30b2dfa6fad877d050332","affectsGlobalScope":true,"impliedFormat":1},{"version":"2088bc26531e38fb05eedac2951480db5309f6be3fa4a08d2221abb0f5b4200d","affectsGlobalScope":true,"impliedFormat":1},{"version":"cb9d366c425fea79716a8fb3af0d78e6b22ebbab3bd64d25063b42dc9f531c1e","affectsGlobalScope":true,"impliedFormat":1},{"version":"500934a8089c26d57ebdb688fc9757389bb6207a3c8f0674d68efa900d2abb34","affectsGlobalScope":true,"impliedFormat":1},{"version":"689da16f46e647cef0d64b0def88910e818a5877ca5379ede156ca3afb780ac3","affectsGlobalScope":true,"impliedFormat":1},{"version":"bc21cc8b6fee4f4c2440d08035b7ea3c06b3511314c8bab6bef7a92de58a2593","affectsGlobalScope":true,"impliedFormat":1},{"version":"7ca53d13d2957003abb47922a71866ba7cb2068f8d154877c596d63c359fed25","affectsGlobalScope":true,"impliedFormat":1},{"version":"54725f8c4df3d900cb4dac84b64689ce29548da0b4e9b7c2de61d41c79293611","affectsGlobalScope":true,"impliedFormat":1},{"version":"e5594bc3076ac29e6c1ebda77939bc4c8833de72f654b6e376862c0473199323","affectsGlobalScope":true,"impliedFormat":1},{"version":"2f3eb332c2d73e729f3364fcc0c2b375e72a121e8157d25a82d67a138c83a95c","affectsGlobalScope":true,"impliedFormat":1},{"version":"6f4427f9642ce8d500970e4e69d1397f64072ab73b97e476b4002a646ac743b1","affectsGlobalScope":true,"impliedFormat":1},{"version":"48915f327cd1dea4d7bd358d9dc7732f58f9e1626a29cc0c05c8c692419d9bb7","affectsGlobalScope":true,"impliedFormat":1},{"version":"b7bf9377723203b5a6a4b920164df22d56a43f593269ba6ae1fdc97774b68855","affectsGlobalScope":true,"impliedFormat":1},{"version":"db9709688f82c9e5f65a119c64d835f906efe5f559d08b11642d56eb85b79357","affectsGlobalScope":true,"impliedFormat":1},{"version":"4b25b8c874acd1a4cf8444c3617e037d444d19080ac9f634b405583fd10ce1f7","affectsGlobalScope":true,"impliedFormat":1},{"version":"37be57d7c90cf1f8112ee2636a068d8fd181289f82b744160ec56a7dc158a9f5","affectsGlobalScope":true,"impliedFormat":1},{"version":"a917a49ac94cd26b754ab84e113369a75d1a47a710661d7cd25e961cc797065f","affectsGlobalScope":true,"impliedFormat":1},{"version":"6d3261badeb7843d157ef3e6f5d1427d0eeb0af0cf9df84a62cfd29fd47ac86e","affectsGlobalScope":true,"impliedFormat":1},{"version":"195daca651dde22f2167ac0d0a05e215308119a3100f5e6268e8317d05a92526","affectsGlobalScope":true,"impliedFormat":1},{"version":"8b11e4285cd2bb164a4dc09248bdec69e9842517db4ca47c1ba913011e44ff2f","affectsGlobalScope":true,"impliedFormat":1},{"version":"0508571a52475e245b02bc50fa1394065a0a3d05277fbf5120c3784b85651799","affectsGlobalScope":true,"impliedFormat":1},{"version":"8f9af488f510c3015af3cc8c267a9e9d96c4dd38a1fdff0e11dc5a544711415b","affectsGlobalScope":true,"impliedFormat":1},{"version":"fc611fea8d30ea72c6bbfb599c9b4d393ce22e2f5bfef2172534781e7d138104","affectsGlobalScope":true,"impliedFormat":1},{"version":"0bd714129fca875f7d4c477a1a392200b0bcd13fb2e80928cd334b63830ea047","affectsGlobalScope":true,"impliedFormat":1},{"version":"e2c9037ae6cd2c52d80ceef0b3c5ffdb488627d71529cf4f63776daf11161c9a","affectsGlobalScope":true,"impliedFormat":1},{"version":"135d5cf4d345f59f1a9caadfafcd858d3d9cc68290db616cc85797224448cccc","affectsGlobalScope":true,"impliedFormat":1},{"version":"bc238c3f81c2984751932b6aab223cd5b830e0ac6cad76389e5e9d2ffc03287d","affectsGlobalScope":true,"impliedFormat":1},{"version":"4a07f9b76d361f572620927e5735b77d6d2101c23cdd94383eb5b706e7b36357","affectsGlobalScope":true,"impliedFormat":1},{"version":"7c4e8dc6ab834cc6baa0227e030606d29e3e8449a9f67cdf5605ea5493c4db29","affectsGlobalScope":true,"impliedFormat":1},{"version":"de7ba0fd02e06cd9a5bd4ab441ed0e122735786e67dde1e849cced1cd8b46b78","affectsGlobalScope":true,"impliedFormat":1},{"version":"6148e4e88d720a06855071c3db02069434142a8332cf9c182cda551adedf3156","affectsGlobalScope":true,"impliedFormat":1},{"version":"d63dba625b108316a40c95a4425f8d4294e0deeccfd6c7e59d819efa19e23409","affectsGlobalScope":true,"impliedFormat":1},{"version":"0568d6befee03dd435bed4fc25c4e46865b24bdcb8c563fdc21f580a2c301904","affectsGlobalScope":true,"impliedFormat":1},{"version":"30d62269b05b584741f19a5369852d5d34895aa2ac4fd948956f886d15f9cc0d","affectsGlobalScope":true,"impliedFormat":1},{"version":"f128dae7c44d8f35ee42e0a437000a57c9f06cc04f8b4fb42eebf44954d53dc8","affectsGlobalScope":true,"impliedFormat":1},{"version":"ffbe6d7b295306b2ba88030f65b74c107d8d99bdcf596ea99c62a02f606108b0","affectsGlobalScope":true,"impliedFormat":1},{"version":"996fb27b15277369c68a4ba46ed138b4e9e839a02fb4ec756f7997629242fd9f","affectsGlobalScope":true,"impliedFormat":1},{"version":"79b712591b270d4778c89706ca2cfc56ddb8c3f895840e477388f1710dc5eda9","affectsGlobalScope":true,"impliedFormat":1},{"version":"20884846cef428b992b9bd032e70a4ef88e349263f63aeddf04dda837a7dba26","affectsGlobalScope":true,"impliedFormat":1},{"version":"5fcab789c73a97cd43828ee3cc94a61264cf24d4c44472ce64ced0e0f148bdb2","affectsGlobalScope":true,"impliedFormat":1},{"version":"db59a81f070c1880ad645b2c0275022baa6a0c4f0acdc58d29d349c6efcf0903","affectsGlobalScope":true,"impliedFormat":1},{"version":"673294292640f5722b700e7d814e17aaf7d93f83a48a2c9b38f33cbc940ad8b0","affectsGlobalScope":true,"impliedFormat":1},{"version":"d786b48f934cbca483b3c6d0a798cb43bbb4ada283e76fb22c28e53ae05b9e69","affectsGlobalScope":true,"impliedFormat":1},{"version":"1ecb8e347cb6b2a8927c09b86263663289418df375f5e68e11a0ae683776978f","affectsGlobalScope":true,"impliedFormat":1},{"version":"142efd4ce210576f777dc34df121777be89eda476942d6d6663b03dcb53be3ff","affectsGlobalScope":true,"impliedFormat":1},{"version":"379bc41580c2d774f82e828c70308f24a005b490c25ba34d679d84bcf05c3d9d","affectsGlobalScope":true,"impliedFormat":1},{"version":"ed484fb2aa8a1a23d0277056ec3336e0a0b52f9b8d6a961f338a642faf43235d","affectsGlobalScope":true,"impliedFormat":1},{"version":"4ffedae1d1c2d53fdbca1c96d3c7dda544281f7d262f99b6880634f8fd8d9820","affectsGlobalScope":true,"impliedFormat":1},{"version":"83a730b125d477dd264df8ba479afab27a3dae7152b005c214ab94dc7ee44fd3","affectsGlobalScope":true,"impliedFormat":1},{"version":"1ce14b81c5cc821994aa8ec1d42b220dd41b27fcc06373bce3958af7421b77d4","affectsGlobalScope":true,"impliedFormat":1},{"version":"b3a048b3e9302ef9a34ef4ebb9aecfb28b66abb3bce577206a79fee559c230da","affectsGlobalScope":true,"impliedFormat":1},{"version":"e303313f2a7abfebbec0080bbef137f9c717991b45c21949a177d68f71ef7834","signature":"7bb0003c6d905471b5bbb0137db5f4c55397f15dbf8d0685d50b2fbebc61c3c4"},{"version":"a205696fd4d4147b86791b2cb3709a39cb51c1d514b5fabdc04feccf46861f58","signature":"491bacf592cc3345c1b7d405a095093ac78a2d1b762cd1e92173523b8e2a7400"},{"version":"b1f41340da951b6297561aec4f9bc6616eaacb9216bf53a52627f2c4fa7d1057","signature":"f5c933a4da58967aef605a51a18bbaf0631be1ebf66074e0135c3c992d5654a3"},{"version":"034fe9e8f5d17185d4736750c055bf34c30784275fd04eb5274418b04428507f","signature":"acb1e9be42766628cc9edcd5d3f5c6f7dde587da9cafeb504ce80b5c54ac1347"},{"version":"55b2f09aaae3ac2e377fd99a21da0b5b9d31385b0ee201b4aef2854eb576107a","signature":"a664a13be736355890421a69c18c6af567c59f9d69b0b6bac21070550f441bf0"},{"version":"c58b40ba216002f560ae15ca095ca417124564e9e9f58e2692180340c6f31531","signature":"b4f9a9d40d6d3ad62ff2c0c3de481c11c71053d3bcd25f9db7bc7bf59c98b52c"},{"version":"f8c659a19d3f8c2e9998f2034de16f25306c85c10e0b15efc595046390d44b47","signature":"fc0a5e7fa5b2fdc5a4037ed6f43654a86643ac8cc65e057624467c8ca5fd66b7"},{"version":"04f934f99ddf379d5e1e1f3794bc08e851e3cf60de22ed2e9147e4d6f923ed1c","signature":"ebf361f0bdafe13632ec389b7c35afc7c19be6dcf7bbab385ca9431a2bd01c62"},{"version":"c85469798cb1e3425ae2bd0f04e83a245efac5416aa29d7bb863df3dee132ea0","signature":"65e1f2b6449bdf6cb1556ac0b953b3b7bd8ce077f3d0fbea718abce1a4d5709b"},{"version":"39f0ce2090ac910227a6d9dcccb954924e0810c65bba2c9b19560c0db4328c7e","signature":"14b3473bd631ca158d97b3cbd327ec6475a7f8b2909cc2719b76430c3db1e252"},{"version":"5716a6fd8cdcc79888eb3584a42e50c290e27c0a025cc1d5746b3f7ef6994b4a","signature":"7ad41c6174c13c6ea8bb9946d167b4647b231a4e4f5e788ba3c139c1b4b2509f"},{"version":"6c7176368037af28cb72f2392010fa1cef295d6d6744bca8cfb54985f3a18c3e","affectsGlobalScope":true,"impliedFormat":1},{"version":"ab41ef1f2cdafb8df48be20cd969d875602483859dc194e9c97c8a576892c052","affectsGlobalScope":true,"impliedFormat":1},{"version":"437e20f2ba32abaeb7985e0afe0002de1917bc74e949ba585e49feba65da6ca1","affectsGlobalScope":true,"impliedFormat":1},{"version":"21d819c173c0cf7cc3ce57c3276e77fd9a8a01d35a06ad87158781515c9a438a","impliedFormat":1},{"version":"98cffbf06d6bab333473c70a893770dbe990783904002c4f1a960447b4b53dca","affectsGlobalScope":true,"impliedFormat":1},{"version":"3af97acf03cc97de58a3a4bc91f8f616408099bc4233f6d0852e72a8ffb91ac9","affectsGlobalScope":true,"impliedFormat":1},{"version":"808069bba06b6768b62fd22429b53362e7af342da4a236ed2d2e1c89fcca3b4a","affectsGlobalScope":true,"impliedFormat":1},{"version":"1db0b7dca579049ca4193d034d835f6bfe73096c73663e5ef9a0b5779939f3d0","affectsGlobalScope":true,"impliedFormat":1},{"version":"9798340ffb0d067d69b1ae5b32faa17ab31b82466a3fc00d8f2f2df0c8554aaa","affectsGlobalScope":true,"impliedFormat":1},{"version":"f26b11d8d8e4b8028f1c7d618b22274c892e4b0ef5b3678a8ccbad85419aef43","affectsGlobalScope":true,"impliedFormat":1},{"version":"8e9c23ba78aabc2e0a27033f18737a6df754067731e69dc5f52823957d60a4b6","impliedFormat":1},{"version":"5929864ce17fba74232584d90cb721a89b7ad277220627cc97054ba15a98ea8f","impliedFormat":1},{"version":"763fe0f42b3d79b440a9b6e51e9ba3f3f91352469c1e4b3b67bfa4ff6352f3f4","impliedFormat":1},{"version":"25c8056edf4314820382a5fdb4bb7816999acdcb929c8f75e3f39473b87e85bc","impliedFormat":1},{"version":"c464d66b20788266e5353b48dc4aa6bc0dc4a707276df1e7152ab0c9ae21fad8","impliedFormat":1},{"version":"78d0d27c130d35c60b5e5566c9f1e5be77caf39804636bc1a40133919a949f21","impliedFormat":1},{"version":"c6fd2c5a395f2432786c9cb8deb870b9b0e8ff7e22c029954fabdd692bff6195","impliedFormat":1},{"version":"1d6e127068ea8e104a912e42fc0a110e2aa5a66a356a917a163e8cf9a65e4a75","impliedFormat":1},{"version":"5ded6427296cdf3b9542de4471d2aa8d3983671d4cac0f4bf9c637208d1ced43","impliedFormat":1},{"version":"7f182617db458e98fc18dfb272d40aa2fff3a353c44a89b2c0ccb3937709bfb5","impliedFormat":1},{"version":"cadc8aced301244057c4e7e73fbcae534b0f5b12a37b150d80e5a45aa4bebcbd","impliedFormat":1},{"version":"385aab901643aa54e1c36f5ef3107913b10d1b5bb8cbcd933d4263b80a0d7f20","impliedFormat":1},{"version":"9670d44354bab9d9982eca21945686b5c24a3f893db73c0dae0fd74217a4c219","impliedFormat":1},{"version":"0b8a9268adaf4da35e7fa830c8981cfa22adbbe5b3f6f5ab91f6658899e657a7","impliedFormat":1},{"version":"11396ed8a44c02ab9798b7dca436009f866e8dae3c9c25e8c1fbc396880bf1bb","impliedFormat":1},{"version":"ba7bc87d01492633cb5a0e5da8a4a42a1c86270e7b3d2dea5d156828a84e4882","impliedFormat":1},{"version":"4893a895ea92c85345017a04ed427cbd6a1710453338df26881a6019432febdd","impliedFormat":1},{"version":"c21dc52e277bcfc75fac0436ccb75c204f9e1b3fa5e12729670910639f27343e","impliedFormat":1},{"version":"13f6f39e12b1518c6650bbb220c8985999020fe0f21d818e28f512b7771d00f9","impliedFormat":1},{"version":"9b5369969f6e7175740bf51223112ff209f94ba43ecd3bb09eefff9fd675624a","impliedFormat":1},{"version":"4fe9e626e7164748e8769bbf74b538e09607f07ed17c2f20af8d680ee49fc1da","impliedFormat":1},{"version":"24515859bc0b836719105bb6cc3d68255042a9f02a6022b3187948b204946bd2","impliedFormat":1},{"version":"ea0148f897b45a76544ae179784c95af1bd6721b8610af9ffa467a518a086a43","impliedFormat":1},{"version":"24c6a117721e606c9984335f71711877293a9651e44f59f3d21c1ea0856f9cc9","impliedFormat":1},{"version":"dd3273ead9fbde62a72949c97dbec2247ea08e0c6952e701a483d74ef92d6a17","impliedFormat":1},{"version":"405822be75ad3e4d162e07439bac80c6bcc6dbae1929e179cf467ec0b9ee4e2e","impliedFormat":1},{"version":"0db18c6e78ea846316c012478888f33c11ffadab9efd1cc8bcc12daded7a60b6","impliedFormat":1},{"version":"e61be3f894b41b7baa1fbd6a66893f2579bfad01d208b4ff61daef21493ef0a8","impliedFormat":1},{"version":"bd0532fd6556073727d28da0edfd1736417a3f9f394877b6d5ef6ad88fba1d1a","impliedFormat":1},{"version":"89167d696a849fce5ca508032aabfe901c0868f833a8625d5a9c6e861ef935d2","impliedFormat":1},{"version":"615ba88d0128ed16bf83ef8ccbb6aff05c3ee2db1cc0f89ab50a4939bfc1943f","impliedFormat":1},{"version":"a4d551dbf8746780194d550c88f26cf937caf8d56f102969a110cfaed4b06656","impliedFormat":1},{"version":"8bd86b8e8f6a6aa6c49b71e14c4ffe1211a0e97c80f08d2c8cc98838006e4b88","impliedFormat":1},{"version":"317e63deeb21ac07f3992f5b50cdca8338f10acd4fbb7257ebf56735bf52ab00","impliedFormat":1},{"version":"4732aec92b20fb28c5fe9ad99521fb59974289ed1e45aecb282616202184064f","impliedFormat":1},{"version":"2e85db9e6fd73cfa3d7f28e0ab6b55417ea18931423bd47b409a96e4a169e8e6","impliedFormat":1},{"version":"c46e079fe54c76f95c67fb89081b3e399da2c7d109e7dca8e4b58d83e332e605","impliedFormat":1},{"version":"bf67d53d168abc1298888693338cb82854bdb2e69ef83f8a0092093c2d562107","impliedFormat":1},{"version":"b52476feb4a0cbcb25e5931b930fc73cb6643fb1a5060bf8a3dda0eeae5b4b68","affectsGlobalScope":true,"impliedFormat":1},{"version":"f9501cc13ce624c72b61f12b3963e84fad210fbdf0ffbc4590e08460a3f04eba","affectsGlobalScope":true,"impliedFormat":1},{"version":"e7721c4f69f93c91360c26a0a84ee885997d748237ef78ef665b153e622b36c1","affectsGlobalScope":true,"impliedFormat":1},{"version":"0fa06ada475b910e2106c98c68b10483dc8811d0c14a8a8dd36efb2672485b29","impliedFormat":1},{"version":"33e5e9aba62c3193d10d1d33ae1fa75c46a1171cf76fef750777377d53b0303f","impliedFormat":1},{"version":"2b06b93fd01bcd49d1a6bd1f9b65ddcae6480b9a86e9061634d6f8e354c1468f","impliedFormat":1},{"version":"6a0cd27e5dc2cfbe039e731cf879d12b0e2dded06d1b1dedad07f7712de0d7f4","affectsGlobalScope":true,"impliedFormat":1},{"version":"13f5c844119c43e51ce777c509267f14d6aaf31eafb2c2b002ca35584cd13b29","impliedFormat":1},{"version":"e60477649d6ad21542bd2dc7e3d9ff6853d0797ba9f689ba2f6653818999c264","impliedFormat":1},{"version":"c2510f124c0293ab80b1777c44d80f812b75612f297b9857406468c0f4dafe29","affectsGlobalScope":true,"impliedFormat":1},{"version":"5524481e56c48ff486f42926778c0a3cce1cc85dc46683b92b1271865bcf015a","impliedFormat":1},{"version":"4c829ab315f57c5442c6667b53769975acbf92003a66aef19bce151987675bd1","affectsGlobalScope":true,"impliedFormat":1},{"version":"b2ade7657e2db96d18315694789eff2ddd3d8aea7215b181f8a0b303277cc579","impliedFormat":1},{"version":"9855e02d837744303391e5623a531734443a5f8e6e8755e018c41d63ad797db2","impliedFormat":1},{"version":"4d631b81fa2f07a0e63a9a143d6a82c25c5f051298651a9b69176ba28930756d","impliedFormat":1},{"version":"836a356aae992ff3c28a0212e3eabcb76dd4b0cc06bcb9607aeef560661b860d","impliedFormat":1},{"version":"1e0d1f8b0adfa0b0330e028c7941b5a98c08b600efe7f14d2d2a00854fb2f393","impliedFormat":1},{"version":"41670ee38943d9cbb4924e436f56fc19ee94232bc96108562de1a734af20dc2c","affectsGlobalScope":true,"impliedFormat":1},{"version":"c906fb15bd2aabc9ed1e3f44eb6a8661199d6c320b3aa196b826121552cb3695","impliedFormat":1},{"version":"22295e8103f1d6d8ea4b5d6211e43421fe4564e34d0dd8e09e520e452d89e659","impliedFormat":1},{"version":"58647d85d0f722a1ce9de50955df60a7489f0593bf1a7015521efe901c06d770","impliedFormat":1},{"version":"6b4e081d55ac24fc8a4631d5dd77fe249fa25900abd7d046abb87d90e3b45645","impliedFormat":1},{"version":"a10f0e1854f3316d7ee437b79649e5a6ae3ae14ffe6322b02d4987071a95362e","impliedFormat":1},{"version":"e208f73ef6a980104304b0d2ca5f6bf1b85de6009d2c7e404028b875020fa8f2","impliedFormat":1},{"version":"d163b6bc2372b4f07260747cbc6c0a6405ab3fbcea3852305e98ac43ca59f5bc","impliedFormat":1},{"version":"e6fa9ad47c5f71ff733744a029d1dc472c618de53804eae08ffc243b936f87ff","affectsGlobalScope":true,"impliedFormat":1},{"version":"a6f137d651076822d4fe884287e68fd61785a0d3d1fdb250a5059b691fa897db","impliedFormat":1},{"version":"24826ed94a78d5c64bd857570fdbd96229ad41b5cb654c08d75a9845e3ab7dde","impliedFormat":1},{"version":"8b479a130ccb62e98f11f136d3ac80f2984fdc07616516d29881f3061f2dd472","impliedFormat":1},{"version":"928af3d90454bf656a52a48679f199f64c1435247d6189d1caf4c68f2eaf921f","affectsGlobalScope":true,"impliedFormat":1},{"version":"bceb58df66ab8fb00170df20cd813978c5ab84be1d285710c4eb005d8e9d8efb","affectsGlobalScope":true,"impliedFormat":1},{"version":"3f16a7e4deafa527ed9995a772bb380eb7d3c2c0fd4ae178c5263ed18394db2c","impliedFormat":1},{"version":"933921f0bb0ec12ef45d1062a1fc0f27635318f4d294e4d99de9a5493e618ca2","impliedFormat":1},{"version":"71a0f3ad612c123b57239a7749770017ecfe6b66411488000aba83e4546fde25","impliedFormat":1},{"version":"77fbe5eecb6fac4b6242bbf6eebfc43e98ce5ccba8fa44e0ef6a95c945ff4d98","impliedFormat":1},{"version":"4f9d8ca0c417b67b69eeb54c7ca1bedd7b56034bb9bfd27c5d4f3bc4692daca7","impliedFormat":1},{"version":"814118df420c4e38fe5ae1b9a3bafb6e9c2aa40838e528cde908381867be6466","impliedFormat":1},{"version":"a3fc63c0d7b031693f665f5494412ba4b551fe644ededccc0ab5922401079c95","impliedFormat":1},{"version":"80523c00b8544a2000ae0143e4a90a00b47f99823eb7926c1e03c494216fc363","impliedFormat":1},{"version":"37ba7b45141a45ce6e80e66f2a96c8a5ab1bcef0fc2d0f56bb58df96ec67e972","impliedFormat":1},{"version":"45650f47bfb376c8a8ed39d4bcda5902ab899a3150029684ee4c10676d9fbaee","impliedFormat":1},{"version":"746911b62b329587939560deb5c036aca48aece03147b021fa680223255d5183","affectsGlobalScope":true,"impliedFormat":1},{"version":"18fd40412d102c5564136f29735e5d1c3b455b8a37f920da79561f1fde068208","impliedFormat":1},{"version":"c8d3e5a18ba35629954e48c4cc8f11dc88224650067a172685c736b27a34a4dc","impliedFormat":1},{"version":"f0be1b8078cd549d91f37c30c222c2a187ac1cf981d994fb476a1adc61387b14","affectsGlobalScope":true,"impliedFormat":1},{"version":"0aaed1d72199b01234152f7a60046bc947f1f37d78d182e9ae09c4289e06a592","impliedFormat":1},{"version":"2b55d426ff2b9087485e52ac4bc7cfafe1dc420fc76dad926cd46526567c501a","impliedFormat":1},{"version":"66ba1b2c3e3a3644a1011cd530fb444a96b1b2dfe2f5e837a002d41a1a799e60","impliedFormat":1},{"version":"7e514f5b852fdbc166b539fdd1f4e9114f29911592a5eb10a94bb3a13ccac3c4","impliedFormat":1},{"version":"5b7aa3c4c1a5d81b411e8cb302b45507fea9358d3569196b27eb1a27ae3a90ef","affectsGlobalScope":true,"impliedFormat":1},{"version":"5987a903da92c7462e0b35704ce7da94d7fdc4b89a984871c0e2b87a8aae9e69","affectsGlobalScope":true,"impliedFormat":1},{"version":"ea08a0345023ade2b47fbff5a76d0d0ed8bff10bc9d22b83f40858a8e941501c","impliedFormat":1},{"version":"47613031a5a31510831304405af561b0ffaedb734437c595256bb61a90f9311b","impliedFormat":1},{"version":"ae062ce7d9510060c5d7e7952ae379224fb3f8f2dd74e88959878af2057c143b","impliedFormat":1},{"version":"8a1a0d0a4a06a8d278947fcb66bf684f117bf147f89b06e50662d79a53be3e9f","affectsGlobalScope":true,"impliedFormat":1},{"version":"358765d5ea8afd285d4fd1532e78b88273f18cb3f87403a9b16fef61ac9fdcfe","impliedFormat":1},{"version":"9f55299850d4f0921e79b6bf344b47c420ce0f507b9dcf593e532b09ea7eeea1","impliedFormat":1}],"root":[[88,98]],"options":{"composite":true,"declaration":true,"declarationMap":true,"esModuleInterop":true,"module":99,"outDir":"./","rootDir":"../src","skipLibCheck":true,"sourceMap":true,"strict":true,"target":99,"tsBuildInfoFile":"./.tsbuildinfo"},"referencedMap":[[150,1],[151,1],[152,2],[104,3],[153,4],[154,5],[155,6],[99,7],[102,8],[100,7],[101,7],[156,9],[157,10],[158,11],[159,12],[160,13],[161,14],[162,14],[163,15],[164,16],[165,17],[166,18],[105,7],[103,7],[167,19],[168,20],[169,21],[203,22],[170,23],[171,7],[172,24],[173,25],[174,26],[175,27],[176,28],[177,29],[178,30],[179,31],[180,32],[181,32],[182,33],[183,7],[184,34],[185,35],[187,36],[186,37],[188,38],[189,39],[190,40],[191,41],[192,42],[193,43],[194,44],[195,45],[196,46],[197,47],[198,48],[199,49],[200,50],[106,7],[107,7],[108,7],[147,51],[148,7],[149,7],[201,52],[202,53],[109,7],[86,7],[87,7],[15,7],[14,7],[2,7],[16,7],[17,7],[18,7],[19,7],[20,7],[21,7],[22,7],[23,7],[3,7],[24,7],[25,7],[4,7],[26,7],[30,7],[27,7],[28,7],[29,7],[31,7],[32,7],[33,7],[5,7],[34,7],[35,7],[36,7],[37,7],[6,7],[41,7],[38,7],[39,7],[40,7],[42,7],[7,7],[43,7],[48,7],[49,7],[44,7],[45,7],[46,7],[47,7],[8,7],[53,7],[50,7],[51,7],[52,7],[54,7],[9,7],[55,7],[56,7],[57,7],[59,7],[58,7],[60,7],[61,7],[10,7],[62,7],[63,7],[64,7],[11,7],[65,7],[66,7],[67,7],[68,7],[69,7],[70,7],[12,7],[71,7],[72,7],[73,7],[74,7],[75,7],[1,7],[76,7],[77,7],[13,7],[78,7],[79,7],[80,7],[81,7],[82,7],[83,7],[84,7],[85,7],[125,54],[135,55],[124,54],[145,56],[116,57],[115,58],[144,59],[138,60],[143,61],[118,62],[132,63],[117,64],[141,65],[113,66],[112,59],[142,67],[114,68],[119,69],[120,7],[123,69],[110,7],[146,70],[136,71],[127,72],[128,73],[130,74],[126,75],[129,76],[139,59],[121,77],[122,78],[131,79],[111,80],[134,71],[133,69],[137,7],[140,81],[89,82],[90,83],[91,83],[92,83],[93,83],[98,84],[97,83],[96,85],[94,83],[88,7],[95,83]],"latestChangedDtsFile":"./index.d.ts","version":"6.0.3"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import type { SecretProvider } from "./types.js";
|
|
2
|
+
export interface AutoPreloadOptions {
|
|
3
|
+
/**
|
|
4
|
+
* Env files to scan for `${provider:id}` references. Paths are
|
|
5
|
+
* resolved against `cwd` (which defaults to `process.cwd()`).
|
|
6
|
+
* Missing files are silently skipped — the helper assumes you
|
|
7
|
+
* already know which files will load and just need the references
|
|
8
|
+
* pre-resolved.
|
|
9
|
+
*/
|
|
10
|
+
readonly envFiles: readonly string[];
|
|
11
|
+
/** Defaults to `process.cwd()`. */
|
|
12
|
+
readonly cwd?: string;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Scan a set of env files for `${provider:id}` references and call
|
|
16
|
+
* `preload()` on every plugin whose `name` matches a found provider.
|
|
17
|
+
* Plugins whose names don't appear in any reference are skipped (no
|
|
18
|
+
* round-trip, no SDK warm-up, no surprise charges).
|
|
19
|
+
*
|
|
20
|
+
* Composes with the rest of envx like this:
|
|
21
|
+
*
|
|
22
|
+
* ```ts
|
|
23
|
+
* import envx from "@super-repo/envx";
|
|
24
|
+
* import { awsSecrets } from "@super-repo/envx-plugins/aws";
|
|
25
|
+
* import { gcpSecrets } from "@super-repo/envx-plugins/gcp";
|
|
26
|
+
* import { autoPreload } from "@super-repo/envx-plugins";
|
|
27
|
+
*
|
|
28
|
+
* const aws = awsSecrets({ region: "us-east-1" });
|
|
29
|
+
* const gcp = gcpSecrets({ projectId: "acme-prod" });
|
|
30
|
+
*
|
|
31
|
+
* await autoPreload([aws, gcp], { envFiles: [".env", "vault/.env.prod"] });
|
|
32
|
+
*
|
|
33
|
+
* envx({
|
|
34
|
+
* resolvers: {
|
|
35
|
+
* [aws.name]: aws.resolve,
|
|
36
|
+
* [gcp.name]: gcp.resolve,
|
|
37
|
+
* },
|
|
38
|
+
* });
|
|
39
|
+
* ```
|
|
40
|
+
*/
|
|
41
|
+
export declare function autoPreload(providers: readonly SecretProvider[], opts: AutoPreloadOptions): Promise<{
|
|
42
|
+
readonly preloaded: Record<string, string[]>;
|
|
43
|
+
}>;
|
|
44
|
+
/**
|
|
45
|
+
* Build a `resolvers:` map from a list of providers — the shape envx's
|
|
46
|
+
* `resolvers` config expects. Saves you from repeating
|
|
47
|
+
* `{ [p.name]: p.resolve }` for every provider.
|
|
48
|
+
*/
|
|
49
|
+
export declare function asResolvers(providers: readonly SecretProvider[]): Record<string, (id: string) => string | undefined>;
|
|
50
|
+
//# sourceMappingURL=auto-preload.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auto-preload.d.ts","sourceRoot":"","sources":["../src/auto-preload.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAOjD,MAAM,WAAW,kBAAkB;IACjC;;;;;;OAMG;IACH,QAAQ,CAAC,QAAQ,EAAE,SAAS,MAAM,EAAE,CAAC;IACrC,mCAAmC;IACnC,QAAQ,CAAC,GAAG,CAAC,EAAE,MAAM,CAAC;CACvB;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,wBAAsB,WAAW,CAC/B,SAAS,EAAE,SAAS,cAAc,EAAE,EACpC,IAAI,EAAE,kBAAkB,GACvB,OAAO,CAAC;IAAE,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,CAAA;CAAE,CAAC,CAiC3D;AAMD;;;;GAIG;AACH,wBAAgB,WAAW,CACzB,SAAS,EAAE,SAAS,cAAc,EAAE,GACnC,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,MAAM,GAAG,SAAS,CAAC,CAIpD"}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import * as fs from "fs";
|
|
2
|
+
import * as path from "path";
|
|
3
|
+
// #region -- autoPreload -----------------------------------
|
|
4
|
+
// Matches `${{provider:id}}` references — see env.ts for the dotenvx-conflict reasoning.
|
|
5
|
+
const REF_RE = /\$\{\{([a-zA-Z][\w-]*):([^}]+)\}\}/g;
|
|
6
|
+
/**
|
|
7
|
+
* Scan a set of env files for `${provider:id}` references and call
|
|
8
|
+
* `preload()` on every plugin whose `name` matches a found provider.
|
|
9
|
+
* Plugins whose names don't appear in any reference are skipped (no
|
|
10
|
+
* round-trip, no SDK warm-up, no surprise charges).
|
|
11
|
+
*
|
|
12
|
+
* Composes with the rest of envx like this:
|
|
13
|
+
*
|
|
14
|
+
* ```ts
|
|
15
|
+
* import envx from "@super-repo/envx";
|
|
16
|
+
* import { awsSecrets } from "@super-repo/envx-plugins/aws";
|
|
17
|
+
* import { gcpSecrets } from "@super-repo/envx-plugins/gcp";
|
|
18
|
+
* import { autoPreload } from "@super-repo/envx-plugins";
|
|
19
|
+
*
|
|
20
|
+
* const aws = awsSecrets({ region: "us-east-1" });
|
|
21
|
+
* const gcp = gcpSecrets({ projectId: "acme-prod" });
|
|
22
|
+
*
|
|
23
|
+
* await autoPreload([aws, gcp], { envFiles: [".env", "vault/.env.prod"] });
|
|
24
|
+
*
|
|
25
|
+
* envx({
|
|
26
|
+
* resolvers: {
|
|
27
|
+
* [aws.name]: aws.resolve,
|
|
28
|
+
* [gcp.name]: gcp.resolve,
|
|
29
|
+
* },
|
|
30
|
+
* });
|
|
31
|
+
* ```
|
|
32
|
+
*/
|
|
33
|
+
export async function autoPreload(providers, opts) {
|
|
34
|
+
const cwd = opts.cwd ?? process.cwd();
|
|
35
|
+
const byProvider = new Map();
|
|
36
|
+
for (const p of providers)
|
|
37
|
+
byProvider.set(p.name, new Set());
|
|
38
|
+
for (const file of opts.envFiles) {
|
|
39
|
+
const abs = path.isAbsolute(file) ? file : path.resolve(cwd, file);
|
|
40
|
+
if (!fs.existsSync(abs))
|
|
41
|
+
continue;
|
|
42
|
+
const content = fs.readFileSync(abs, "utf8");
|
|
43
|
+
let m;
|
|
44
|
+
REF_RE.lastIndex = 0;
|
|
45
|
+
while ((m = REF_RE.exec(content)) !== null) {
|
|
46
|
+
const provider = m[1];
|
|
47
|
+
const id = m[2];
|
|
48
|
+
if (provider === undefined || id === undefined)
|
|
49
|
+
continue;
|
|
50
|
+
const set = byProvider.get(provider);
|
|
51
|
+
if (set)
|
|
52
|
+
set.add(id);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
const preloaded = {};
|
|
56
|
+
await Promise.all(providers.map(async (p) => {
|
|
57
|
+
const ids = [...(byProvider.get(p.name) ?? [])];
|
|
58
|
+
if (ids.length === 0) {
|
|
59
|
+
preloaded[p.name] = [];
|
|
60
|
+
return;
|
|
61
|
+
}
|
|
62
|
+
await p.preload(ids);
|
|
63
|
+
preloaded[p.name] = ids;
|
|
64
|
+
}));
|
|
65
|
+
return { preloaded };
|
|
66
|
+
}
|
|
67
|
+
// #endregion -----------------------------------------------
|
|
68
|
+
// #region -- Convenience ---------------------------------
|
|
69
|
+
/**
|
|
70
|
+
* Build a `resolvers:` map from a list of providers — the shape envx's
|
|
71
|
+
* `resolvers` config expects. Saves you from repeating
|
|
72
|
+
* `{ [p.name]: p.resolve }` for every provider.
|
|
73
|
+
*/
|
|
74
|
+
export function asResolvers(providers) {
|
|
75
|
+
const out = {};
|
|
76
|
+
for (const p of providers)
|
|
77
|
+
out[p.name] = (id) => p.resolve(id);
|
|
78
|
+
return out;
|
|
79
|
+
}
|
|
80
|
+
// #endregion -----------------------------------------------
|
|
81
|
+
//# sourceMappingURL=auto-preload.js.map
|