@cdklabs/cdk-ecs-codedeploy 0.0.172 → 0.0.174
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 +3 -3
- package/lib/api-canary/index.js +1 -1
- package/lib/ecs-appspec/index.js +1 -1
- package/lib/ecs-deployment/index.js +1 -1
- package/lib/ecs-patterns/application-load-balanced-codedeployed-fargate-service.js +1 -1
- package/node_modules/@aws-crypto/crc32/CHANGELOG.md +76 -0
- package/node_modules/@aws-crypto/crc32/LICENSE +201 -0
- package/node_modules/@aws-crypto/crc32/README.md +16 -0
- package/node_modules/@aws-crypto/crc32/build/aws_crc32.d.ts +7 -0
- package/node_modules/@aws-crypto/crc32/build/aws_crc32.js +31 -0
- package/node_modules/@aws-crypto/crc32/build/aws_crc32.js.map +1 -0
- package/node_modules/@aws-crypto/crc32/build/index.d.ts +7 -0
- package/node_modules/@aws-crypto/crc32/build/index.js +108 -0
- package/node_modules/@aws-crypto/crc32/build/index.js.map +1 -0
- package/node_modules/@aws-crypto/crc32/node_modules/tslib/CopyrightNotice.txt +15 -0
- package/node_modules/@aws-crypto/crc32/node_modules/tslib/LICENSE.txt +12 -0
- package/node_modules/@aws-crypto/crc32/node_modules/tslib/README.md +142 -0
- package/node_modules/@aws-crypto/crc32/node_modules/tslib/modules/index.js +51 -0
- package/node_modules/@aws-crypto/crc32/node_modules/tslib/modules/package.json +3 -0
- package/node_modules/@aws-crypto/crc32/node_modules/tslib/package.json +37 -0
- package/node_modules/@aws-crypto/crc32/node_modules/tslib/test/validateModuleExportsMatchCommonJS/index.js +23 -0
- package/node_modules/@aws-crypto/crc32/node_modules/tslib/test/validateModuleExportsMatchCommonJS/package.json +6 -0
- package/node_modules/@aws-crypto/crc32/node_modules/tslib/tslib.d.ts +37 -0
- package/node_modules/@aws-crypto/crc32/node_modules/tslib/tslib.es6.html +1 -0
- package/node_modules/@aws-crypto/crc32/node_modules/tslib/tslib.es6.js +218 -0
- package/node_modules/@aws-crypto/crc32/node_modules/tslib/tslib.html +1 -0
- package/node_modules/@aws-crypto/crc32/node_modules/tslib/tslib.js +284 -0
- package/node_modules/@aws-crypto/crc32/package.json +28 -0
- package/node_modules/@aws-crypto/crc32/src/aws_crc32.ts +24 -0
- package/node_modules/@aws-crypto/crc32/src/index.ts +92 -0
- package/node_modules/@aws-crypto/crc32/tsconfig.json +23 -0
- package/node_modules/@aws-sdk/abort-controller/package.json +2 -2
- package/node_modules/@aws-sdk/client-codedeploy/package.json +29 -29
- package/node_modules/@aws-sdk/client-sso/package.json +25 -25
- package/node_modules/@aws-sdk/client-sso-oidc/package.json +25 -25
- package/node_modules/@aws-sdk/client-sts/package.json +28 -28
- package/node_modules/@aws-sdk/config-resolver/package.json +4 -4
- package/node_modules/@aws-sdk/credential-provider-env/package.json +3 -3
- package/node_modules/@aws-sdk/credential-provider-imds/package.json +5 -5
- package/node_modules/@aws-sdk/credential-provider-ini/package.json +9 -9
- package/node_modules/@aws-sdk/credential-provider-node/package.json +10 -10
- package/node_modules/@aws-sdk/credential-provider-process/package.json +4 -4
- package/node_modules/@aws-sdk/credential-provider-sso/package.json +6 -6
- package/node_modules/@aws-sdk/credential-provider-web-identity/package.json +3 -3
- package/node_modules/@aws-sdk/eventstream-codec/LICENSE +201 -0
- package/node_modules/@aws-sdk/eventstream-codec/README.md +4 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-cjs/EventStreamCodec.js +66 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-cjs/HeaderMarshaller.js +186 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-cjs/Int64.js +47 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-cjs/Message.js +2 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-cjs/MessageDecoderStream.js +18 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-cjs/MessageEncoderStream.js +21 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-cjs/SmithyMessageDecoderStream.js +20 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-cjs/SmithyMessageEncoderStream.js +18 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-cjs/TestVectors.fixture.js +149 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-cjs/index.js +11 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-cjs/splitMessage.js +34 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-cjs/vectorTypes.fixture.js +2 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-es/EventStreamCodec.js +62 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-es/HeaderMarshaller.js +182 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-es/Int64.js +43 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-es/Message.js +1 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-es/MessageDecoderStream.js +14 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-es/MessageEncoderStream.js +17 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-es/SmithyMessageDecoderStream.js +16 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-es/SmithyMessageEncoderStream.js +14 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-es/TestVectors.fixture.js +146 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-es/index.js +8 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-es/splitMessage.js +30 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-es/vectorTypes.fixture.js +1 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/EventStreamCodec.d.ts +31 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/HeaderMarshaller.d.ts +12 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/Int64.d.ts +20 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/Message.d.ts +26 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/MessageDecoderStream.d.ts +17 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/MessageEncoderStream.d.ts +18 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/SmithyMessageDecoderStream.d.ts +17 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/SmithyMessageEncoderStream.d.ts +17 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/TestVectors.fixture.d.ts +2 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/index.d.ts +8 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/splitMessage.d.ts +11 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/ts3.4/EventStreamCodec.d.ts +24 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/ts3.4/HeaderMarshaller.d.ts +9 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/ts3.4/Int64.d.ts +9 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/ts3.4/Message.d.ts +30 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/ts3.4/MessageDecoderStream.d.ts +11 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/ts3.4/MessageEncoderStream.d.ts +12 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/ts3.4/SmithyMessageDecoderStream.d.ts +11 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/ts3.4/SmithyMessageEncoderStream.d.ts +13 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/ts3.4/TestVectors.fixture.d.ts +2 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/ts3.4/index.d.ts +8 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/ts3.4/splitMessage.d.ts +9 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/ts3.4/vectorTypes.fixture.d.ts +12 -0
- package/node_modules/@aws-sdk/eventstream-codec/dist-types/vectorTypes.fixture.d.ts +12 -0
- package/node_modules/@aws-sdk/eventstream-codec/package.json +57 -0
- package/node_modules/@aws-sdk/fetch-http-handler/package.json +5 -5
- package/node_modules/@aws-sdk/hash-node/package.json +2 -2
- package/node_modules/@aws-sdk/invalid-dependency/package.json +2 -2
- package/node_modules/@aws-sdk/middleware-content-length/package.json +3 -3
- package/node_modules/@aws-sdk/middleware-endpoint/package.json +5 -5
- package/node_modules/@aws-sdk/middleware-host-header/package.json +3 -3
- package/node_modules/@aws-sdk/middleware-logger/package.json +2 -2
- package/node_modules/@aws-sdk/middleware-recursion-detection/package.json +3 -3
- package/node_modules/@aws-sdk/middleware-retry/package.json +7 -7
- package/node_modules/@aws-sdk/middleware-sdk-sts/package.json +3 -3
- package/node_modules/@aws-sdk/middleware-serde/package.json +2 -2
- package/node_modules/@aws-sdk/middleware-signing/dist-cjs/index.js +2 -2
- package/node_modules/@aws-sdk/middleware-signing/dist-es/index.js +2 -2
- package/node_modules/@aws-sdk/middleware-signing/dist-types/{middleware.d.ts → awsAuthMiddleware.d.ts} +1 -1
- package/node_modules/@aws-sdk/middleware-signing/dist-types/index.d.ts +2 -2
- package/node_modules/@aws-sdk/middleware-signing/dist-types/ts3.4/{middleware.d.ts → awsAuthMiddleware.d.ts} +1 -1
- package/node_modules/@aws-sdk/middleware-signing/dist-types/ts3.4/index.d.ts +2 -2
- package/node_modules/@aws-sdk/middleware-signing/package.json +6 -6
- package/node_modules/@aws-sdk/middleware-stack/package.json +2 -2
- package/node_modules/@aws-sdk/middleware-user-agent/package.json +4 -4
- package/node_modules/@aws-sdk/node-config-provider/package.json +4 -4
- package/node_modules/@aws-sdk/node-http-handler/package.json +5 -5
- package/node_modules/@aws-sdk/property-provider/package.json +2 -2
- package/node_modules/@aws-sdk/protocol-http/package.json +2 -2
- package/node_modules/@aws-sdk/querystring-builder/package.json +2 -2
- package/node_modules/@aws-sdk/querystring-parser/package.json +2 -2
- package/node_modules/@aws-sdk/service-error-classification/package.json +2 -2
- package/node_modules/@aws-sdk/shared-ini-file-loader/package.json +2 -2
- package/node_modules/@aws-sdk/signature-v4/dist-cjs/SignatureV4.js +19 -0
- package/node_modules/@aws-sdk/signature-v4/dist-es/SignatureV4.js +20 -1
- package/node_modules/@aws-sdk/signature-v4/dist-types/SignatureV4.d.ts +5 -2
- package/node_modules/@aws-sdk/signature-v4/dist-types/ts3.4/SignatureV4.d.ts +18 -1
- package/node_modules/@aws-sdk/signature-v4/package.json +5 -4
- package/node_modules/@aws-sdk/smithy-client/package.json +3 -3
- package/node_modules/@aws-sdk/token-providers/package.json +5 -5
- package/node_modules/@aws-sdk/types/dist-cjs/encode.js +2 -0
- package/node_modules/@aws-sdk/types/dist-cjs/index.js +1 -0
- package/node_modules/@aws-sdk/types/dist-es/encode.js +1 -0
- package/node_modules/@aws-sdk/types/dist-es/index.js +1 -0
- package/node_modules/@aws-sdk/types/dist-types/encode.d.ts +19 -0
- package/node_modules/@aws-sdk/types/dist-types/eventStream.d.ts +14 -63
- package/node_modules/@aws-sdk/types/dist-types/index.d.ts +1 -0
- package/node_modules/@aws-sdk/types/dist-types/signature.d.ts +22 -0
- package/node_modules/@aws-sdk/types/dist-types/ts3.4/encode.d.ts +19 -0
- package/node_modules/@aws-sdk/types/dist-types/ts3.4/eventStream.d.ts +14 -36
- package/node_modules/@aws-sdk/types/dist-types/ts3.4/index.d.ts +1 -0
- package/node_modules/@aws-sdk/types/dist-types/ts3.4/signature.d.ts +19 -0
- package/node_modules/@aws-sdk/types/package.json +1 -1
- package/node_modules/@aws-sdk/url-parser/package.json +3 -3
- package/node_modules/@aws-sdk/util-defaults-mode-browser/package.json +4 -4
- package/node_modules/@aws-sdk/util-defaults-mode-node/package.json +7 -7
- package/node_modules/@aws-sdk/util-endpoints/package.json +2 -2
- package/node_modules/@aws-sdk/util-middleware/package.json +2 -2
- package/node_modules/@aws-sdk/util-retry/package.json +3 -3
- package/node_modules/@aws-sdk/util-user-agent-browser/package.json +2 -2
- package/node_modules/@aws-sdk/util-user-agent-node/package.json +3 -3
- package/node_modules/@aws-sdk/util-waiter/package.json +3 -3
- package/package.json +4 -4
- /package/node_modules/@aws-sdk/middleware-signing/dist-cjs/{configurations.js → awsAuthConfiguration.js} +0 -0
- /package/node_modules/@aws-sdk/middleware-signing/dist-cjs/{middleware.js → awsAuthMiddleware.js} +0 -0
- /package/node_modules/@aws-sdk/middleware-signing/dist-es/{configurations.js → awsAuthConfiguration.js} +0 -0
- /package/node_modules/@aws-sdk/middleware-signing/dist-es/{middleware.js → awsAuthMiddleware.js} +0 -0
- /package/node_modules/@aws-sdk/middleware-signing/dist-types/{configurations.d.ts → awsAuthConfiguration.d.ts} +0 -0
- /package/node_modules/@aws-sdk/middleware-signing/dist-types/ts3.4/{configurations.d.ts → awsAuthConfiguration.d.ts} +0 -0
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.HeaderMarshaller = void 0;
|
|
4
|
+
const util_hex_encoding_1 = require("@aws-sdk/util-hex-encoding");
|
|
5
|
+
const Int64_1 = require("./Int64");
|
|
6
|
+
class HeaderMarshaller {
|
|
7
|
+
constructor(toUtf8, fromUtf8) {
|
|
8
|
+
this.toUtf8 = toUtf8;
|
|
9
|
+
this.fromUtf8 = fromUtf8;
|
|
10
|
+
}
|
|
11
|
+
format(headers) {
|
|
12
|
+
const chunks = [];
|
|
13
|
+
for (const headerName of Object.keys(headers)) {
|
|
14
|
+
const bytes = this.fromUtf8(headerName);
|
|
15
|
+
chunks.push(Uint8Array.from([bytes.byteLength]), bytes, this.formatHeaderValue(headers[headerName]));
|
|
16
|
+
}
|
|
17
|
+
const out = new Uint8Array(chunks.reduce((carry, bytes) => carry + bytes.byteLength, 0));
|
|
18
|
+
let position = 0;
|
|
19
|
+
for (const chunk of chunks) {
|
|
20
|
+
out.set(chunk, position);
|
|
21
|
+
position += chunk.byteLength;
|
|
22
|
+
}
|
|
23
|
+
return out;
|
|
24
|
+
}
|
|
25
|
+
formatHeaderValue(header) {
|
|
26
|
+
switch (header.type) {
|
|
27
|
+
case "boolean":
|
|
28
|
+
return Uint8Array.from([header.value ? 0 : 1]);
|
|
29
|
+
case "byte":
|
|
30
|
+
return Uint8Array.from([2, header.value]);
|
|
31
|
+
case "short":
|
|
32
|
+
const shortView = new DataView(new ArrayBuffer(3));
|
|
33
|
+
shortView.setUint8(0, 3);
|
|
34
|
+
shortView.setInt16(1, header.value, false);
|
|
35
|
+
return new Uint8Array(shortView.buffer);
|
|
36
|
+
case "integer":
|
|
37
|
+
const intView = new DataView(new ArrayBuffer(5));
|
|
38
|
+
intView.setUint8(0, 4);
|
|
39
|
+
intView.setInt32(1, header.value, false);
|
|
40
|
+
return new Uint8Array(intView.buffer);
|
|
41
|
+
case "long":
|
|
42
|
+
const longBytes = new Uint8Array(9);
|
|
43
|
+
longBytes[0] = 5;
|
|
44
|
+
longBytes.set(header.value.bytes, 1);
|
|
45
|
+
return longBytes;
|
|
46
|
+
case "binary":
|
|
47
|
+
const binView = new DataView(new ArrayBuffer(3 + header.value.byteLength));
|
|
48
|
+
binView.setUint8(0, 6);
|
|
49
|
+
binView.setUint16(1, header.value.byteLength, false);
|
|
50
|
+
const binBytes = new Uint8Array(binView.buffer);
|
|
51
|
+
binBytes.set(header.value, 3);
|
|
52
|
+
return binBytes;
|
|
53
|
+
case "string":
|
|
54
|
+
const utf8Bytes = this.fromUtf8(header.value);
|
|
55
|
+
const strView = new DataView(new ArrayBuffer(3 + utf8Bytes.byteLength));
|
|
56
|
+
strView.setUint8(0, 7);
|
|
57
|
+
strView.setUint16(1, utf8Bytes.byteLength, false);
|
|
58
|
+
const strBytes = new Uint8Array(strView.buffer);
|
|
59
|
+
strBytes.set(utf8Bytes, 3);
|
|
60
|
+
return strBytes;
|
|
61
|
+
case "timestamp":
|
|
62
|
+
const tsBytes = new Uint8Array(9);
|
|
63
|
+
tsBytes[0] = 8;
|
|
64
|
+
tsBytes.set(Int64_1.Int64.fromNumber(header.value.valueOf()).bytes, 1);
|
|
65
|
+
return tsBytes;
|
|
66
|
+
case "uuid":
|
|
67
|
+
if (!UUID_PATTERN.test(header.value)) {
|
|
68
|
+
throw new Error(`Invalid UUID received: ${header.value}`);
|
|
69
|
+
}
|
|
70
|
+
const uuidBytes = new Uint8Array(17);
|
|
71
|
+
uuidBytes[0] = 9;
|
|
72
|
+
uuidBytes.set((0, util_hex_encoding_1.fromHex)(header.value.replace(/\-/g, "")), 1);
|
|
73
|
+
return uuidBytes;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
parse(headers) {
|
|
77
|
+
const out = {};
|
|
78
|
+
let position = 0;
|
|
79
|
+
while (position < headers.byteLength) {
|
|
80
|
+
const nameLength = headers.getUint8(position++);
|
|
81
|
+
const name = this.toUtf8(new Uint8Array(headers.buffer, headers.byteOffset + position, nameLength));
|
|
82
|
+
position += nameLength;
|
|
83
|
+
switch (headers.getUint8(position++)) {
|
|
84
|
+
case 0:
|
|
85
|
+
out[name] = {
|
|
86
|
+
type: BOOLEAN_TAG,
|
|
87
|
+
value: true,
|
|
88
|
+
};
|
|
89
|
+
break;
|
|
90
|
+
case 1:
|
|
91
|
+
out[name] = {
|
|
92
|
+
type: BOOLEAN_TAG,
|
|
93
|
+
value: false,
|
|
94
|
+
};
|
|
95
|
+
break;
|
|
96
|
+
case 2:
|
|
97
|
+
out[name] = {
|
|
98
|
+
type: BYTE_TAG,
|
|
99
|
+
value: headers.getInt8(position++),
|
|
100
|
+
};
|
|
101
|
+
break;
|
|
102
|
+
case 3:
|
|
103
|
+
out[name] = {
|
|
104
|
+
type: SHORT_TAG,
|
|
105
|
+
value: headers.getInt16(position, false),
|
|
106
|
+
};
|
|
107
|
+
position += 2;
|
|
108
|
+
break;
|
|
109
|
+
case 4:
|
|
110
|
+
out[name] = {
|
|
111
|
+
type: INT_TAG,
|
|
112
|
+
value: headers.getInt32(position, false),
|
|
113
|
+
};
|
|
114
|
+
position += 4;
|
|
115
|
+
break;
|
|
116
|
+
case 5:
|
|
117
|
+
out[name] = {
|
|
118
|
+
type: LONG_TAG,
|
|
119
|
+
value: new Int64_1.Int64(new Uint8Array(headers.buffer, headers.byteOffset + position, 8)),
|
|
120
|
+
};
|
|
121
|
+
position += 8;
|
|
122
|
+
break;
|
|
123
|
+
case 6:
|
|
124
|
+
const binaryLength = headers.getUint16(position, false);
|
|
125
|
+
position += 2;
|
|
126
|
+
out[name] = {
|
|
127
|
+
type: BINARY_TAG,
|
|
128
|
+
value: new Uint8Array(headers.buffer, headers.byteOffset + position, binaryLength),
|
|
129
|
+
};
|
|
130
|
+
position += binaryLength;
|
|
131
|
+
break;
|
|
132
|
+
case 7:
|
|
133
|
+
const stringLength = headers.getUint16(position, false);
|
|
134
|
+
position += 2;
|
|
135
|
+
out[name] = {
|
|
136
|
+
type: STRING_TAG,
|
|
137
|
+
value: this.toUtf8(new Uint8Array(headers.buffer, headers.byteOffset + position, stringLength)),
|
|
138
|
+
};
|
|
139
|
+
position += stringLength;
|
|
140
|
+
break;
|
|
141
|
+
case 8:
|
|
142
|
+
out[name] = {
|
|
143
|
+
type: TIMESTAMP_TAG,
|
|
144
|
+
value: new Date(new Int64_1.Int64(new Uint8Array(headers.buffer, headers.byteOffset + position, 8)).valueOf()),
|
|
145
|
+
};
|
|
146
|
+
position += 8;
|
|
147
|
+
break;
|
|
148
|
+
case 9:
|
|
149
|
+
const uuidBytes = new Uint8Array(headers.buffer, headers.byteOffset + position, 16);
|
|
150
|
+
position += 16;
|
|
151
|
+
out[name] = {
|
|
152
|
+
type: UUID_TAG,
|
|
153
|
+
value: `${(0, util_hex_encoding_1.toHex)(uuidBytes.subarray(0, 4))}-${(0, util_hex_encoding_1.toHex)(uuidBytes.subarray(4, 6))}-${(0, util_hex_encoding_1.toHex)(uuidBytes.subarray(6, 8))}-${(0, util_hex_encoding_1.toHex)(uuidBytes.subarray(8, 10))}-${(0, util_hex_encoding_1.toHex)(uuidBytes.subarray(10))}`,
|
|
154
|
+
};
|
|
155
|
+
break;
|
|
156
|
+
default:
|
|
157
|
+
throw new Error(`Unrecognized header type tag`);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
return out;
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
exports.HeaderMarshaller = HeaderMarshaller;
|
|
164
|
+
var HEADER_VALUE_TYPE;
|
|
165
|
+
(function (HEADER_VALUE_TYPE) {
|
|
166
|
+
HEADER_VALUE_TYPE[HEADER_VALUE_TYPE["boolTrue"] = 0] = "boolTrue";
|
|
167
|
+
HEADER_VALUE_TYPE[HEADER_VALUE_TYPE["boolFalse"] = 1] = "boolFalse";
|
|
168
|
+
HEADER_VALUE_TYPE[HEADER_VALUE_TYPE["byte"] = 2] = "byte";
|
|
169
|
+
HEADER_VALUE_TYPE[HEADER_VALUE_TYPE["short"] = 3] = "short";
|
|
170
|
+
HEADER_VALUE_TYPE[HEADER_VALUE_TYPE["integer"] = 4] = "integer";
|
|
171
|
+
HEADER_VALUE_TYPE[HEADER_VALUE_TYPE["long"] = 5] = "long";
|
|
172
|
+
HEADER_VALUE_TYPE[HEADER_VALUE_TYPE["byteArray"] = 6] = "byteArray";
|
|
173
|
+
HEADER_VALUE_TYPE[HEADER_VALUE_TYPE["string"] = 7] = "string";
|
|
174
|
+
HEADER_VALUE_TYPE[HEADER_VALUE_TYPE["timestamp"] = 8] = "timestamp";
|
|
175
|
+
HEADER_VALUE_TYPE[HEADER_VALUE_TYPE["uuid"] = 9] = "uuid";
|
|
176
|
+
})(HEADER_VALUE_TYPE || (HEADER_VALUE_TYPE = {}));
|
|
177
|
+
const BOOLEAN_TAG = "boolean";
|
|
178
|
+
const BYTE_TAG = "byte";
|
|
179
|
+
const SHORT_TAG = "short";
|
|
180
|
+
const INT_TAG = "integer";
|
|
181
|
+
const LONG_TAG = "long";
|
|
182
|
+
const BINARY_TAG = "binary";
|
|
183
|
+
const STRING_TAG = "string";
|
|
184
|
+
const TIMESTAMP_TAG = "timestamp";
|
|
185
|
+
const UUID_TAG = "uuid";
|
|
186
|
+
const UUID_PATTERN = /^[a-f0-9]{8}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{12}$/;
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Int64 = void 0;
|
|
4
|
+
const util_hex_encoding_1 = require("@aws-sdk/util-hex-encoding");
|
|
5
|
+
class Int64 {
|
|
6
|
+
constructor(bytes) {
|
|
7
|
+
this.bytes = bytes;
|
|
8
|
+
if (bytes.byteLength !== 8) {
|
|
9
|
+
throw new Error("Int64 buffers must be exactly 8 bytes");
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
static fromNumber(number) {
|
|
13
|
+
if (number > 9223372036854776000 || number < -9223372036854776000) {
|
|
14
|
+
throw new Error(`${number} is too large (or, if negative, too small) to represent as an Int64`);
|
|
15
|
+
}
|
|
16
|
+
const bytes = new Uint8Array(8);
|
|
17
|
+
for (let i = 7, remaining = Math.abs(Math.round(number)); i > -1 && remaining > 0; i--, remaining /= 256) {
|
|
18
|
+
bytes[i] = remaining;
|
|
19
|
+
}
|
|
20
|
+
if (number < 0) {
|
|
21
|
+
negate(bytes);
|
|
22
|
+
}
|
|
23
|
+
return new Int64(bytes);
|
|
24
|
+
}
|
|
25
|
+
valueOf() {
|
|
26
|
+
const bytes = this.bytes.slice(0);
|
|
27
|
+
const negative = bytes[0] & 0b10000000;
|
|
28
|
+
if (negative) {
|
|
29
|
+
negate(bytes);
|
|
30
|
+
}
|
|
31
|
+
return parseInt((0, util_hex_encoding_1.toHex)(bytes), 16) * (negative ? -1 : 1);
|
|
32
|
+
}
|
|
33
|
+
toString() {
|
|
34
|
+
return String(this.valueOf());
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
exports.Int64 = Int64;
|
|
38
|
+
function negate(bytes) {
|
|
39
|
+
for (let i = 0; i < 8; i++) {
|
|
40
|
+
bytes[i] ^= 0xff;
|
|
41
|
+
}
|
|
42
|
+
for (let i = 7; i > -1; i--) {
|
|
43
|
+
bytes[i]++;
|
|
44
|
+
if (bytes[i] !== 0)
|
|
45
|
+
break;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MessageDecoderStream = void 0;
|
|
4
|
+
class MessageDecoderStream {
|
|
5
|
+
constructor(options) {
|
|
6
|
+
this.options = options;
|
|
7
|
+
}
|
|
8
|
+
[Symbol.asyncIterator]() {
|
|
9
|
+
return this.asyncIterator();
|
|
10
|
+
}
|
|
11
|
+
async *asyncIterator() {
|
|
12
|
+
for await (const bytes of this.options.inputStream) {
|
|
13
|
+
const decoded = this.options.decoder.decode(bytes);
|
|
14
|
+
yield decoded;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
exports.MessageDecoderStream = MessageDecoderStream;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MessageEncoderStream = void 0;
|
|
4
|
+
class MessageEncoderStream {
|
|
5
|
+
constructor(options) {
|
|
6
|
+
this.options = options;
|
|
7
|
+
}
|
|
8
|
+
[Symbol.asyncIterator]() {
|
|
9
|
+
return this.asyncIterator();
|
|
10
|
+
}
|
|
11
|
+
async *asyncIterator() {
|
|
12
|
+
for await (const msg of this.options.messageStream) {
|
|
13
|
+
const encoded = this.options.encoder.encode(msg);
|
|
14
|
+
yield encoded;
|
|
15
|
+
}
|
|
16
|
+
if (this.options.includeEndFrame) {
|
|
17
|
+
yield new Uint8Array(0);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
exports.MessageEncoderStream = MessageEncoderStream;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SmithyMessageDecoderStream = void 0;
|
|
4
|
+
class SmithyMessageDecoderStream {
|
|
5
|
+
constructor(options) {
|
|
6
|
+
this.options = options;
|
|
7
|
+
}
|
|
8
|
+
[Symbol.asyncIterator]() {
|
|
9
|
+
return this.asyncIterator();
|
|
10
|
+
}
|
|
11
|
+
async *asyncIterator() {
|
|
12
|
+
for await (const message of this.options.messageStream) {
|
|
13
|
+
const deserialized = await this.options.deserializer(message);
|
|
14
|
+
if (deserialized === undefined)
|
|
15
|
+
continue;
|
|
16
|
+
yield deserialized;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
exports.SmithyMessageDecoderStream = SmithyMessageDecoderStream;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SmithyMessageEncoderStream = void 0;
|
|
4
|
+
class SmithyMessageEncoderStream {
|
|
5
|
+
constructor(options) {
|
|
6
|
+
this.options = options;
|
|
7
|
+
}
|
|
8
|
+
[Symbol.asyncIterator]() {
|
|
9
|
+
return this.asyncIterator();
|
|
10
|
+
}
|
|
11
|
+
async *asyncIterator() {
|
|
12
|
+
for await (const chunk of this.options.inputStream) {
|
|
13
|
+
const payloadBuf = this.options.serializer(chunk);
|
|
14
|
+
yield payloadBuf;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
exports.SmithyMessageEncoderStream = SmithyMessageEncoderStream;
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.vectors = void 0;
|
|
4
|
+
const Int64_1 = require("./Int64");
|
|
5
|
+
exports.vectors = {
|
|
6
|
+
all_headers: {
|
|
7
|
+
expectation: "success",
|
|
8
|
+
encoded: Uint8Array.from([
|
|
9
|
+
0, 0, 0, 204, 0, 0, 0, 175, 15, 174, 100, 202, 10, 101, 118, 101, 110, 116, 45, 116, 121, 112, 101, 4, 0, 0, 160,
|
|
10
|
+
12, 12, 99, 111, 110, 116, 101, 110, 116, 45, 116, 121, 112, 101, 7, 0, 16, 97, 112, 112, 108, 105, 99, 97, 116,
|
|
11
|
+
105, 111, 110, 47, 106, 115, 111, 110, 10, 98, 111, 111, 108, 32, 102, 97, 108, 115, 101, 1, 9, 98, 111, 111, 108,
|
|
12
|
+
32, 116, 114, 117, 101, 0, 4, 98, 121, 116, 101, 2, 207, 8, 98, 121, 116, 101, 32, 98, 117, 102, 6, 0, 20, 73, 39,
|
|
13
|
+
109, 32, 97, 32, 108, 105, 116, 116, 108, 101, 32, 116, 101, 97, 112, 111, 116, 33, 9, 116, 105, 109, 101, 115,
|
|
14
|
+
116, 97, 109, 112, 8, 0, 0, 0, 0, 0, 132, 95, 237, 5, 105, 110, 116, 49, 54, 3, 0, 42, 5, 105, 110, 116, 54, 52,
|
|
15
|
+
5, 0, 0, 0, 0, 2, 135, 87, 178, 4, 117, 117, 105, 100, 9, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16,
|
|
16
|
+
123, 39, 102, 111, 111, 39, 58, 39, 98, 97, 114, 39, 125, 171, 165, 241, 12,
|
|
17
|
+
]),
|
|
18
|
+
decoded: {
|
|
19
|
+
headers: {
|
|
20
|
+
"event-type": {
|
|
21
|
+
type: "integer",
|
|
22
|
+
value: 40972,
|
|
23
|
+
},
|
|
24
|
+
"content-type": {
|
|
25
|
+
type: "string",
|
|
26
|
+
value: "application/json",
|
|
27
|
+
},
|
|
28
|
+
"bool false": {
|
|
29
|
+
type: "boolean",
|
|
30
|
+
value: false,
|
|
31
|
+
},
|
|
32
|
+
"bool true": {
|
|
33
|
+
type: "boolean",
|
|
34
|
+
value: true,
|
|
35
|
+
},
|
|
36
|
+
byte: {
|
|
37
|
+
type: "byte",
|
|
38
|
+
value: -49,
|
|
39
|
+
},
|
|
40
|
+
"byte buf": {
|
|
41
|
+
type: "binary",
|
|
42
|
+
value: Uint8Array.from([
|
|
43
|
+
73, 39, 109, 32, 97, 32, 108, 105, 116, 116, 108, 101, 32, 116, 101, 97, 112, 111, 116, 33,
|
|
44
|
+
]),
|
|
45
|
+
},
|
|
46
|
+
timestamp: {
|
|
47
|
+
type: "timestamp",
|
|
48
|
+
value: new Date(8675309),
|
|
49
|
+
},
|
|
50
|
+
int16: {
|
|
51
|
+
type: "short",
|
|
52
|
+
value: 42,
|
|
53
|
+
},
|
|
54
|
+
int64: {
|
|
55
|
+
type: "long",
|
|
56
|
+
value: Int64_1.Int64.fromNumber(42424242),
|
|
57
|
+
},
|
|
58
|
+
uuid: {
|
|
59
|
+
type: "uuid",
|
|
60
|
+
value: "01020304-0506-0708-090a-0b0c0d0e0f10",
|
|
61
|
+
},
|
|
62
|
+
},
|
|
63
|
+
body: Uint8Array.from([123, 39, 102, 111, 111, 39, 58, 39, 98, 97, 114, 39, 125]),
|
|
64
|
+
},
|
|
65
|
+
},
|
|
66
|
+
empty_message: {
|
|
67
|
+
expectation: "success",
|
|
68
|
+
encoded: Uint8Array.from([0, 0, 0, 16, 0, 0, 0, 0, 5, 194, 72, 235, 125, 152, 200, 255]),
|
|
69
|
+
decoded: {
|
|
70
|
+
headers: {},
|
|
71
|
+
body: Uint8Array.from([]),
|
|
72
|
+
},
|
|
73
|
+
},
|
|
74
|
+
int32_header: {
|
|
75
|
+
expectation: "success",
|
|
76
|
+
encoded: Uint8Array.from([
|
|
77
|
+
0, 0, 0, 45, 0, 0, 0, 16, 65, 196, 36, 184, 10, 101, 118, 101, 110, 116, 45, 116, 121, 112, 101, 4, 0, 0, 160, 12,
|
|
78
|
+
123, 39, 102, 111, 111, 39, 58, 39, 98, 97, 114, 39, 125, 54, 244, 128, 160,
|
|
79
|
+
]),
|
|
80
|
+
decoded: {
|
|
81
|
+
headers: {
|
|
82
|
+
"event-type": {
|
|
83
|
+
type: "integer",
|
|
84
|
+
value: 40972,
|
|
85
|
+
},
|
|
86
|
+
},
|
|
87
|
+
body: Uint8Array.from([123, 39, 102, 111, 111, 39, 58, 39, 98, 97, 114, 39, 125]),
|
|
88
|
+
},
|
|
89
|
+
},
|
|
90
|
+
payload_no_headers: {
|
|
91
|
+
expectation: "success",
|
|
92
|
+
encoded: Uint8Array.from([
|
|
93
|
+
0, 0, 0, 29, 0, 0, 0, 0, 253, 82, 140, 90, 123, 39, 102, 111, 111, 39, 58, 39, 98, 97, 114, 39, 125, 195, 101, 57,
|
|
94
|
+
54,
|
|
95
|
+
]),
|
|
96
|
+
decoded: {
|
|
97
|
+
headers: {},
|
|
98
|
+
body: Uint8Array.from([123, 39, 102, 111, 111, 39, 58, 39, 98, 97, 114, 39, 125]),
|
|
99
|
+
},
|
|
100
|
+
},
|
|
101
|
+
payload_one_str_header: {
|
|
102
|
+
expectation: "success",
|
|
103
|
+
encoded: Uint8Array.from([
|
|
104
|
+
0, 0, 0, 61, 0, 0, 0, 32, 7, 253, 131, 150, 12, 99, 111, 110, 116, 101, 110, 116, 45, 116, 121, 112, 101, 7, 0,
|
|
105
|
+
16, 97, 112, 112, 108, 105, 99, 97, 116, 105, 111, 110, 47, 106, 115, 111, 110, 123, 39, 102, 111, 111, 39, 58,
|
|
106
|
+
39, 98, 97, 114, 39, 125, 141, 156, 8, 177,
|
|
107
|
+
]),
|
|
108
|
+
decoded: {
|
|
109
|
+
headers: {
|
|
110
|
+
"content-type": {
|
|
111
|
+
type: "string",
|
|
112
|
+
value: "application/json",
|
|
113
|
+
},
|
|
114
|
+
},
|
|
115
|
+
body: Uint8Array.from([123, 39, 102, 111, 111, 39, 58, 39, 98, 97, 114, 39, 125]),
|
|
116
|
+
},
|
|
117
|
+
},
|
|
118
|
+
corrupted_headers: {
|
|
119
|
+
expectation: "failure",
|
|
120
|
+
encoded: Uint8Array.from([
|
|
121
|
+
0, 0, 0, 61, 0, 0, 0, 32, 7, 253, 131, 150, 12, 99, 111, 110, 116, 101, 110, 116, 45, 116, 121, 112, 101, 7, 0,
|
|
122
|
+
16, 97, 112, 112, 108, 105, 99, 97, 116, 105, 111, 110, 47, 106, 115, 111, 110, 123, 97, 102, 111, 111, 39, 58,
|
|
123
|
+
39, 98, 97, 114, 39, 125, 141, 156, 8, 177,
|
|
124
|
+
]),
|
|
125
|
+
},
|
|
126
|
+
corrupted_header_len: {
|
|
127
|
+
expectation: "failure",
|
|
128
|
+
encoded: Uint8Array.from([
|
|
129
|
+
0, 0, 0, 61, 0, 0, 0, 33, 7, 253, 131, 150, 12, 99, 111, 110, 116, 101, 110, 116, 45, 116, 121, 112, 101, 7, 0,
|
|
130
|
+
16, 97, 112, 112, 108, 105, 99, 97, 116, 105, 111, 110, 47, 106, 115, 111, 110, 123, 39, 102, 111, 111, 39, 58,
|
|
131
|
+
39, 98, 97, 114, 39, 125, 141, 156, 8, 177,
|
|
132
|
+
]),
|
|
133
|
+
},
|
|
134
|
+
corrupted_length: {
|
|
135
|
+
expectation: "failure",
|
|
136
|
+
encoded: Uint8Array.from([
|
|
137
|
+
0, 0, 0, 62, 0, 0, 0, 32, 7, 253, 131, 150, 12, 99, 111, 110, 116, 101, 110, 116, 45, 116, 121, 112, 101, 7, 0,
|
|
138
|
+
16, 97, 112, 112, 108, 105, 99, 97, 116, 105, 111, 110, 47, 106, 115, 111, 110, 123, 39, 102, 111, 111, 39, 58,
|
|
139
|
+
39, 98, 97, 114, 39, 125, 141, 156, 8, 177,
|
|
140
|
+
]),
|
|
141
|
+
},
|
|
142
|
+
corrupted_payload: {
|
|
143
|
+
expectation: "failure",
|
|
144
|
+
encoded: Uint8Array.from([
|
|
145
|
+
0, 0, 0, 29, 0, 0, 0, 0, 253, 82, 140, 90, 91, 39, 102, 111, 111, 39, 58, 39, 98, 97, 114, 39, 125, 195, 101, 57,
|
|
146
|
+
54,
|
|
147
|
+
]),
|
|
148
|
+
},
|
|
149
|
+
};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
tslib_1.__exportStar(require("./EventStreamCodec"), exports);
|
|
5
|
+
tslib_1.__exportStar(require("./HeaderMarshaller"), exports);
|
|
6
|
+
tslib_1.__exportStar(require("./Int64"), exports);
|
|
7
|
+
tslib_1.__exportStar(require("./Message"), exports);
|
|
8
|
+
tslib_1.__exportStar(require("./MessageDecoderStream"), exports);
|
|
9
|
+
tslib_1.__exportStar(require("./MessageEncoderStream"), exports);
|
|
10
|
+
tslib_1.__exportStar(require("./SmithyMessageDecoderStream"), exports);
|
|
11
|
+
tslib_1.__exportStar(require("./SmithyMessageEncoderStream"), exports);
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.splitMessage = void 0;
|
|
4
|
+
const crc32_1 = require("@aws-crypto/crc32");
|
|
5
|
+
const PRELUDE_MEMBER_LENGTH = 4;
|
|
6
|
+
const PRELUDE_LENGTH = PRELUDE_MEMBER_LENGTH * 2;
|
|
7
|
+
const CHECKSUM_LENGTH = 4;
|
|
8
|
+
const MINIMUM_MESSAGE_LENGTH = PRELUDE_LENGTH + CHECKSUM_LENGTH * 2;
|
|
9
|
+
function splitMessage({ byteLength, byteOffset, buffer }) {
|
|
10
|
+
if (byteLength < MINIMUM_MESSAGE_LENGTH) {
|
|
11
|
+
throw new Error("Provided message too short to accommodate event stream message overhead");
|
|
12
|
+
}
|
|
13
|
+
const view = new DataView(buffer, byteOffset, byteLength);
|
|
14
|
+
const messageLength = view.getUint32(0, false);
|
|
15
|
+
if (byteLength !== messageLength) {
|
|
16
|
+
throw new Error("Reported message length does not match received message length");
|
|
17
|
+
}
|
|
18
|
+
const headerLength = view.getUint32(PRELUDE_MEMBER_LENGTH, false);
|
|
19
|
+
const expectedPreludeChecksum = view.getUint32(PRELUDE_LENGTH, false);
|
|
20
|
+
const expectedMessageChecksum = view.getUint32(byteLength - CHECKSUM_LENGTH, false);
|
|
21
|
+
const checksummer = new crc32_1.Crc32().update(new Uint8Array(buffer, byteOffset, PRELUDE_LENGTH));
|
|
22
|
+
if (expectedPreludeChecksum !== checksummer.digest()) {
|
|
23
|
+
throw new Error(`The prelude checksum specified in the message (${expectedPreludeChecksum}) does not match the calculated CRC32 checksum (${checksummer.digest()})`);
|
|
24
|
+
}
|
|
25
|
+
checksummer.update(new Uint8Array(buffer, byteOffset + PRELUDE_LENGTH, byteLength - (PRELUDE_LENGTH + CHECKSUM_LENGTH)));
|
|
26
|
+
if (expectedMessageChecksum !== checksummer.digest()) {
|
|
27
|
+
throw new Error(`The message checksum (${checksummer.digest()}) did not match the expected value of ${expectedMessageChecksum}`);
|
|
28
|
+
}
|
|
29
|
+
return {
|
|
30
|
+
headers: new DataView(buffer, byteOffset + PRELUDE_LENGTH + CHECKSUM_LENGTH, headerLength),
|
|
31
|
+
body: new Uint8Array(buffer, byteOffset + PRELUDE_LENGTH + CHECKSUM_LENGTH + headerLength, messageLength - headerLength - (PRELUDE_LENGTH + CHECKSUM_LENGTH + CHECKSUM_LENGTH)),
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
exports.splitMessage = splitMessage;
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { Crc32 } from "@aws-crypto/crc32";
|
|
2
|
+
import { HeaderMarshaller } from "./HeaderMarshaller";
|
|
3
|
+
import { splitMessage } from "./splitMessage";
|
|
4
|
+
export class EventStreamCodec {
|
|
5
|
+
constructor(toUtf8, fromUtf8) {
|
|
6
|
+
this.headerMarshaller = new HeaderMarshaller(toUtf8, fromUtf8);
|
|
7
|
+
this.messageBuffer = [];
|
|
8
|
+
this.isEndOfStream = false;
|
|
9
|
+
}
|
|
10
|
+
feed(message) {
|
|
11
|
+
this.messageBuffer.push(this.decode(message));
|
|
12
|
+
}
|
|
13
|
+
endOfStream() {
|
|
14
|
+
this.isEndOfStream = true;
|
|
15
|
+
}
|
|
16
|
+
getMessage() {
|
|
17
|
+
const message = this.messageBuffer.pop();
|
|
18
|
+
const isEndOfStream = this.isEndOfStream;
|
|
19
|
+
return {
|
|
20
|
+
getMessage() {
|
|
21
|
+
return message;
|
|
22
|
+
},
|
|
23
|
+
isEndOfStream() {
|
|
24
|
+
return isEndOfStream;
|
|
25
|
+
},
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
getAvailableMessages() {
|
|
29
|
+
const messages = this.messageBuffer;
|
|
30
|
+
this.messageBuffer = [];
|
|
31
|
+
const isEndOfStream = this.isEndOfStream;
|
|
32
|
+
return {
|
|
33
|
+
getMessages() {
|
|
34
|
+
return messages;
|
|
35
|
+
},
|
|
36
|
+
isEndOfStream() {
|
|
37
|
+
return isEndOfStream;
|
|
38
|
+
},
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
encode({ headers: rawHeaders, body }) {
|
|
42
|
+
const headers = this.headerMarshaller.format(rawHeaders);
|
|
43
|
+
const length = headers.byteLength + body.byteLength + 16;
|
|
44
|
+
const out = new Uint8Array(length);
|
|
45
|
+
const view = new DataView(out.buffer, out.byteOffset, out.byteLength);
|
|
46
|
+
const checksum = new Crc32();
|
|
47
|
+
view.setUint32(0, length, false);
|
|
48
|
+
view.setUint32(4, headers.byteLength, false);
|
|
49
|
+
view.setUint32(8, checksum.update(out.subarray(0, 8)).digest(), false);
|
|
50
|
+
out.set(headers, 12);
|
|
51
|
+
out.set(body, headers.byteLength + 12);
|
|
52
|
+
view.setUint32(length - 4, checksum.update(out.subarray(8, length - 4)).digest(), false);
|
|
53
|
+
return out;
|
|
54
|
+
}
|
|
55
|
+
decode(message) {
|
|
56
|
+
const { headers, body } = splitMessage(message);
|
|
57
|
+
return { headers: this.headerMarshaller.parse(headers), body };
|
|
58
|
+
}
|
|
59
|
+
formatHeaders(rawHeaders) {
|
|
60
|
+
return this.headerMarshaller.format(rawHeaders);
|
|
61
|
+
}
|
|
62
|
+
}
|