cdk-docker-image-deployment 0.0.976 → 0.0.978
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.
package/.jsii
CHANGED
|
@@ -3559,6 +3559,6 @@
|
|
|
3559
3559
|
"symbolId": "src/source:SourceContext"
|
|
3560
3560
|
}
|
|
3561
3561
|
},
|
|
3562
|
-
"version": "0.0.
|
|
3563
|
-
"fingerprint": "+
|
|
3562
|
+
"version": "0.0.978",
|
|
3563
|
+
"fingerprint": "5AoH7+qeAqccOEoX5uwa/sg9Me5RtO+fmqmuIrjTze0="
|
|
3564
3564
|
}
|
package/lib/destination.js
CHANGED
|
@@ -26,7 +26,7 @@ class Destination {
|
|
|
26
26
|
}
|
|
27
27
|
exports.Destination = Destination;
|
|
28
28
|
_a = JSII_RTTI_SYMBOL_1;
|
|
29
|
-
Destination[_a] = { fqn: "cdk-docker-image-deployment.Destination", version: "0.0.
|
|
29
|
+
Destination[_a] = { fqn: "cdk-docker-image-deployment.Destination", version: "0.0.978" };
|
|
30
30
|
/**
|
|
31
31
|
* Class used when the destination of docker image deployment is an ECR repository in the same account as the stack
|
|
32
32
|
*/
|
|
@@ -114,5 +114,5 @@ class DockerImageDeployment extends constructs_1.Construct {
|
|
|
114
114
|
}
|
|
115
115
|
exports.DockerImageDeployment = DockerImageDeployment;
|
|
116
116
|
_a = JSII_RTTI_SYMBOL_1;
|
|
117
|
-
DockerImageDeployment[_a] = { fqn: "cdk-docker-image-deployment.DockerImageDeployment", version: "0.0.
|
|
117
|
+
DockerImageDeployment[_a] = { fqn: "cdk-docker-image-deployment.DockerImageDeployment", version: "0.0.978" };
|
|
118
118
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docker-image-deployment.js","sourceRoot":"","sources":["../src/docker-image-deployment.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport { CustomResource, Duration, CfnOutput, Token } from 'aws-cdk-lib';\nimport * as codebuild from 'aws-cdk-lib/aws-codebuild';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport { Runtime } from 'aws-cdk-lib/aws-lambda';\nimport * as lambda from 'aws-cdk-lib/aws-lambda-nodejs';\nimport * as cr from 'aws-cdk-lib/custom-resources';\nimport { Construct } from 'constructs';\nimport { Destination } from './destination';\nimport { Source } from './source';\n\nexport interface DockerImageDeploymentProps {\n  /**\n   * Source of the image to deploy.\n   */\n  readonly source: Source;\n\n  /**\n   * Destination repository to deploy the image to.\n   */\n  readonly destination: Destination;\n}\n\n/**\n * `DockerImageDeployment` pushes an image from a local or external source to a specified external destination\n */\nexport class DockerImageDeployment extends Construct {\n  private readonly cb: codebuild.Project;\n\n  constructor(scope: Construct, id: string, props: DockerImageDeploymentProps) {\n    super(scope, id);\n\n    const handlerRole = new iam.Role(this, 'DockerImageDeployRole', {\n      assumedBy: new iam.ServicePrincipal('codebuild.amazonaws.com'),\n    });\n\n    const sourceConfig = props.source.bind(this, { handlerRole });\n    const destinationConfig = props.destination.bind(handlerRole);\n\n    const sourceUri = sourceConfig.imageUri;\n\n    const destTag = destinationConfig.destinationTag ?? sourceConfig.imageTag;\n    this.validateTag(destTag);\n\n    const destUri = `${destinationConfig.destinationUri}:${destTag}`;\n\n    const commands = [\n      sourceConfig.loginConfig.loginCommand,\n      `docker pull ${sourceUri}`,\n      `docker tag ${sourceUri} ${destUri}`,\n    ];\n\n    if (sourceConfig.loginConfig.region !== destinationConfig.loginConfig.region || !sourceConfig.loginConfig.region) { // different regions or either undefined should logout and login\n      commands.push('docker logout');\n      commands.push(destinationConfig.loginConfig.loginCommand);\n    }\n\n    commands.push(`docker push ${destUri}`);\n    commands.push('docker logout');\n\n    this.cb = new codebuild.Project(this, 'DockerImageDeployProject', {\n      buildSpec: codebuild.BuildSpec.fromObject({\n        version: '0.2',\n        phases: {\n          build: {\n            commands: commands,\n          },\n        },\n      }),\n      environment: {\n        privileged: true,\n        buildImage: codebuild.LinuxBuildImage.STANDARD_5_0,\n      },\n      role: handlerRole,\n    });\n\n    const onEventHandler = new lambda.NodejsFunction(this, 'onEventHandler', {\n      entry: path.join(__dirname, 'codebuild-handler/index.js'),\n      handler: 'onEventhandler',\n      runtime: Runtime.NODEJS_16_X,\n    });\n\n    const isCompleteHandler = new lambda.NodejsFunction(this, 'isCompleteHandler', {\n      entry: path.join(__dirname, 'codebuild-handler/index.js'),\n      handler: 'isCompleteHandler',\n      runtime: Runtime.NODEJS_16_X,\n    });\n\n    // https://github.com/aws/aws-cdk/issues/21721 issue to add grant methods to codebuild\n    const grantOnEvent = iam.Grant.addToPrincipal({\n      grantee: onEventHandler,\n      actions: ['codebuild:StartBuild'],\n      resourceArns: [this.cb.projectArn],\n      scope: this,\n    });\n\n    const grantIsComplete = iam.Grant.addToPrincipal({\n      grantee: isCompleteHandler,\n      actions: [\n        'codebuild:ListBuildsForProject',\n        'codebuild:BatchGetBuilds',\n      ],\n      resourceArns: [this.cb.projectArn],\n      scope: this,\n    });\n\n    const crProvider = new cr.Provider(this, 'CRProvider', {\n      onEventHandler: onEventHandler,\n      isCompleteHandler: isCompleteHandler,\n      queryInterval: Duration.seconds(30),\n      totalTimeout: Duration.minutes(30),\n    });\n\n    const customResource = new CustomResource(this, `CustomResource${Date.now().toString()}`, {\n      serviceToken: crProvider.serviceToken,\n      properties: {\n        projectName: this.cb.projectName,\n      },\n    });\n\n    customResource.node.addDependency(grantOnEvent, grantIsComplete);\n\n    try {\n      new CfnOutput(this, 'CustomResourceReport', {\n        value: `${customResource.getAttString('Status')}, see the logs here: ${customResource.getAtt('LogsUrl')}`,\n      });\n    } catch (error) {\n      throw new Error('Error getting the report from the custom resource');\n    }\n  }\n\n  private validateTag(tag: string): void {\n    if (Token.isUnresolved(tag)) {\n      return; // if token tag is likely from source, so assume it is valid\n    }\n    if (tag.length > 128) {\n      throw new Error (`Invalid tag: tags may contain a maximum of 128 characters; your tag ${tag} has ${tag.length} characters`);\n    }\n    if (!/^[^-.][a-zA-Z0-9-_.]+$/.test(tag)) {\n      throw new Error(`Invalid tag: tags must contain alphanumeric characters and \\'-\\' \\'_\\' \\'.\\' only and must not begin with \\'.\\' or \\'-\\'; your tag was ${tag}`);\n    }\n  }\n}\n"]}
|
package/lib/source.js
CHANGED
|
@@ -40,7 +40,7 @@ class Source {
|
|
|
40
40
|
}
|
|
41
41
|
exports.Source = Source;
|
|
42
42
|
_a = JSII_RTTI_SYMBOL_1;
|
|
43
|
-
Source[_a] = { fqn: "cdk-docker-image-deployment.Source", version: "0.0.
|
|
43
|
+
Source[_a] = { fqn: "cdk-docker-image-deployment.Source", version: "0.0.978" };
|
|
44
44
|
/**
|
|
45
45
|
* Source of docker image deployment is a local image from a directory
|
|
46
46
|
*/
|
|
@@ -63,6 +63,7 @@
|
|
|
63
63
|
clearBuffers(parser)
|
|
64
64
|
parser.q = parser.c = ''
|
|
65
65
|
parser.bufferCheckPosition = sax.MAX_BUFFER_LENGTH
|
|
66
|
+
parser.encoding = null;
|
|
66
67
|
parser.opt = opt || {}
|
|
67
68
|
parser.opt.lowercase = parser.opt.lowercase || parser.opt.lowercasetags
|
|
68
69
|
parser.looseCase = parser.opt.lowercase ? 'toLowerCase' : 'toUpperCase'
|
|
@@ -207,6 +208,39 @@
|
|
|
207
208
|
return new SAXStream(strict, opt)
|
|
208
209
|
}
|
|
209
210
|
|
|
211
|
+
function determineBufferEncoding(data, isEnd) {
|
|
212
|
+
// BOM-based detection is the most reliable signal when present.
|
|
213
|
+
if (data.length >= 2) {
|
|
214
|
+
if (data[0] === 0xff && data[1] === 0xfe) {
|
|
215
|
+
return 'utf-16le'
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
if (data[0] === 0xfe && data[1] === 0xff) {
|
|
219
|
+
return 'utf-16be'
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
if (data.length >= 3 && data[0] === 0xef && data[1] === 0xbb && data[2] === 0xbf) {
|
|
224
|
+
return 'utf8'
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
if (data.length >= 4) {
|
|
228
|
+
// XML documents without a BOM still start with "<?xml", which is enough
|
|
229
|
+
// to distinguish UTF-16LE/BE from UTF-8 by looking at the zero bytes.
|
|
230
|
+
if (data[0] === 0x3c && data[1] === 0x00 && data[2] === 0x3f && data[3] === 0x00) {
|
|
231
|
+
return 'utf-16le'
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
if (data[0] === 0x00 && data[1] === 0x3c && data[2] === 0x00 && data[3] === 0x3f) {
|
|
235
|
+
return 'utf-16be'
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
return 'utf8'
|
|
239
|
+
}
|
|
240
|
+
|
|
241
|
+
return isEnd ? 'utf8' : null
|
|
242
|
+
}
|
|
243
|
+
|
|
210
244
|
function SAXStream(strict, opt) {
|
|
211
245
|
if (!(this instanceof SAXStream)) {
|
|
212
246
|
return new SAXStream(strict, opt)
|
|
@@ -233,7 +267,7 @@
|
|
|
233
267
|
}
|
|
234
268
|
|
|
235
269
|
this._decoder = null
|
|
236
|
-
|
|
270
|
+
this._decoderBuffer = null
|
|
237
271
|
streamWraps.forEach(function (ev) {
|
|
238
272
|
Object.defineProperty(me, 'on' + ev, {
|
|
239
273
|
get: function () {
|
|
@@ -259,16 +293,47 @@
|
|
|
259
293
|
},
|
|
260
294
|
})
|
|
261
295
|
|
|
296
|
+
SAXStream.prototype._decodeBuffer = function (data, isEnd) {
|
|
297
|
+
if (this._decoderBuffer) {
|
|
298
|
+
// Keep incomplete leading bytes until we have enough data to infer the
|
|
299
|
+
// stream encoding, then decode the buffered prefix together with the next chunk.
|
|
300
|
+
data = Buffer.concat([this._decoderBuffer, data])
|
|
301
|
+
this._decoderBuffer = null
|
|
302
|
+
}
|
|
303
|
+
|
|
304
|
+
if (!this._decoder) {
|
|
305
|
+
var encoding = determineBufferEncoding(data, isEnd)
|
|
306
|
+
if (!encoding) {
|
|
307
|
+
// A very short first chunk may not contain enough bytes to detect the
|
|
308
|
+
// encoding yet, so defer decoding until the next write/end call.
|
|
309
|
+
this._decoderBuffer = data
|
|
310
|
+
return ''
|
|
311
|
+
}
|
|
312
|
+
|
|
313
|
+
// Store the detected transport encoding so strict mode can compare it
|
|
314
|
+
// with the optional encoding declared in the XML prolog later on.
|
|
315
|
+
this._parser.encoding = encoding
|
|
316
|
+
this._decoder = new TextDecoder(encoding)
|
|
317
|
+
}
|
|
318
|
+
|
|
319
|
+
return this._decoder.decode(data, { stream: !isEnd })
|
|
320
|
+
}
|
|
321
|
+
|
|
262
322
|
SAXStream.prototype.write = function (data) {
|
|
263
323
|
if (
|
|
264
324
|
typeof Buffer === 'function' &&
|
|
265
325
|
typeof Buffer.isBuffer === 'function' &&
|
|
266
326
|
Buffer.isBuffer(data)
|
|
267
327
|
) {
|
|
268
|
-
|
|
269
|
-
|
|
328
|
+
data = this._decodeBuffer(data, false)
|
|
329
|
+
} else if (this._decoderBuffer) {
|
|
330
|
+
// Flush any buffered binary prefix before handling a string chunk.
|
|
331
|
+
// This only matters if the caller mixes Buffer and string writes (used in test).
|
|
332
|
+
var remaining = this._decodeBuffer(Buffer.alloc(0), true)
|
|
333
|
+
if (remaining) {
|
|
334
|
+
this._parser.write(remaining)
|
|
335
|
+
this.emit('data', remaining)
|
|
270
336
|
}
|
|
271
|
-
data = this._decoder.decode(data, { stream: true })
|
|
272
337
|
}
|
|
273
338
|
|
|
274
339
|
this._parser.write(data.toString())
|
|
@@ -281,7 +346,13 @@
|
|
|
281
346
|
this.write(chunk)
|
|
282
347
|
}
|
|
283
348
|
// Flush any remaining decoded data from the TextDecoder
|
|
284
|
-
if (this.
|
|
349
|
+
if (this._decoderBuffer) {
|
|
350
|
+
var finalChunk = this._decodeBuffer(Buffer.alloc(0), true)
|
|
351
|
+
if (finalChunk) {
|
|
352
|
+
this._parser.write(finalChunk)
|
|
353
|
+
this.emit('data', finalChunk)
|
|
354
|
+
}
|
|
355
|
+
} else if (this._decoder) {
|
|
285
356
|
var remaining = this._decoder.decode()
|
|
286
357
|
if (remaining) {
|
|
287
358
|
this._parser.write(remaining)
|
|
@@ -674,6 +745,59 @@
|
|
|
674
745
|
parser[event] && parser[event](data)
|
|
675
746
|
}
|
|
676
747
|
|
|
748
|
+
function getDeclaredEncoding(body) {
|
|
749
|
+
var match = body && body.match(/(?:^|\s)encoding\s*=\s*(['"])([^'"]+)\1/i)
|
|
750
|
+
return match ? match[2] : null
|
|
751
|
+
}
|
|
752
|
+
|
|
753
|
+
function normalizeEncodingName(encoding) {
|
|
754
|
+
if (!encoding) {
|
|
755
|
+
return null
|
|
756
|
+
}
|
|
757
|
+
|
|
758
|
+
return encoding.toLowerCase().replace(/[^a-z0-9]/g, '')
|
|
759
|
+
}
|
|
760
|
+
|
|
761
|
+
function encodingsMatch(detectedEncoding, declaredEncoding) {
|
|
762
|
+
const detected = normalizeEncodingName(detectedEncoding)
|
|
763
|
+
const declared = normalizeEncodingName(declaredEncoding)
|
|
764
|
+
|
|
765
|
+
if (!detected || !declared) {
|
|
766
|
+
return true
|
|
767
|
+
}
|
|
768
|
+
|
|
769
|
+
if (declared === 'utf16') {
|
|
770
|
+
return detected === 'utf16le' || detected === 'utf16be'
|
|
771
|
+
}
|
|
772
|
+
|
|
773
|
+
return detected === declared
|
|
774
|
+
}
|
|
775
|
+
|
|
776
|
+
function validateXmlDeclarationEncoding(parser, data) {
|
|
777
|
+
if (
|
|
778
|
+
!parser.strict ||
|
|
779
|
+
!parser.encoding ||
|
|
780
|
+
!data ||
|
|
781
|
+
data.name !== 'xml'
|
|
782
|
+
) {
|
|
783
|
+
return
|
|
784
|
+
}
|
|
785
|
+
|
|
786
|
+
var declaredEncoding = getDeclaredEncoding(data.body)
|
|
787
|
+
if (
|
|
788
|
+
declaredEncoding &&
|
|
789
|
+
!encodingsMatch(parser.encoding, declaredEncoding)
|
|
790
|
+
) {
|
|
791
|
+
strictFail(
|
|
792
|
+
parser,
|
|
793
|
+
'XML declaration encoding ' +
|
|
794
|
+
declaredEncoding +
|
|
795
|
+
' does not match detected stream encoding ' +
|
|
796
|
+
parser.encoding.toUpperCase()
|
|
797
|
+
)
|
|
798
|
+
}
|
|
799
|
+
}
|
|
800
|
+
|
|
677
801
|
function emitNode(parser, nodeType, data) {
|
|
678
802
|
if (parser.textNode) closeText(parser)
|
|
679
803
|
emit(parser, nodeType, data)
|
|
@@ -1379,10 +1503,12 @@
|
|
|
1379
1503
|
|
|
1380
1504
|
case S.PROC_INST_ENDING:
|
|
1381
1505
|
if (c === '>') {
|
|
1382
|
-
|
|
1506
|
+
const procInstEndData = {
|
|
1383
1507
|
name: parser.procInstName,
|
|
1384
1508
|
body: parser.procInstBody,
|
|
1385
|
-
}
|
|
1509
|
+
}
|
|
1510
|
+
validateXmlDeclarationEncoding(parser, procInstEndData)
|
|
1511
|
+
emitNode(parser, 'onprocessinginstruction', procInstEndData)
|
|
1386
1512
|
parser.procInstName = parser.procInstBody = ''
|
|
1387
1513
|
parser.state = S.TEXT
|
|
1388
1514
|
} else {
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
"name": "sax",
|
|
3
3
|
"description": "An evented streaming XML parser in JavaScript",
|
|
4
4
|
"author": "Isaac Z. Schlueter <i@izs.me> (http://blog.izs.me/)",
|
|
5
|
-
"version": "1.
|
|
5
|
+
"version": "1.6.0",
|
|
6
6
|
"main": "lib/sax.js",
|
|
7
7
|
"license": "BlueOak-1.0.0",
|
|
8
8
|
"scripts": {
|
|
@@ -12,7 +12,10 @@
|
|
|
12
12
|
"postpublish": "git push origin --all; git push origin --tags",
|
|
13
13
|
"format": "prettier --write . --log-level warn"
|
|
14
14
|
},
|
|
15
|
-
"repository":
|
|
15
|
+
"repository": {
|
|
16
|
+
"type": "git",
|
|
17
|
+
"url": "git+ssh://git@github.com/isaacs/sax-js.git"
|
|
18
|
+
},
|
|
16
19
|
"files": [
|
|
17
20
|
"lib/sax.js",
|
|
18
21
|
"LICENSE",
|
package/package.json
CHANGED
|
@@ -57,7 +57,7 @@
|
|
|
57
57
|
"jsii-docgen": "^10.5.0",
|
|
58
58
|
"jsii-pacmak": "^1.127.0",
|
|
59
59
|
"jsii-rosetta": "~5.9.0",
|
|
60
|
-
"projen": "^0.99.
|
|
60
|
+
"projen": "^0.99.21",
|
|
61
61
|
"ts-jest": "^27",
|
|
62
62
|
"ts-node": "^10.9.2",
|
|
63
63
|
"typescript": "^4.9.5"
|
|
@@ -83,7 +83,7 @@
|
|
|
83
83
|
"publishConfig": {
|
|
84
84
|
"access": "public"
|
|
85
85
|
},
|
|
86
|
-
"version": "0.0.
|
|
86
|
+
"version": "0.0.978",
|
|
87
87
|
"jest": {
|
|
88
88
|
"coverageProvider": "v8",
|
|
89
89
|
"testMatch": [
|