@venturekit/core 0.0.0-dev.20260307234057

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.
@@ -0,0 +1,345 @@
1
+ "use strict";
2
+ /**
3
+ * VentureKit Presets
4
+ *
5
+ * AWS-like preset sizes that expand to explicit configuration values.
6
+ * Users can use these as shortcuts and override specific fields.
7
+ *
8
+ * Merge order: PRESET ← USER_OVERRIDES
9
+ */
10
+ Object.defineProperty(exports, "__esModule", { value: true });
11
+ exports.DATA_SAFETY_CONFIG = exports.DEFAULT_DATA_SAFETY = exports.PRESET_LARGE = exports.PRESET_MEDIUM = exports.PRESET_MICRO = exports.PRESET_NANO = void 0;
12
+ exports.getPreset = getPreset;
13
+ /**
14
+ * Default IAM config (empty - VentureKit handles basic permissions)
15
+ */
16
+ const DEFAULT_IAM = {
17
+ managedPolicyArns: [],
18
+ inlineStatements: [],
19
+ };
20
+ /**
21
+ * Default subnet config
22
+ */
23
+ const DEFAULT_SUBNETS = {
24
+ publicSubnets: { cidrMask: 24 },
25
+ privateSubnets: { cidrMask: 24 },
26
+ isolatedSubnets: undefined,
27
+ };
28
+ /**
29
+ * Default security group rules (allow all outbound)
30
+ */
31
+ const DEFAULT_SECURITY_GROUP = {
32
+ lambdaSecurityGroupIngress: [],
33
+ lambdaSecurityGroupEgress: [
34
+ { protocol: '-1', fromPort: 0, toPort: 0, cidrBlocks: ['0.0.0.0/0'], description: 'Allow all outbound' },
35
+ ],
36
+ };
37
+ /**
38
+ * NANO preset - Minimal resources for development/testing
39
+ *
40
+ * Use case: Local development, CI/CD testing, proof of concepts
41
+ * Cost: ~$5-15/month
42
+ */
43
+ exports.PRESET_NANO = {
44
+ lambda: {
45
+ memoryMb: 128,
46
+ timeoutSec: 10,
47
+ logRetentionDays: 7,
48
+ reservedConcurrency: undefined,
49
+ provisionedConcurrency: undefined,
50
+ tracingEnabled: false,
51
+ vpcEnabled: false,
52
+ runtime: 'nodejs20.x',
53
+ architecture: 'arm64',
54
+ iam: DEFAULT_IAM,
55
+ environmentVariables: {},
56
+ layers: [],
57
+ },
58
+ api: {
59
+ throttleRateLimit: 10,
60
+ throttleBurstLimit: 20,
61
+ detailedMetricsEnabled: false,
62
+ },
63
+ vpc: {
64
+ maxAzs: 2,
65
+ natGateways: 0,
66
+ cidr: '10.0.0.0/16',
67
+ flowLogsEnabled: false,
68
+ flowLogsRetentionDays: 7,
69
+ ...DEFAULT_SUBNETS,
70
+ enableVpcEndpoints: false,
71
+ ...DEFAULT_SECURITY_GROUP,
72
+ },
73
+ observability: {
74
+ logs: {
75
+ namePattern: '/venturekit/{name}/{env}/{function}',
76
+ streamNamePattern: '{instance}/{timestamp}',
77
+ retentionDays: 7,
78
+ },
79
+ metrics: {
80
+ namespace: 'VentureKit',
81
+ detailedMetricsEnabled: false,
82
+ defaultDimensions: {},
83
+ },
84
+ alarms: {
85
+ enabled: false,
86
+ topicArn: undefined,
87
+ evaluationPeriods: 3,
88
+ periodSec: 60,
89
+ },
90
+ tracing: {
91
+ enabled: false,
92
+ samplingRate: 0.05,
93
+ },
94
+ },
95
+ websocket: {
96
+ enabled: false,
97
+ routeSelectionExpression: '$request.body.action',
98
+ idleTimeoutSec: 600,
99
+ throttleRateLimit: 10,
100
+ throttleBurstLimit: 20,
101
+ },
102
+ };
103
+ /**
104
+ * MICRO preset - Small production workloads
105
+ *
106
+ * Use case: Early-stage startups, low-traffic APIs, internal tools
107
+ * Cost: ~$30-80/month
108
+ */
109
+ exports.PRESET_MICRO = {
110
+ lambda: {
111
+ memoryMb: 256,
112
+ timeoutSec: 10,
113
+ logRetentionDays: 14,
114
+ reservedConcurrency: undefined,
115
+ provisionedConcurrency: undefined,
116
+ tracingEnabled: false,
117
+ vpcEnabled: true,
118
+ runtime: 'nodejs20.x',
119
+ architecture: 'arm64',
120
+ iam: DEFAULT_IAM,
121
+ environmentVariables: {},
122
+ layers: [],
123
+ },
124
+ api: {
125
+ throttleRateLimit: 50,
126
+ throttleBurstLimit: 100,
127
+ detailedMetricsEnabled: false,
128
+ },
129
+ vpc: {
130
+ maxAzs: 2,
131
+ natGateways: 1,
132
+ cidr: '10.0.0.0/16',
133
+ flowLogsEnabled: false,
134
+ flowLogsRetentionDays: 14,
135
+ ...DEFAULT_SUBNETS,
136
+ enableVpcEndpoints: true,
137
+ ...DEFAULT_SECURITY_GROUP,
138
+ },
139
+ observability: {
140
+ logs: {
141
+ namePattern: '/venturekit/{name}/{env}/{function}',
142
+ streamNamePattern: '{instance}/{timestamp}',
143
+ retentionDays: 14,
144
+ },
145
+ metrics: {
146
+ namespace: 'VentureKit',
147
+ detailedMetricsEnabled: false,
148
+ defaultDimensions: {},
149
+ },
150
+ alarms: {
151
+ enabled: false,
152
+ topicArn: undefined,
153
+ evaluationPeriods: 3,
154
+ periodSec: 60,
155
+ },
156
+ tracing: {
157
+ enabled: false,
158
+ samplingRate: 0.1,
159
+ },
160
+ },
161
+ websocket: {
162
+ enabled: false,
163
+ routeSelectionExpression: '$request.body.action',
164
+ idleTimeoutSec: 600,
165
+ throttleRateLimit: 50,
166
+ throttleBurstLimit: 100,
167
+ },
168
+ };
169
+ /**
170
+ * MEDIUM preset - Standard production workloads
171
+ *
172
+ * Use case: Growing startups, moderate traffic, customer-facing APIs
173
+ * Cost: ~$100-300/month
174
+ */
175
+ exports.PRESET_MEDIUM = {
176
+ lambda: {
177
+ memoryMb: 512,
178
+ timeoutSec: 15,
179
+ logRetentionDays: 30,
180
+ reservedConcurrency: undefined,
181
+ provisionedConcurrency: undefined,
182
+ tracingEnabled: true,
183
+ vpcEnabled: true,
184
+ runtime: 'nodejs20.x',
185
+ architecture: 'arm64',
186
+ iam: DEFAULT_IAM,
187
+ environmentVariables: {},
188
+ layers: [],
189
+ },
190
+ api: {
191
+ throttleRateLimit: 100,
192
+ throttleBurstLimit: 200,
193
+ detailedMetricsEnabled: true,
194
+ },
195
+ vpc: {
196
+ maxAzs: 2,
197
+ natGateways: 1,
198
+ cidr: '10.0.0.0/16',
199
+ flowLogsEnabled: true,
200
+ flowLogsRetentionDays: 30,
201
+ ...DEFAULT_SUBNETS,
202
+ isolatedSubnets: { cidrMask: 24 },
203
+ enableVpcEndpoints: true,
204
+ ...DEFAULT_SECURITY_GROUP,
205
+ },
206
+ observability: {
207
+ logs: {
208
+ namePattern: '/venturekit/{name}/{env}/{function}',
209
+ streamNamePattern: '{instance}/{timestamp}',
210
+ retentionDays: 30,
211
+ },
212
+ metrics: {
213
+ namespace: 'VentureKit',
214
+ detailedMetricsEnabled: true,
215
+ defaultDimensions: {},
216
+ },
217
+ alarms: {
218
+ enabled: true,
219
+ topicArn: undefined,
220
+ evaluationPeriods: 3,
221
+ periodSec: 60,
222
+ },
223
+ tracing: {
224
+ enabled: true,
225
+ samplingRate: 0.25,
226
+ },
227
+ },
228
+ websocket: {
229
+ enabled: false,
230
+ routeSelectionExpression: '$request.body.action',
231
+ idleTimeoutSec: 600,
232
+ throttleRateLimit: 100,
233
+ throttleBurstLimit: 200,
234
+ },
235
+ };
236
+ /**
237
+ * LARGE preset - High-traffic production workloads
238
+ *
239
+ * Use case: Scaled startups, high traffic, mission-critical APIs
240
+ * Cost: ~$500+/month
241
+ */
242
+ exports.PRESET_LARGE = {
243
+ lambda: {
244
+ memoryMb: 1024,
245
+ timeoutSec: 30,
246
+ logRetentionDays: 90,
247
+ reservedConcurrency: undefined,
248
+ provisionedConcurrency: undefined,
249
+ tracingEnabled: true,
250
+ vpcEnabled: true,
251
+ runtime: 'nodejs20.x',
252
+ architecture: 'arm64',
253
+ iam: DEFAULT_IAM,
254
+ environmentVariables: {},
255
+ layers: [],
256
+ },
257
+ api: {
258
+ throttleRateLimit: 500,
259
+ throttleBurstLimit: 1000,
260
+ detailedMetricsEnabled: true,
261
+ },
262
+ vpc: {
263
+ maxAzs: 3,
264
+ natGateways: 2,
265
+ cidr: '10.0.0.0/16',
266
+ flowLogsEnabled: true,
267
+ flowLogsRetentionDays: 90,
268
+ ...DEFAULT_SUBNETS,
269
+ isolatedSubnets: { cidrMask: 24 },
270
+ enableVpcEndpoints: true,
271
+ ...DEFAULT_SECURITY_GROUP,
272
+ },
273
+ observability: {
274
+ logs: {
275
+ namePattern: '/venturekit/{name}/{env}/{function}',
276
+ streamNamePattern: '{instance}/{timestamp}',
277
+ retentionDays: 90,
278
+ },
279
+ metrics: {
280
+ namespace: 'VentureKit',
281
+ detailedMetricsEnabled: true,
282
+ defaultDimensions: {},
283
+ },
284
+ alarms: {
285
+ enabled: true,
286
+ topicArn: undefined,
287
+ evaluationPeriods: 3,
288
+ periodSec: 60,
289
+ },
290
+ tracing: {
291
+ enabled: true,
292
+ samplingRate: 0.5,
293
+ },
294
+ },
295
+ websocket: {
296
+ enabled: false,
297
+ routeSelectionExpression: '$request.body.action',
298
+ idleTimeoutSec: 600,
299
+ throttleRateLimit: 500,
300
+ throttleBurstLimit: 1000,
301
+ },
302
+ };
303
+ /**
304
+ * Get preset configuration by name
305
+ */
306
+ function getPreset(preset) {
307
+ switch (preset) {
308
+ case 'nano':
309
+ return exports.PRESET_NANO;
310
+ case 'micro':
311
+ return exports.PRESET_MICRO;
312
+ case 'medium':
313
+ return exports.PRESET_MEDIUM;
314
+ case 'large':
315
+ return exports.PRESET_LARGE;
316
+ default:
317
+ throw new Error(`Unknown preset: ${preset}`);
318
+ }
319
+ }
320
+ /**
321
+ * Default data safety per environment
322
+ */
323
+ exports.DEFAULT_DATA_SAFETY = {
324
+ dev: 'relaxed',
325
+ stage: 'standard',
326
+ prod: 'strict',
327
+ };
328
+ /**
329
+ * Data safety configurations
330
+ */
331
+ exports.DATA_SAFETY_CONFIG = {
332
+ strict: {
333
+ removalPolicy: 'retain',
334
+ deletionProtection: true,
335
+ },
336
+ standard: {
337
+ removalPolicy: 'retain',
338
+ deletionProtection: true,
339
+ },
340
+ relaxed: {
341
+ removalPolicy: 'destroy',
342
+ deletionProtection: false,
343
+ },
344
+ };
345
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"presets.js","sourceRoot":"","sources":["../src/presets.ts"],"names":[],"mappings":";AAAA;;;;;;;GAOG;;;AAgUH,8BAaC;AAzTD;;GAEG;AACH,MAAM,WAAW,GAAG;IAClB,iBAAiB,EAAE,EAAE;IACrB,gBAAgB,EAAE,EAAE;CACrB,CAAC;AAEF;;GAEG;AACH,MAAM,eAAe,GAAG;IACtB,aAAa,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE;IAC/B,cAAc,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE;IAChC,eAAe,EAAE,SAAS;CAC3B,CAAC;AAEF;;GAEG;AACH,MAAM,sBAAsB,GAAG;IAC7B,0BAA0B,EAAE,EAAE;IAC9B,yBAAyB,EAAE;QACzB,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,UAAU,EAAE,CAAC,WAAW,CAAC,EAAE,WAAW,EAAE,oBAAoB,EAAE;KACzG;CACF,CAAC;AAEF;;;;;GAKG;AACU,QAAA,WAAW,GAAiB;IACvC,MAAM,EAAE;QACN,QAAQ,EAAE,GAAG;QACb,UAAU,EAAE,EAAE;QACd,gBAAgB,EAAE,CAAC;QACnB,mBAAmB,EAAE,SAAS;QAC9B,sBAAsB,EAAE,SAAS;QACjC,cAAc,EAAE,KAAK;QACrB,UAAU,EAAE,KAAK;QACjB,OAAO,EAAE,YAAY;QACrB,YAAY,EAAE,OAAO;QACrB,GAAG,EAAE,WAAW;QAChB,oBAAoB,EAAE,EAAE;QACxB,MAAM,EAAE,EAAE;KACX;IACD,GAAG,EAAE;QACH,iBAAiB,EAAE,EAAE;QACrB,kBAAkB,EAAE,EAAE;QACtB,sBAAsB,EAAE,KAAK;KAC9B;IACD,GAAG,EAAE;QACH,MAAM,EAAE,CAAC;QACT,WAAW,EAAE,CAAC;QACd,IAAI,EAAE,aAAa;QACnB,eAAe,EAAE,KAAK;QACtB,qBAAqB,EAAE,CAAC;QACxB,GAAG,eAAe;QAClB,kBAAkB,EAAE,KAAK;QACzB,GAAG,sBAAsB;KAC1B;IACD,aAAa,EAAE;QACb,IAAI,EAAE;YACJ,WAAW,EAAE,qCAAqC;YAClD,iBAAiB,EAAE,wBAAwB;YAC3C,aAAa,EAAE,CAAC;SACjB;QACD,OAAO,EAAE;YACP,SAAS,EAAE,YAAY;YACvB,sBAAsB,EAAE,KAAK;YAC7B,iBAAiB,EAAE,EAAE;SACtB;QACD,MAAM,EAAE;YACN,OAAO,EAAE,KAAK;YACd,QAAQ,EAAE,SAAS;YACnB,iBAAiB,EAAE,CAAC;YACpB,SAAS,EAAE,EAAE;SACd;QACD,OAAO,EAAE;YACP,OAAO,EAAE,KAAK;YACd,YAAY,EAAE,IAAI;SACnB;KACF;IACD,SAAS,EAAE;QACT,OAAO,EAAE,KAAK;QACd,wBAAwB,EAAE,sBAAsB;QAChD,cAAc,EAAE,GAAG;QACnB,iBAAiB,EAAE,EAAE;QACrB,kBAAkB,EAAE,EAAE;KACvB;CACF,CAAC;AAEF;;;;;GAKG;AACU,QAAA,YAAY,GAAiB;IACxC,MAAM,EAAE;QACN,QAAQ,EAAE,GAAG;QACb,UAAU,EAAE,EAAE;QACd,gBAAgB,EAAE,EAAE;QACpB,mBAAmB,EAAE,SAAS;QAC9B,sBAAsB,EAAE,SAAS;QACjC,cAAc,EAAE,KAAK;QACrB,UAAU,EAAE,IAAI;QAChB,OAAO,EAAE,YAAY;QACrB,YAAY,EAAE,OAAO;QACrB,GAAG,EAAE,WAAW;QAChB,oBAAoB,EAAE,EAAE;QACxB,MAAM,EAAE,EAAE;KACX;IACD,GAAG,EAAE;QACH,iBAAiB,EAAE,EAAE;QACrB,kBAAkB,EAAE,GAAG;QACvB,sBAAsB,EAAE,KAAK;KAC9B;IACD,GAAG,EAAE;QACH,MAAM,EAAE,CAAC;QACT,WAAW,EAAE,CAAC;QACd,IAAI,EAAE,aAAa;QACnB,eAAe,EAAE,KAAK;QACtB,qBAAqB,EAAE,EAAE;QACzB,GAAG,eAAe;QAClB,kBAAkB,EAAE,IAAI;QACxB,GAAG,sBAAsB;KAC1B;IACD,aAAa,EAAE;QACb,IAAI,EAAE;YACJ,WAAW,EAAE,qCAAqC;YAClD,iBAAiB,EAAE,wBAAwB;YAC3C,aAAa,EAAE,EAAE;SAClB;QACD,OAAO,EAAE;YACP,SAAS,EAAE,YAAY;YACvB,sBAAsB,EAAE,KAAK;YAC7B,iBAAiB,EAAE,EAAE;SACtB;QACD,MAAM,EAAE;YACN,OAAO,EAAE,KAAK;YACd,QAAQ,EAAE,SAAS;YACnB,iBAAiB,EAAE,CAAC;YACpB,SAAS,EAAE,EAAE;SACd;QACD,OAAO,EAAE;YACP,OAAO,EAAE,KAAK;YACd,YAAY,EAAE,GAAG;SAClB;KACF;IACD,SAAS,EAAE;QACT,OAAO,EAAE,KAAK;QACd,wBAAwB,EAAE,sBAAsB;QAChD,cAAc,EAAE,GAAG;QACnB,iBAAiB,EAAE,EAAE;QACrB,kBAAkB,EAAE,GAAG;KACxB;CACF,CAAC;AAEF;;;;;GAKG;AACU,QAAA,aAAa,GAAiB;IACzC,MAAM,EAAE;QACN,QAAQ,EAAE,GAAG;QACb,UAAU,EAAE,EAAE;QACd,gBAAgB,EAAE,EAAE;QACpB,mBAAmB,EAAE,SAAS;QAC9B,sBAAsB,EAAE,SAAS;QACjC,cAAc,EAAE,IAAI;QACpB,UAAU,EAAE,IAAI;QAChB,OAAO,EAAE,YAAY;QACrB,YAAY,EAAE,OAAO;QACrB,GAAG,EAAE,WAAW;QAChB,oBAAoB,EAAE,EAAE;QACxB,MAAM,EAAE,EAAE;KACX;IACD,GAAG,EAAE;QACH,iBAAiB,EAAE,GAAG;QACtB,kBAAkB,EAAE,GAAG;QACvB,sBAAsB,EAAE,IAAI;KAC7B;IACD,GAAG,EAAE;QACH,MAAM,EAAE,CAAC;QACT,WAAW,EAAE,CAAC;QACd,IAAI,EAAE,aAAa;QACnB,eAAe,EAAE,IAAI;QACrB,qBAAqB,EAAE,EAAE;QACzB,GAAG,eAAe;QAClB,eAAe,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE;QACjC,kBAAkB,EAAE,IAAI;QACxB,GAAG,sBAAsB;KAC1B;IACD,aAAa,EAAE;QACb,IAAI,EAAE;YACJ,WAAW,EAAE,qCAAqC;YAClD,iBAAiB,EAAE,wBAAwB;YAC3C,aAAa,EAAE,EAAE;SAClB;QACD,OAAO,EAAE;YACP,SAAS,EAAE,YAAY;YACvB,sBAAsB,EAAE,IAAI;YAC5B,iBAAiB,EAAE,EAAE;SACtB;QACD,MAAM,EAAE;YACN,OAAO,EAAE,IAAI;YACb,QAAQ,EAAE,SAAS;YACnB,iBAAiB,EAAE,CAAC;YACpB,SAAS,EAAE,EAAE;SACd;QACD,OAAO,EAAE;YACP,OAAO,EAAE,IAAI;YACb,YAAY,EAAE,IAAI;SACnB;KACF;IACD,SAAS,EAAE;QACT,OAAO,EAAE,KAAK;QACd,wBAAwB,EAAE,sBAAsB;QAChD,cAAc,EAAE,GAAG;QACnB,iBAAiB,EAAE,GAAG;QACtB,kBAAkB,EAAE,GAAG;KACxB;CACF,CAAC;AAEF;;;;;GAKG;AACU,QAAA,YAAY,GAAiB;IACxC,MAAM,EAAE;QACN,QAAQ,EAAE,IAAI;QACd,UAAU,EAAE,EAAE;QACd,gBAAgB,EAAE,EAAE;QACpB,mBAAmB,EAAE,SAAS;QAC9B,sBAAsB,EAAE,SAAS;QACjC,cAAc,EAAE,IAAI;QACpB,UAAU,EAAE,IAAI;QAChB,OAAO,EAAE,YAAY;QACrB,YAAY,EAAE,OAAO;QACrB,GAAG,EAAE,WAAW;QAChB,oBAAoB,EAAE,EAAE;QACxB,MAAM,EAAE,EAAE;KACX;IACD,GAAG,EAAE;QACH,iBAAiB,EAAE,GAAG;QACtB,kBAAkB,EAAE,IAAI;QACxB,sBAAsB,EAAE,IAAI;KAC7B;IACD,GAAG,EAAE;QACH,MAAM,EAAE,CAAC;QACT,WAAW,EAAE,CAAC;QACd,IAAI,EAAE,aAAa;QACnB,eAAe,EAAE,IAAI;QACrB,qBAAqB,EAAE,EAAE;QACzB,GAAG,eAAe;QAClB,eAAe,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE;QACjC,kBAAkB,EAAE,IAAI;QACxB,GAAG,sBAAsB;KAC1B;IACD,aAAa,EAAE;QACb,IAAI,EAAE;YACJ,WAAW,EAAE,qCAAqC;YAClD,iBAAiB,EAAE,wBAAwB;YAC3C,aAAa,EAAE,EAAE;SAClB;QACD,OAAO,EAAE;YACP,SAAS,EAAE,YAAY;YACvB,sBAAsB,EAAE,IAAI;YAC5B,iBAAiB,EAAE,EAAE;SACtB;QACD,MAAM,EAAE;YACN,OAAO,EAAE,IAAI;YACb,QAAQ,EAAE,SAAS;YACnB,iBAAiB,EAAE,CAAC;YACpB,SAAS,EAAE,EAAE;SACd;QACD,OAAO,EAAE;YACP,OAAO,EAAE,IAAI;YACb,YAAY,EAAE,GAAG;SAClB;KACF;IACD,SAAS,EAAE;QACT,OAAO,EAAE,KAAK;QACd,wBAAwB,EAAE,sBAAsB;QAChD,cAAc,EAAE,GAAG;QACnB,iBAAiB,EAAE,GAAG;QACtB,kBAAkB,EAAE,IAAI;KACzB;CACF,CAAC;AAEF;;GAEG;AACH,SAAgB,SAAS,CAAC,MAAc;IACtC,QAAQ,MAAM,EAAE,CAAC;QACf,KAAK,MAAM;YACT,OAAO,mBAAW,CAAC;QACrB,KAAK,OAAO;YACV,OAAO,oBAAY,CAAC;QACtB,KAAK,QAAQ;YACX,OAAO,qBAAa,CAAC;QACvB,KAAK,OAAO;YACV,OAAO,oBAAY,CAAC;QACtB;YACE,MAAM,IAAI,KAAK,CAAC,mBAAmB,MAAM,EAAE,CAAC,CAAC;IACjD,CAAC;AACH,CAAC;AAED;;GAEG;AACU,QAAA,mBAAmB,GAA+B;IAC7D,GAAG,EAAE,SAAS;IACd,KAAK,EAAE,UAAU;IACjB,IAAI,EAAE,QAAQ;CACf,CAAC;AAEF;;GAEG;AACU,QAAA,kBAAkB,GAG1B;IACH,MAAM,EAAE;QACN,aAAa,EAAE,QAAQ;QACvB,kBAAkB,EAAE,IAAI;KACzB;IACD,QAAQ,EAAE;QACR,aAAa,EAAE,QAAQ;QACvB,kBAAkB,EAAE,IAAI;KACzB;IACD,OAAO,EAAE;QACP,aAAa,EAAE,SAAS;QACxB,kBAAkB,EAAE,KAAK;KAC1B;CACF,CAAC","sourcesContent":["/**\n * VentureKit Presets\n * \n * AWS-like preset sizes that expand to explicit configuration values.\n * Users can use these as shortcuts and override specific fields.\n * \n * Merge order: PRESET ← USER_OVERRIDES\n */\n\nimport { LambdaEnvConfig } from './types/lambda';\nimport { ApiEnvConfig } from './types/api';\nimport { VpcEnvConfig } from './types/vpc';\nimport { ObservabilityEnvConfig } from './types/observability';\nimport { WebSocketEnvConfig } from './types/websocket';\nimport { Preset, DataSafety } from './types/env';\n\n/**\n * Preset configuration (fully specified, no optionals)\n */\nexport interface PresetConfig {\n  lambda: LambdaEnvConfig;\n  api: Omit<ApiEnvConfig, 'cors' | 'customDomain'>;\n  vpc: VpcEnvConfig;\n  observability: ObservabilityEnvConfig;\n  websocket: WebSocketEnvConfig;\n}\n\n/**\n * Default IAM config (empty - VentureKit handles basic permissions)\n */\nconst DEFAULT_IAM = {\n  managedPolicyArns: [],\n  inlineStatements: [],\n};\n\n/**\n * Default subnet config\n */\nconst DEFAULT_SUBNETS = {\n  publicSubnets: { cidrMask: 24 },\n  privateSubnets: { cidrMask: 24 },\n  isolatedSubnets: undefined,\n};\n\n/**\n * Default security group rules (allow all outbound)\n */\nconst DEFAULT_SECURITY_GROUP = {\n  lambdaSecurityGroupIngress: [],\n  lambdaSecurityGroupEgress: [\n    { protocol: '-1', fromPort: 0, toPort: 0, cidrBlocks: ['0.0.0.0/0'], description: 'Allow all outbound' },\n  ],\n};\n\n/**\n * NANO preset - Minimal resources for development/testing\n * \n * Use case: Local development, CI/CD testing, proof of concepts\n * Cost: ~$5-15/month\n */\nexport const PRESET_NANO: PresetConfig = {\n  lambda: {\n    memoryMb: 128,\n    timeoutSec: 10,\n    logRetentionDays: 7,\n    reservedConcurrency: undefined,\n    provisionedConcurrency: undefined,\n    tracingEnabled: false,\n    vpcEnabled: false,\n    runtime: 'nodejs20.x',\n    architecture: 'arm64',\n    iam: DEFAULT_IAM,\n    environmentVariables: {},\n    layers: [],\n  },\n  api: {\n    throttleRateLimit: 10,\n    throttleBurstLimit: 20,\n    detailedMetricsEnabled: false,\n  },\n  vpc: {\n    maxAzs: 2,\n    natGateways: 0,\n    cidr: '10.0.0.0/16',\n    flowLogsEnabled: false,\n    flowLogsRetentionDays: 7,\n    ...DEFAULT_SUBNETS,\n    enableVpcEndpoints: false,\n    ...DEFAULT_SECURITY_GROUP,\n  },\n  observability: {\n    logs: {\n      namePattern: '/venturekit/{name}/{env}/{function}',\n      streamNamePattern: '{instance}/{timestamp}',\n      retentionDays: 7,\n    },\n    metrics: {\n      namespace: 'VentureKit',\n      detailedMetricsEnabled: false,\n      defaultDimensions: {},\n    },\n    alarms: {\n      enabled: false,\n      topicArn: undefined,\n      evaluationPeriods: 3,\n      periodSec: 60,\n    },\n    tracing: {\n      enabled: false,\n      samplingRate: 0.05,\n    },\n  },\n  websocket: {\n    enabled: false,\n    routeSelectionExpression: '$request.body.action',\n    idleTimeoutSec: 600,\n    throttleRateLimit: 10,\n    throttleBurstLimit: 20,\n  },\n};\n\n/**\n * MICRO preset - Small production workloads\n * \n * Use case: Early-stage startups, low-traffic APIs, internal tools\n * Cost: ~$30-80/month\n */\nexport const PRESET_MICRO: PresetConfig = {\n  lambda: {\n    memoryMb: 256,\n    timeoutSec: 10,\n    logRetentionDays: 14,\n    reservedConcurrency: undefined,\n    provisionedConcurrency: undefined,\n    tracingEnabled: false,\n    vpcEnabled: true,\n    runtime: 'nodejs20.x',\n    architecture: 'arm64',\n    iam: DEFAULT_IAM,\n    environmentVariables: {},\n    layers: [],\n  },\n  api: {\n    throttleRateLimit: 50,\n    throttleBurstLimit: 100,\n    detailedMetricsEnabled: false,\n  },\n  vpc: {\n    maxAzs: 2,\n    natGateways: 1,\n    cidr: '10.0.0.0/16',\n    flowLogsEnabled: false,\n    flowLogsRetentionDays: 14,\n    ...DEFAULT_SUBNETS,\n    enableVpcEndpoints: true,\n    ...DEFAULT_SECURITY_GROUP,\n  },\n  observability: {\n    logs: {\n      namePattern: '/venturekit/{name}/{env}/{function}',\n      streamNamePattern: '{instance}/{timestamp}',\n      retentionDays: 14,\n    },\n    metrics: {\n      namespace: 'VentureKit',\n      detailedMetricsEnabled: false,\n      defaultDimensions: {},\n    },\n    alarms: {\n      enabled: false,\n      topicArn: undefined,\n      evaluationPeriods: 3,\n      periodSec: 60,\n    },\n    tracing: {\n      enabled: false,\n      samplingRate: 0.1,\n    },\n  },\n  websocket: {\n    enabled: false,\n    routeSelectionExpression: '$request.body.action',\n    idleTimeoutSec: 600,\n    throttleRateLimit: 50,\n    throttleBurstLimit: 100,\n  },\n};\n\n/**\n * MEDIUM preset - Standard production workloads\n * \n * Use case: Growing startups, moderate traffic, customer-facing APIs\n * Cost: ~$100-300/month\n */\nexport const PRESET_MEDIUM: PresetConfig = {\n  lambda: {\n    memoryMb: 512,\n    timeoutSec: 15,\n    logRetentionDays: 30,\n    reservedConcurrency: undefined,\n    provisionedConcurrency: undefined,\n    tracingEnabled: true,\n    vpcEnabled: true,\n    runtime: 'nodejs20.x',\n    architecture: 'arm64',\n    iam: DEFAULT_IAM,\n    environmentVariables: {},\n    layers: [],\n  },\n  api: {\n    throttleRateLimit: 100,\n    throttleBurstLimit: 200,\n    detailedMetricsEnabled: true,\n  },\n  vpc: {\n    maxAzs: 2,\n    natGateways: 1,\n    cidr: '10.0.0.0/16',\n    flowLogsEnabled: true,\n    flowLogsRetentionDays: 30,\n    ...DEFAULT_SUBNETS,\n    isolatedSubnets: { cidrMask: 24 },\n    enableVpcEndpoints: true,\n    ...DEFAULT_SECURITY_GROUP,\n  },\n  observability: {\n    logs: {\n      namePattern: '/venturekit/{name}/{env}/{function}',\n      streamNamePattern: '{instance}/{timestamp}',\n      retentionDays: 30,\n    },\n    metrics: {\n      namespace: 'VentureKit',\n      detailedMetricsEnabled: true,\n      defaultDimensions: {},\n    },\n    alarms: {\n      enabled: true,\n      topicArn: undefined,\n      evaluationPeriods: 3,\n      periodSec: 60,\n    },\n    tracing: {\n      enabled: true,\n      samplingRate: 0.25,\n    },\n  },\n  websocket: {\n    enabled: false,\n    routeSelectionExpression: '$request.body.action',\n    idleTimeoutSec: 600,\n    throttleRateLimit: 100,\n    throttleBurstLimit: 200,\n  },\n};\n\n/**\n * LARGE preset - High-traffic production workloads\n * \n * Use case: Scaled startups, high traffic, mission-critical APIs\n * Cost: ~$500+/month\n */\nexport const PRESET_LARGE: PresetConfig = {\n  lambda: {\n    memoryMb: 1024,\n    timeoutSec: 30,\n    logRetentionDays: 90,\n    reservedConcurrency: undefined,\n    provisionedConcurrency: undefined,\n    tracingEnabled: true,\n    vpcEnabled: true,\n    runtime: 'nodejs20.x',\n    architecture: 'arm64',\n    iam: DEFAULT_IAM,\n    environmentVariables: {},\n    layers: [],\n  },\n  api: {\n    throttleRateLimit: 500,\n    throttleBurstLimit: 1000,\n    detailedMetricsEnabled: true,\n  },\n  vpc: {\n    maxAzs: 3,\n    natGateways: 2,\n    cidr: '10.0.0.0/16',\n    flowLogsEnabled: true,\n    flowLogsRetentionDays: 90,\n    ...DEFAULT_SUBNETS,\n    isolatedSubnets: { cidrMask: 24 },\n    enableVpcEndpoints: true,\n    ...DEFAULT_SECURITY_GROUP,\n  },\n  observability: {\n    logs: {\n      namePattern: '/venturekit/{name}/{env}/{function}',\n      streamNamePattern: '{instance}/{timestamp}',\n      retentionDays: 90,\n    },\n    metrics: {\n      namespace: 'VentureKit',\n      detailedMetricsEnabled: true,\n      defaultDimensions: {},\n    },\n    alarms: {\n      enabled: true,\n      topicArn: undefined,\n      evaluationPeriods: 3,\n      periodSec: 60,\n    },\n    tracing: {\n      enabled: true,\n      samplingRate: 0.5,\n    },\n  },\n  websocket: {\n    enabled: false,\n    routeSelectionExpression: '$request.body.action',\n    idleTimeoutSec: 600,\n    throttleRateLimit: 500,\n    throttleBurstLimit: 1000,\n  },\n};\n\n/**\n * Get preset configuration by name\n */\nexport function getPreset(preset: Preset): PresetConfig {\n  switch (preset) {\n    case 'nano':\n      return PRESET_NANO;\n    case 'micro':\n      return PRESET_MICRO;\n    case 'medium':\n      return PRESET_MEDIUM;\n    case 'large':\n      return PRESET_LARGE;\n    default:\n      throw new Error(`Unknown preset: ${preset}`);\n  }\n}\n\n/**\n * Default data safety per environment\n */\nexport const DEFAULT_DATA_SAFETY: Record<string, DataSafety> = {\n  dev: 'relaxed',\n  stage: 'standard',\n  prod: 'strict',\n};\n\n/**\n * Data safety configurations\n */\nexport const DATA_SAFETY_CONFIG: Record<DataSafety, { \n  removalPolicy: 'retain' | 'destroy';\n  deletionProtection: boolean;\n}> = {\n  strict: {\n    removalPolicy: 'retain',\n    deletionProtection: true,\n  },\n  standard: {\n    removalPolicy: 'retain',\n    deletionProtection: true,\n  },\n  relaxed: {\n    removalPolicy: 'destroy',\n    deletionProtection: false,\n  },\n};\n"]}
@@ -0,0 +1,28 @@
1
+ /**
2
+ * VentureKit Configuration Resolution
3
+ *
4
+ * Merges base config + env config input into a fully resolved configuration.
5
+ *
6
+ * Merge order: PRESET ← USER_OVERRIDES
7
+ *
8
+ * This ensures:
9
+ * - Presets provide sensible defaults
10
+ * - Users can override any specific field
11
+ * - Final config has no undefined values (except where explicitly typed)
12
+ */
13
+ import { BaseConfig } from './types/base';
14
+ import { SecurityConfig } from './types/security';
15
+ import { EnvConfig, EnvConfigInput, Environment } from './types/env';
16
+ import { ResolvedConfig } from './types/resolved';
17
+ /**
18
+ * Resolve environment configuration
19
+ *
20
+ * Takes user input and produces a fully resolved EnvConfig.
21
+ */
22
+ export declare function resolveEnvConfig(env: Environment, input: EnvConfigInput): EnvConfig;
23
+ /**
24
+ * Resolve full configuration
25
+ *
26
+ * Merges base config + security config + env config into a complete ResolvedConfig.
27
+ */
28
+ export declare function resolveConfig(base: BaseConfig, security: SecurityConfig, env: Environment, envInput: EnvConfigInput): ResolvedConfig;
@@ -0,0 +1,188 @@
1
+ "use strict";
2
+ /**
3
+ * VentureKit Configuration Resolution
4
+ *
5
+ * Merges base config + env config input into a fully resolved configuration.
6
+ *
7
+ * Merge order: PRESET ← USER_OVERRIDES
8
+ *
9
+ * This ensures:
10
+ * - Presets provide sensible defaults
11
+ * - Users can override any specific field
12
+ * - Final config has no undefined values (except where explicitly typed)
13
+ */
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.resolveEnvConfig = resolveEnvConfig;
16
+ exports.resolveConfig = resolveConfig;
17
+ const presets_1 = require("./presets");
18
+ /**
19
+ * Resolve Lambda configuration
20
+ */
21
+ function resolveLambda(preset, input) {
22
+ if (!input)
23
+ return preset.lambda;
24
+ const { iam, ...rest } = input;
25
+ return {
26
+ ...preset.lambda,
27
+ ...rest,
28
+ iam: iam ? {
29
+ managedPolicyArns: iam.managedPolicyArns ?? preset.lambda.iam.managedPolicyArns,
30
+ inlineStatements: iam.inlineStatements ?? preset.lambda.iam.inlineStatements,
31
+ } : preset.lambda.iam,
32
+ };
33
+ }
34
+ /**
35
+ * Resolve API configuration
36
+ */
37
+ function resolveApi(preset, input) {
38
+ const base = {
39
+ ...preset.api,
40
+ cors: undefined,
41
+ customDomain: undefined,
42
+ };
43
+ if (!input)
44
+ return base;
45
+ const { cors, customDomain, ...rest } = input;
46
+ const result = { ...base, ...rest };
47
+ // Handle CORS separately (partial merge)
48
+ if (cors) {
49
+ const defaultCors = {
50
+ allowOrigins: ['*'],
51
+ allowMethods: ['GET', 'POST', 'PUT', 'DELETE', 'OPTIONS'],
52
+ allowHeaders: ['Content-Type', 'Authorization'],
53
+ allowCredentials: false,
54
+ maxAgeSec: 86400,
55
+ };
56
+ result.cors = { ...defaultCors, ...cors };
57
+ }
58
+ // Custom domain is all-or-nothing
59
+ if (customDomain) {
60
+ result.customDomain = customDomain;
61
+ }
62
+ return result;
63
+ }
64
+ /**
65
+ * Resolve VPC configuration
66
+ */
67
+ function resolveVpc(preset, input) {
68
+ if (!input)
69
+ return preset.vpc;
70
+ const { publicSubnets, privateSubnets, isolatedSubnets, ...rest } = input;
71
+ const result = { ...preset.vpc, ...rest };
72
+ if (publicSubnets) {
73
+ result.publicSubnets = { ...preset.vpc.publicSubnets, ...publicSubnets };
74
+ }
75
+ if (privateSubnets) {
76
+ result.privateSubnets = { ...preset.vpc.privateSubnets, ...privateSubnets };
77
+ }
78
+ if (isolatedSubnets !== undefined) {
79
+ if (isolatedSubnets && preset.vpc.isolatedSubnets) {
80
+ result.isolatedSubnets = { ...preset.vpc.isolatedSubnets, ...isolatedSubnets };
81
+ }
82
+ else if (isolatedSubnets) {
83
+ result.isolatedSubnets = { cidrMask: isolatedSubnets.cidrMask ?? 24 };
84
+ }
85
+ else {
86
+ result.isolatedSubnets = undefined;
87
+ }
88
+ }
89
+ return result;
90
+ }
91
+ /**
92
+ * Resolve Observability configuration
93
+ */
94
+ function resolveObservability(preset, input) {
95
+ if (!input)
96
+ return preset.observability;
97
+ const { logs, metrics, alarms, tracing, ...shorthands } = input;
98
+ // Start with preset
99
+ const result = { ...preset.observability };
100
+ // Apply nested configs
101
+ if (logs) {
102
+ result.logs = { ...result.logs, ...logs };
103
+ }
104
+ if (metrics) {
105
+ result.metrics = { ...result.metrics, ...metrics };
106
+ }
107
+ if (alarms) {
108
+ result.alarms = { ...result.alarms, ...alarms };
109
+ }
110
+ if (tracing) {
111
+ result.tracing = { ...result.tracing, ...tracing };
112
+ }
113
+ // Apply shorthands
114
+ if (shorthands.alarmsEnabled !== undefined) {
115
+ result.alarms.enabled = shorthands.alarmsEnabled;
116
+ }
117
+ if (shorthands.tracingEnabled !== undefined) {
118
+ result.tracing.enabled = shorthands.tracingEnabled;
119
+ }
120
+ if (shorthands.logRetentionDays !== undefined) {
121
+ result.logs.retentionDays = shorthands.logRetentionDays;
122
+ }
123
+ if (shorthands.detailedMetricsEnabled !== undefined) {
124
+ result.metrics.detailedMetricsEnabled = shorthands.detailedMetricsEnabled;
125
+ }
126
+ return result;
127
+ }
128
+ /**
129
+ * Resolve WebSocket configuration
130
+ */
131
+ function resolveWebSocket(preset, input) {
132
+ if (!input)
133
+ return preset.websocket;
134
+ return { ...preset.websocket, ...input };
135
+ }
136
+ /**
137
+ * Resolve environment configuration
138
+ *
139
+ * Takes user input and produces a fully resolved EnvConfig.
140
+ */
141
+ function resolveEnvConfig(env, input) {
142
+ // Determine preset (default to 'micro' if not specified)
143
+ const presetName = input.preset ?? 'micro';
144
+ const preset = (0, presets_1.getPreset)(presetName);
145
+ // Determine data safety (default based on environment)
146
+ const dataSafety = input.dataSafety ?? presets_1.DEFAULT_DATA_SAFETY[env];
147
+ return {
148
+ env,
149
+ dataSafety,
150
+ lambda: resolveLambda(preset, input.lambda),
151
+ api: resolveApi(preset, input.api),
152
+ vpc: resolveVpc(preset, input.vpc),
153
+ observability: resolveObservability(preset, input.observability),
154
+ websocket: resolveWebSocket(preset, input.websocket),
155
+ };
156
+ }
157
+ /**
158
+ * Resolve full configuration
159
+ *
160
+ * Merges base config + security config + env config into a complete ResolvedConfig.
161
+ */
162
+ function resolveConfig(base, security, env, envInput) {
163
+ const envConfig = resolveEnvConfig(env, envInput);
164
+ return {
165
+ // From base
166
+ name: base.name,
167
+ displayName: base.displayName,
168
+ region: base.region,
169
+ // From security
170
+ scopes: security.scopes,
171
+ appClients: security.appClients,
172
+ // From env
173
+ env: envConfig.env,
174
+ dataSafety: envConfig.dataSafety,
175
+ lambda: envConfig.lambda,
176
+ api: envConfig.api,
177
+ vpc: envConfig.vpc,
178
+ observability: envConfig.observability,
179
+ websocket: envConfig.websocket,
180
+ // Auto-generated
181
+ tags: {
182
+ Project: base.name,
183
+ Environment: env,
184
+ ManagedBy: 'venturekit',
185
+ },
186
+ };
187
+ }
188
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resolve.js","sourceRoot":"","sources":["../src/resolve.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * VentureKit Configuration Resolution\n * \n * Merges base config + env config input into a fully resolved configuration.\n * \n * Merge order: PRESET ← USER_OVERRIDES\n * \n * This ensures:\n * - Presets provide sensible defaults\n * - Users can override any specific field\n * - Final config has no undefined values (except where explicitly typed)\n */\n\nimport { BaseConfig } from './types/base';\nimport { SecurityConfig } from './types/security';\nimport { EnvConfig, EnvConfigInput, Environment, DataSafety } from './types/env';\nimport { LambdaEnvConfig } from './types/lambda';\nimport { ApiEnvConfig, CorsConfig } from './types/api';\nimport { VpcEnvConfig } from './types/vpc';\nimport { ObservabilityEnvConfig } from './types/observability';\nimport { WebSocketEnvConfig } from './types/websocket';\nimport { ResolvedConfig } from './types/resolved';\nimport { getPreset, DEFAULT_DATA_SAFETY, PresetConfig } from './presets';\n\n/**\n * Resolve Lambda configuration\n */\nfunction resolveLambda(\n  preset: PresetConfig,\n  input: EnvConfigInput['lambda']\n): LambdaEnvConfig {\n  if (!input) return preset.lambda;\n  \n  const { iam, ...rest } = input;\n  \n  return {\n    ...preset.lambda,\n    ...rest,\n    iam: iam ? {\n      managedPolicyArns: iam.managedPolicyArns ?? preset.lambda.iam.managedPolicyArns,\n      inlineStatements: iam.inlineStatements ?? preset.lambda.iam.inlineStatements,\n    } : preset.lambda.iam,\n  };\n}\n\n/**\n * Resolve API configuration\n */\nfunction resolveApi(\n  preset: PresetConfig,\n  input: EnvConfigInput['api']\n): ApiEnvConfig {\n  const base: ApiEnvConfig = {\n    ...preset.api,\n    cors: undefined,\n    customDomain: undefined,\n  };\n  \n  if (!input) return base;\n  \n  const { cors, customDomain, ...rest } = input;\n  \n  const result: ApiEnvConfig = { ...base, ...rest };\n  \n  // Handle CORS separately (partial merge)\n  if (cors) {\n    const defaultCors: CorsConfig = {\n      allowOrigins: ['*'],\n      allowMethods: ['GET', 'POST', 'PUT', 'DELETE', 'OPTIONS'],\n      allowHeaders: ['Content-Type', 'Authorization'],\n      allowCredentials: false,\n      maxAgeSec: 86400,\n    };\n    result.cors = { ...defaultCors, ...cors };\n  }\n  \n  // Custom domain is all-or-nothing\n  if (customDomain) {\n    result.customDomain = customDomain;\n  }\n  \n  return result;\n}\n\n/**\n * Resolve VPC configuration\n */\nfunction resolveVpc(\n  preset: PresetConfig,\n  input: EnvConfigInput['vpc']\n): VpcEnvConfig {\n  if (!input) return preset.vpc;\n  \n  const { publicSubnets, privateSubnets, isolatedSubnets, ...rest } = input;\n  \n  const result: VpcEnvConfig = { ...preset.vpc, ...rest };\n  \n  if (publicSubnets) {\n    result.publicSubnets = { ...preset.vpc.publicSubnets, ...publicSubnets };\n  }\n  if (privateSubnets) {\n    result.privateSubnets = { ...preset.vpc.privateSubnets, ...privateSubnets };\n  }\n  if (isolatedSubnets !== undefined) {\n    if (isolatedSubnets && preset.vpc.isolatedSubnets) {\n      result.isolatedSubnets = { ...preset.vpc.isolatedSubnets, ...isolatedSubnets };\n    } else if (isolatedSubnets) {\n      result.isolatedSubnets = { cidrMask: isolatedSubnets.cidrMask ?? 24 };\n    } else {\n      result.isolatedSubnets = undefined;\n    }\n  }\n  \n  return result;\n}\n\n/**\n * Resolve Observability configuration\n */\nfunction resolveObservability(\n  preset: PresetConfig,\n  input: EnvConfigInput['observability']\n): ObservabilityEnvConfig {\n  if (!input) return preset.observability;\n  \n  const { logs, metrics, alarms, tracing, ...shorthands } = input;\n  \n  // Start with preset\n  const result = { ...preset.observability };\n  \n  // Apply nested configs\n  if (logs) {\n    result.logs = { ...result.logs, ...logs };\n  }\n  if (metrics) {\n    result.metrics = { ...result.metrics, ...metrics };\n  }\n  if (alarms) {\n    result.alarms = { ...result.alarms, ...alarms };\n  }\n  if (tracing) {\n    result.tracing = { ...result.tracing, ...tracing };\n  }\n  \n  // Apply shorthands\n  if (shorthands.alarmsEnabled !== undefined) {\n    result.alarms.enabled = shorthands.alarmsEnabled;\n  }\n  if (shorthands.tracingEnabled !== undefined) {\n    result.tracing.enabled = shorthands.tracingEnabled;\n  }\n  if (shorthands.logRetentionDays !== undefined) {\n    result.logs.retentionDays = shorthands.logRetentionDays;\n  }\n  if (shorthands.detailedMetricsEnabled !== undefined) {\n    result.metrics.detailedMetricsEnabled = shorthands.detailedMetricsEnabled;\n  }\n  \n  return result;\n}\n\n/**\n * Resolve WebSocket configuration\n */\nfunction resolveWebSocket(\n  preset: PresetConfig,\n  input: EnvConfigInput['websocket']\n): WebSocketEnvConfig {\n  if (!input) return preset.websocket;\n  return { ...preset.websocket, ...input };\n}\n\n/**\n * Resolve environment configuration\n * \n * Takes user input and produces a fully resolved EnvConfig.\n */\nexport function resolveEnvConfig(\n  env: Environment,\n  input: EnvConfigInput\n): EnvConfig {\n  // Determine preset (default to 'micro' if not specified)\n  const presetName = input.preset ?? 'micro';\n  const preset = getPreset(presetName);\n  \n  // Determine data safety (default based on environment)\n  const dataSafety = input.dataSafety ?? DEFAULT_DATA_SAFETY[env];\n  \n  return {\n    env,\n    dataSafety,\n    lambda: resolveLambda(preset, input.lambda),\n    api: resolveApi(preset, input.api),\n    vpc: resolveVpc(preset, input.vpc),\n    observability: resolveObservability(preset, input.observability),\n    websocket: resolveWebSocket(preset, input.websocket),\n  };\n}\n\n/**\n * Resolve full configuration\n * \n * Merges base config + security config + env config into a complete ResolvedConfig.\n */\nexport function resolveConfig(\n  base: BaseConfig,\n  security: SecurityConfig,\n  env: Environment,\n  envInput: EnvConfigInput\n): ResolvedConfig {\n  const envConfig = resolveEnvConfig(env, envInput);\n  \n  return {\n    // From base\n    name: base.name,\n    displayName: base.displayName,\n    region: base.region,\n    \n    // From security\n    scopes: security.scopes,\n    appClients: security.appClients,\n    \n    // From env\n    env: envConfig.env,\n    dataSafety: envConfig.dataSafety,\n    lambda: envConfig.lambda,\n    api: envConfig.api,\n    vpc: envConfig.vpc,\n    observability: envConfig.observability,\n    websocket: envConfig.websocket,\n    \n    // Auto-generated\n    tags: {\n      Project: base.name,\n      Environment: env,\n      ManagedBy: 'venturekit',\n    },\n  };\n}\n"]}
@@ -0,0 +1,54 @@
1
+ /**
2
+ * API Gateway Environment Configuration
3
+ *
4
+ * Controls rate limiting and API behavior per environment.
5
+ * All fields are REQUIRED - no implicit defaults at the type level.
6
+ */
7
+ /**
8
+ * CORS configuration
9
+ */
10
+ export interface CorsConfig {
11
+ /** Allowed origins (e.g., ['https://app.example.com']) */
12
+ allowOrigins: string[];
13
+ /** Allowed HTTP methods */
14
+ allowMethods: string[];
15
+ /** Allowed headers */
16
+ allowHeaders: string[];
17
+ /** Allow credentials */
18
+ allowCredentials: boolean;
19
+ /** Max age in seconds for preflight cache */
20
+ maxAgeSec: number;
21
+ }
22
+ /**
23
+ * Custom domain configuration
24
+ */
25
+ export interface CustomDomainConfig {
26
+ /** Domain name (e.g., 'api.example.com') */
27
+ domainName: string;
28
+ /** ACM certificate ARN */
29
+ certificateArn: string;
30
+ }
31
+ /**
32
+ * API Gateway configuration
33
+ *
34
+ * All fields required - use presets or explicit values.
35
+ */
36
+ export interface ApiEnvConfig {
37
+ /** Steady-state request rate limit (requests per second) */
38
+ throttleRateLimit: number;
39
+ /** Burst capacity (concurrent requests) */
40
+ throttleBurstLimit: number;
41
+ /** Enable detailed CloudWatch metrics */
42
+ detailedMetricsEnabled: boolean;
43
+ /** CORS configuration (undefined = no CORS) */
44
+ cors: CorsConfig | undefined;
45
+ /** Custom domain (undefined = use default API Gateway domain) */
46
+ customDomain: CustomDomainConfig | undefined;
47
+ }
48
+ /**
49
+ * API configuration input (for user overrides)
50
+ */
51
+ export type ApiEnvConfigInput = Partial<Omit<ApiEnvConfig, 'cors' | 'customDomain'>> & {
52
+ cors?: Partial<CorsConfig>;
53
+ customDomain?: CustomDomainConfig;
54
+ };