@stacksjs/ts-cloud 0.1.3 → 0.1.6

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/ecr.ts DELETED
@@ -1,621 +0,0 @@
1
- /**
2
- * AWS ECR (Elastic Container Registry) Client
3
- * Manages Docker container image repositories using direct API calls
4
- */
5
-
6
- import { AWSClient } from './client'
7
-
8
- export interface Repository {
9
- repositoryArn?: string
10
- registryId?: string
11
- repositoryName?: string
12
- repositoryUri?: string
13
- createdAt?: string
14
- imageTagMutability?: 'MUTABLE' | 'IMMUTABLE'
15
- imageScanningConfiguration?: {
16
- scanOnPush?: boolean
17
- }
18
- encryptionConfiguration?: {
19
- encryptionType?: 'AES256' | 'KMS'
20
- kmsKey?: string
21
- }
22
- }
23
-
24
- export interface AuthorizationData {
25
- authorizationToken?: string
26
- expiresAt?: string
27
- proxyEndpoint?: string
28
- }
29
-
30
- export interface ImageDetail {
31
- registryId?: string
32
- repositoryName?: string
33
- imageDigest?: string
34
- imageTags?: string[]
35
- imageSizeInBytes?: number
36
- imagePushedAt?: string
37
- imageScanStatus?: {
38
- status?: string
39
- description?: string
40
- }
41
- imageScanFindingsSummary?: {
42
- findingSeverityCounts?: Record<string, number>
43
- }
44
- }
45
-
46
- export interface CreateRepositoryOptions {
47
- repositoryName: string
48
- tags?: { Key: string, Value: string }[]
49
- imageTagMutability?: 'MUTABLE' | 'IMMUTABLE'
50
- imageScanningConfiguration?: {
51
- scanOnPush?: boolean
52
- }
53
- encryptionConfiguration?: {
54
- encryptionType?: 'AES256' | 'KMS'
55
- kmsKey?: string
56
- }
57
- }
58
-
59
- export interface LifecyclePolicy {
60
- rulePriority: number
61
- description?: string
62
- selection: {
63
- tagStatus: 'tagged' | 'untagged' | 'any'
64
- tagPrefixList?: string[]
65
- countType: 'imageCountMoreThan' | 'sinceImagePushed'
66
- countNumber?: number
67
- countUnit?: 'days'
68
- }
69
- action: {
70
- type: 'expire'
71
- }
72
- }
73
-
74
- /**
75
- * ECR service management using direct API calls
76
- */
77
- export class ECRClient {
78
- private client: AWSClient
79
- private region: string
80
-
81
- constructor(region: string = 'us-east-1', profile?: string) {
82
- this.region = region
83
- this.client = new AWSClient()
84
- }
85
-
86
- /**
87
- * Create a new ECR repository
88
- */
89
- async createRepository(options: CreateRepositoryOptions): Promise<{ repository?: Repository }> {
90
- const params: Record<string, any> = {
91
- repositoryName: options.repositoryName,
92
- }
93
-
94
- if (options.imageTagMutability) {
95
- params.imageTagMutability = options.imageTagMutability
96
- }
97
-
98
- if (options.imageScanningConfiguration) {
99
- params.imageScanningConfiguration = options.imageScanningConfiguration
100
- }
101
-
102
- if (options.encryptionConfiguration) {
103
- params.encryptionConfiguration = options.encryptionConfiguration
104
- }
105
-
106
- if (options.tags && options.tags.length > 0) {
107
- params.tags = options.tags
108
- }
109
-
110
- const result = await this.client.request({
111
- service: 'ecr',
112
- region: this.region,
113
- method: 'POST',
114
- path: '/',
115
- headers: {
116
- 'X-Amz-Target': 'AmazonEC2ContainerRegistry_V20150921.CreateRepository',
117
- 'Content-Type': 'application/x-amz-json-1.1',
118
- },
119
- body: JSON.stringify(params),
120
- })
121
-
122
- return {
123
- repository: result.repository ? this.parseRepository(result.repository) : undefined,
124
- }
125
- }
126
-
127
- /**
128
- * Describe ECR repositories
129
- */
130
- async describeRepositories(options?: {
131
- repositoryNames?: string[]
132
- registryId?: string
133
- maxResults?: number
134
- nextToken?: string
135
- }): Promise<{ repositories?: Repository[], nextToken?: string }> {
136
- const params: Record<string, any> = {}
137
-
138
- if (options?.repositoryNames && options.repositoryNames.length > 0) {
139
- params.repositoryNames = options.repositoryNames
140
- }
141
-
142
- if (options?.registryId) {
143
- params.registryId = options.registryId
144
- }
145
-
146
- if (options?.maxResults) {
147
- params.maxResults = options.maxResults
148
- }
149
-
150
- if (options?.nextToken) {
151
- params.nextToken = options.nextToken
152
- }
153
-
154
- const result = await this.client.request({
155
- service: 'ecr',
156
- region: this.region,
157
- method: 'POST',
158
- path: '/',
159
- headers: {
160
- 'X-Amz-Target': 'AmazonEC2ContainerRegistry_V20150921.DescribeRepositories',
161
- 'Content-Type': 'application/x-amz-json-1.1',
162
- },
163
- body: JSON.stringify(params),
164
- })
165
-
166
- return {
167
- repositories: result.repositories?.map((repo: any) => this.parseRepository(repo)),
168
- nextToken: result.nextToken,
169
- }
170
- }
171
-
172
- /**
173
- * Get authorization token for Docker login
174
- */
175
- async getAuthorizationToken(registryIds?: string[]): Promise<{
176
- authorizationData?: AuthorizationData[]
177
- }> {
178
- const params: Record<string, any> = {}
179
-
180
- if (registryIds && registryIds.length > 0) {
181
- params.registryIds = registryIds
182
- }
183
-
184
- const result = await this.client.request({
185
- service: 'ecr',
186
- region: this.region,
187
- method: 'POST',
188
- path: '/',
189
- headers: {
190
- 'X-Amz-Target': 'AmazonEC2ContainerRegistry_V20150921.GetAuthorizationToken',
191
- 'Content-Type': 'application/x-amz-json-1.1',
192
- },
193
- body: JSON.stringify(params),
194
- })
195
-
196
- return {
197
- authorizationData: result.authorizationData?.map((auth: any) => ({
198
- authorizationToken: auth.authorizationToken,
199
- expiresAt: auth.expiresAt,
200
- proxyEndpoint: auth.proxyEndpoint,
201
- })),
202
- }
203
- }
204
-
205
- /**
206
- * Delete an ECR repository
207
- */
208
- async deleteRepository(options: {
209
- repositoryName: string
210
- registryId?: string
211
- force?: boolean
212
- }): Promise<{ repository?: Repository }> {
213
- const params: Record<string, any> = {
214
- repositoryName: options.repositoryName,
215
- }
216
-
217
- if (options.registryId) {
218
- params.registryId = options.registryId
219
- }
220
-
221
- if (options.force !== undefined) {
222
- params.force = options.force
223
- }
224
-
225
- const result = await this.client.request({
226
- service: 'ecr',
227
- region: this.region,
228
- method: 'POST',
229
- path: '/',
230
- headers: {
231
- 'X-Amz-Target': 'AmazonEC2ContainerRegistry_V20150921.DeleteRepository',
232
- 'Content-Type': 'application/x-amz-json-1.1',
233
- },
234
- body: JSON.stringify(params),
235
- })
236
-
237
- return {
238
- repository: result.repository ? this.parseRepository(result.repository) : undefined,
239
- }
240
- }
241
-
242
- /**
243
- * Describe images in a repository
244
- */
245
- async describeImages(options: {
246
- repositoryName: string
247
- registryId?: string
248
- imageIds?: { imageTag?: string, imageDigest?: string }[]
249
- filter?: { tagStatus?: 'TAGGED' | 'UNTAGGED' | 'ANY' }
250
- maxResults?: number
251
- nextToken?: string
252
- }): Promise<{ imageDetails?: ImageDetail[], nextToken?: string }> {
253
- const params: Record<string, any> = {
254
- repositoryName: options.repositoryName,
255
- }
256
-
257
- if (options.registryId) {
258
- params.registryId = options.registryId
259
- }
260
-
261
- if (options.imageIds && options.imageIds.length > 0) {
262
- params.imageIds = options.imageIds
263
- }
264
-
265
- if (options.filter) {
266
- params.filter = options.filter
267
- }
268
-
269
- if (options.maxResults) {
270
- params.maxResults = options.maxResults
271
- }
272
-
273
- if (options.nextToken) {
274
- params.nextToken = options.nextToken
275
- }
276
-
277
- const result = await this.client.request({
278
- service: 'ecr',
279
- region: this.region,
280
- method: 'POST',
281
- path: '/',
282
- headers: {
283
- 'X-Amz-Target': 'AmazonEC2ContainerRegistry_V20150921.DescribeImages',
284
- 'Content-Type': 'application/x-amz-json-1.1',
285
- },
286
- body: JSON.stringify(params),
287
- })
288
-
289
- return {
290
- imageDetails: result.imageDetails?.map((img: any) => this.parseImageDetail(img)),
291
- nextToken: result.nextToken,
292
- }
293
- }
294
-
295
- /**
296
- * Batch delete images from a repository
297
- */
298
- async batchDeleteImage(options: {
299
- repositoryName: string
300
- registryId?: string
301
- imageIds: { imageTag?: string, imageDigest?: string }[]
302
- }): Promise<{
303
- imageIds?: { imageTag?: string, imageDigest?: string }[]
304
- failures?: { imageId?: { imageTag?: string, imageDigest?: string }, failureCode?: string, failureReason?: string }[]
305
- }> {
306
- const params: Record<string, any> = {
307
- repositoryName: options.repositoryName,
308
- imageIds: options.imageIds,
309
- }
310
-
311
- if (options.registryId) {
312
- params.registryId = options.registryId
313
- }
314
-
315
- const result = await this.client.request({
316
- service: 'ecr',
317
- region: this.region,
318
- method: 'POST',
319
- path: '/',
320
- headers: {
321
- 'X-Amz-Target': 'AmazonEC2ContainerRegistry_V20150921.BatchDeleteImage',
322
- 'Content-Type': 'application/x-amz-json-1.1',
323
- },
324
- body: JSON.stringify(params),
325
- })
326
-
327
- return {
328
- imageIds: result.imageIds,
329
- failures: result.failures,
330
- }
331
- }
332
-
333
- /**
334
- * Put lifecycle policy on a repository
335
- */
336
- async putLifecyclePolicy(options: {
337
- repositoryName: string
338
- registryId?: string
339
- lifecyclePolicyText: string
340
- }): Promise<{
341
- registryId?: string
342
- repositoryName?: string
343
- lifecyclePolicyText?: string
344
- }> {
345
- const params: Record<string, any> = {
346
- repositoryName: options.repositoryName,
347
- lifecyclePolicyText: options.lifecyclePolicyText,
348
- }
349
-
350
- if (options.registryId) {
351
- params.registryId = options.registryId
352
- }
353
-
354
- const result = await this.client.request({
355
- service: 'ecr',
356
- region: this.region,
357
- method: 'POST',
358
- path: '/',
359
- headers: {
360
- 'X-Amz-Target': 'AmazonEC2ContainerRegistry_V20150921.PutLifecyclePolicy',
361
- 'Content-Type': 'application/x-amz-json-1.1',
362
- },
363
- body: JSON.stringify(params),
364
- })
365
-
366
- return {
367
- registryId: result.registryId,
368
- repositoryName: result.repositoryName,
369
- lifecyclePolicyText: result.lifecyclePolicyText,
370
- }
371
- }
372
-
373
- /**
374
- * Get lifecycle policy for a repository
375
- */
376
- async getLifecyclePolicy(options: {
377
- repositoryName: string
378
- registryId?: string
379
- }): Promise<{
380
- registryId?: string
381
- repositoryName?: string
382
- lifecyclePolicyText?: string
383
- lastEvaluatedAt?: string
384
- }> {
385
- const params: Record<string, any> = {
386
- repositoryName: options.repositoryName,
387
- }
388
-
389
- if (options.registryId) {
390
- params.registryId = options.registryId
391
- }
392
-
393
- const result = await this.client.request({
394
- service: 'ecr',
395
- region: this.region,
396
- method: 'POST',
397
- path: '/',
398
- headers: {
399
- 'X-Amz-Target': 'AmazonEC2ContainerRegistry_V20150921.GetLifecyclePolicy',
400
- 'Content-Type': 'application/x-amz-json-1.1',
401
- },
402
- body: JSON.stringify(params),
403
- })
404
-
405
- return {
406
- registryId: result.registryId,
407
- repositoryName: result.repositoryName,
408
- lifecyclePolicyText: result.lifecyclePolicyText,
409
- lastEvaluatedAt: result.lastEvaluatedAt,
410
- }
411
- }
412
-
413
- /**
414
- * Set repository policy
415
- */
416
- async setRepositoryPolicy(options: {
417
- repositoryName: string
418
- policyText: string
419
- registryId?: string
420
- force?: boolean
421
- }): Promise<{
422
- registryId?: string
423
- repositoryName?: string
424
- policyText?: string
425
- }> {
426
- const params: Record<string, any> = {
427
- repositoryName: options.repositoryName,
428
- policyText: options.policyText,
429
- }
430
-
431
- if (options.registryId) {
432
- params.registryId = options.registryId
433
- }
434
-
435
- if (options.force !== undefined) {
436
- params.force = options.force
437
- }
438
-
439
- const result = await this.client.request({
440
- service: 'ecr',
441
- region: this.region,
442
- method: 'POST',
443
- path: '/',
444
- headers: {
445
- 'X-Amz-Target': 'AmazonEC2ContainerRegistry_V20150921.SetRepositoryPolicy',
446
- 'Content-Type': 'application/x-amz-json-1.1',
447
- },
448
- body: JSON.stringify(params),
449
- })
450
-
451
- return {
452
- registryId: result.registryId,
453
- repositoryName: result.repositoryName,
454
- policyText: result.policyText,
455
- }
456
- }
457
-
458
- /**
459
- * Get repository policy
460
- */
461
- async getRepositoryPolicy(options: {
462
- repositoryName: string
463
- registryId?: string
464
- }): Promise<{
465
- registryId?: string
466
- repositoryName?: string
467
- policyText?: string
468
- }> {
469
- const params: Record<string, any> = {
470
- repositoryName: options.repositoryName,
471
- }
472
-
473
- if (options.registryId) {
474
- params.registryId = options.registryId
475
- }
476
-
477
- const result = await this.client.request({
478
- service: 'ecr',
479
- region: this.region,
480
- method: 'POST',
481
- path: '/',
482
- headers: {
483
- 'X-Amz-Target': 'AmazonEC2ContainerRegistry_V20150921.GetRepositoryPolicy',
484
- 'Content-Type': 'application/x-amz-json-1.1',
485
- },
486
- body: JSON.stringify(params),
487
- })
488
-
489
- return {
490
- registryId: result.registryId,
491
- repositoryName: result.repositoryName,
492
- policyText: result.policyText,
493
- }
494
- }
495
-
496
- /**
497
- * Tag a repository resource
498
- */
499
- async tagResource(options: {
500
- resourceArn: string
501
- tags: { Key: string, Value: string }[]
502
- }): Promise<void> {
503
- const params: Record<string, any> = {
504
- resourceArn: options.resourceArn,
505
- tags: options.tags,
506
- }
507
-
508
- await this.client.request({
509
- service: 'ecr',
510
- region: this.region,
511
- method: 'POST',
512
- path: '/',
513
- headers: {
514
- 'X-Amz-Target': 'AmazonEC2ContainerRegistry_V20150921.TagResource',
515
- 'Content-Type': 'application/x-amz-json-1.1',
516
- },
517
- body: JSON.stringify(params),
518
- })
519
- }
520
-
521
- /**
522
- * List tags for a resource
523
- */
524
- async listTagsForResource(resourceArn: string): Promise<{
525
- tags?: { Key: string, Value: string }[]
526
- }> {
527
- const params: Record<string, any> = {
528
- resourceArn,
529
- }
530
-
531
- const result = await this.client.request({
532
- service: 'ecr',
533
- region: this.region,
534
- method: 'POST',
535
- path: '/',
536
- headers: {
537
- 'X-Amz-Target': 'AmazonEC2ContainerRegistry_V20150921.ListTagsForResource',
538
- 'Content-Type': 'application/x-amz-json-1.1',
539
- },
540
- body: JSON.stringify(params),
541
- })
542
-
543
- return {
544
- tags: result.tags,
545
- }
546
- }
547
-
548
- /**
549
- * Helper: Create a standard lifecycle policy to keep only N images
550
- */
551
- createLifecyclePolicyText(rules: LifecyclePolicy[]): string {
552
- return JSON.stringify({
553
- rules: rules.map(rule => ({
554
- rulePriority: rule.rulePriority,
555
- description: rule.description,
556
- selection: rule.selection,
557
- action: rule.action,
558
- })),
559
- })
560
- }
561
-
562
- /**
563
- * Helper: Get docker login command
564
- */
565
- async getDockerLoginCommand(): Promise<string> {
566
- const authResult = await this.getAuthorizationToken()
567
-
568
- if (!authResult.authorizationData?.[0]) {
569
- throw new Error('Failed to get authorization token')
570
- }
571
-
572
- const auth = authResult.authorizationData[0]
573
- const token = auth.authorizationToken || ''
574
- const endpoint = auth.proxyEndpoint || ''
575
-
576
- // Token is base64 encoded "AWS:password"
577
- const decoded = Buffer.from(token, 'base64').toString('utf8')
578
- const password = decoded.split(':')[1]
579
-
580
- return `echo "${password}" | docker login --username AWS --password-stdin ${endpoint}`
581
- }
582
-
583
- /**
584
- * Helper: Get the registry URI for this region
585
- */
586
- getRegistryUri(accountId: string): string {
587
- return `${accountId}.dkr.ecr.${this.region}.amazonaws.com`
588
- }
589
-
590
- /**
591
- * Parse repository response
592
- */
593
- private parseRepository(repo: any): Repository {
594
- return {
595
- repositoryArn: repo.repositoryArn,
596
- registryId: repo.registryId,
597
- repositoryName: repo.repositoryName,
598
- repositoryUri: repo.repositoryUri,
599
- createdAt: repo.createdAt,
600
- imageTagMutability: repo.imageTagMutability,
601
- imageScanningConfiguration: repo.imageScanningConfiguration,
602
- encryptionConfiguration: repo.encryptionConfiguration,
603
- }
604
- }
605
-
606
- /**
607
- * Parse image detail response
608
- */
609
- private parseImageDetail(img: any): ImageDetail {
610
- return {
611
- registryId: img.registryId,
612
- repositoryName: img.repositoryName,
613
- imageDigest: img.imageDigest,
614
- imageTags: img.imageTags,
615
- imageSizeInBytes: img.imageSizeInBytes,
616
- imagePushedAt: img.imagePushedAt,
617
- imageScanStatus: img.imageScanStatus,
618
- imageScanFindingsSummary: img.imageScanFindingsSummary,
619
- }
620
- }
621
- }