@stacksjs/ts-cloud 0.1.7 → 0.1.9

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/dist/aws/s3.d.ts +1 -1
  2. package/dist/bin/cli.js +223 -222
  3. package/dist/index.js +132 -132
  4. package/package.json +18 -16
  5. package/src/aws/acm.ts +768 -0
  6. package/src/aws/application-autoscaling.ts +845 -0
  7. package/src/aws/bedrock.ts +4074 -0
  8. package/src/aws/client.ts +891 -0
  9. package/src/aws/cloudformation.ts +896 -0
  10. package/src/aws/cloudfront.ts +1531 -0
  11. package/src/aws/cloudwatch-logs.ts +154 -0
  12. package/src/aws/comprehend.ts +839 -0
  13. package/src/aws/connect.ts +1056 -0
  14. package/src/aws/deploy-imap.ts +384 -0
  15. package/src/aws/dynamodb.ts +340 -0
  16. package/src/aws/ec2.ts +1385 -0
  17. package/src/aws/ecr.ts +621 -0
  18. package/src/aws/ecs.ts +615 -0
  19. package/src/aws/elasticache.ts +301 -0
  20. package/src/aws/elbv2.ts +942 -0
  21. package/src/aws/email.ts +928 -0
  22. package/src/aws/eventbridge.ts +248 -0
  23. package/src/aws/iam.ts +1689 -0
  24. package/src/aws/imap-server.ts +2100 -0
  25. package/src/aws/index.ts +213 -0
  26. package/src/aws/kendra.ts +1097 -0
  27. package/src/aws/lambda.ts +786 -0
  28. package/src/aws/opensearch.ts +158 -0
  29. package/src/aws/personalize.ts +977 -0
  30. package/src/aws/polly.ts +559 -0
  31. package/src/aws/rds.ts +888 -0
  32. package/src/aws/rekognition.ts +846 -0
  33. package/src/aws/route53-domains.ts +359 -0
  34. package/src/aws/route53.ts +1046 -0
  35. package/src/aws/s3.ts +2334 -0
  36. package/src/aws/scheduler.ts +571 -0
  37. package/src/aws/secrets-manager.ts +769 -0
  38. package/src/aws/ses.ts +1081 -0
  39. package/src/aws/setup-phone.ts +104 -0
  40. package/src/aws/setup-sms.ts +580 -0
  41. package/src/aws/sms.ts +1735 -0
  42. package/src/aws/smtp-server.ts +531 -0
  43. package/src/aws/sns.ts +758 -0
  44. package/src/aws/sqs.ts +382 -0
  45. package/src/aws/ssm.ts +807 -0
  46. package/src/aws/sts.ts +92 -0
  47. package/src/aws/support.ts +391 -0
  48. package/src/aws/test-imap.ts +86 -0
  49. package/src/aws/textract.ts +780 -0
  50. package/src/aws/transcribe.ts +108 -0
  51. package/src/aws/translate.ts +641 -0
  52. package/src/aws/voice.ts +1379 -0
  53. package/src/config.ts +35 -0
  54. package/src/deploy/index.ts +7 -0
  55. package/src/deploy/static-site-external-dns.ts +945 -0
  56. package/src/deploy/static-site.ts +1175 -0
  57. package/src/dns/cloudflare.ts +548 -0
  58. package/src/dns/godaddy.ts +412 -0
  59. package/src/dns/index.ts +205 -0
  60. package/src/dns/porkbun.ts +362 -0
  61. package/src/dns/route53-adapter.ts +414 -0
  62. package/src/dns/types.ts +119 -0
  63. package/src/dns/validator.ts +369 -0
  64. package/src/generators/index.ts +5 -0
  65. package/src/generators/infrastructure.ts +1660 -0
  66. package/src/index.ts +163 -0
  67. package/src/push/apns.ts +452 -0
  68. package/src/push/fcm.ts +506 -0
  69. package/src/push/index.ts +58 -0
  70. package/src/security/pre-deploy-scanner.ts +655 -0
  71. package/src/ssl/acme-client.ts +478 -0
  72. package/src/ssl/index.ts +7 -0
  73. package/src/ssl/letsencrypt.ts +747 -0
  74. package/src/types.ts +2 -0
  75. package/src/utils/cli.ts +398 -0
  76. package/src/validation/index.ts +5 -0
  77. package/src/validation/template.ts +405 -0
