@stacksjs/ts-cloud 0.1.11 → 0.1.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (77) hide show
  1. package/README.md +41 -379
  2. package/dist/bin/cli.js +1039 -416
  3. package/dist/index.d.ts +34 -1
  4. package/dist/index.js +76467 -7133
  5. package/package.json +6 -6
  6. package/dist/aws/acm.d.ts +0 -129
  7. package/dist/aws/application-autoscaling.d.ts +0 -282
  8. package/dist/aws/bedrock.d.ts +0 -2292
  9. package/dist/aws/client.d.ts +0 -79
  10. package/dist/aws/cloudformation.d.ts +0 -105
  11. package/dist/aws/cloudfront.d.ts +0 -265
  12. package/dist/aws/cloudwatch-logs.d.ts +0 -48
  13. package/dist/aws/comprehend.d.ts +0 -505
  14. package/dist/aws/connect.d.ts +0 -377
  15. package/dist/aws/deploy-imap.d.ts +0 -14
  16. package/dist/aws/dynamodb.d.ts +0 -176
  17. package/dist/aws/ec2.d.ts +0 -272
  18. package/dist/aws/ecr.d.ts +0 -149
  19. package/dist/aws/ecs.d.ts +0 -162
  20. package/dist/aws/elasticache.d.ts +0 -71
  21. package/dist/aws/elbv2.d.ts +0 -248
  22. package/dist/aws/email.d.ts +0 -175
  23. package/dist/aws/eventbridge.d.ts +0 -142
  24. package/dist/aws/iam.d.ts +0 -638
  25. package/dist/aws/imap-server.d.ts +0 -119
  26. package/dist/aws/index.d.ts +0 -192
  27. package/dist/aws/kendra.d.ts +0 -782
  28. package/dist/aws/lambda.d.ts +0 -232
  29. package/dist/aws/opensearch.d.ts +0 -87
  30. package/dist/aws/personalize.d.ts +0 -516
  31. package/dist/aws/polly.d.ts +0 -214
  32. package/dist/aws/rds.d.ts +0 -240
  33. package/dist/aws/rekognition.d.ts +0 -543
  34. package/dist/aws/route53-domains.d.ts +0 -113
  35. package/dist/aws/route53.d.ts +0 -215
  36. package/dist/aws/s3.d.ts +0 -212
  37. package/dist/aws/scheduler.d.ts +0 -140
  38. package/dist/aws/secrets-manager.d.ts +0 -170
  39. package/dist/aws/ses.d.ts +0 -288
  40. package/dist/aws/setup-phone.d.ts +0 -0
  41. package/dist/aws/setup-sms.d.ts +0 -116
  42. package/dist/aws/sms.d.ts +0 -304
  43. package/dist/aws/smtp-server.d.ts +0 -61
  44. package/dist/aws/sns.d.ts +0 -117
  45. package/dist/aws/sqs.d.ts +0 -65
  46. package/dist/aws/ssm.d.ts +0 -179
  47. package/dist/aws/sts.d.ts +0 -15
  48. package/dist/aws/support.d.ts +0 -104
  49. package/dist/aws/test-imap.d.ts +0 -0
  50. package/dist/aws/textract.d.ts +0 -403
  51. package/dist/aws/transcribe.d.ts +0 -60
  52. package/dist/aws/translate.d.ts +0 -358
  53. package/dist/aws/voice.d.ts +0 -219
  54. package/dist/config.d.ts +0 -7
  55. package/dist/deploy/index.d.ts +0 -2
  56. package/dist/deploy/static-site-external-dns.d.ts +0 -51
  57. package/dist/deploy/static-site.d.ts +0 -71
  58. package/dist/dns/cloudflare.d.ts +0 -52
  59. package/dist/dns/godaddy.d.ts +0 -38
  60. package/dist/dns/index.d.ts +0 -45
  61. package/dist/dns/porkbun.d.ts +0 -18
  62. package/dist/dns/route53-adapter.d.ts +0 -38
  63. package/dist/dns/types.d.ts +0 -77
  64. package/dist/dns/validator.d.ts +0 -78
  65. package/dist/generators/index.d.ts +0 -1
  66. package/dist/generators/infrastructure.d.ts +0 -30
  67. package/dist/push/apns.d.ts +0 -60
  68. package/dist/push/fcm.d.ts +0 -117
  69. package/dist/push/index.d.ts +0 -14
  70. package/dist/security/pre-deploy-scanner.d.ts +0 -69
  71. package/dist/ssl/acme-client.d.ts +0 -67
  72. package/dist/ssl/index.d.ts +0 -2
  73. package/dist/ssl/letsencrypt.d.ts +0 -48
  74. package/dist/types.d.ts +0 -1
  75. package/dist/utils/cli.d.ts +0 -123
  76. package/dist/validation/index.d.ts +0 -1
  77. package/dist/validation/template.d.ts +0 -23
