@stacksjs/ts-cloud 0.1.2 → 0.1.5

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 (187) hide show
  1. package/README.md +98 -13
  2. package/dist/aws/acm.d.ts +129 -0
  3. package/dist/aws/application-autoscaling.d.ts +282 -0
  4. package/dist/aws/bedrock.d.ts +2292 -0
  5. package/dist/aws/client.d.ts +79 -0
  6. package/dist/aws/cloudformation.d.ts +105 -0
  7. package/dist/aws/cloudfront.d.ts +265 -0
  8. package/dist/aws/cloudwatch-logs.d.ts +48 -0
  9. package/dist/aws/comprehend.d.ts +505 -0
  10. package/dist/aws/connect.d.ts +377 -0
  11. package/dist/aws/deploy-imap.d.ts +14 -0
  12. package/dist/aws/dynamodb.d.ts +176 -0
  13. package/dist/aws/ec2.d.ts +272 -0
  14. package/dist/aws/ecr.d.ts +149 -0
  15. package/dist/aws/ecs.d.ts +162 -0
  16. package/dist/aws/elasticache.d.ts +71 -0
  17. package/dist/aws/elbv2.d.ts +248 -0
  18. package/dist/aws/email.d.ts +175 -0
  19. package/dist/aws/eventbridge.d.ts +142 -0
  20. package/dist/aws/iam.d.ts +638 -0
  21. package/dist/aws/imap-server.d.ts +119 -0
  22. package/{src/aws/index.ts → dist/aws/index.d.ts} +62 -83
  23. package/{src/aws/kendra.ts → dist/aws/kendra.d.ts} +71 -386
  24. package/dist/aws/lambda.d.ts +232 -0
  25. package/dist/aws/opensearch.d.ts +87 -0
  26. package/dist/aws/personalize.d.ts +516 -0
  27. package/dist/aws/polly.d.ts +214 -0
  28. package/dist/aws/rds.d.ts +240 -0
  29. package/dist/aws/rekognition.d.ts +543 -0
  30. package/dist/aws/route53-domains.d.ts +113 -0
  31. package/dist/aws/route53.d.ts +215 -0
  32. package/dist/aws/s3.d.ts +212 -0
  33. package/dist/aws/scheduler.d.ts +140 -0
  34. package/dist/aws/secrets-manager.d.ts +170 -0
  35. package/dist/aws/ses.d.ts +288 -0
  36. package/dist/aws/setup-phone.d.ts +0 -0
  37. package/dist/aws/setup-sms.d.ts +115 -0
  38. package/dist/aws/sms.d.ts +304 -0
  39. package/dist/aws/smtp-server.d.ts +61 -0
  40. package/dist/aws/sns.d.ts +117 -0
  41. package/dist/aws/sqs.d.ts +65 -0
  42. package/dist/aws/ssm.d.ts +179 -0
  43. package/dist/aws/sts.d.ts +15 -0
  44. package/dist/aws/support.d.ts +104 -0
  45. package/dist/aws/test-imap.d.ts +0 -0
  46. package/dist/aws/textract.d.ts +403 -0
  47. package/dist/aws/transcribe.d.ts +60 -0
  48. package/dist/aws/translate.d.ts +358 -0
  49. package/dist/aws/voice.d.ts +219 -0
  50. package/dist/bin/cli.js +1724 -0
  51. package/dist/config.d.ts +7 -0
  52. package/dist/deploy/index.d.ts +2 -0
  53. package/dist/deploy/static-site-external-dns.d.ts +51 -0
  54. package/dist/deploy/static-site.d.ts +71 -0
  55. package/dist/dns/cloudflare.d.ts +52 -0
  56. package/dist/dns/godaddy.d.ts +38 -0
  57. package/dist/dns/index.d.ts +45 -0
  58. package/dist/dns/porkbun.d.ts +18 -0
  59. package/dist/dns/route53-adapter.d.ts +38 -0
  60. package/{src/dns/types.ts → dist/dns/types.d.ts} +26 -63
  61. package/dist/dns/validator.d.ts +78 -0
  62. package/dist/generators/index.d.ts +1 -0
  63. package/dist/generators/infrastructure.d.ts +30 -0
  64. package/{src/index.ts → dist/index.d.ts} +70 -93
  65. package/dist/index.js +7881 -0
  66. package/dist/push/apns.d.ts +60 -0
  67. package/dist/push/fcm.d.ts +117 -0
  68. package/dist/push/index.d.ts +14 -0
  69. package/dist/security/pre-deploy-scanner.d.ts +69 -0
  70. package/dist/ssl/acme-client.d.ts +67 -0
  71. package/dist/ssl/index.d.ts +2 -0
  72. package/dist/ssl/letsencrypt.d.ts +48 -0
  73. package/dist/types.d.ts +1 -0
  74. package/dist/utils/cli.d.ts +123 -0
  75. package/dist/validation/index.d.ts +1 -0
  76. package/dist/validation/template.d.ts +23 -0
  77. package/package.json +8 -8
  78. package/bin/cli.ts +0 -133
  79. package/bin/commands/analytics.ts +0 -328
  80. package/bin/commands/api.ts +0 -379
  81. package/bin/commands/assets.ts +0 -221
  82. package/bin/commands/audit.ts +0 -501
  83. package/bin/commands/backup.ts +0 -682
  84. package/bin/commands/cache.ts +0 -294
  85. package/bin/commands/cdn.ts +0 -281
  86. package/bin/commands/config.ts +0 -202
  87. package/bin/commands/container.ts +0 -105
  88. package/bin/commands/cost.ts +0 -208
  89. package/bin/commands/database.ts +0 -401
  90. package/bin/commands/deploy.ts +0 -674
  91. package/bin/commands/domain.ts +0 -397
  92. package/bin/commands/email.ts +0 -423
  93. package/bin/commands/environment.ts +0 -285
  94. package/bin/commands/events.ts +0 -424
  95. package/bin/commands/firewall.ts +0 -145
  96. package/bin/commands/function.ts +0 -116
  97. package/bin/commands/generate.ts +0 -280
  98. package/bin/commands/git.ts +0 -139
  99. package/bin/commands/iam.ts +0 -464
  100. package/bin/commands/index.ts +0 -48
  101. package/bin/commands/init.ts +0 -120
  102. package/bin/commands/logs.ts +0 -148
  103. package/bin/commands/network.ts +0 -579
  104. package/bin/commands/notify.ts +0 -489
  105. package/bin/commands/queue.ts +0 -407
  106. package/bin/commands/scheduler.ts +0 -370
  107. package/bin/commands/secrets.ts +0 -54
  108. package/bin/commands/server.ts +0 -629
  109. package/bin/commands/shared.ts +0 -97
  110. package/bin/commands/ssl.ts +0 -138
  111. package/bin/commands/stack.ts +0 -325
  112. package/bin/commands/status.ts +0 -385
  113. package/bin/commands/storage.ts +0 -450
  114. package/bin/commands/team.ts +0 -96
  115. package/bin/commands/tunnel.ts +0 -489
  116. package/bin/commands/utils.ts +0 -202
  117. package/build.ts +0 -15
  118. package/cloud +0 -2
  119. package/src/aws/acm.ts +0 -768
  120. package/src/aws/application-autoscaling.ts +0 -845
  121. package/src/aws/bedrock.ts +0 -4074
  122. package/src/aws/client.ts +0 -878
  123. package/src/aws/cloudformation.ts +0 -896
  124. package/src/aws/cloudfront.ts +0 -1531
  125. package/src/aws/cloudwatch-logs.ts +0 -154
  126. package/src/aws/comprehend.ts +0 -839
  127. package/src/aws/connect.ts +0 -1056
  128. package/src/aws/deploy-imap.ts +0 -384
  129. package/src/aws/dynamodb.ts +0 -340
  130. package/src/aws/ec2.ts +0 -1385
  131. package/src/aws/ecr.ts +0 -621
  132. package/src/aws/ecs.ts +0 -615
  133. package/src/aws/elasticache.ts +0 -301
  134. package/src/aws/elbv2.ts +0 -942
  135. package/src/aws/email.ts +0 -928
  136. package/src/aws/eventbridge.ts +0 -248
  137. package/src/aws/iam.ts +0 -1689
  138. package/src/aws/imap-server.ts +0 -2100
  139. package/src/aws/lambda.ts +0 -786
  140. package/src/aws/opensearch.ts +0 -158
  141. package/src/aws/personalize.ts +0 -977
  142. package/src/aws/polly.ts +0 -559
  143. package/src/aws/rds.ts +0 -888
  144. package/src/aws/rekognition.ts +0 -846
  145. package/src/aws/route53-domains.ts +0 -359
  146. package/src/aws/route53.ts +0 -1046
  147. package/src/aws/s3.ts +0 -2318
  148. package/src/aws/scheduler.ts +0 -571
  149. package/src/aws/secrets-manager.ts +0 -769
  150. package/src/aws/ses.ts +0 -1081
  151. package/src/aws/setup-phone.ts +0 -104
  152. package/src/aws/setup-sms.ts +0 -580
  153. package/src/aws/sms.ts +0 -1735
  154. package/src/aws/smtp-server.ts +0 -531
  155. package/src/aws/sns.ts +0 -758
  156. package/src/aws/sqs.ts +0 -382
  157. package/src/aws/ssm.ts +0 -807
  158. package/src/aws/sts.ts +0 -92
  159. package/src/aws/support.ts +0 -391
  160. package/src/aws/test-imap.ts +0 -86
  161. package/src/aws/textract.ts +0 -780
  162. package/src/aws/transcribe.ts +0 -108
  163. package/src/aws/translate.ts +0 -641
  164. package/src/aws/voice.ts +0 -1379
  165. package/src/config.ts +0 -35
  166. package/src/deploy/index.ts +0 -7
  167. package/src/deploy/static-site-external-dns.ts +0 -906
  168. package/src/deploy/static-site.ts +0 -1125
  169. package/src/dns/godaddy.ts +0 -412
  170. package/src/dns/index.ts +0 -183
  171. package/src/dns/porkbun.ts +0 -362
  172. package/src/dns/route53-adapter.ts +0 -414
  173. package/src/dns/validator.ts +0 -369
  174. package/src/generators/index.ts +0 -5
  175. package/src/generators/infrastructure.ts +0 -1660
  176. package/src/push/apns.ts +0 -452
  177. package/src/push/fcm.ts +0 -506
  178. package/src/push/index.ts +0 -58
  179. package/src/ssl/acme-client.ts +0 -478
  180. package/src/ssl/index.ts +0 -7
  181. package/src/ssl/letsencrypt.ts +0 -747
  182. package/src/types.ts +0 -2
  183. package/src/utils/cli.ts +0 -398
  184. package/src/validation/index.ts +0 -5
  185. package/src/validation/template.ts +0 -405
  186. package/test/index.test.ts +0 -128
  187. package/tsconfig.json +0 -18
