@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,60 +0,0 @@
1
- import { AWSClient } from './client';
2
- export declare interface TranscriptionJob {
3
- TranscriptionJobName: string
4
- TranscriptionJobStatus: 'QUEUED' | 'IN_PROGRESS' | 'FAILED' | 'COMPLETED'
5
- LanguageCode?: string
6
- MediaSampleRateHertz?: number
7
- MediaFormat?: string
8
- Media?: {
9
- MediaFileUri?: string
10
- }
11
- Transcript?: {
12
- TranscriptFileUri?: string
13
- }
14
- StartTime?: string
15
- CreationTime?: string
16
- CompletionTime?: string
17
- FailureReason?: string
18
- }
19
- /**
20
- * Transcribe client for direct API calls
21
- */
22
- export declare class TranscribeClient {
23
- private client: AWSClient;
24
- private region: string;
25
- constructor(region?: string);
26
- private request<T>(action: string, params: Record<string, any>): Promise<T>;
27
- startTranscriptionJob(params: {
28
- TranscriptionJobName: string
29
- LanguageCode: string
30
- MediaFormat?: 'mp3' | 'mp4' | 'wav' | 'flac' | 'ogg' | 'amr' | 'webm'
31
- Media: {
32
- MediaFileUri: string
33
- }
34
- OutputBucketName?: string
35
- OutputKey?: string
36
- Settings?: {
37
- ShowSpeakerLabels?: boolean
38
- MaxSpeakerLabels?: number
39
- ChannelIdentification?: boolean
40
- ShowAlternatives?: boolean
41
- MaxAlternatives?: number
42
- }
43
- }): Promise<{ TranscriptionJob: TranscriptionJob }>;
44
- getTranscriptionJob(params: {
45
- TranscriptionJobName: string
46
- }): Promise<{ TranscriptionJob: TranscriptionJob }>;
47
- listTranscriptionJobs(params?: {
48
- Status?: 'QUEUED' | 'IN_PROGRESS' | 'FAILED' | 'COMPLETED'
49
- JobNameContains?: string
50
- NextToken?: string
51
- MaxResults?: number
52
- }): Promise<{
53
- Status?: string
54
- NextToken?: string
55
- TranscriptionJobSummaries: TranscriptionJob[]
56
- }>;
57
- deleteTranscriptionJob(params: {
58
- TranscriptionJobName: string
59
- }): Promise<void>;
60
- }
@@ -1,358 +0,0 @@
1
- import { AWSClient } from './client';
2
- /**
3
- * Quick translation
4
- */
5
- export declare function translate(text: string, targetLanguage: string, options?: {
6
- sourceLanguage?: string
7
- region?: string
8
- }): Promise<string>;
9
- /**
10
- * Translate to multiple languages
11
- */
12
- export declare function translateToMultiple(text: string, targetLanguages: string[], options?: {
13
- sourceLanguage?: string
14
- region?: string
15
- }): Promise<Record<string, string>>;
16
- /**
17
- * List supported languages
18
- */
19
- export declare function listLanguages(region?: string): Promise<Language[]>;
20
- // ============================================================================
21
- // Types
22
- // ============================================================================
23
- export declare interface TranslateTextCommandInput {
24
- Text: string
25
- SourceLanguageCode: string
26
- TargetLanguageCode: string
27
- TerminologyNames?: string[]
28
- Settings?: {
29
- Formality?: 'FORMAL' | 'INFORMAL'
30
- Profanity?: 'MASK'
31
- Brevity?: 'ON'
32
- }
33
- }
34
- export declare interface TranslatedDocument {
35
- Content: Uint8Array
36
- }
37
- export declare interface AppliedTerminology {
38
- Name?: string
39
- Terms?: Array<{
40
- SourceText?: string
41
- TargetText?: string
42
- }>
43
- }
44
- export declare interface TranslateTextCommandOutput {
45
- TranslatedText: string
46
- SourceLanguageCode: string
47
- TargetLanguageCode: string
48
- AppliedTerminologies?: AppliedTerminology[]
49
- AppliedSettings?: {
50
- Formality?: 'FORMAL' | 'INFORMAL'
51
- Profanity?: 'MASK'
52
- Brevity?: 'ON'
53
- }
54
- }
55
- export declare interface TranslateDocumentCommandInput {
56
- Document: {
57
- Content: Uint8Array
58
- ContentType: 'text/html' | 'text/plain' | 'application/vnd.openxmlformats-officedocument.wordprocessingml.document'
59
- }
60
- SourceLanguageCode: string
61
- TargetLanguageCode: string
62
- TerminologyNames?: string[]
63
- Settings?: {
64
- Formality?: 'FORMAL' | 'INFORMAL'
65
- Profanity?: 'MASK'
66
- Brevity?: 'ON'
67
- }
68
- }
69
- export declare interface TranslateDocumentCommandOutput {
70
- TranslatedDocument: TranslatedDocument
71
- SourceLanguageCode: string
72
- TargetLanguageCode: string
73
- AppliedTerminologies?: AppliedTerminology[]
74
- AppliedSettings?: {
75
- Formality?: 'FORMAL' | 'INFORMAL'
76
- Profanity?: 'MASK'
77
- Brevity?: 'ON'
78
- }
79
- }
80
- export declare interface StartTextTranslationJobCommandInput {
81
- JobName?: string
82
- InputDataConfig: {
83
- S3Uri: string
84
- ContentType: 'text/html' | 'text/plain' | 'application/vnd.openxmlformats-officedocument.wordprocessingml.document' | 'application/vnd.openxmlformats-officedocument.presentationml.presentation' | 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' | 'application/x-xliff+xml'
85
- }
86
- OutputDataConfig: {
87
- S3Uri: string
88
- EncryptionKey?: {
89
- Type: 'KMS'
90
- Id: string
91
- }
92
- }
93
- DataAccessRoleArn: string
94
- SourceLanguageCode: string
95
- TargetLanguageCodes: string[]
96
- TerminologyNames?: string[]
97
- ParallelDataNames?: string[]
98
- ClientToken?: string
99
- Settings?: {
100
- Formality?: 'FORMAL' | 'INFORMAL'
101
- Profanity?: 'MASK'
102
- Brevity?: 'ON'
103
- }
104
- }
105
- export declare interface StartTextTranslationJobCommandOutput {
106
- JobId?: string
107
- JobStatus?: 'SUBMITTED' | 'IN_PROGRESS' | 'COMPLETED' | 'COMPLETED_WITH_ERROR' | 'FAILED' | 'STOP_REQUESTED' | 'STOPPED'
108
- }
109
- export declare interface DescribeTextTranslationJobCommandInput {
110
- JobId: string
111
- }
112
- export declare interface TextTranslationJobProperties {
113
- JobId?: string
114
- JobName?: string
115
- JobStatus?: 'SUBMITTED' | 'IN_PROGRESS' | 'COMPLETED' | 'COMPLETED_WITH_ERROR' | 'FAILED' | 'STOP_REQUESTED' | 'STOPPED'
116
- JobDetails?: {
117
- TranslatedDocumentsCount?: number
118
- DocumentsWithErrorsCount?: number
119
- InputDocumentsCount?: number
120
- }
121
- SourceLanguageCode?: string
122
- TargetLanguageCodes?: string[]
123
- TerminologyNames?: string[]
124
- ParallelDataNames?: string[]
125
- Message?: string
126
- SubmittedTime?: string
127
- EndTime?: string
128
- InputDataConfig?: {
129
- S3Uri?: string
130
- ContentType?: string
131
- }
132
- OutputDataConfig?: {
133
- S3Uri?: string
134
- EncryptionKey?: {
135
- Type?: string
136
- Id?: string
137
- }
138
- }
139
- DataAccessRoleArn?: string
140
- Settings?: {
141
- Formality?: 'FORMAL' | 'INFORMAL'
142
- Profanity?: 'MASK'
143
- Brevity?: 'ON'
144
- }
145
- }
146
- export declare interface DescribeTextTranslationJobCommandOutput {
147
- TextTranslationJobProperties?: TextTranslationJobProperties
148
- }
149
- export declare interface ListTextTranslationJobsCommandInput {
150
- Filter?: {
151
- JobName?: string
152
- JobStatus?: 'SUBMITTED' | 'IN_PROGRESS' | 'COMPLETED' | 'COMPLETED_WITH_ERROR' | 'FAILED' | 'STOP_REQUESTED' | 'STOPPED'
153
- SubmittedBeforeTime?: string
154
- SubmittedAfterTime?: string
155
- }
156
- NextToken?: string
157
- MaxResults?: number
158
- }
159
- export declare interface ListTextTranslationJobsCommandOutput {
160
- TextTranslationJobPropertiesList?: TextTranslationJobProperties[]
161
- NextToken?: string
162
- }
163
- export declare interface StopTextTranslationJobCommandInput {
164
- JobId: string
165
- }
166
- export declare interface StopTextTranslationJobCommandOutput {
167
- JobId?: string
168
- JobStatus?: 'SUBMITTED' | 'IN_PROGRESS' | 'COMPLETED' | 'COMPLETED_WITH_ERROR' | 'FAILED' | 'STOP_REQUESTED' | 'STOPPED'
169
- }
170
- export declare interface ListLanguagesCommandInput {
171
- DisplayLanguageCode?: string
172
- NextToken?: string
173
- MaxResults?: number
174
- }
175
- export declare interface Language {
176
- LanguageName?: string
177
- LanguageCode?: string
178
- }
179
- export declare interface ListLanguagesCommandOutput {
180
- Languages?: Language[]
181
- DisplayLanguageCode?: string
182
- NextToken?: string
183
- }
184
- export declare interface ImportTerminologyCommandInput {
185
- Name: string
186
- MergeStrategy: 'OVERWRITE'
187
- Description?: string
188
- TerminologyData: {
189
- File: Uint8Array
190
- Format: 'CSV' | 'TMX' | 'TSV'
191
- Directionality?: 'UNI' | 'MULTI'
192
- }
193
- EncryptionKey?: {
194
- Type: 'KMS'
195
- Id: string
196
- }
197
- Tags?: Array<{ Key: string; Value: string }>
198
- }
199
- export declare interface TerminologyProperties {
200
- Name?: string
201
- Description?: string
202
- Arn?: string
203
- SourceLanguageCode?: string
204
- TargetLanguageCodes?: string[]
205
- EncryptionKey?: {
206
- Type?: string
207
- Id?: string
208
- }
209
- SizeBytes?: number
210
- TermCount?: number
211
- CreatedAt?: string
212
- LastUpdatedAt?: string
213
- Directionality?: 'UNI' | 'MULTI'
214
- Message?: string
215
- SkippedTermCount?: number
216
- Format?: 'CSV' | 'TMX' | 'TSV'
217
- }
218
- export declare interface ImportTerminologyCommandOutput {
219
- TerminologyProperties?: TerminologyProperties
220
- AuxiliaryDataLocation?: {
221
- RepositoryType?: string
222
- Location?: string
223
- }
224
- }
225
- export declare interface GetTerminologyCommandInput {
226
- Name: string
227
- TerminologyDataFormat?: 'CSV' | 'TMX' | 'TSV'
228
- }
229
- export declare interface GetTerminologyCommandOutput {
230
- TerminologyProperties?: TerminologyProperties
231
- TerminologyDataLocation?: {
232
- RepositoryType?: string
233
- Location?: string
234
- }
235
- AuxiliaryDataLocation?: {
236
- RepositoryType?: string
237
- Location?: string
238
- }
239
- }
240
- export declare interface ListTerminologiesCommandInput {
241
- NextToken?: string
242
- MaxResults?: number
243
- }
244
- export declare interface ListTerminologiesCommandOutput {
245
- TerminologyPropertiesList?: TerminologyProperties[]
246
- NextToken?: string
247
- }
248
- export declare interface DeleteTerminologyCommandInput {
249
- Name: string
250
- }
251
- export declare interface DeleteTerminologyCommandOutput {
252
-
253
- }
254
- export declare interface CreateParallelDataCommandInput {
255
- Name: string
256
- Description?: string
257
- ParallelDataConfig: {
258
- S3Uri: string
259
- Format: 'TSV' | 'CSV' | 'TMX'
260
- }
261
- EncryptionKey?: {
262
- Type: 'KMS'
263
- Id: string
264
- }
265
- ClientToken?: string
266
- Tags?: Array<{ Key: string; Value: string }>
267
- }
268
- export declare interface ParallelDataProperties {
269
- Name?: string
270
- Arn?: string
271
- Description?: string
272
- Status?: 'CREATING' | 'UPDATING' | 'ACTIVE' | 'DELETING' | 'FAILED'
273
- SourceLanguageCode?: string
274
- TargetLanguageCodes?: string[]
275
- ParallelDataConfig?: {
276
- S3Uri?: string
277
- Format?: 'TSV' | 'CSV' | 'TMX'
278
- }
279
- Message?: string
280
- ImportedDataSize?: number
281
- ImportedRecordCount?: number
282
- FailedRecordCount?: number
283
- SkippedRecordCount?: number
284
- EncryptionKey?: {
285
- Type?: string
286
- Id?: string
287
- }
288
- CreatedAt?: string
289
- LastUpdatedAt?: string
290
- LatestUpdateAttemptStatus?: 'CREATING' | 'UPDATING' | 'ACTIVE' | 'DELETING' | 'FAILED'
291
- LatestUpdateAttemptAt?: string
292
- }
293
- export declare interface CreateParallelDataCommandOutput {
294
- Name?: string
295
- Status?: 'CREATING' | 'UPDATING' | 'ACTIVE' | 'DELETING' | 'FAILED'
296
- }
297
- export declare interface GetParallelDataCommandInput {
298
- Name: string
299
- }
300
- export declare interface GetParallelDataCommandOutput {
301
- ParallelDataProperties?: ParallelDataProperties
302
- DataLocation?: {
303
- RepositoryType?: string
304
- Location?: string
305
- }
306
- AuxiliaryDataLocation?: {
307
- RepositoryType?: string
308
- Location?: string
309
- }
310
- LatestUpdateAttemptAuxiliaryDataLocation?: {
311
- RepositoryType?: string
312
- Location?: string
313
- }
314
- }
315
- export declare interface ListParallelDataCommandInput {
316
- NextToken?: string
317
- MaxResults?: number
318
- }
319
- export declare interface ListParallelDataCommandOutput {
320
- ParallelDataPropertiesList?: ParallelDataProperties[]
321
- NextToken?: string
322
- }
323
- export declare interface DeleteParallelDataCommandInput {
324
- Name: string
325
- }
326
- export declare interface DeleteParallelDataCommandOutput {
327
- Name?: string
328
- Status?: 'CREATING' | 'UPDATING' | 'ACTIVE' | 'DELETING' | 'FAILED'
329
- }
330
- // ============================================================================
331
- // Translate Client
332
- // ============================================================================
333
- export declare class TranslateClient {
334
- private client: AWSClient;
335
- private region: string;
336
- constructor(region?: string);
337
- private request<T>(action: string, params: Record<string, unknown>): Promise<T>;
338
- translateText(params: TranslateTextCommandInput): Promise<TranslateTextCommandOutput>;
339
- translateDocument(params: TranslateDocumentCommandInput): Promise<TranslateDocumentCommandOutput>;
340
- startTextTranslationJob(params: StartTextTranslationJobCommandInput): Promise<StartTextTranslationJobCommandOutput>;
341
- describeTextTranslationJob(params: DescribeTextTranslationJobCommandInput): Promise<DescribeTextTranslationJobCommandOutput>;
342
- listTextTranslationJobs(params?: ListTextTranslationJobsCommandInput): Promise<ListTextTranslationJobsCommandOutput>;
343
- stopTextTranslationJob(params: StopTextTranslationJobCommandInput): Promise<StopTextTranslationJobCommandOutput>;
344
- listLanguages(params?: ListLanguagesCommandInput): Promise<ListLanguagesCommandOutput>;
345
- importTerminology(params: ImportTerminologyCommandInput): Promise<ImportTerminologyCommandOutput>;
346
- getTerminology(params: GetTerminologyCommandInput): Promise<GetTerminologyCommandOutput>;
347
- listTerminologies(params?: ListTerminologiesCommandInput): Promise<ListTerminologiesCommandOutput>;
348
- deleteTerminology(params: DeleteTerminologyCommandInput): Promise<DeleteTerminologyCommandOutput>;
349
- createParallelData(params: CreateParallelDataCommandInput): Promise<CreateParallelDataCommandOutput>;
350
- getParallelData(params: GetParallelDataCommandInput): Promise<GetParallelDataCommandOutput>;
351
- listParallelData(params?: ListParallelDataCommandInput): Promise<ListParallelDataCommandOutput>;
352
- deleteParallelData(params: DeleteParallelDataCommandInput): Promise<DeleteParallelDataCommandOutput>;
353
- translate(text: string, targetLanguage: string, sourceLanguage?: string): Promise<string>;
354
- translateFormal(text: string, targetLanguage: string, sourceLanguage?: string, formality?: 'FORMAL' | 'INFORMAL'): Promise<string>;
355
- translateToMultiple(text: string, targetLanguages: string[], sourceLanguage?: string): Promise<Record<string, string>>;
356
- waitForJob(jobId: string, options?: { maxWaitMs?: number; pollIntervalMs?: number }): Promise<TextTranslationJobProperties>;
357
- getSupportedLanguages(): Promise<string[]>;
358
- }
@@ -1,219 +0,0 @@
1
- import { ConnectClient } from './connect';
2
- import { S3Client } from './s3';
3
- import { TranscribeClient } from './transcribe';
4
- /**
5
- * Create a Lambda handler for processing incoming voicemails
6
- * Use this with Connect's voicemail feature or custom IVR
7
- *
8
- * @example
9
- * ```typescript
10
- * // lambda.ts
11
- * import { createVoicemailHandler } from 'ts-cloud/aws/voice'
12
- *
13
- * export const handler = createVoicemailHandler({
14
- * bucket: 'my-voicemail-bucket',
15
- * prefix: 'voicemail/',
16
- * region: 'us-east-1',
17
- * })
18
- * ```
19
- */
20
- export declare function createVoicemailHandler(config: {
21
- bucket: string
22
- prefix?: string
23
- region?: string
24
- onVoicemail?: (voicemail: Voicemail) => Promise<void>
25
- }): void;
26
- /**
27
- * Create a Lambda handler for Connect recording events
28
- * This processes call recordings uploaded to S3 by Connect
29
- */
30
- export declare function createRecordingHandler(config: {
31
- bucket: string
32
- prefix?: string
33
- region?: string
34
- onRecording?: (recording: CallRecording) => Promise<void>
35
- }): void;
36
- /**
37
- * Convenience function to create a voice client
38
- */
39
- export declare function createVoiceClient(config?: VoiceClientConfig): VoiceClient;
40
- export declare interface VoiceClientConfig {
41
- region?: string
42
- voicemailBucket?: string
43
- voicemailPrefix?: string
44
- recordingsPrefix?: string
45
- connectInstanceId?: string
46
- connectContactFlowId?: string
47
- defaultCallerId?: string
48
- enableTranscription?: boolean
49
- transcriptionLanguage?: string
50
- }
51
- export declare interface Voicemail {
52
- key: string
53
- from: string
54
- to: string
55
- duration: number
56
- timestamp: Date
57
- transcription?: string
58
- transcriptionStatus?: 'pending' | 'processing' | 'completed' | 'failed'
59
- transcriptionJobName?: string
60
- audioUrl?: string
61
- read?: boolean
62
- readAt?: Date
63
- contentType?: string
64
- size?: number
65
- raw?: any
66
- }
67
- export declare interface CallRecording {
68
- key: string
69
- contactId: string
70
- from?: string
71
- to?: string
72
- duration: number
73
- timestamp: Date
74
- audioUrl?: string
75
- contentType?: string
76
- size?: number
77
- }
78
- export declare interface MakeCallOptions {
79
- to: string
80
- from?: string
81
- message?: string
82
- voiceId?: string
83
- audioUrl?: string
84
- contactFlowId?: string
85
- attributes?: Record<string, string>
86
- }
87
- export declare interface SendVoiceMessageOptions {
88
- to: string
89
- from?: string
90
- message: string
91
- voiceId?: string
92
- languageCode?: string
93
- }
94
- export declare interface VoicemailGreeting {
95
- id: string
96
- name: string
97
- type: 'default' | 'busy' | 'unavailable' | 'custom'
98
- text?: string
99
- audioKey?: string
100
- audioUrl?: string
101
- voiceId?: string
102
- languageCode?: string
103
- isActive: boolean
104
- createdAt: Date
105
- updatedAt?: Date
106
- }
107
- export declare interface CallForwardingRule {
108
- id: string
109
- name: string
110
- enabled: boolean
111
- condition: 'always' | 'busy' | 'no_answer' | 'unreachable' | 'after_hours'
112
- forwardTo: string
113
- ringTimeout?: number
114
- businessHours?: {
115
- timezone: string
116
- schedule: Array<{
117
- day: 'mon' | 'tue' | 'wed' | 'thu' | 'fri' | 'sat' | 'sun'
118
- start: string // HH:MM format
119
- end: string
120
- }>
121
- }
122
- priority: number
123
- createdAt: Date
124
- updatedAt?: Date
125
- }
126
- /**
127
- * Voice Client with S3 voicemail storage
128
- */
129
- export declare class VoiceClient {
130
- private config: VoiceClientConfig;
131
- private connect?: ConnectClient;
132
- private s3?: S3Client;
133
- private transcribe?: TranscribeClient;
134
- constructor(config?: VoiceClientConfig);
135
- call(options: MakeCallOptions): Promise<{ callId: string }>;
136
- sendVoiceMessage(options: SendVoiceMessageOptions): Promise<{ messageId: string }>;
137
- speak(to: string, message: string, voiceId?: string): Promise<{ messageId: string }>;
138
- getVoicemails(options?: {
139
- prefix?: string
140
- maxResults?: number
141
- }): Promise<Voicemail[]>;
142
- getVoicemail(key: string): Promise<Voicemail | null>;
143
- getVoicemailAudioUrl(key: string, expiresIn?: number): Promise<string>;
144
- deleteVoicemail(key: string): Promise<void>;
145
- archiveVoicemail(key: string): Promise<string>;
146
- getVoicemailCount(): Promise<number>;
147
- getUnreadCount(): Promise<number>;
148
- markAsRead(key: string): Promise<void>;
149
- markAsUnread(key: string): Promise<void>;
150
- markManyAsRead(keys: string[]): Promise<void>;
151
- deleteMany(keys: string[]): Promise<void>;
152
- transcribeVoicemail(key: string): Promise<{ jobName: string }>;
153
- getTranscriptionStatus(jobName: string): Promise<{
154
- status: 'IN_PROGRESS' | 'COMPLETED' | 'FAILED'
155
- transcription?: string
156
- }>;
157
- updateTranscription(key: string, transcription: string): Promise<void>;
158
- createGreeting(greeting: {
159
- name: string
160
- type: 'default' | 'busy' | 'unavailable' | 'custom'
161
- text?: string
162
- audioData?: Buffer | string
163
- voiceId?: string
164
- languageCode?: string
165
- setActive?: boolean
166
- }): Promise<VoicemailGreeting>;
167
- getGreetings(): Promise<VoicemailGreeting[]>;
168
- getGreeting(id: string): Promise<VoicemailGreeting | null>;
169
- getActiveGreeting(type: 'default' | 'busy' | 'unavailable' | 'custom'): Promise<VoicemailGreeting | null>;
170
- setActiveGreeting(id: string): Promise<void>;
171
- private deactivateGreetingsOfType(type: string): Promise<void>;
172
- updateGreeting(id: string, updates: { name?: string; text?: string; audioData?: Buffer | string }): Promise<VoicemailGreeting>;
173
- deleteGreeting(id: string): Promise<void>;
174
- getGreetingAudioUrl(id: string, expiresIn?: number): Promise<string | null>;
175
- createForwardingRule(rule: {
176
- name: string
177
- condition: 'always' | 'busy' | 'no_answer' | 'unreachable' | 'after_hours'
178
- forwardTo: string
179
- ringTimeout?: number
180
- businessHours?: CallForwardingRule['businessHours']
181
- priority?: number
182
- enabled?: boolean
183
- }): Promise<CallForwardingRule>;
184
- getForwardingRules(): Promise<CallForwardingRule[]>;
185
- getForwardingRule(id: string): Promise<CallForwardingRule | null>;
186
- updateForwardingRule(id: string, updates: Partial<Omit<CallForwardingRule, 'id' | 'createdAt' | 'updatedAt'>>): Promise<CallForwardingRule>;
187
- setForwardingRuleEnabled(id: string, enabled: boolean): Promise<void>;
188
- deleteForwardingRule(id: string): Promise<void>;
189
- getApplicableForwardingRule(currentConditions?: {
190
- isBusy?: boolean
191
- isUnreachable?: boolean
192
- noAnswer?: boolean
193
- }): Promise<CallForwardingRule | null>;
194
- private isWithinBusinessHours(date: Date, businessHours: NonNullable<CallForwardingRule['businessHours']>): boolean;
195
- getRecordings(options?: {
196
- prefix?: string
197
- maxResults?: number
198
- }): Promise<CallRecording[]>;
199
- getRecordingUrl(key: string, expiresIn?: number): Promise<string>;
200
- storeVoicemail(voicemail: {
201
- from: string
202
- to: string
203
- audioData: Buffer | string
204
- duration?: number
205
- transcription?: string
206
- contentType?: string
207
- timestamp?: Date
208
- }): Promise<string>;
209
- storeRecording(recording: {
210
- contactId: string
211
- from?: string
212
- to?: string
213
- audioData: Buffer | string
214
- duration?: number
215
- contentType?: string
216
- timestamp?: Date
217
- }): Promise<string>;
218
- private getVoicemailMetadata(audioKey: string): Promise<Voicemail | null>;
219
- }
package/dist/config.d.ts DELETED
@@ -1,7 +0,0 @@
1
- import type { CloudOptions } from 'ts-cloud-types';
2
- export declare function getConfig(): Promise<CloudOptions>;
3
- export declare const defaultConfig: CloudOptions;
4
- // Alias for CLI usage
5
- export declare const loadCloudConfig: () => Promise<CloudOptions>;
6
- // For backwards compatibility - synchronous access with default fallback
7
- export declare const config: CloudOptions;
@@ -1,2 +0,0 @@
1
- export * from './static-site';
2
- export * from './static-site-external-dns';
@@ -1,51 +0,0 @@
1
- import type { DnsProviderConfig } from '../dns/types';
2
- /**
3
- * Generate CloudFormation template for static site infrastructure (without Route53)
4
- */
5
- export declare function generateExternalDnsStaticSiteTemplate(config: {
6
- bucketName: string
7
- domain?: string
8
- aliases?: string[]
9
- certificateArn?: string
10
- defaultRootObject?: string
11
- errorDocument?: string
12
- }): object;
13
- /**
14
- * Deploy a static site to AWS with external DNS provider
15
- */
16
- export declare function deployStaticSiteWithExternalDns(config: ExternalDnsStaticSiteConfig): Promise<ExternalDnsDeployResult>;
17
- /**
18
- * Full deployment with external DNS: infrastructure + files + cache invalidation
19
- */
20
- export declare function deployStaticSiteWithExternalDnsFull(config: ExternalDnsStaticSiteConfig & {
21
- sourceDir: string
22
- cleanBucket?: boolean
23
- onProgress?: (stage: string, detail?: string) => void
24
- }): Promise<ExternalDnsDeployResult>;
25
- export declare interface ExternalDnsStaticSiteConfig {
26
- siteName: string
27
- region?: string
28
- domain: string
29
- bucket?: string
30
- certificateArn?: string
31
- stackName?: string
32
- defaultRootObject?: string
33
- errorDocument?: string
34
- cacheControl?: string
35
- tags?: Record<string, string>
36
- dnsProvider: DnsProviderConfig
37
- skipDnsVerification?: boolean
38
- }
39
- export declare interface ExternalDnsDeployResult {
40
- success: boolean
41
- stackId?: string
42
- stackName: string
43
- bucket: string
44
- distributionId?: string
45
- distributionDomain?: string
46
- domain?: string
47
- certificateArn?: string
48
- message: string
49
- filesUploaded?: number
50
- filesSkipped?: number
51
- }