@reclaimprotocol/attestor-core 3.0.1
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/README.md +39 -0
- package/lib/avs/abis/avsDirectoryABI.d.ts +60 -0
- package/lib/avs/abis/avsDirectoryABI.js +344 -0
- package/lib/avs/abis/delegationABI.d.ts +126 -0
- package/lib/avs/abis/delegationABI.js +5 -0
- package/lib/avs/abis/registryABI.d.ts +136 -0
- package/lib/avs/abis/registryABI.js +729 -0
- package/lib/avs/client/create-claim-on-avs.d.ts +10 -0
- package/lib/avs/client/create-claim-on-avs.js +147 -0
- package/lib/avs/config.d.ts +7 -0
- package/lib/avs/config.js +24 -0
- package/lib/avs/contracts/ReclaimServiceManager.d.ts +697 -0
- package/lib/avs/contracts/ReclaimServiceManager.js +3 -0
- package/lib/avs/contracts/common.d.ts +21 -0
- package/lib/avs/contracts/common.js +3 -0
- package/lib/avs/contracts/factories/ReclaimServiceManager__factory.d.ts +888 -0
- package/lib/avs/contracts/factories/ReclaimServiceManager__factory.js +1174 -0
- package/lib/avs/contracts/factories/index.d.ts +1 -0
- package/lib/avs/contracts/factories/index.js +9 -0
- package/lib/avs/contracts/index.d.ts +3 -0
- package/lib/avs/contracts/index.js +30 -0
- package/lib/avs/tests/test.operator.d.ts +11 -0
- package/lib/avs/tests/test.operator.js +313 -0
- package/lib/avs/tests/utils.d.ts +2 -0
- package/lib/avs/tests/utils.js +50 -0
- package/lib/avs/types/index.d.ts +55 -0
- package/lib/avs/types/index.js +3 -0
- package/lib/avs/utils/contracts.d.ts +21 -0
- package/lib/avs/utils/contracts.js +38 -0
- package/lib/avs/utils/register.d.ts +27 -0
- package/lib/avs/utils/register.js +76 -0
- package/lib/avs/utils/tasks.d.ts +22 -0
- package/lib/avs/utils/tasks.js +45 -0
- package/lib/client/create-claim.d.ts +5 -0
- package/lib/client/create-claim.js +357 -0
- package/lib/client/index.d.ts +3 -0
- package/lib/client/index.js +20 -0
- package/lib/client/tunnels/make-rpc-tcp-tunnel.d.ts +16 -0
- package/lib/client/tunnels/make-rpc-tcp-tunnel.js +60 -0
- package/lib/client/tunnels/make-rpc-tls-tunnel.d.ts +25 -0
- package/lib/client/tunnels/make-rpc-tls-tunnel.js +135 -0
- package/lib/client/utils/attestor-pool.d.ts +6 -0
- package/lib/client/utils/attestor-pool.js +28 -0
- package/lib/client/utils/client-socket.d.ts +9 -0
- package/lib/client/utils/client-socket.js +77 -0
- package/lib/client/utils/message-handler.d.ts +4 -0
- package/lib/client/utils/message-handler.js +93 -0
- package/lib/config/index.d.ts +23 -0
- package/lib/config/index.js +35 -0
- package/lib/index.d.ts +9 -0
- package/lib/index.js +39 -0
- package/lib/proto/api.d.ts +414 -0
- package/lib/proto/api.js +2756 -0
- package/lib/providers/http/index.d.ts +3 -0
- package/lib/providers/http/index.js +472 -0
- package/lib/providers/http/utils.d.ts +44 -0
- package/lib/providers/http/utils.js +302 -0
- package/lib/providers/index.d.ts +4 -0
- package/lib/providers/index.js +11 -0
- package/lib/scripts/check-avs-registration.d.ts +1 -0
- package/lib/scripts/check-avs-registration.js +28 -0
- package/lib/scripts/generate-provider-types.d.ts +5 -0
- package/lib/scripts/generate-provider-types.js +82 -0
- package/lib/scripts/generate-receipt.d.ts +9 -0
- package/lib/scripts/generate-receipt.js +93 -0
- package/lib/scripts/register-avs-operator.d.ts +1 -0
- package/lib/scripts/register-avs-operator.js +6 -0
- package/lib/scripts/start-server.d.ts +1 -0
- package/lib/scripts/start-server.js +6 -0
- package/lib/scripts/verify-root-ca.d.ts +1 -0
- package/lib/scripts/verify-root-ca.js +51 -0
- package/lib/server/create-server.d.ts +7 -0
- package/lib/server/create-server.js +85 -0
- package/lib/server/handlers/claimTunnel.d.ts +2 -0
- package/lib/server/handlers/claimTunnel.js +55 -0
- package/lib/server/handlers/completeClaimOnChain.d.ts +2 -0
- package/lib/server/handlers/completeClaimOnChain.js +28 -0
- package/lib/server/handlers/createClaimOnChain.d.ts +2 -0
- package/lib/server/handlers/createClaimOnChain.js +31 -0
- package/lib/server/handlers/createTunnel.d.ts +2 -0
- package/lib/server/handlers/createTunnel.js +65 -0
- package/lib/server/handlers/disconnectTunnel.d.ts +2 -0
- package/lib/server/handlers/disconnectTunnel.js +10 -0
- package/lib/server/handlers/index.d.ts +4 -0
- package/lib/server/handlers/index.js +18 -0
- package/lib/server/handlers/init.d.ts +2 -0
- package/lib/server/handlers/init.js +21 -0
- package/lib/server/index.d.ts +4 -0
- package/lib/server/index.js +21 -0
- package/lib/server/socket.d.ts +11 -0
- package/lib/server/socket.js +95 -0
- package/lib/server/tunnels/make-tcp-tunnel.d.ts +20 -0
- package/lib/server/tunnels/make-tcp-tunnel.js +182 -0
- package/lib/server/utils/apm.d.ts +11 -0
- package/lib/server/utils/apm.js +39 -0
- package/lib/server/utils/assert-valid-claim-request.d.ts +29 -0
- package/lib/server/utils/assert-valid-claim-request.js +189 -0
- package/lib/server/utils/config-env.d.ts +1 -0
- package/lib/server/utils/config-env.js +7 -0
- package/lib/server/utils/generics.d.ts +22 -0
- package/lib/server/utils/generics.js +59 -0
- package/lib/server/utils/iso.d.ts +1 -0
- package/lib/server/utils/iso.js +260 -0
- package/lib/server/utils/keep-alive.d.ts +7 -0
- package/lib/server/utils/keep-alive.js +42 -0
- package/lib/server/utils/process-handshake.d.ts +13 -0
- package/lib/server/utils/process-handshake.js +179 -0
- package/lib/server/utils/verify-server-certificates.d.ts +7 -0
- package/lib/server/utils/verify-server-certificates.js +102 -0
- package/lib/tests/describe-with-server.d.ts +21 -0
- package/lib/tests/describe-with-server.js +67 -0
- package/lib/tests/mock-provider-server.d.ts +13 -0
- package/lib/tests/mock-provider-server.js +65 -0
- package/lib/tests/mocks.d.ts +4 -0
- package/lib/tests/mocks.js +23 -0
- package/lib/tests/test.claim-creation.d.ts +1 -0
- package/lib/tests/test.claim-creation.js +187 -0
- package/lib/tests/test.http-parser.d.ts +1 -0
- package/lib/tests/test.http-parser.js +118 -0
- package/lib/tests/test.http-provider-utils.d.ts +1 -0
- package/lib/tests/test.http-provider-utils.js +1932 -0
- package/lib/tests/test.http-provider.d.ts +1 -0
- package/lib/tests/test.http-provider.js +43 -0
- package/lib/tests/test.rpc-communication.d.ts +1 -0
- package/lib/tests/test.rpc-communication.js +64 -0
- package/lib/tests/test.rpc-tunnel.d.ts +1 -0
- package/lib/tests/test.rpc-tunnel.js +168 -0
- package/lib/tests/test.signatures.d.ts +1 -0
- package/lib/tests/test.signatures.js +24 -0
- package/lib/tests/test.tcp-tunnel.d.ts +1 -0
- package/lib/tests/test.tcp-tunnel.js +64 -0
- package/lib/tests/test.zk.d.ts +1 -0
- package/lib/tests/test.zk.js +169 -0
- package/lib/tests/utils.d.ts +12 -0
- package/lib/tests/utils.js +49 -0
- package/lib/types/claims.d.ts +64 -0
- package/lib/types/claims.js +3 -0
- package/lib/types/client.d.ts +136 -0
- package/lib/types/client.js +3 -0
- package/lib/types/general.d.ts +39 -0
- package/lib/types/general.js +3 -0
- package/lib/types/handlers.d.ts +10 -0
- package/lib/types/handlers.js +3 -0
- package/lib/types/index.d.ts +9 -0
- package/lib/types/index.js +26 -0
- package/lib/types/providers.d.ts +135 -0
- package/lib/types/providers.gen.d.ts +414 -0
- package/lib/types/providers.gen.js +14 -0
- package/lib/types/providers.js +3 -0
- package/lib/types/rpc.d.ts +35 -0
- package/lib/types/rpc.js +3 -0
- package/lib/types/signatures.d.ts +28 -0
- package/lib/types/signatures.js +3 -0
- package/lib/types/tunnel.d.ts +18 -0
- package/lib/types/tunnel.js +3 -0
- package/lib/types/zk.d.ts +16 -0
- package/lib/types/zk.js +3 -0
- package/lib/utils/benchmark.d.ts +1 -0
- package/lib/utils/benchmark.js +70 -0
- package/lib/utils/claims.d.ts +33 -0
- package/lib/utils/claims.js +112 -0
- package/lib/utils/env.d.ts +3 -0
- package/lib/utils/env.js +20 -0
- package/lib/utils/error.d.ts +27 -0
- package/lib/utils/error.js +43 -0
- package/lib/utils/generics.d.ts +112 -0
- package/lib/utils/generics.js +348 -0
- package/lib/utils/http-parser.d.ts +55 -0
- package/lib/utils/http-parser.js +249 -0
- package/lib/utils/index.d.ts +10 -0
- package/lib/utils/index.js +27 -0
- package/lib/utils/logger.d.ts +13 -0
- package/lib/utils/logger.js +100 -0
- package/lib/utils/prepare-packets.d.ts +16 -0
- package/lib/utils/prepare-packets.js +61 -0
- package/lib/utils/redactions.d.ts +41 -0
- package/lib/utils/redactions.js +111 -0
- package/lib/utils/retries.d.ts +12 -0
- package/lib/utils/retries.js +28 -0
- package/lib/utils/signatures/eth.d.ts +2 -0
- package/lib/utils/signatures/eth.js +33 -0
- package/lib/utils/signatures/index.d.ts +5 -0
- package/lib/utils/signatures/index.js +11 -0
- package/lib/utils/socket-base.d.ts +21 -0
- package/lib/utils/socket-base.js +89 -0
- package/lib/utils/tls.d.ts +2 -0
- package/lib/utils/tls.js +32 -0
- package/lib/utils/validation.d.ts +2 -0
- package/lib/utils/validation.js +46 -0
- package/lib/utils/ws.d.ts +12 -0
- package/lib/utils/ws.js +21 -0
- package/lib/utils/zk.d.ts +50 -0
- package/lib/utils/zk.js +282 -0
- package/lib/window-rpc/index.d.ts +3 -0
- package/lib/window-rpc/index.js +20 -0
- package/lib/window-rpc/setup-window-rpc.d.ts +5 -0
- package/lib/window-rpc/setup-window-rpc.js +239 -0
- package/lib/window-rpc/types.d.ts +184 -0
- package/lib/window-rpc/types.js +3 -0
- package/lib/window-rpc/utils.d.ts +13 -0
- package/lib/window-rpc/utils.js +76 -0
- package/lib/window-rpc/window-rpc-zk.d.ts +11 -0
- package/lib/window-rpc/window-rpc-zk.js +72 -0
- package/package.json +117 -0
|
@@ -0,0 +1,348 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.unixTimestampSeconds = void 0;
|
|
4
|
+
exports.uint8ArrayToStr = uint8ArrayToStr;
|
|
5
|
+
exports.getTranscriptString = getTranscriptString;
|
|
6
|
+
exports.findIndexInUint8Array = findIndexInUint8Array;
|
|
7
|
+
exports.uint8ArrayToBinaryStr = uint8ArrayToBinaryStr;
|
|
8
|
+
exports.gunzipSync = gunzipSync;
|
|
9
|
+
exports.getZkAlgorithmForCipherSuite = getZkAlgorithmForCipherSuite;
|
|
10
|
+
exports.getPureCiphertext = getPureCiphertext;
|
|
11
|
+
exports.getRecordIV = getRecordIV;
|
|
12
|
+
exports.getProviderValue = getProviderValue;
|
|
13
|
+
exports.generateRpcMessageId = generateRpcMessageId;
|
|
14
|
+
exports.generateSessionId = generateSessionId;
|
|
15
|
+
exports.generateTunnelId = generateTunnelId;
|
|
16
|
+
exports.makeRpcEvent = makeRpcEvent;
|
|
17
|
+
exports.getRpcTypeFromKey = getRpcTypeFromKey;
|
|
18
|
+
exports.getRpcResponseType = getRpcResponseType;
|
|
19
|
+
exports.getRpcRequestType = getRpcRequestType;
|
|
20
|
+
exports.isApplicationData = isApplicationData;
|
|
21
|
+
exports.extractArrayBufferFromWsData = extractArrayBufferFromWsData;
|
|
22
|
+
exports.getRpcRequest = getRpcRequest;
|
|
23
|
+
exports.extractApplicationDataFromTranscript = extractApplicationDataFromTranscript;
|
|
24
|
+
exports.extractHandshakeFromTranscript = extractHandshakeFromTranscript;
|
|
25
|
+
exports.decryptDirect = decryptDirect;
|
|
26
|
+
exports.packRpcMessages = packRpcMessages;
|
|
27
|
+
exports.ethersStructToPlainObject = ethersStructToPlainObject;
|
|
28
|
+
const circom_symmetric_crypto_1 = require("@reclaimprotocol/circom-symmetric-crypto");
|
|
29
|
+
const tls_1 = require("@reclaimprotocol/tls");
|
|
30
|
+
const api_1 = require("src/proto/api");
|
|
31
|
+
const DEFAULT_REDACTION_DATA = new Uint8Array(4)
|
|
32
|
+
.fill(circom_symmetric_crypto_1.REDACTION_CHAR_CODE);
|
|
33
|
+
function uint8ArrayToStr(arr) {
|
|
34
|
+
return new TextDecoder().decode(arr);
|
|
35
|
+
}
|
|
36
|
+
function getTranscriptString(receipt) {
|
|
37
|
+
var _a;
|
|
38
|
+
const applMsgs = extractApplicationDataFromTranscript(receipt);
|
|
39
|
+
const strList = [];
|
|
40
|
+
for (const { message, sender } of applMsgs) {
|
|
41
|
+
const content = uint8ArrayToStr(message);
|
|
42
|
+
if ((_a = strList[strList.length - 1]) === null || _a === void 0 ? void 0 : _a.startsWith(sender)) {
|
|
43
|
+
strList[strList.length - 1] += content;
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
strList.push(`${sender}: ${content}`);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
return strList.join('\n');
|
|
50
|
+
}
|
|
51
|
+
const unixTimestampSeconds = () => Math.floor(Date.now() / 1000);
|
|
52
|
+
exports.unixTimestampSeconds = unixTimestampSeconds;
|
|
53
|
+
/**
|
|
54
|
+
* Find index of needle in haystack
|
|
55
|
+
*/
|
|
56
|
+
function findIndexInUint8Array(haystack, needle) {
|
|
57
|
+
for (let i = 0; i < haystack.length; i++) {
|
|
58
|
+
if ((0, tls_1.areUint8ArraysEqual)(haystack.slice(i, i + needle.length), needle)) {
|
|
59
|
+
return i;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
return -1;
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* convert a Uint8Array to a binary encoded str
|
|
66
|
+
* from: https://github.com/feross/buffer/blob/795bbb5bda1b39f1370ebd784bea6107b087e3a7/index.js#L1063
|
|
67
|
+
* @param buf
|
|
68
|
+
* @returns
|
|
69
|
+
*/
|
|
70
|
+
function uint8ArrayToBinaryStr(buf) {
|
|
71
|
+
let ret = '';
|
|
72
|
+
for (const v of buf) {
|
|
73
|
+
(ret += String.fromCharCode(v));
|
|
74
|
+
}
|
|
75
|
+
return ret;
|
|
76
|
+
}
|
|
77
|
+
function gunzipSync(buf) {
|
|
78
|
+
const { gunzipSync } = require('zlib');
|
|
79
|
+
return gunzipSync(buf);
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Fetch the ZK algorithm for the specified cipher suite
|
|
83
|
+
*/
|
|
84
|
+
function getZkAlgorithmForCipherSuite(cipherSuite) {
|
|
85
|
+
if (cipherSuite.includes('CHACHA20')) {
|
|
86
|
+
return 'chacha20';
|
|
87
|
+
}
|
|
88
|
+
if (cipherSuite.includes('AES_256_GCM')) {
|
|
89
|
+
return 'aes-256-ctr';
|
|
90
|
+
}
|
|
91
|
+
if (cipherSuite.includes('AES_128_GCM')) {
|
|
92
|
+
return 'aes-128-ctr';
|
|
93
|
+
}
|
|
94
|
+
throw new Error(`${cipherSuite} not supported for ZK ops`);
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* Get the pure ciphertext without any MAC,
|
|
98
|
+
* or authentication tag,
|
|
99
|
+
* @param content content w/o header
|
|
100
|
+
* @param cipherSuite
|
|
101
|
+
*/
|
|
102
|
+
function getPureCiphertext(content, cipherSuite) {
|
|
103
|
+
// assert that the cipher suite is supported
|
|
104
|
+
getZkAlgorithmForCipherSuite(cipherSuite);
|
|
105
|
+
// 16 => auth tag length
|
|
106
|
+
content = content.slice(0, -16);
|
|
107
|
+
const { ivLength: fixedIvLength, } = tls_1.SUPPORTED_CIPHER_SUITE_MAP[cipherSuite];
|
|
108
|
+
// 12 => total IV length
|
|
109
|
+
const recordIvLength = 12 - fixedIvLength;
|
|
110
|
+
// record IV is prefixed to the ciphertext
|
|
111
|
+
content = content.slice(recordIvLength);
|
|
112
|
+
return content;
|
|
113
|
+
}
|
|
114
|
+
/**
|
|
115
|
+
* Get the 8 byte IV part that's stored in the record for some cipher suites
|
|
116
|
+
* @param content content w/o header
|
|
117
|
+
* @param cipherSuite
|
|
118
|
+
*/
|
|
119
|
+
function getRecordIV(content, cipherSuite) {
|
|
120
|
+
// assert that the cipher suite is supported
|
|
121
|
+
getZkAlgorithmForCipherSuite(cipherSuite);
|
|
122
|
+
const { ivLength: fixedIvLength, } = tls_1.SUPPORTED_CIPHER_SUITE_MAP[cipherSuite];
|
|
123
|
+
// 12 => total IV length
|
|
124
|
+
const recordIvLength = 12 - fixedIvLength;
|
|
125
|
+
return content.slice(0, recordIvLength);
|
|
126
|
+
}
|
|
127
|
+
function getProviderValue(params, fn) {
|
|
128
|
+
return typeof fn === 'function'
|
|
129
|
+
// @ts-ignore
|
|
130
|
+
? fn(params)
|
|
131
|
+
: fn;
|
|
132
|
+
}
|
|
133
|
+
function generateRpcMessageId() {
|
|
134
|
+
return (0, tls_1.uint8ArrayToDataView)(tls_1.crypto.randomBytes(8)).getUint32(0);
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* Random session ID for a WebSocket client.
|
|
138
|
+
*/
|
|
139
|
+
function generateSessionId() {
|
|
140
|
+
return generateRpcMessageId();
|
|
141
|
+
}
|
|
142
|
+
/**
|
|
143
|
+
* Random ID for a tunnel.
|
|
144
|
+
*/
|
|
145
|
+
function generateTunnelId() {
|
|
146
|
+
return generateRpcMessageId();
|
|
147
|
+
}
|
|
148
|
+
function makeRpcEvent(type, data) {
|
|
149
|
+
const ev = new Event(type);
|
|
150
|
+
ev.data = data;
|
|
151
|
+
return ev;
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* Get the RPC type from the key.
|
|
155
|
+
* For eg. "claimTunnelRequest" ->
|
|
156
|
+
* { type: 'claimTunnel', direction: 'request' }
|
|
157
|
+
*/
|
|
158
|
+
function getRpcTypeFromKey(key) {
|
|
159
|
+
if (key.endsWith('Request')) {
|
|
160
|
+
return {
|
|
161
|
+
type: key.slice(0, -7),
|
|
162
|
+
direction: 'request'
|
|
163
|
+
};
|
|
164
|
+
}
|
|
165
|
+
if (key.endsWith('Response')) {
|
|
166
|
+
return {
|
|
167
|
+
type: key.slice(0, -8),
|
|
168
|
+
direction: 'response'
|
|
169
|
+
};
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
/**
|
|
173
|
+
* Get the RPC response type from the RPC type.
|
|
174
|
+
* For eg. "claimTunnel" -> "claimTunnelResponse"
|
|
175
|
+
*/
|
|
176
|
+
function getRpcResponseType(type) {
|
|
177
|
+
return `${type}Response`;
|
|
178
|
+
}
|
|
179
|
+
/**
|
|
180
|
+
* Get the RPC request type from the RPC type.
|
|
181
|
+
* For eg. "claimTunnel" -> "claimTunnelRequest"
|
|
182
|
+
*/
|
|
183
|
+
function getRpcRequestType(type) {
|
|
184
|
+
return `${type}Request`;
|
|
185
|
+
}
|
|
186
|
+
function isApplicationData(packet, tlsVersion) {
|
|
187
|
+
return packet.type === 'ciphertext'
|
|
188
|
+
&& (packet.contentType === 'APPLICATION_DATA'
|
|
189
|
+
|| (packet.data[0] === tls_1.PACKET_TYPE.WRAPPED_RECORD
|
|
190
|
+
&& tlsVersion === 'TLS1_2'));
|
|
191
|
+
}
|
|
192
|
+
/**
|
|
193
|
+
* Convert the received data from a WS to a Uint8Array
|
|
194
|
+
*/
|
|
195
|
+
async function extractArrayBufferFromWsData(data) {
|
|
196
|
+
if (data instanceof ArrayBuffer) {
|
|
197
|
+
return new Uint8Array(data);
|
|
198
|
+
}
|
|
199
|
+
// uint8array/Buffer
|
|
200
|
+
if (typeof data === 'object' && data && 'buffer' in data) {
|
|
201
|
+
return data;
|
|
202
|
+
}
|
|
203
|
+
if (typeof data === 'string') {
|
|
204
|
+
return (0, tls_1.strToUint8Array)(data);
|
|
205
|
+
}
|
|
206
|
+
if (data instanceof Blob) {
|
|
207
|
+
return new Uint8Array(await data.arrayBuffer());
|
|
208
|
+
}
|
|
209
|
+
throw new Error('unsupported data: ' + String(data));
|
|
210
|
+
}
|
|
211
|
+
/**
|
|
212
|
+
* Check if the RPC message is a request or a response.
|
|
213
|
+
*/
|
|
214
|
+
function getRpcRequest(msg) {
|
|
215
|
+
if (msg.requestError) {
|
|
216
|
+
return {
|
|
217
|
+
direction: 'response',
|
|
218
|
+
type: 'error'
|
|
219
|
+
};
|
|
220
|
+
}
|
|
221
|
+
for (const key in msg) {
|
|
222
|
+
if (!msg[key]) {
|
|
223
|
+
continue;
|
|
224
|
+
}
|
|
225
|
+
const rpcType = getRpcTypeFromKey(key);
|
|
226
|
+
if (!rpcType) {
|
|
227
|
+
continue;
|
|
228
|
+
}
|
|
229
|
+
return rpcType;
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
/**
|
|
233
|
+
* Finds all application data messages in a transcript
|
|
234
|
+
* and returns them. Removes the "contentType" suffix from the message.
|
|
235
|
+
* in TLS 1.3
|
|
236
|
+
*/
|
|
237
|
+
function extractApplicationDataFromTranscript({ transcript, tlsVersion }) {
|
|
238
|
+
const msgs = [];
|
|
239
|
+
for (const m of transcript) {
|
|
240
|
+
let message;
|
|
241
|
+
// redacted msgs but with a valid packet header
|
|
242
|
+
// can be considered application data messages
|
|
243
|
+
if (m.redacted) {
|
|
244
|
+
if (!m.plaintextLength) {
|
|
245
|
+
message = DEFAULT_REDACTION_DATA;
|
|
246
|
+
}
|
|
247
|
+
else {
|
|
248
|
+
const len = tlsVersion === 'TLS1_3'
|
|
249
|
+
// remove content type suffix
|
|
250
|
+
? m.plaintextLength - 1
|
|
251
|
+
: m.plaintextLength;
|
|
252
|
+
message = new Uint8Array(len)
|
|
253
|
+
.fill(circom_symmetric_crypto_1.REDACTION_CHAR_CODE);
|
|
254
|
+
}
|
|
255
|
+
// otherwise, we need to check the content type
|
|
256
|
+
}
|
|
257
|
+
else if (tlsVersion === 'TLS1_3') {
|
|
258
|
+
const contentType = m.message[m.message.length - 1];
|
|
259
|
+
if (contentType !== tls_1.CONTENT_TYPE_MAP['APPLICATION_DATA']) {
|
|
260
|
+
continue;
|
|
261
|
+
}
|
|
262
|
+
message = m.message.slice(0, -1);
|
|
263
|
+
}
|
|
264
|
+
else if (m.recordHeader[0] === tls_1.PACKET_TYPE.WRAPPED_RECORD) {
|
|
265
|
+
message = m.message;
|
|
266
|
+
}
|
|
267
|
+
else {
|
|
268
|
+
continue;
|
|
269
|
+
}
|
|
270
|
+
msgs.push({ message, sender: m.sender });
|
|
271
|
+
}
|
|
272
|
+
return msgs;
|
|
273
|
+
}
|
|
274
|
+
function extractHandshakeFromTranscript({ transcript, tlsVersion }) {
|
|
275
|
+
const msgs = [];
|
|
276
|
+
for (const [i, m] of transcript.entries()) {
|
|
277
|
+
if (m.redacted) {
|
|
278
|
+
break; // stop at first encrypted message
|
|
279
|
+
}
|
|
280
|
+
let message;
|
|
281
|
+
if (m.recordHeader[0] === tls_1.PACKET_TYPE.HELLO) {
|
|
282
|
+
message = m.message;
|
|
283
|
+
}
|
|
284
|
+
else if (m.recordHeader[0] === tls_1.PACKET_TYPE.WRAPPED_RECORD) {
|
|
285
|
+
if (tlsVersion === 'TLS1_3') {
|
|
286
|
+
const contentType = m.message[m.message.length - 1];
|
|
287
|
+
if (contentType !== tls_1.CONTENT_TYPE_MAP['HANDSHAKE']) {
|
|
288
|
+
break;
|
|
289
|
+
}
|
|
290
|
+
message = m.message.slice(0, -1);
|
|
291
|
+
}
|
|
292
|
+
else {
|
|
293
|
+
break;
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
else {
|
|
297
|
+
continue;
|
|
298
|
+
}
|
|
299
|
+
if (!message.length) {
|
|
300
|
+
throw new Error('unsupported handshake message');
|
|
301
|
+
}
|
|
302
|
+
msgs.push({ message, sender: m.sender, index: i });
|
|
303
|
+
}
|
|
304
|
+
return msgs;
|
|
305
|
+
}
|
|
306
|
+
async function decryptDirect(directReveal, cipherSuite, recordHeader, serverTlsVersion, content) {
|
|
307
|
+
const { key, iv, recordNumber } = directReveal;
|
|
308
|
+
const { cipher } = tls_1.SUPPORTED_CIPHER_SUITE_MAP[cipherSuite];
|
|
309
|
+
const importedKey = await tls_1.crypto.importKey(cipher, key);
|
|
310
|
+
return await (0, tls_1.decryptWrappedRecord)(content, {
|
|
311
|
+
iv,
|
|
312
|
+
key: importedKey,
|
|
313
|
+
recordHeader,
|
|
314
|
+
recordNumber,
|
|
315
|
+
version: serverTlsVersion,
|
|
316
|
+
cipherSuite,
|
|
317
|
+
});
|
|
318
|
+
}
|
|
319
|
+
function packRpcMessages(...msgs) {
|
|
320
|
+
return api_1.RPCMessages.create({
|
|
321
|
+
messages: msgs.map(msg => (api_1.RPCMessage.create({
|
|
322
|
+
...msg,
|
|
323
|
+
id: msg.id || generateRpcMessageId()
|
|
324
|
+
})))
|
|
325
|
+
});
|
|
326
|
+
}
|
|
327
|
+
/**
|
|
328
|
+
* Converts an Ethers struct (an array w named keys) to
|
|
329
|
+
* a plain object. Recursively converts all structs inside.
|
|
330
|
+
* Required to correctly JSON.stringify the struct.
|
|
331
|
+
*/
|
|
332
|
+
function ethersStructToPlainObject(struct) {
|
|
333
|
+
if (!Array.isArray(struct)) {
|
|
334
|
+
return struct;
|
|
335
|
+
}
|
|
336
|
+
const namedKeys = Object.keys(struct)
|
|
337
|
+
.filter(key => isNaN(Number(key)));
|
|
338
|
+
// seems to be an actual array
|
|
339
|
+
if (!namedKeys.length) {
|
|
340
|
+
return struct.map(ethersStructToPlainObject);
|
|
341
|
+
}
|
|
342
|
+
const obj = {};
|
|
343
|
+
for (const key of namedKeys) {
|
|
344
|
+
obj[key] = ethersStructToPlainObject(struct[key]);
|
|
345
|
+
}
|
|
346
|
+
return obj;
|
|
347
|
+
}
|
|
348
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generics.js","sourceRoot":"","sources":["../../src/utils/generics.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import type { IncomingHttpHeaders } from 'http';
|
|
2
|
+
import type { ArraySlice, Transcript } from 'src/types';
|
|
3
|
+
export type HttpRequest = {
|
|
4
|
+
method: string;
|
|
5
|
+
url: string;
|
|
6
|
+
protocol: string;
|
|
7
|
+
headers: IncomingHttpHeaders;
|
|
8
|
+
body?: Uint8Array;
|
|
9
|
+
};
|
|
10
|
+
export type HttpResponse = {
|
|
11
|
+
statusCode: number;
|
|
12
|
+
statusMessage: string;
|
|
13
|
+
headers: IncomingHttpHeaders;
|
|
14
|
+
body: Uint8Array;
|
|
15
|
+
headersComplete: boolean;
|
|
16
|
+
complete: boolean;
|
|
17
|
+
/**
|
|
18
|
+
* Index of the first byte of the status line
|
|
19
|
+
*/
|
|
20
|
+
statusLineEndIndex?: number;
|
|
21
|
+
/**
|
|
22
|
+
* Index of the first byte of the body
|
|
23
|
+
* in the complete response
|
|
24
|
+
*/
|
|
25
|
+
bodyStartIndex?: number;
|
|
26
|
+
/**
|
|
27
|
+
* If using chunked transfer encoding,
|
|
28
|
+
* this will be set & contain indices of each
|
|
29
|
+
* chunk in the complete response
|
|
30
|
+
*/
|
|
31
|
+
chunks?: ArraySlice[];
|
|
32
|
+
headerIndices: Map<string, ArraySlice>;
|
|
33
|
+
};
|
|
34
|
+
/**
|
|
35
|
+
* parses http/1.1 responses
|
|
36
|
+
*/
|
|
37
|
+
export declare function makeHttpResponseParser(): {
|
|
38
|
+
res: HttpResponse;
|
|
39
|
+
/**
|
|
40
|
+
* Parse the next chunk of data
|
|
41
|
+
* @param data the data to parse
|
|
42
|
+
*/
|
|
43
|
+
onChunk(data: Uint8Array): void;
|
|
44
|
+
/**
|
|
45
|
+
* Call to prevent further parsing; indicating the end of the request
|
|
46
|
+
* Checks that the response is valid & complete, otherwise throws an error
|
|
47
|
+
*/
|
|
48
|
+
streamEnded(): void;
|
|
49
|
+
};
|
|
50
|
+
/**
|
|
51
|
+
* Read the HTTP request from a TLS receipt transcript.
|
|
52
|
+
* @param receipt the transcript to read from or application messages if they were extracted beforehand
|
|
53
|
+
* @returns the parsed HTTP request
|
|
54
|
+
*/
|
|
55
|
+
export declare function getHttpRequestDataFromTranscript(receipt: Transcript<Uint8Array>): HttpRequest;
|
|
@@ -0,0 +1,249 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.makeHttpResponseParser = makeHttpResponseParser;
|
|
4
|
+
exports.getHttpRequestDataFromTranscript = getHttpRequestDataFromTranscript;
|
|
5
|
+
const tls_1 = require("@reclaimprotocol/tls");
|
|
6
|
+
const generics_1 = require("src/utils/generics");
|
|
7
|
+
const redactions_1 = require("src/utils/redactions");
|
|
8
|
+
const HTTP_HEADER_LINE_END = (0, tls_1.strToUint8Array)('\r\n');
|
|
9
|
+
/**
|
|
10
|
+
* parses http/1.1 responses
|
|
11
|
+
*/
|
|
12
|
+
function makeHttpResponseParser() {
|
|
13
|
+
/** the HTTP response data */
|
|
14
|
+
const res = {
|
|
15
|
+
statusCode: 0,
|
|
16
|
+
statusMessage: '',
|
|
17
|
+
headers: {},
|
|
18
|
+
body: new Uint8Array(),
|
|
19
|
+
complete: false,
|
|
20
|
+
headersComplete: false,
|
|
21
|
+
headerIndices: new Map()
|
|
22
|
+
};
|
|
23
|
+
let remainingBodyBytes = 0;
|
|
24
|
+
let isChunked = false;
|
|
25
|
+
let remaining = new Uint8Array();
|
|
26
|
+
let currentByteIdx = 0;
|
|
27
|
+
return {
|
|
28
|
+
res,
|
|
29
|
+
/**
|
|
30
|
+
* Parse the next chunk of data
|
|
31
|
+
* @param data the data to parse
|
|
32
|
+
*/
|
|
33
|
+
onChunk(data) {
|
|
34
|
+
var _a, _b;
|
|
35
|
+
// concatenate the remaining data from the last chunk
|
|
36
|
+
remaining = (0, tls_1.concatenateUint8Arrays)([remaining, data]);
|
|
37
|
+
// if we don't have the headers yet, keep reading lines
|
|
38
|
+
// as each header is in a line
|
|
39
|
+
if (!res.headersComplete) {
|
|
40
|
+
for (let line = getLine(); typeof line !== 'undefined'; line = getLine()) {
|
|
41
|
+
// first line is the HTTP version, status code & message
|
|
42
|
+
if (!res.statusCode) {
|
|
43
|
+
const [, statusCode, statusMessage] = line.match(/HTTP\/\d\.\d (\d+) (.*)/) || [];
|
|
44
|
+
res.statusCode = Number(statusCode);
|
|
45
|
+
res.statusMessage = statusMessage;
|
|
46
|
+
res.statusLineEndIndex = currentByteIdx - HTTP_HEADER_LINE_END.length;
|
|
47
|
+
}
|
|
48
|
+
else if (line === '') { // empty line signifies end of headers
|
|
49
|
+
res.headersComplete = true;
|
|
50
|
+
// if the response is chunked, we need to process the body differently
|
|
51
|
+
if ((_a = res.headers['transfer-encoding']) === null || _a === void 0 ? void 0 : _a.includes('chunked')) {
|
|
52
|
+
isChunked = true;
|
|
53
|
+
res.chunks = [];
|
|
54
|
+
break;
|
|
55
|
+
// if the response has a content-length, we know how many bytes to read
|
|
56
|
+
}
|
|
57
|
+
else if (res.headers['content-length']) {
|
|
58
|
+
remainingBodyBytes = Number(res.headers['content-length']);
|
|
59
|
+
break;
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
remainingBodyBytes = -1;
|
|
63
|
+
// otherwise,
|
|
64
|
+
// no content-length, no chunked transfer encoding
|
|
65
|
+
// means wait till the stream ends
|
|
66
|
+
// https://stackoverflow.com/a/11376887
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
else if (!res.complete) { // parse the header
|
|
70
|
+
const [key, value] = line.split(': ');
|
|
71
|
+
res.headers[key.toLowerCase()] = value;
|
|
72
|
+
res.headerIndices[key.toLowerCase()] = {
|
|
73
|
+
fromIndex: currentByteIdx - line.length - HTTP_HEADER_LINE_END.length,
|
|
74
|
+
toIndex: currentByteIdx - HTTP_HEADER_LINE_END.length
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
throw new Error('got more data after response was complete');
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
if (res.headersComplete) {
|
|
83
|
+
if (remainingBodyBytes) {
|
|
84
|
+
readBody();
|
|
85
|
+
// if no more body bytes to read,
|
|
86
|
+
// and the response was not chunked we're done
|
|
87
|
+
if (!remainingBodyBytes && !isChunked) {
|
|
88
|
+
res.complete = true;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
if (res.headers['content-length'] === '0') {
|
|
92
|
+
res.complete = true;
|
|
93
|
+
}
|
|
94
|
+
if (isChunked) {
|
|
95
|
+
for (let line = getLine(); typeof line !== 'undefined'; line = getLine()) {
|
|
96
|
+
if (line === '') {
|
|
97
|
+
continue;
|
|
98
|
+
}
|
|
99
|
+
const chunkSize = Number.parseInt(line, 16);
|
|
100
|
+
// if chunk size is 0, we're done
|
|
101
|
+
if (!chunkSize) {
|
|
102
|
+
res.complete = true;
|
|
103
|
+
continue;
|
|
104
|
+
}
|
|
105
|
+
(_b = res.chunks) === null || _b === void 0 ? void 0 : _b.push({
|
|
106
|
+
fromIndex: currentByteIdx,
|
|
107
|
+
toIndex: currentByteIdx + chunkSize,
|
|
108
|
+
});
|
|
109
|
+
// otherwise read the chunk
|
|
110
|
+
remainingBodyBytes = chunkSize;
|
|
111
|
+
readBody();
|
|
112
|
+
// if we read all the data we had,
|
|
113
|
+
// but there's still data left,
|
|
114
|
+
// break the loop and wait for the next chunk
|
|
115
|
+
if (remainingBodyBytes) {
|
|
116
|
+
break;
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
},
|
|
122
|
+
/**
|
|
123
|
+
* Call to prevent further parsing; indicating the end of the request
|
|
124
|
+
* Checks that the response is valid & complete, otherwise throws an error
|
|
125
|
+
*/
|
|
126
|
+
streamEnded() {
|
|
127
|
+
if (!res.headersComplete) {
|
|
128
|
+
throw new Error('stream ended before headers were complete');
|
|
129
|
+
}
|
|
130
|
+
if (remaining.length) {
|
|
131
|
+
throw new Error('stream ended with remaining data');
|
|
132
|
+
}
|
|
133
|
+
if (remainingBodyBytes > 0) {
|
|
134
|
+
throw new Error('stream ended before all body bytes were received');
|
|
135
|
+
}
|
|
136
|
+
res.complete = true;
|
|
137
|
+
}
|
|
138
|
+
};
|
|
139
|
+
function readBody() {
|
|
140
|
+
if (res.complete) {
|
|
141
|
+
throw new Error('got more data after response was complete');
|
|
142
|
+
}
|
|
143
|
+
if (!res.bodyStartIndex) {
|
|
144
|
+
res.bodyStartIndex = currentByteIdx;
|
|
145
|
+
}
|
|
146
|
+
let bytesToCopy;
|
|
147
|
+
if (remainingBodyBytes === -1) {
|
|
148
|
+
// all bytes are body bytes
|
|
149
|
+
bytesToCopy = remaining.length;
|
|
150
|
+
}
|
|
151
|
+
else {
|
|
152
|
+
// take the number of bytes we need to read, or the number of bytes remaining
|
|
153
|
+
// and append to the bytes of the body
|
|
154
|
+
bytesToCopy = Math.min(remainingBodyBytes, remaining.length);
|
|
155
|
+
remainingBodyBytes -= bytesToCopy;
|
|
156
|
+
}
|
|
157
|
+
res.body = (0, tls_1.concatenateUint8Arrays)([
|
|
158
|
+
res.body,
|
|
159
|
+
remaining.slice(0, bytesToCopy)
|
|
160
|
+
]);
|
|
161
|
+
remaining = remaining.slice(bytesToCopy);
|
|
162
|
+
currentByteIdx += bytesToCopy;
|
|
163
|
+
}
|
|
164
|
+
function getLine() {
|
|
165
|
+
// find end of line, if it exists
|
|
166
|
+
// otherwise return undefined
|
|
167
|
+
const idx = (0, generics_1.findIndexInUint8Array)(remaining, HTTP_HEADER_LINE_END);
|
|
168
|
+
if (idx === -1) {
|
|
169
|
+
return undefined;
|
|
170
|
+
}
|
|
171
|
+
const line = (0, generics_1.uint8ArrayToStr)(remaining.slice(0, idx));
|
|
172
|
+
remaining = remaining.slice(idx + HTTP_HEADER_LINE_END.length);
|
|
173
|
+
currentByteIdx += idx + HTTP_HEADER_LINE_END.length;
|
|
174
|
+
return line;
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
/**
|
|
178
|
+
* Read the HTTP request from a TLS receipt transcript.
|
|
179
|
+
* @param receipt the transcript to read from or application messages if they were extracted beforehand
|
|
180
|
+
* @returns the parsed HTTP request
|
|
181
|
+
*/
|
|
182
|
+
function getHttpRequestDataFromTranscript(receipt) {
|
|
183
|
+
const clientMsgs = receipt
|
|
184
|
+
.filter(s => s.sender === 'client');
|
|
185
|
+
// if the first message is redacted, we can't parse it
|
|
186
|
+
// as we don't know what the request was
|
|
187
|
+
if (clientMsgs[0].message[0] === redactions_1.REDACTION_CHAR_CODE) {
|
|
188
|
+
throw new Error('First client message request is redacted. Cannot parse');
|
|
189
|
+
}
|
|
190
|
+
const request = {
|
|
191
|
+
method: '',
|
|
192
|
+
url: '',
|
|
193
|
+
protocol: '',
|
|
194
|
+
headers: {}
|
|
195
|
+
};
|
|
196
|
+
let requestBuffer = (0, tls_1.concatenateUint8Arrays)(clientMsgs.map(m => m.message));
|
|
197
|
+
// keep reading lines until we get to the end of the headers
|
|
198
|
+
for (let line = getLine(); typeof line !== 'undefined'; line = getLine()) {
|
|
199
|
+
if (line === '') {
|
|
200
|
+
break;
|
|
201
|
+
}
|
|
202
|
+
if (!request.method) {
|
|
203
|
+
const [, method, url, protocol] = line.match(/(\w+) (.*) (.*)/) || [];
|
|
204
|
+
request.method = method.toLowerCase();
|
|
205
|
+
request.url = url;
|
|
206
|
+
request.protocol = protocol;
|
|
207
|
+
}
|
|
208
|
+
else {
|
|
209
|
+
let keyIdx = line.indexOf(':');
|
|
210
|
+
if (keyIdx === -1) {
|
|
211
|
+
keyIdx = line.length - 1;
|
|
212
|
+
}
|
|
213
|
+
const key = line.slice(0, keyIdx)
|
|
214
|
+
.toLowerCase()
|
|
215
|
+
.trim();
|
|
216
|
+
const value = line.slice(keyIdx + 1)
|
|
217
|
+
.trim();
|
|
218
|
+
const oldValue = request.headers[key];
|
|
219
|
+
if (typeof oldValue === 'string') {
|
|
220
|
+
request.headers[key] = [oldValue, value];
|
|
221
|
+
}
|
|
222
|
+
else if (Array.isArray(oldValue)) {
|
|
223
|
+
oldValue.push(value);
|
|
224
|
+
}
|
|
225
|
+
else {
|
|
226
|
+
request.headers[key] = value;
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
//the rest is request body
|
|
231
|
+
if (requestBuffer.length) {
|
|
232
|
+
request.body = requestBuffer;
|
|
233
|
+
}
|
|
234
|
+
if (!request.method) {
|
|
235
|
+
throw new Error('Client request is incomplete');
|
|
236
|
+
}
|
|
237
|
+
return request;
|
|
238
|
+
function getLine() {
|
|
239
|
+
const idx = (0, generics_1.findIndexInUint8Array)(requestBuffer, HTTP_HEADER_LINE_END);
|
|
240
|
+
if (idx === -1) {
|
|
241
|
+
return undefined;
|
|
242
|
+
}
|
|
243
|
+
const line = (0, generics_1.uint8ArrayToStr)(requestBuffer.slice(0, idx));
|
|
244
|
+
requestBuffer = requestBuffer
|
|
245
|
+
.slice(idx + HTTP_HEADER_LINE_END.length);
|
|
246
|
+
return line;
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-parser.js","sourceRoot":"","sources":["../../src/utils/http-parser.ts"],"names":[],"mappings":"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"}
|