package/src/aws/sts.ts DELETED
@@ -1,92 +0,0 @@
1
- /**
2
- * AWS STS Operations
3
- * Direct API calls without AWS CLI dependency
4
- */
5
-
6
- import { AWSClient } from './client'
7
-
8
- export interface CallerIdentity {
9
- UserId?: string
10
- Account?: string
11
- Arn?: string
12
- }
13
-
14
- /**
15
- * STS (Security Token Service) management using direct API calls
16
- */
17
- export class STSClient {
18
- private client: AWSClient
19
- private region: string
20
-
21
- constructor(region: string = 'us-east-1', profile?: string) {
22
- this.region = region
23
- this.client = new AWSClient()
24
- }
25
-
26
- /**
27
- * Get information about the IAM identity whose credentials are used to call the operation
28
- */
29
- async getCallerIdentity(): Promise<CallerIdentity> {
30
- const result = await this.client.request({
31
- service: 'sts',
32
- region: this.region,
33
- method: 'POST',
34
- path: '/',
35
- headers: {
36
- 'Content-Type': 'application/x-www-form-urlencoded',
37
- },
38
- body: 'Action=GetCallerIdentity&Version=2011-06-15',
39
- })
40
-
41
- // Parse XML response
42
- // The response will be in XML format like:
43
- // <GetCallerIdentityResponse>
44
- // <GetCallerIdentityResult>
45
- // <Account>123456789012</Account>
46
- // <UserId>AIDAI...</UserId>
47
- // <Arn>arn:aws:iam::...</Arn>
48
- // </GetCallerIdentityResult>
49
- // </GetCallerIdentityResponse>
50
-
51
- if (typeof result === 'string') {
52
- const accountMatch = result.match(/<Account>(\d+)<\/Account>/)
53
- const userIdMatch = result.match(/<UserId>([^<]+)<\/UserId>/)
54
- const arnMatch = result.match(/<Arn>([^<]+)<\/Arn>/)
55
-
56
- return {
57
- Account: accountMatch?.[1],
58
- UserId: userIdMatch?.[1],
59
- Arn: arnMatch?.[1],
60
- }
61
- }
62
-
63
- // Handle parsed XML response - the structure can be either:
64
- // 1. { GetCallerIdentityResponse: { GetCallerIdentityResult: { Account, UserId, Arn } } }
65
- // 2. { GetCallerIdentityResult: { Account, UserId, Arn } } (more common)
66
- const identityResult = result?.GetCallerIdentityResponse?.GetCallerIdentityResult
67
- || result?.GetCallerIdentityResult
68
-
69
- if (identityResult) {
70
- return {
71
- Account: String(identityResult.Account),
72
- UserId: identityResult.UserId,
73
- Arn: identityResult.Arn,
74
- }
75
- }
76
-
77
- // Direct object structure
78
- if (result?.Account) {
79
- return {
80
- Account: String(result.Account),
81
- UserId: result.UserId,
82
- Arn: result.Arn,
83
- }
84
- }
85
-
86
- return {
87
- Account: undefined,
88
- UserId: undefined,
89
- Arn: undefined,
90
- }
91
- }
92
- }
@@ -1,391 +0,0 @@
1
- /**
2
- * AWS Support API Operations
3
- * Automates support ticket creation for service limit increases and sandbox exits
4
- */
5
-
6
- import { AWSClient } from './client'
7
-
8
- export interface SupportCase {
9
- caseId?: string
10
- displayId?: string
11
- subject?: string
12
- status?: string
13
- serviceCode?: string
14
- categoryCode?: string
15
- severityCode?: string
16
- submittedBy?: string
17
- timeCreated?: string
18
- recentCommunications?: {
19
- communications?: Array<{
20
- body?: string
21
- submittedBy?: string
22
- timeCreated?: string
23
- }>
24
- }
25
- }
26
-
27
- export interface CreateCaseParams {
28
- subject: string
29
- communicationBody: string
30
- serviceCode: string
31
- categoryCode: string
32
- severityCode?: 'low' | 'normal' | 'high' | 'urgent' | 'critical'
33
- ccEmailAddresses?: string[]
34
- language?: string
35
- issueType?: 'customer-service' | 'technical'
36
- attachmentSetId?: string
37
- }
38
-
39
- export interface SupportService {
40
- code: string
41
- name: string
42
- categories?: Array<{
43
- code: string
44
- name: string
45
- }>
46
- }
47
-
48
- /**
49
- * AWS Support client for creating and managing support cases
50
- */
51
- export class SupportClient {
52
- private client: AWSClient
53
- private region: string
54
-
55
- constructor(region: string = 'us-east-1') {
56
- this.region = region
57
- this.client = new AWSClient()
58
- }
59
-
60
- /**
61
- * Create a new support case
62
- */
63
- async createCase(params: CreateCaseParams): Promise<{ caseId?: string }> {
64
- const result = await this.client.request({
65
- service: 'support',
66
- region: this.region,
67
- method: 'POST',
68
- path: '/',
69
- headers: {
70
- 'Content-Type': 'application/x-amz-json-1.1',
71
- 'X-Amz-Target': 'AWSSupport_20130415.CreateCase',
72
- },
73
- body: JSON.stringify({
74
- subject: params.subject,
75
- communicationBody: params.communicationBody,
76
- serviceCode: params.serviceCode,
77
- categoryCode: params.categoryCode,
78
- severityCode: params.severityCode || 'normal',
79
- ccEmailAddresses: params.ccEmailAddresses,
80
- language: params.language || 'en',
81
- issueType: params.issueType || 'customer-service',
82
- attachmentSetId: params.attachmentSetId,
83
- }),
84
- })
85
-
86
- return result as { caseId?: string }
87
- }
88
-
89
- /**
90
- * Get details of a support case
91
- */
92
- async describeCase(caseId: string): Promise<SupportCase | null> {
93
- const result = await this.client.request({
94
- service: 'support',
95
- region: this.region,
96
- method: 'POST',
97
- path: '/',
98
- headers: {
99
- 'Content-Type': 'application/x-amz-json-1.1',
100
- 'X-Amz-Target': 'AWSSupport_20130415.DescribeCases',
101
- },
102
- body: JSON.stringify({
103
- caseIdList: [caseId],
104
- includeResolvedCases: true,
105
- includeCommunications: true,
106
- }),
107
- })
108
-
109
- const cases = (result as { cases?: SupportCase[] }).cases
110
- return cases?.[0] || null
111
- }
112
-
113
- /**
114
- * List all support cases
115
- */
116
- async listCases(options?: {
117
- includeResolved?: boolean
118
- maxResults?: number
119
- nextToken?: string
120
- }): Promise<{ cases: SupportCase[], nextToken?: string }> {
121
- const result = await this.client.request({
122
- service: 'support',
123
- region: this.region,
124
- method: 'POST',
125
- path: '/',
126
- headers: {
127
- 'Content-Type': 'application/x-amz-json-1.1',
128
- 'X-Amz-Target': 'AWSSupport_20130415.DescribeCases',
129
- },
130
- body: JSON.stringify({
131
- includeResolvedCases: options?.includeResolved ?? false,
132
- maxResults: options?.maxResults,
133
- nextToken: options?.nextToken,
134
- includeCommunications: true,
135
- }),
136
- })
137
-
138
- return result as { cases: SupportCase[], nextToken?: string }
139
- }
140
-
141
- /**
142
- * Add a communication to an existing case
143
- */
144
- async addCommunication(caseId: string, message: string, ccEmailAddresses?: string[]): Promise<boolean> {
145
- const result = await this.client.request({
146
- service: 'support',
147
- region: this.region,
148
- method: 'POST',
149
- path: '/',
150
- headers: {
151
- 'Content-Type': 'application/x-amz-json-1.1',
152
- 'X-Amz-Target': 'AWSSupport_20130415.AddCommunicationToCase',
153
- },
154
- body: JSON.stringify({
155
- caseId,
156
- communicationBody: message,
157
- ccEmailAddresses,
158
- }),
159
- })
160
-
161
- return (result as { result?: boolean }).result ?? true
162
- }
163
-
164
- /**
165
- * Resolve a support case
166
- */
167
- async resolveCase(caseId: string): Promise<{ initialCaseStatus?: string, finalCaseStatus?: string }> {
168
- const result = await this.client.request({
169
- service: 'support',
170
- region: this.region,
171
- method: 'POST',
172
- path: '/',
173
- headers: {
174
- 'Content-Type': 'application/x-amz-json-1.1',
175
- 'X-Amz-Target': 'AWSSupport_20130415.ResolveCase',
176
- },
177
- body: JSON.stringify({
178
- caseId,
179
- }),
180
- })
181
-
182
- return result as { initialCaseStatus?: string, finalCaseStatus?: string }
183
- }
184
-
185
- /**
186
- * Get available services and categories for support cases
187
- */
188
- async describeServices(serviceCodeList?: string[]): Promise<SupportService[]> {
189
- const result = await this.client.request({
190
- service: 'support',
191
- region: this.region,
192
- method: 'POST',
193
- path: '/',
194
- headers: {
195
- 'Content-Type': 'application/x-amz-json-1.1',
196
- 'X-Amz-Target': 'AWSSupport_20130415.DescribeServices',
197
- },
198
- body: JSON.stringify({
199
- serviceCodeList,
200
- language: 'en',
201
- }),
202
- })
203
-
204
- return (result as { services?: SupportService[] }).services || []
205
- }
206
-
207
- /**
208
- * Get available severity levels
209
- */
210
- async describeSeverityLevels(): Promise<Array<{ code: string, name: string }>> {
211
- const result = await this.client.request({
212
- service: 'support',
213
- region: this.region,
214
- method: 'POST',
215
- path: '/',
216
- headers: {
217
- 'Content-Type': 'application/x-amz-json-1.1',
218
- 'X-Amz-Target': 'AWSSupport_20130415.DescribeSeverityLevels',
219
- },
220
- body: JSON.stringify({
221
- language: 'en',
222
- }),
223
- })
224
-
225
- return (result as { severityLevels?: Array<{ code: string, name: string }> }).severityLevels || []
226
- }
227
- }
228
-
229
- export interface SmsSandboxExitParams {
230
- companyName: string
231
- useCase: string
232
- expectedMonthlyVolume: number
233
- websiteUrl?: string
234
- }
235
-
236
- export interface SmsSpendLimitIncreaseParams {
237
- companyName: string
238
- currentLimit: number
239
- requestedLimit: number
240
- useCase: string
241
- }
242
-
243
- export interface SesSandboxExitParams {
244
- companyName: string
245
- websiteUrl: string
246
- useCase: string
247
- expectedDailyVolume: number
248
- }
249
-
250
- export interface ConnectPhoneNumberIncreaseParams {
251
- companyName: string
252
- instanceId: string
253
- currentLimit: number
254
- requestedLimit: number
255
- useCase: string
256
- }
257
-
258
- /**
259
- * Pre-built support case templates for common requests
260
- */
261
- export const SupportTemplates = {
262
- /**
263
- * Request to exit SMS sandbox
264
- */
265
- smsSandboxExit: (params: SmsSandboxExitParams): CreateCaseParams => ({
266
- subject: 'Request to exit SMS sandbox for production use',
267
- serviceCode: 'service-limit-increase',
268
- categoryCode: 'service-limit-increase-sms-pinpoint',
269
- severityCode: 'normal',
270
- communicationBody: `Hello,
271
-
272
- I would like to request that our AWS account be moved out of the SMS sandbox to enable production SMS messaging.
273
-
274
- **Company/Project**: ${params.companyName}
275
- **Website**: ${params.websiteUrl || 'N/A'}
276
-
277
- **Use Case**:
278
- ${params.useCase}
279
-
280
- **Expected Monthly SMS Volume**: ${params.expectedMonthlyVolume.toLocaleString()} messages
281
-
282
- **Message Types**:
283
- - Transactional (verification codes, order confirmations, etc.)
284
- - Account notifications
285
-
286
- **Opt-out Handling**:
287
- We have implemented standard opt-out handling with STOP, UNSUBSCRIBE, CANCEL, END, and QUIT keywords.
288
-
289
- **Compliance**:
290
- - We will only send SMS to users who have explicitly opted in
291
- - We will include opt-out instructions in promotional messages
292
- - We will honor all opt-out requests immediately
293
-
294
- Thank you for reviewing this request.`,
295
- }),
296
-
297
- /**
298
- * Request to increase SMS spending limit
299
- */
300
- smsSpendLimitIncrease: (params: SmsSpendLimitIncreaseParams): CreateCaseParams => ({
301
- subject: `Request to increase SMS spending limit from $${params.currentLimit} to $${params.requestedLimit}`,
302
- serviceCode: 'service-limit-increase',
303
- categoryCode: 'service-limit-increase-sms-pinpoint',
304
- severityCode: 'normal',
305
- communicationBody: `Hello,
306
-
307
- I would like to request an increase to our monthly SMS spending limit.
308
-
309
- **Company/Project**: ${params.companyName}
310
-
311
- **Current Limit**: $${params.currentLimit}/month
312
- **Requested Limit**: $${params.requestedLimit}/month
313
-
314
- **Justification**:
315
- ${params.useCase}
316
-
317
- **Message Types**:
318
- - Transactional notifications
319
- - Verification codes
320
- - Account alerts
321
-
322
- We have proper opt-out handling in place and comply with all SMS messaging regulations.
323
-
324
- Thank you for reviewing this request.`,
325
- }),
326
-
327
- /**
328
- * Request SES production access (exit sandbox)
329
- */
330
- sesSandboxExit: (params: SesSandboxExitParams): CreateCaseParams => ({
331
- subject: 'Request to move out of Amazon SES sandbox',
332
- serviceCode: 'service-limit-increase',
333
- categoryCode: 'service-limit-increase-ses-702',
334
- severityCode: 'normal',
335
- communicationBody: `Hello,
336
-
337
- I would like to request that our AWS account be moved out of the Amazon SES sandbox to enable production email sending.
338
-
339
- **Company/Project**: ${params.companyName}
340
- **Website**: ${params.websiteUrl}
341
-
342
- **Use Case**:
343
- ${params.useCase}
344
-
345
- **Expected Daily Email Volume**: ${params.expectedDailyVolume.toLocaleString()} emails
346
-
347
- **Email Types**:
348
- - Transactional emails (password resets, order confirmations, etc.)
349
- - Account notifications
350
- - System alerts
351
-
352
- **Compliance**:
353
- - We will only send emails to users who have explicitly opted in
354
- - We have implemented proper bounce and complaint handling
355
- - We will include unsubscribe links in all marketing emails
356
- - We maintain a clean mailing list and honor all unsubscribe requests
357
-
358
- **Technical Setup**:
359
- - Domain verification: Complete (DKIM, SPF, DMARC configured)
360
- - Bounce/complaint handling: SNS notifications configured
361
- - Email authentication: Fully implemented
362
-
363
- Thank you for reviewing this request.`,
364
- }),
365
-
366
- /**
367
- * Request Connect phone number limit increase
368
- */
369
- connectPhoneNumberIncrease: (params: ConnectPhoneNumberIncreaseParams): CreateCaseParams => ({
370
- subject: `Request to increase Amazon Connect phone number limit from ${params.currentLimit} to ${params.requestedLimit}`,
371
- serviceCode: 'service-limit-increase',
372
- categoryCode: 'service-limit-increase-connect',
373
- severityCode: 'normal',
374
- communicationBody: `Hello,
375
-
376
- I would like to request an increase to our Amazon Connect phone number limit.
377
-
378
- **Company/Project**: ${params.companyName}
379
- **Connect Instance ID**: ${params.instanceId}
380
-
381
- **Current Limit**: ${params.currentLimit} phone numbers
382
- **Requested Limit**: ${params.requestedLimit} phone numbers
383
-
384
- **Use Case**:
385
- ${params.useCase}
386
-
387
- Thank you for reviewing this request.`,
388
- }),
389
- }
390
-
391
- export default SupportClient
@@ -1,86 +0,0 @@
1
- #!/usr/bin/env bun
2
- /**
3
- * Test script to run the IMAP server locally
4
- * This reads emails from S3 and serves them via IMAP
5
- *
6
- * Usage:
7
- * bun run src/aws/test-imap.ts
8
- *
9
- * Then configure Mail.app:
10
- * IMAP Server: localhost
11
- * Port: 1143 (or 143 if running as root)
12
- * Username: chris
13
- * Password: test123
14
- */
15
-
16
- import { startImapServer } from './imap-server'
17
-
18
- async function main() {
19
- console.log('Starting IMAP-to-S3 bridge server...')
20
- console.log('')
21
-
22
- const port = Number.parseInt(process.env.IMAP_PORT || '1143', 10)
23
- const sslPort = Number.parseInt(process.env.IMAPS_PORT || '1993', 10)
24
-
25
- const server = await startImapServer({
26
- port, // Use 1143 for non-root, or 143 if running as root
27
- sslPort, // Use 1993 for non-root, or 993 if running as root
28
- host: '0.0.0.0',
29
- region: 'us-east-1',
30
- bucket: 'stacks-production-email',
31
- prefix: 'incoming/',
32
- domain: 'stacksjs.com',
33
- users: {
34
- chris: {
35
- password: 'test123',
36
- email: 'chris@stacksjs.com',
37
- },
38
- blake: {
39
- password: 'test123',
40
- email: 'blake@stacksjs.com',
41
- },
42
- glenn: {
43
- password: 'test123',
44
- email: 'glenn@stacksjs.com',
45
- },
46
- },
47
- // To enable TLS, provide certificate paths:
48
- // tls: {
49
- // key: '/path/to/key.pem',
50
- // cert: '/path/to/cert.pem',
51
- // },
52
- })
53
-
54
- console.log('')
55
- console.log('='.repeat(60))
56
- console.log('IMAP-to-S3 Bridge Server Running')
57
- console.log('='.repeat(60))
58
- console.log('')
59
- console.log('Mail.app Settings:')
60
- console.log(' Account Type: IMAP')
61
- console.log(' Incoming Server: localhost')
62
- console.log(` Port: ${port}`)
63
- console.log(' Username: chris (or blake, glenn)')
64
- console.log(' Password: test123')
65
- console.log(` SSL: Off (or ${sslPort} with SSL)`)
66
- console.log('')
67
- console.log('For production, use ports 143/993 (requires root or port forwarding)')
68
- console.log('Set IMAP_PORT and IMAPS_PORT environment variables to change ports')
69
- console.log('')
70
- console.log('Press Ctrl+C to stop')
71
-
72
- // Handle graceful shutdown
73
- process.on('SIGINT', async () => {
74
- console.log('\nShutting down...')
75
- await server.stop()
76
- process.exit(0)
77
- })
78
-
79
- process.on('SIGTERM', async () => {
80
- console.log('\nShutting down...')
81
- await server.stop()
82
- process.exit(0)
83
- })
84
- }
85
-
86
- main().catch(console.error)