@@ -1,248 +0,0 @@
1
- import { AWSClient } from './client';
2
- export declare interface LoadBalancer {
3
- LoadBalancerArn?: string
4
- DNSName?: string
5
- CanonicalHostedZoneId?: string
6
- CreatedTime?: string
7
- LoadBalancerName?: string
8
- Scheme?: 'internet-facing' | 'internal'
9
- VpcId?: string
10
- State?: {
11
- Code?: 'active' | 'provisioning' | 'active_impaired' | 'failed'
12
- Reason?: string
13
- }
14
- Type?: 'application' | 'network' | 'gateway'
15
- AvailabilityZones?: AvailabilityZone[]
16
- SecurityGroups?: string[]
17
- IpAddressType?: 'ipv4' | 'dualstack'
18
- }
19
- export declare interface AvailabilityZone {
20
- ZoneName?: string
21
- SubnetId?: string
22
- OutpostId?: string
23
- LoadBalancerAddresses?: LoadBalancerAddress[]
24
- }
25
- export declare interface LoadBalancerAddress {
26
- IpAddress?: string
27
- AllocationId?: string
28
- PrivateIPv4Address?: string
29
- IPv6Address?: string
30
- }
31
- export declare interface TargetGroup {
32
- TargetGroupArn?: string
33
- TargetGroupName?: string
34
- Protocol?: string
35
- Port?: number
36
- VpcId?: string
37
- HealthCheckProtocol?: string
38
- HealthCheckPort?: string
39
- HealthCheckEnabled?: boolean
40
- HealthCheckIntervalSeconds?: number
41
- HealthCheckTimeoutSeconds?: number
42
- HealthyThresholdCount?: number
43
- UnhealthyThresholdCount?: number
44
- HealthCheckPath?: string
45
- Matcher?: {
46
- HttpCode?: string
47
- GrpcCode?: string
48
- }
49
- LoadBalancerArns?: string[]
50
- TargetType?: 'instance' | 'ip' | 'lambda' | 'alb'
51
- ProtocolVersion?: string
52
- IpAddressType?: 'ipv4' | 'ipv6'
53
- }
54
- export declare interface Listener {
55
- ListenerArn?: string
56
- LoadBalancerArn?: string
57
- Port?: number
58
- Protocol?: string
59
- Certificates?: Certificate[]
60
- SslPolicy?: string
61
- DefaultActions?: Action[]
62
- AlpnPolicy?: string[]
63
- }
64
- export declare interface Certificate {
65
- CertificateArn?: string
66
- IsDefault?: boolean
67
- }
68
- export declare interface Action {
69
- Type?: 'forward' | 'redirect' | 'fixed-response' | 'authenticate-oidc' | 'authenticate-cognito'
70
- TargetGroupArn?: string
71
- Order?: number
72
- RedirectConfig?: {
73
- Protocol?: string
74
- Port?: string
75
- Host?: string
76
- Path?: string
77
- Query?: string
78
- StatusCode?: 'HTTP_301' | 'HTTP_302'
79
- }
80
- FixedResponseConfig?: {
81
- MessageBody?: string
82
- StatusCode?: string
83
- ContentType?: string
84
- }
85
- ForwardConfig?: {
86
- TargetGroups?: Array<{
87
- TargetGroupArn?: string
88
- Weight?: number
89
- }>
90
- TargetGroupStickinessConfig?: {
91
- Enabled?: boolean
92
- DurationSeconds?: number
93
- }
94
- }
95
- }
96
- export declare interface Rule {
97
- RuleArn?: string
98
- Priority?: string
99
- Conditions?: Condition[]
100
- Actions?: Action[]
101
- IsDefault?: boolean
102
- }
103
- export declare interface Condition {
104
- Field?: string
105
- Values?: string[]
106
- HostHeaderConfig?: { Values?: string[] }
107
- PathPatternConfig?: { Values?: string[] }
108
- HttpHeaderConfig?: { HttpHeaderName?: string, Values?: string[] }
109
- QueryStringConfig?: { Values?: Array<{ Key?: string, Value?: string }> }
110
- HttpRequestMethodConfig?: { Values?: string[] }
111
- SourceIpConfig?: { Values?: string[] }
112
- }
113
- export declare interface TargetHealthDescription {
114
- Target?: {
115
- Id?: string
116
- Port?: number
117
- AvailabilityZone?: string
118
- }
119
- HealthCheckPort?: string
120
- TargetHealth?: {
121
- State?: 'initial' | 'healthy' | 'unhealthy' | 'unused' | 'draining' | 'unavailable'
122
- Reason?: string
123
- Description?: string
124
- }
125
- }
126
- /**
127
- * ELBv2 client for managing Application, Network, and Gateway Load Balancers
128
- */
129
- export declare class ELBv2Client {
130
- private client: AWSClient;
131
- private region: string;
132
- constructor(region?: string);
133
- describeLoadBalancers(options?: {
134
- LoadBalancerArns?: string[]
135
- Names?: string[]
136
- Marker?: string
137
- PageSize?: number
138
- }): Promise<{ LoadBalancers?: LoadBalancer[], NextMarker?: string }>;
139
- describeTargetGroups(options?: {
140
- LoadBalancerArn?: string
141
- TargetGroupArns?: string[]
142
- Names?: string[]
143
- Marker?: string
144
- PageSize?: number
145
- }): Promise<{ TargetGroups?: TargetGroup[], NextMarker?: string }>;
146
- describeTargetHealth(options: {
147
- TargetGroupArn: string
148
- Targets?: Array<{ Id: string, Port?: number, AvailabilityZone?: string }>
149
- }): Promise<{ TargetHealthDescriptions?: TargetHealthDescription[] }>;
150
- describeListeners(options?: {
151
- LoadBalancerArn?: string
152
- ListenerArns?: string[]
153
- Marker?: string
154
- PageSize?: number
155
- }): Promise<{ Listeners?: Listener[], NextMarker?: string }>;
156
- describeRules(options?: {
157
- ListenerArn?: string
158
- RuleArns?: string[]
159
- Marker?: string
160
- PageSize?: number
161
- }): Promise<{ Rules?: Rule[], NextMarker?: string }>;
162
- describeLoadBalancerAttributes(loadBalancerArn: string): Promise<{ Attributes?: Array<{ Key: string, Value: string }> }>;
163
- describeTargetGroupAttributes(targetGroupArn: string): Promise<{ Attributes?: Array<{ Key: string, Value: string }> }>;
164
- createLoadBalancer(options: {
165
- Name: string
166
- Subnets?: string[]
167
- SubnetMappings?: Array<{
168
- SubnetId: string
169
- AllocationId?: string
170
- PrivateIPv4Address?: string
171
- IPv6Address?: string
172
- }>
173
- SecurityGroups?: string[]
174
- Scheme?: 'internet-facing' | 'internal'
175
- Type?: 'application' | 'network' | 'gateway'
176
- IpAddressType?: 'ipv4' | 'dualstack'
177
- Tags?: Array<{ Key: string, Value: string }>
178
- }): Promise<{ LoadBalancers?: LoadBalancer[] }>;
179
- deleteLoadBalancer(loadBalancerArn: string): Promise<void>;
180
- createTargetGroup(options: {
181
- Name: string
182
- Protocol?: string
183
- ProtocolVersion?: string
184
- Port?: number
185
- VpcId?: string
186
- HealthCheckProtocol?: string
187
- HealthCheckPort?: string
188
- HealthCheckEnabled?: boolean
189
- HealthCheckPath?: string
190
- HealthCheckIntervalSeconds?: number
191
- HealthCheckTimeoutSeconds?: number
192
- HealthyThresholdCount?: number
193
- UnhealthyThresholdCount?: number
194
- Matcher?: { HttpCode?: string, GrpcCode?: string }
195
- TargetType?: 'instance' | 'ip' | 'lambda' | 'alb'
196
- Tags?: Array<{ Key: string, Value: string }>
197
- IpAddressType?: 'ipv4' | 'ipv6'
198
- }): Promise<{ TargetGroups?: TargetGroup[] }>;
199
- deleteTargetGroup(targetGroupArn: string): Promise<void>;
200
- registerTargets(options: {
201
- TargetGroupArn: string
202
- Targets: Array<{ Id: string, Port?: number, AvailabilityZone?: string }>
203
- }): Promise<void>;
204
- deregisterTargets(options: {
205
- TargetGroupArn: string
206
- Targets: Array<{ Id: string, Port?: number, AvailabilityZone?: string }>
207
- }): Promise<void>;
208
- createListener(options: {
209
- LoadBalancerArn: string
210
- Protocol?: string
211
- Port: number
212
- SslPolicy?: string
213
- Certificates?: Array<{ CertificateArn: string }>
214
- DefaultActions: Array<{
215
- Type: 'forward' | 'redirect' | 'fixed-response'
216
- TargetGroupArn?: string
217
- Order?: number
218
- RedirectConfig?: {
219
- Protocol?: string
220
- Port?: string
221
- Host?: string
222
- Path?: string
223
- Query?: string
224
- StatusCode: 'HTTP_301' | 'HTTP_302'
225
- }
226
- FixedResponseConfig?: {
227
- MessageBody?: string
228
- StatusCode: string
229
- ContentType?: string
230
- }
231
- }>
232
- AlpnPolicy?: string[]
233
- Tags?: Array<{ Key: string, Value: string }>
234
- }): Promise<{ Listeners?: Listener[] }>;
235
- deleteListener(listenerArn: string): Promise<void>;
236
- modifyListener(options: {
237
- ListenerArn: string
238
- Port?: number
239
- Protocol?: string
240
- SslPolicy?: string
241
- Certificates?: Array<{ CertificateArn: string }>
242
- DefaultActions?: Action[]
243
- AlpnPolicy?: string[]
244
- }): Promise<{ Listeners?: Listener[] }>;
245
- private buildFormBody(action: string, params: Record<string, any>): string;
246
- private normalizeResult(parsed: any, resultKey: string): any;
247
- private normalizeArrays(obj: any): any;
248
- }
@@ -1,175 +0,0 @@
1
- import { IAMClient } from './iam';
2
- import { Route53Client } from './route53';
3
- import { S3Client } from './s3';
4
- import { SESClient } from './ses';
5
- // Export a default instance for convenience
6
- export declare const email: EmailClient;
7
- export declare interface EmailConfig {
8
- domain: string
9
- region?: string
10
- mailboxes?: string[]
11
- storage?: {
12
- bucket?: string
13
- prefix?: string
14
- retentionDays?: number
15
- }
16
- smtp?: {
17
- enabled?: boolean
18
- username?: string
19
- }
20
- }
21
- export declare interface EmailSetupResult {
22
- domainVerified: boolean
23
- dkimStatus: string
24
- dkimTokens?: string[]
25
- mailFromStatus?: string
26
- receiptRuleSet?: string
27
- storageBucket?: string
28
- smtpCredentials?: {
29
- username: string
30
- server: string
31
- port: number
32
- }
33
- }
34
- export declare interface SendEmailOptions {
35
- from?: string
36
- fromName?: string
37
- to: string | string[]
38
- cc?: string | string[]
39
- bcc?: string | string[]
40
- subject: string
41
- text?: string
42
- html?: string
43
- replyTo?: string | string[]
44
- attachments?: Array<{
45
- filename: string
46
- content: string // Base64 encoded
47
- contentType?: string
48
- }>
49
- }
50
- export declare interface EmailDeploymentConfig {
51
- domain: string
52
- accountId: string
53
- region?: string
54
- appName: string
55
- environment: string
56
- mailboxes?: string[]
57
- catchAll?: boolean
58
- storage?: {
59
- bucketName?: string
60
- prefix?: string
61
- }
62
- notifications?: {
63
- bounces?: boolean
64
- complaints?: boolean
65
- newEmail?: boolean
66
- }
67
- }
68
- /**
69
- * High-level Email client for serverless and server deployments
70
- */
71
- export declare class EmailClient {
72
- private ses: SESClient;
73
- private s3: S3Client;
74
- private iam: IAMClient;
75
- private route53: Route53Client;
76
- private region: string;
77
- private domain?: string;
78
- private defaultFrom?: string;
79
- constructor(options?: {
80
- region?: string
81
- domain?: string
82
- defaultFrom?: string
83
- });
84
- send(options: SendEmailOptions): Promise<{ messageId: string }>;
85
- sendTemplate(options: {
86
- from?: string
87
- fromName?: string
88
- to: string | string[]
89
- templateName: string
90
- templateData: Record<string, any>
91
- replyTo?: string | string[]
92
- }): Promise<{ messageId: string }>;
93
- sendBulk(options: {
94
- from?: string
95
- templateName: string
96
- defaultTemplateData: Record<string, any>
97
- recipients: Array<{
98
- to: string | string[]
99
- templateData?: Record<string, any>
100
- }>
101
- }): Promise<{ results: Array<{ status: string; messageId?: string; error?: string }> }>;
102
- setupDomain(domain: string): Promise<EmailSetupResult>;
103
- getDnsRecords(domain: string): Promise<Array<{
104
- type: string
105
- name: string
106
- value: string
107
- priority?: number
108
- ttl?: number
109
- }>>;
110
- isDomainReady(domain: string): Promise<boolean>;
111
- setupReceiving(config: {
112
- domain: string
113
- ruleSetName: string
114
- ruleName: string
115
- bucketName: string
116
- prefix?: string
117
- accountId: string
118
- recipients?: string[] // If not provided, catches all domain emails
119
- scanEnabled?: boolean
120
- lambdaArn?: string
121
- }): Promise<void>;
122
- getIncomingEmails(options: {
123
- bucket: string
124
- prefix?: string
125
- maxResults?: number
126
- }): Promise<Array<{ key: string; lastModified: string; size: number }>>;
127
- readEmail(options: {
128
- bucket: string
129
- key: string
130
- }): Promise<string>;
131
- createSmtpCredentials(options: {
132
- username: string
133
- domain: string
134
- }): Promise<{
135
- username: string
136
- password: string
137
- server: string
138
- port: number
139
- }>;
140
- private deriveSmtpPassword(secretAccessKey: string): string;
141
- createTemplate(options: {
142
- name: string
143
- subject: string
144
- text?: string
145
- html?: string
146
- }): Promise<void>;
147
- getTemplate(name: string): Promise<{
148
- name: string
149
- subject?: string
150
- text?: string
151
- html?: string
152
- } | null>;
153
- deleteTemplate(name: string): Promise<void>;
154
- listTemplates(): Promise<Array<{ name: string; createdAt?: string }>>;
155
- deploy(config: EmailDeploymentConfig): Promise<{
156
- success: boolean
157
- domainVerified: boolean
158
- dkimStatus: string
159
- receiptRuleSet: string
160
- storageBucket: string
161
- dnsRecords: Array<{ type: string; name: string; value: string }>
162
- }>;
163
- undeploy(config: {
164
- appName: string
165
- environment: string
166
- domain: string
167
- deleteBucket?: boolean
168
- }): Promise<void>;
169
- getSendingStats(): Promise<{
170
- sentLast24Hours: number
171
- maxSendRate: number
172
- max24HourSend: number
173
- }>;
174
- private buildRawEmail(options: SendEmailOptions, from: string, to: string[]): string;
175
- }
@@ -1,142 +0,0 @@
1
- import { AWSClient } from './client';
2
- export declare interface EventBridgeRule {
3
- Name: string
4
- Arn?: string
5
- EventPattern?: string
6
- ScheduleExpression?: string
7
- State?: 'ENABLED' | 'DISABLED'
8
- Description?: string
9
- RoleArn?: string
10
- EventBusName?: string
11
- }
12
- export declare interface EventBus {
13
- Name?: string
14
- Arn?: string
15
- Policy?: string
16
- }
17
- export declare interface EventBridgeTarget {
18
- Id: string
19
- Arn: string
20
- RoleArn?: string
21
- Input?: string
22
- InputPath?: string
23
- InputTransformer?: {
24
- InputPathsMap?: Record<string, string>
25
- InputTemplate: string
26
- }
27
- RetryPolicy?: {
28
- MaximumRetryAttempts?: number
29
- MaximumEventAgeInSeconds?: number
30
- }
31
- }
32
- /**
33
- * EventBridge client for direct API calls
34
- */
35
- export declare class EventBridgeClient {
36
- private client: AWSClient;
37
- private region: string;
38
- constructor(region?: string);
39
- private request<T>(action: string, params: Record<string, any>): Promise<T>;
40
- putRule(params: {
41
- Name: string
42
- ScheduleExpression?: string
43
- EventPattern?: string
44
- State?: 'ENABLED' | 'DISABLED'
45
- Description?: string
46
- RoleArn?: string
47
- Tags?: Array<{ Key: string; Value: string }>
48
- EventBusName?: string
49
- }): Promise<{ RuleArn: string }>;
50
- deleteRule(params: {
51
- Name: string
52
- EventBusName?: string
53
- Force?: boolean
54
- }): Promise<void>;
55
- describeRule(params: {
56
- Name: string
57
- EventBusName?: string
58
- }): Promise<EventBridgeRule>;
59
- listRules(params?: {
60
- NamePrefix?: string
61
- EventBusName?: string
62
- NextToken?: string
63
- Limit?: number
64
- }): Promise<{ Rules: EventBridgeRule[]; NextToken?: string }>;
65
- listEventBuses(params?: {
66
- NamePrefix?: string
67
- NextToken?: string
68
- Limit?: number
69
- }): Promise<{ EventBuses: EventBus[]; NextToken?: string }>;
70
- enableRule(params: {
71
- Name: string
72
- EventBusName?: string
73
- }): Promise<void>;
74
- disableRule(params: {
75
- Name: string
76
- EventBusName?: string
77
- }): Promise<void>;
78
- putTargets(params: {
79
- Rule: string
80
- EventBusName?: string
81
- Targets: EventBridgeTarget[]
82
- }): Promise<{
83
- FailedEntryCount: number
84
- FailedEntries: Array<{
85
- TargetId: string
86
- ErrorCode: string
87
- ErrorMessage: string
88
- }>
89
- }>;
90
- removeTargets(params: {
91
- Rule: string
92
- EventBusName?: string
93
- Ids: string[]
94
- Force?: boolean
95
- }): Promise<{
96
- FailedEntryCount: number
97
- FailedEntries: Array<{
98
- TargetId: string
99
- ErrorCode: string
100
- ErrorMessage: string
101
- }>
102
- }>;
103
- listTargetsByRule(params: {
104
- Rule: string
105
- EventBusName?: string
106
- NextToken?: string
107
- Limit?: number
108
- }): Promise<{ Targets: EventBridgeTarget[]; NextToken?: string }>;
109
- putEvents(params: {
110
- Entries: Array<{
111
- Time?: string
112
- Source: string
113
- Resources?: string[]
114
- DetailType: string
115
- Detail: string
116
- EventBusName?: string
117
- }>
118
- }): Promise<{
119
- FailedEntryCount: number
120
- Entries: Array<{
121
- EventId?: string
122
- ErrorCode?: string
123
- ErrorMessage?: string
124
- }>
125
- }>;
126
- createSchedule(params: {
127
- Name: string
128
- ScheduleExpression: string
129
- FlexibleTimeWindow: {
130
- Mode: 'OFF' | 'FLEXIBLE'
131
- MaximumWindowInMinutes?: number
132
- }
133
- Target: {
134
- Arn: string
135
- RoleArn: string
136
- Input?: string
137
- }
138
- Description?: string
139
- State?: 'ENABLED' | 'DISABLED'
140
- GroupName?: string
141
- }): Promise<{ ScheduleArn: string }>;
142
- }