package/src/aws/sqs.ts ADDED
@@ -0,0 +1,382 @@
1
+ /**
2
+ * AWS SQS Operations
3
+ * Direct API calls without AWS CLI dependency
4
+ */
5
+
6
+ import { AWSClient } from './client'
7
+
8
+ export interface QueueAttributes {
9
+ QueueUrl: string
10
+ QueueArn?: string
11
+ ApproximateNumberOfMessages?: string
12
+ ApproximateNumberOfMessagesNotVisible?: string
13
+ ApproximateNumberOfMessagesDelayed?: string
14
+ CreatedTimestamp?: string
15
+ LastModifiedTimestamp?: string
16
+ VisibilityTimeout?: string
17
+ MaximumMessageSize?: string
18
+ MessageRetentionPeriod?: string
19
+ DelaySeconds?: string
20
+ ReceiveMessageWaitTimeSeconds?: string
21
+ FifoQueue?: string
22
+ ContentBasedDeduplication?: string
23
+ }
24
+
25
+ export interface CreateQueueOptions {
26
+ queueName: string
27
+ fifo?: boolean
28
+ visibilityTimeout?: number
29
+ messageRetentionPeriod?: number
30
+ delaySeconds?: number
31
+ maxMessageSize?: number
32
+ receiveMessageWaitTime?: number
33
+ deadLetterTargetArn?: string
34
+ maxReceiveCount?: number
35
+ contentBasedDeduplication?: boolean
36
+ tags?: Record<string, string>
37
+ }
38
+
39
+ export interface Message {
40
+ MessageId: string
41
+ ReceiptHandle: string
42
+ Body: string
43
+ Attributes?: Record<string, string>
44
+ MessageAttributes?: Record<string, any>
45
+ }
46
+
47
+ /**
48
+ * SQS queue management using direct API calls
49
+ */
50
+ export class SQSClient {
51
+ private client: AWSClient
52
+ private region: string
53
+
54
+ constructor(region: string = 'us-east-1', profile?: string) {
55
+ this.region = region
56
+ this.client = new AWSClient()
57
+ }
58
+
59
+ /**
60
+ * Create a new SQS queue
61
+ */
62
+ async createQueue(options: CreateQueueOptions): Promise<{ QueueUrl: string }> {
63
+ const queueName = options.fifo && !options.queueName.endsWith('.fifo')
64
+ ? `${options.queueName}.fifo`
65
+ : options.queueName
66
+
67
+ const params: Record<string, any> = {
68
+ Action: 'CreateQueue',
69
+ QueueName: queueName,
70
+ Version: '2012-11-05',
71
+ }
72
+
73
+ let attrIndex = 1
74
+
75
+ if (options.visibilityTimeout !== undefined) {
76
+ params[`Attribute.${attrIndex}.Name`] = 'VisibilityTimeout'
77
+ params[`Attribute.${attrIndex}.Value`] = options.visibilityTimeout.toString()
78
+ attrIndex++
79
+ }
80
+
81
+ if (options.messageRetentionPeriod !== undefined) {
82
+ params[`Attribute.${attrIndex}.Name`] = 'MessageRetentionPeriod'
83
+ params[`Attribute.${attrIndex}.Value`] = options.messageRetentionPeriod.toString()
84
+ attrIndex++
85
+ }
86
+
87
+ if (options.delaySeconds !== undefined) {
88
+ params[`Attribute.${attrIndex}.Name`] = 'DelaySeconds'
89
+ params[`Attribute.${attrIndex}.Value`] = options.delaySeconds.toString()
90
+ attrIndex++
91
+ }
92
+
93
+ if (options.maxMessageSize !== undefined) {
94
+ params[`Attribute.${attrIndex}.Name`] = 'MaximumMessageSize'
95
+ params[`Attribute.${attrIndex}.Value`] = options.maxMessageSize.toString()
96
+ attrIndex++
97
+ }
98
+
99
+ if (options.receiveMessageWaitTime !== undefined) {
100
+ params[`Attribute.${attrIndex}.Name`] = 'ReceiveMessageWaitTimeSeconds'
101
+ params[`Attribute.${attrIndex}.Value`] = options.receiveMessageWaitTime.toString()
102
+ attrIndex++
103
+ }
104
+
105
+ if (options.fifo) {
106
+ params[`Attribute.${attrIndex}.Name`] = 'FifoQueue'
107
+ params[`Attribute.${attrIndex}.Value`] = 'true'
108
+ attrIndex++
109
+
110
+ if (options.contentBasedDeduplication) {
111
+ params[`Attribute.${attrIndex}.Name`] = 'ContentBasedDeduplication'
112
+ params[`Attribute.${attrIndex}.Value`] = 'true'
113
+ attrIndex++
114
+ }
115
+ }
116
+
117
+ if (options.deadLetterTargetArn && options.maxReceiveCount) {
118
+ params[`Attribute.${attrIndex}.Name`] = 'RedrivePolicy'
119
+ params[`Attribute.${attrIndex}.Value`] = JSON.stringify({
120
+ deadLetterTargetArn: options.deadLetterTargetArn,
121
+ maxReceiveCount: options.maxReceiveCount,
122
+ })
123
+ attrIndex++
124
+ }
125
+
126
+ if (options.tags && Object.keys(options.tags).length > 0) {
127
+ let tagIndex = 1
128
+ for (const [key, value] of Object.entries(options.tags)) {
129
+ params[`Tag.${tagIndex}.Key`] = key
130
+ params[`Tag.${tagIndex}.Value`] = value
131
+ tagIndex++
132
+ }
133
+ }
134
+
135
+ const result = await this.client.request({
136
+ service: 'sqs',
137
+ region: this.region,
138
+ method: 'POST',
139
+ path: '/',
140
+ body: new URLSearchParams(params).toString(),
141
+ })
142
+
143
+ return { QueueUrl: result.QueueUrl || result.CreateQueueResult?.QueueUrl }
144
+ }
145
+
146
+ /**
147
+ * List all queues
148
+ */
149
+ async listQueues(prefix?: string): Promise<{ QueueUrls: string[] }> {
150
+ const params: Record<string, any> = {
151
+ Action: 'ListQueues',
152
+ Version: '2012-11-05',
153
+ }
154
+
155
+ if (prefix) {
156
+ params.QueueNamePrefix = prefix
157
+ }
158
+
159
+ const result = await this.client.request({
160
+ service: 'sqs',
161
+ region: this.region,
162
+ method: 'POST',
163
+ path: '/',
164
+ body: new URLSearchParams(params).toString(),
165
+ })
166
+
167
+ // Parse queue URLs from response
168
+ const queueUrls: string[] = []
169
+ if (result.QueueUrl) {
170
+ queueUrls.push(result.QueueUrl)
171
+ }
172
+ else if (result.ListQueuesResult?.QueueUrl) {
173
+ if (Array.isArray(result.ListQueuesResult.QueueUrl)) {
174
+ queueUrls.push(...result.ListQueuesResult.QueueUrl)
175
+ }
176
+ else {
177
+ queueUrls.push(result.ListQueuesResult.QueueUrl)
178
+ }
179
+ }
180
+
181
+ return { QueueUrls: queueUrls }
182
+ }
183
+
184
+ /**
185
+ * Get queue attributes
186
+ */
187
+ async getQueueAttributes(queueUrl: string): Promise<{ Attributes: Record<string, string> }> {
188
+ const params: Record<string, any> = {
189
+ Action: 'GetQueueAttributes',
190
+ QueueUrl: queueUrl,
191
+ Version: '2012-11-05',
192
+ 'AttributeName.1': 'All',
193
+ }
194
+
195
+ const result = await this.client.request({
196
+ service: 'sqs',
197
+ region: this.region,
198
+ method: 'POST',
199
+ path: '/',
200
+ body: new URLSearchParams(params).toString(),
201
+ })
202
+
203
+ return { Attributes: result.Attributes || result.GetQueueAttributesResult?.Attributes || {} }
204
+ }
205
+
206
+ /**
207
+ * Get queue URL by name
208
+ */
209
+ async getQueueUrl(queueName: string): Promise<{ QueueUrl: string }> {
210
+ const params: Record<string, any> = {
211
+ Action: 'GetQueueUrl',
212
+ QueueName: queueName,
213
+ Version: '2012-11-05',
214
+ }
215
+
216
+ const result = await this.client.request({
217
+ service: 'sqs',
218
+ region: this.region,
219
+ method: 'POST',
220
+ path: '/',
221
+ body: new URLSearchParams(params).toString(),
222
+ })
223
+
224
+ return { QueueUrl: result.QueueUrl || result.GetQueueUrlResult?.QueueUrl }
225
+ }
226
+
227
+ /**
228
+ * Delete a queue
229
+ */
230
+ async deleteQueue(queueUrl: string): Promise<void> {
231
+ const params: Record<string, any> = {
232
+ Action: 'DeleteQueue',
233
+ QueueUrl: queueUrl,
234
+ Version: '2012-11-05',
235
+ }
236
+
237
+ await this.client.request({
238
+ service: 'sqs',
239
+ region: this.region,
240
+ method: 'POST',
241
+ path: '/',
242
+ body: new URLSearchParams(params).toString(),
243
+ })
244
+ }
245
+
246
+ /**
247
+ * Purge queue (delete all messages)
248
+ */
249
+ async purgeQueue(queueUrl: string): Promise<void> {
250
+ const params: Record<string, any> = {
251
+ Action: 'PurgeQueue',
252
+ QueueUrl: queueUrl,
253
+ Version: '2012-11-05',
254
+ }
255
+
256
+ await this.client.request({
257
+ service: 'sqs',
258
+ region: this.region,
259
+ method: 'POST',
260
+ path: '/',
261
+ body: new URLSearchParams(params).toString(),
262
+ })
263
+ }
264
+
265
+ /**
266
+ * Send message to queue
267
+ */
268
+ async sendMessage(options: {
269
+ queueUrl: string
270
+ messageBody: string
271
+ delaySeconds?: number
272
+ messageGroupId?: string
273
+ messageDeduplicationId?: string
274
+ }): Promise<{ MessageId: string }> {
275
+ const params: Record<string, any> = {
276
+ Action: 'SendMessage',
277
+ QueueUrl: options.queueUrl,
278
+ MessageBody: options.messageBody,
279
+ Version: '2012-11-05',
280
+ }
281
+
282
+ if (options.delaySeconds !== undefined) {
283
+ params.DelaySeconds = options.delaySeconds
284
+ }
285
+
286
+ if (options.messageGroupId) {
287
+ params.MessageGroupId = options.messageGroupId
288
+ }
289
+
290
+ if (options.messageDeduplicationId) {
291
+ params.MessageDeduplicationId = options.messageDeduplicationId
292
+ }
293
+
294
+ const result = await this.client.request({
295
+ service: 'sqs',
296
+ region: this.region,
297
+ method: 'POST',
298
+ path: '/',
299
+ body: new URLSearchParams(params).toString(),
300
+ })
301
+
302
+ return { MessageId: result.MessageId || result.SendMessageResult?.MessageId }
303
+ }
304
+
305
+ /**
306
+ * Receive messages from queue
307
+ */
308
+ async receiveMessages(options: {
309
+ queueUrl: string
310
+ maxMessages?: number
311
+ visibilityTimeout?: number
312
+ waitTimeSeconds?: number
313
+ }): Promise<{ Messages: Message[] }> {
314
+ const params: Record<string, any> = {
315
+ Action: 'ReceiveMessage',
316
+ QueueUrl: options.queueUrl,
317
+ Version: '2012-11-05',
318
+ }
319
+
320
+ if (options.maxMessages !== undefined) {
321
+ params.MaxNumberOfMessages = options.maxMessages
322
+ }
323
+
324
+ if (options.visibilityTimeout !== undefined) {
325
+ params.VisibilityTimeout = options.visibilityTimeout
326
+ }
327
+
328
+ if (options.waitTimeSeconds !== undefined) {
329
+ params.WaitTimeSeconds = options.waitTimeSeconds
330
+ }
331
+
332
+ const result = await this.client.request({
333
+ service: 'sqs',
334
+ region: this.region,
335
+ method: 'POST',
336
+ path: '/',
337
+ body: new URLSearchParams(params).toString(),
338
+ })
339
+
340
+ const messages: Message[] = []
341
+ const msgData = result.Message || result.ReceiveMessageResult?.Message
342
+
343
+ if (msgData) {
344
+ if (Array.isArray(msgData)) {
345
+ messages.push(...msgData.map((m: any) => ({
346
+ MessageId: m.MessageId,
347
+ ReceiptHandle: m.ReceiptHandle,
348
+ Body: m.Body,
349
+ })))
350
+ }
351
+ else {
352
+ messages.push({
353
+ MessageId: msgData.MessageId,
354
+ ReceiptHandle: msgData.ReceiptHandle,
355
+ Body: msgData.Body,
356
+ })
357
+ }
358
+ }
359
+
360
+ return { Messages: messages }
361
+ }
362
+
363
+ /**
364
+ * Delete message from queue
365
+ */
366
+ async deleteMessage(queueUrl: string, receiptHandle: string): Promise<void> {
367
+ const params: Record<string, any> = {
368
+ Action: 'DeleteMessage',
369
+ QueueUrl: queueUrl,
370
+ ReceiptHandle: receiptHandle,
371
+ Version: '2012-11-05',
372
+ }
373
+
374
+ await this.client.request({
375
+ service: 'sqs',
376
+ region: this.region,
377
+ method: 'POST',
378
+ path: '/',
379
+ body: new URLSearchParams(params).toString(),
380
+ })
381
+ }
382
+ }