@bsv/sdk 1.5.3 → 1.6.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/dist/cjs/package.json +1 -1
- package/dist/cjs/src/overlay-tools/LookupResolver.js +0 -4
- package/dist/cjs/src/overlay-tools/LookupResolver.js.map +1 -1
- package/dist/cjs/src/overlay-tools/SHIPBroadcaster.js +0 -2
- package/dist/cjs/src/overlay-tools/SHIPBroadcaster.js.map +1 -1
- package/dist/cjs/src/primitives/AESGCM.js +113 -137
- package/dist/cjs/src/primitives/AESGCM.js.map +1 -1
- package/dist/cjs/src/primitives/BigNumber.js +1019 -3947
- package/dist/cjs/src/primitives/BigNumber.js.map +1 -1
- package/dist/cjs/src/primitives/K256.js +53 -37
- package/dist/cjs/src/primitives/K256.js.map +1 -1
- package/dist/cjs/src/primitives/Mersenne.js +16 -21
- package/dist/cjs/src/primitives/Mersenne.js.map +1 -1
- package/dist/cjs/src/primitives/MontgomoryMethod.js.map +1 -1
- package/dist/cjs/src/primitives/utils.js +27 -17
- package/dist/cjs/src/primitives/utils.js.map +1 -1
- package/dist/cjs/src/script/Spend.js +618 -858
- package/dist/cjs/src/script/Spend.js.map +1 -1
- package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -1
- package/dist/esm/src/overlay-tools/LookupResolver.js +0 -4
- package/dist/esm/src/overlay-tools/LookupResolver.js.map +1 -1
- package/dist/esm/src/overlay-tools/SHIPBroadcaster.js +0 -2
- package/dist/esm/src/overlay-tools/SHIPBroadcaster.js.map +1 -1
- package/dist/esm/src/primitives/AESGCM.js +112 -137
- package/dist/esm/src/primitives/AESGCM.js.map +1 -1
- package/dist/esm/src/primitives/BigNumber.js +1011 -3969
- package/dist/esm/src/primitives/BigNumber.js.map +1 -1
- package/dist/esm/src/primitives/K256.js +53 -37
- package/dist/esm/src/primitives/K256.js.map +1 -1
- package/dist/esm/src/primitives/Mersenne.js +16 -21
- package/dist/esm/src/primitives/Mersenne.js.map +1 -1
- package/dist/esm/src/primitives/MontgomoryMethod.js.map +1 -1
- package/dist/esm/src/primitives/utils.js +29 -17
- package/dist/esm/src/primitives/utils.js.map +1 -1
- package/dist/esm/src/script/Spend.js +618 -857
- package/dist/esm/src/script/Spend.js.map +1 -1
- package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
- package/dist/types/src/overlay-tools/LookupResolver.d.ts +1 -3
- package/dist/types/src/overlay-tools/LookupResolver.d.ts.map +1 -1
- package/dist/types/src/overlay-tools/SHIPBroadcaster.d.ts +1 -0
- package/dist/types/src/overlay-tools/SHIPBroadcaster.d.ts.map +1 -1
- package/dist/types/src/primitives/AESGCM.d.ts.map +1 -1
- package/dist/types/src/primitives/BigNumber.d.ts +238 -1705
- package/dist/types/src/primitives/BigNumber.d.ts.map +1 -1
- package/dist/types/src/primitives/K256.d.ts.map +1 -1
- package/dist/types/src/primitives/Mersenne.d.ts +2 -2
- package/dist/types/src/primitives/Mersenne.d.ts.map +1 -1
- package/dist/types/src/primitives/utils.d.ts +2 -0
- package/dist/types/src/primitives/utils.d.ts.map +1 -1
- package/dist/types/src/script/Spend.d.ts +11 -1
- package/dist/types/src/script/Spend.d.ts.map +1 -1
- package/dist/types/tsconfig.types.tsbuildinfo +1 -1
- package/dist/umd/bundle.js +1 -1
- package/docs/performance.md +70 -0
- package/docs/primitives.md +262 -3049
- package/package.json +1 -1
- package/src/auth/__tests/Peer.test.ts +38 -23
- package/src/auth/certificates/__tests/MasterCertificate.test.ts +27 -20
- package/src/auth/certificates/__tests/VerifiableCertificate.test.ts +24 -24
- package/src/overlay-tools/LookupResolver.ts +1 -9
- package/src/overlay-tools/SHIPBroadcaster.ts +1 -2
- package/src/overlay-tools/__tests/LookupResolver.test.ts +0 -112
- package/src/primitives/AESGCM.ts +118 -164
- package/src/primitives/BigNumber.ts +867 -4180
- package/src/primitives/K256.ts +57 -37
- package/src/primitives/Mersenne.ts +16 -20
- package/src/primitives/MontgomoryMethod.ts +2 -2
- package/src/primitives/__tests/ReductionContext.test.ts +6 -1
- package/src/primitives/utils.ts +28 -17
- package/src/script/Spend.ts +634 -1309
- package/src/transaction/__tests/Transaction.test.ts +14 -16
- package/src/transaction/__tests/Transaction.benchmarks.test.ts +0 -237
package/package.json
CHANGED
|
@@ -8,6 +8,10 @@ import { MasterCertificate } from '../../auth/certificates/MasterCertificate.js'
|
|
|
8
8
|
import { getVerifiableCertificates } from '../../auth/utils/getVerifiableCertificates.js'
|
|
9
9
|
import { CompletedProtoWallet } from '../certificates/__tests/CompletedProtoWallet.js'
|
|
10
10
|
|
|
11
|
+
const certifierPrivKey = new PrivateKey(21)
|
|
12
|
+
const alicePrivKey = new PrivateKey(22)
|
|
13
|
+
const bobPrivKey = new PrivateKey(23)
|
|
14
|
+
|
|
11
15
|
jest.mock('../../auth/utils/getVerifiableCertificates')
|
|
12
16
|
|
|
13
17
|
class LocalTransport implements Transport {
|
|
@@ -40,6 +44,19 @@ class LocalTransport implements Transport {
|
|
|
40
44
|
}
|
|
41
45
|
}
|
|
42
46
|
|
|
47
|
+
function waitForNextGeneralMessage (
|
|
48
|
+
peer: Peer,
|
|
49
|
+
handler?: (senderPublicKey: string, payload: number[]) => void
|
|
50
|
+
): Promise<void> {
|
|
51
|
+
return new Promise(resolve => {
|
|
52
|
+
const listenerId = peer.listenForGeneralMessages((senderPublicKey, payload) => {
|
|
53
|
+
peer.stopListeningForGeneralMessages(listenerId)
|
|
54
|
+
if (handler !== undefined) handler(senderPublicKey, payload)
|
|
55
|
+
resolve()
|
|
56
|
+
})
|
|
57
|
+
})
|
|
58
|
+
}
|
|
59
|
+
|
|
43
60
|
describe('Peer class mutual authentication and certificate exchange', () => {
|
|
44
61
|
let walletA: WalletInterface, walletB: WalletInterface
|
|
45
62
|
let transportA: LocalTransport, transportB: LocalTransport
|
|
@@ -49,7 +66,7 @@ describe('Peer class mutual authentication and certificate exchange', () => {
|
|
|
49
66
|
|
|
50
67
|
const certificateType = Utils.toBase64(new Array(32).fill(1))
|
|
51
68
|
// const certificateSerialNumber = Utils.toBase64(new Array(32).fill(2))
|
|
52
|
-
const certifierPrivateKey =
|
|
69
|
+
const certifierPrivateKey = certifierPrivKey
|
|
53
70
|
const certifierPublicKey = certifierPrivateKey.toPublicKey().toString()
|
|
54
71
|
const certificatesToRequest = {
|
|
55
72
|
certifiers: [certifierPublicKey],
|
|
@@ -198,8 +215,8 @@ describe('Peer class mutual authentication and certificate exchange', () => {
|
|
|
198
215
|
certificatesReceivedByAlice = []
|
|
199
216
|
certificatesReceivedByBob = []
|
|
200
217
|
|
|
201
|
-
walletA = new CompletedProtoWallet(
|
|
202
|
-
walletB = new CompletedProtoWallet(
|
|
218
|
+
walletA = new CompletedProtoWallet(alicePrivKey)
|
|
219
|
+
walletB = new CompletedProtoWallet(bobPrivKey)
|
|
203
220
|
})
|
|
204
221
|
|
|
205
222
|
it('Neither Alice nor Bob request certificates, mutual authentication completes successfully', async () => {
|
|
@@ -235,10 +252,10 @@ describe('Peer class mutual authentication and certificate exchange', () => {
|
|
|
235
252
|
const transportA2 = new LocalTransport()
|
|
236
253
|
const transportB = new LocalTransport()
|
|
237
254
|
transportA1.connect(transportB)
|
|
238
|
-
const aliceKey =
|
|
255
|
+
const aliceKey = alicePrivKey
|
|
239
256
|
const walletA1 = new CompletedProtoWallet(aliceKey)
|
|
240
257
|
const walletA2 = new CompletedProtoWallet(aliceKey)
|
|
241
|
-
const walletB = new CompletedProtoWallet(
|
|
258
|
+
const walletB = new CompletedProtoWallet(alicePrivKey)
|
|
242
259
|
const aliceFirstDevice = new Peer(
|
|
243
260
|
walletA1,
|
|
244
261
|
transportA1
|
|
@@ -264,22 +281,14 @@ describe('Peer class mutual authentication and certificate exchange', () => {
|
|
|
264
281
|
})().catch(e => { })
|
|
265
282
|
})
|
|
266
283
|
})
|
|
267
|
-
|
|
268
|
-
aliceFirstDevice
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
const aliceReceivedGeneralMessageOnOtherDevice = new Promise<void>((resolve) => {
|
|
276
|
-
aliceOtherDevice.listenForGeneralMessages((senderPublicKey, payload) => {
|
|
277
|
-
(async () => {
|
|
278
|
-
resolve()
|
|
279
|
-
alice2MessageHandler(senderPublicKey, payload)
|
|
280
|
-
})().catch(e => { })
|
|
281
|
-
})
|
|
282
|
-
})
|
|
284
|
+
const aliceReceivedGeneralMessageOnFirstDevice = waitForNextGeneralMessage(
|
|
285
|
+
aliceFirstDevice,
|
|
286
|
+
alice1MessageHandler
|
|
287
|
+
)
|
|
288
|
+
const aliceReceivedGeneralMessageOnOtherDevice = waitForNextGeneralMessage(
|
|
289
|
+
aliceOtherDevice,
|
|
290
|
+
alice2MessageHandler
|
|
291
|
+
)
|
|
283
292
|
|
|
284
293
|
await aliceFirstDevice.toPeer(Utils.toArray('Hello Bob!'))
|
|
285
294
|
await bobReceivedGeneralMessage
|
|
@@ -288,8 +297,14 @@ describe('Peer class mutual authentication and certificate exchange', () => {
|
|
|
288
297
|
await aliceOtherDevice.toPeer(Utils.toArray('Hello Bob from my other device!'))
|
|
289
298
|
await aliceReceivedGeneralMessageOnOtherDevice
|
|
290
299
|
transportA1.connect(transportB)
|
|
291
|
-
|
|
292
|
-
|
|
300
|
+
const waitForSecondMessage = waitForNextGeneralMessage(
|
|
301
|
+
aliceFirstDevice,
|
|
302
|
+
alice1MessageHandler
|
|
303
|
+
)
|
|
304
|
+
await aliceFirstDevice.toPeer(
|
|
305
|
+
Utils.toArray('Back on my first device now, Bob! Can you still hear me?')
|
|
306
|
+
)
|
|
307
|
+
await waitForSecondMessage
|
|
293
308
|
expect(alice1MessageHandler.mock.calls.length).toEqual(2)
|
|
294
309
|
}, 30000)
|
|
295
310
|
|
|
@@ -3,23 +3,30 @@ import { VerifiableCertificate } from '../../../auth/certificates/VerifiableCert
|
|
|
3
3
|
import { PrivateKey, SymmetricKey, Utils, Random } from '../../../../mod'
|
|
4
4
|
import { CompletedProtoWallet } from '../../../auth/certificates/__tests/CompletedProtoWallet'
|
|
5
5
|
|
|
6
|
+
const subjectPrivateKey = new PrivateKey(21)
|
|
7
|
+
const certifierPrivateKey = new PrivateKey(22)
|
|
8
|
+
|
|
9
|
+
const fieldSymFixed1 = new SymmetricKey(51)
|
|
10
|
+
const fieldSymWrong = new SymmetricKey(61)
|
|
11
|
+
|
|
12
|
+
const subjectKey2 = new PrivateKey(71)
|
|
13
|
+
const verifierKey2 = new PrivateKey(81)
|
|
14
|
+
|
|
15
|
+
// A mock revocation outpoint for testing
|
|
16
|
+
const mockRevocationOutpoint =
|
|
17
|
+
'deadbeefdeadbeefdeadbeefdeadbeef00000000000000000000000000000000.1'
|
|
18
|
+
|
|
19
|
+
// Arbitrary certificate data (in plaintext)
|
|
20
|
+
const plaintextFields = {
|
|
21
|
+
name: 'Alice',
|
|
22
|
+
email: 'alice@example.com',
|
|
23
|
+
department: 'Engineering'
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
const subjectWallet = new CompletedProtoWallet(subjectPrivateKey)
|
|
27
|
+
const certifierWallet = new CompletedProtoWallet(certifierPrivateKey)
|
|
28
|
+
|
|
6
29
|
describe('MasterCertificate', () => {
|
|
7
|
-
const subjectPrivateKey = PrivateKey.fromRandom()
|
|
8
|
-
const certifierPrivateKey = PrivateKey.fromRandom()
|
|
9
|
-
|
|
10
|
-
// A mock revocation outpoint for testing
|
|
11
|
-
const mockRevocationOutpoint =
|
|
12
|
-
'deadbeefdeadbeefdeadbeefdeadbeef00000000000000000000000000000000.1'
|
|
13
|
-
|
|
14
|
-
// Arbitrary certificate data (in plaintext)
|
|
15
|
-
const plaintextFields = {
|
|
16
|
-
name: 'Alice',
|
|
17
|
-
email: 'alice@example.com',
|
|
18
|
-
department: 'Engineering'
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
const subjectWallet = new CompletedProtoWallet(subjectPrivateKey)
|
|
22
|
-
const certifierWallet = new CompletedProtoWallet(certifierPrivateKey)
|
|
23
30
|
let subjectIdentityKey: string
|
|
24
31
|
let certifierIdentityKey: string
|
|
25
32
|
|
|
@@ -35,7 +42,7 @@ describe('MasterCertificate', () => {
|
|
|
35
42
|
describe('constructor', () => {
|
|
36
43
|
it('should construct a MasterCertificate successfully when masterKeyring is valid', () => {
|
|
37
44
|
// Prepare a minimal valid MasterCertificate
|
|
38
|
-
const fieldSymKey =
|
|
45
|
+
const fieldSymKey = fieldSymFixed1
|
|
39
46
|
const encryptedFieldValue = Utils.toBase64(
|
|
40
47
|
fieldSymKey.encrypt(Utils.toArray('Alice', 'utf8')) as number[]
|
|
41
48
|
)
|
|
@@ -129,7 +136,7 @@ describe('MasterCertificate', () => {
|
|
|
129
136
|
mockRevocationOutpoint,
|
|
130
137
|
{
|
|
131
138
|
name: Utils.toBase64(
|
|
132
|
-
|
|
139
|
+
fieldSymWrong.encrypt(
|
|
133
140
|
Utils.toArray('Alice', 'utf8')
|
|
134
141
|
) as number[]
|
|
135
142
|
)
|
|
@@ -149,7 +156,7 @@ describe('MasterCertificate', () => {
|
|
|
149
156
|
})
|
|
150
157
|
|
|
151
158
|
describe('createKeyringForVerifier (static)', () => {
|
|
152
|
-
const verifierPrivateKey =
|
|
159
|
+
const verifierPrivateKey = verifierKey2
|
|
153
160
|
const verifierWallet = new CompletedProtoWallet(verifierPrivateKey)
|
|
154
161
|
let verifierIdentityKey: string
|
|
155
162
|
|
|
@@ -350,7 +357,7 @@ describe('MasterCertificate', () => {
|
|
|
350
357
|
})
|
|
351
358
|
it('should allow issuing a self-signed certificate and decrypt it with the same wallet', async () => {
|
|
352
359
|
// In a self-signed scenario, the subject and certifier are the same
|
|
353
|
-
const subjectWallet = new CompletedProtoWallet(
|
|
360
|
+
const subjectWallet = new CompletedProtoWallet(subjectKey2)
|
|
354
361
|
|
|
355
362
|
// Some sample fields
|
|
356
363
|
const selfSignedFields = {
|
|
@@ -5,28 +5,31 @@ import { CompletedProtoWallet } from '../../../auth/certificates/__tests/Complet
|
|
|
5
5
|
import { MasterCertificate } from '../../../auth/certificates/MasterCertificate'
|
|
6
6
|
import { ProtoWallet, WalletCertificate } from '../../../wallet/index'
|
|
7
7
|
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
8
|
+
const subjectPrivateKey = new PrivateKey(21)
|
|
9
|
+
const subjectIdentityKey = subjectPrivateKey.toPublicKey().toString()
|
|
10
|
+
const certifierPrivateKey = new PrivateKey(22)
|
|
11
|
+
const certifierIdentityKey = certifierPrivateKey.toPublicKey().toString()
|
|
12
|
+
const verifierPrivateKey = new PrivateKey(23)
|
|
13
|
+
const verifierIdentityKey = verifierPrivateKey.toPublicKey().toString()
|
|
14
|
+
|
|
15
|
+
const wrongPrivateKey = new PrivateKey(31)
|
|
16
|
+
const wrongWallet = new CompletedProtoWallet(wrongPrivateKey)
|
|
17
|
+
|
|
18
|
+
const subjectWallet = new CompletedProtoWallet(subjectPrivateKey)
|
|
19
|
+
const verifierWallet = new CompletedProtoWallet(verifierPrivateKey)
|
|
20
|
+
|
|
21
|
+
const sampleType = Utils.toBase64(new Array(32).fill(1))
|
|
22
|
+
const sampleSerialNumber = Utils.toBase64(new Array(32).fill(2))
|
|
23
|
+
const sampleRevocationOutpoint =
|
|
24
|
+
'deadbeefdeadbeefdeadbeefdeadbeef00000000000000000000000000000000.1'
|
|
25
|
+
|
|
26
|
+
const plaintextFields = {
|
|
27
|
+
name: 'Alice',
|
|
28
|
+
email: 'alice@example.com',
|
|
29
|
+
organization: 'Example Corp'
|
|
30
|
+
}
|
|
29
31
|
|
|
32
|
+
describe('VerifiableCertificate', () => {
|
|
30
33
|
let verifiableCert: VerifiableCertificate
|
|
31
34
|
|
|
32
35
|
beforeEach(async () => {
|
|
@@ -79,9 +82,6 @@ describe('VerifiableCertificate', () => {
|
|
|
79
82
|
})
|
|
80
83
|
|
|
81
84
|
it('should fail if the verifier wallet does not have the correct private key (wrong key)', async () => {
|
|
82
|
-
const wrongPrivateKey = PrivateKey.fromRandom()
|
|
83
|
-
const wrongWallet = new CompletedProtoWallet(wrongPrivateKey)
|
|
84
|
-
|
|
85
85
|
await expect(verifiableCert.decryptFields(wrongWallet)).rejects.toThrow(
|
|
86
86
|
/Failed to decrypt selectively revealed certificate fields using keyring/
|
|
87
87
|
)
|
|
@@ -27,12 +27,9 @@ export type LookupAnswer =
|
|
|
27
27
|
outputs: Array<{
|
|
28
28
|
beef: number[]
|
|
29
29
|
outputIndex: number
|
|
30
|
+
context?: number[]
|
|
30
31
|
}>
|
|
31
32
|
}
|
|
32
|
-
| {
|
|
33
|
-
type: 'freeform'
|
|
34
|
-
result: unknown
|
|
35
|
-
}
|
|
36
33
|
|
|
37
34
|
/** Default SLAP trackers */
|
|
38
35
|
export const DEFAULT_SLAP_TRACKERS: string[] = [
|
|
@@ -200,11 +197,6 @@ export default class LookupResolver {
|
|
|
200
197
|
}
|
|
201
198
|
|
|
202
199
|
// Process the successful responses
|
|
203
|
-
if (successfulResponses[0].type === 'freeform') {
|
|
204
|
-
// Return the first freeform response
|
|
205
|
-
return successfulResponses[0]
|
|
206
|
-
}
|
|
207
|
-
|
|
208
200
|
// Aggregate outputs from all successful responses
|
|
209
201
|
const outputs = new Map<string, { beef: number[], outputIndex: number }>()
|
|
210
202
|
|
|
@@ -16,6 +16,7 @@ import OverlayAdminTokenTemplate from './OverlayAdminTokenTemplate.js'
|
|
|
16
16
|
export interface TaggedBEEF {
|
|
17
17
|
beef: number[]
|
|
18
18
|
topics: string[]
|
|
19
|
+
offChainValues?: number[]
|
|
19
20
|
}
|
|
20
21
|
|
|
21
22
|
/**
|
|
@@ -86,7 +87,6 @@ export class HTTPSOverlayBroadcastFacilitator implements OverlayBroadcastFacilit
|
|
|
86
87
|
}
|
|
87
88
|
|
|
88
89
|
async send (url: string, taggedBEEF: TaggedBEEF): Promise<STEAK> {
|
|
89
|
-
console.log(url)
|
|
90
90
|
if (!url.startsWith('https:') && !this.allowHTTP) {
|
|
91
91
|
throw new Error(
|
|
92
92
|
'HTTPS facilitator can only use URLs that start with "https:"'
|
|
@@ -164,7 +164,6 @@ export default class TopicBroadcaster implements Broadcaster {
|
|
|
164
164
|
)
|
|
165
165
|
}
|
|
166
166
|
const interestedHosts = await this.findInterestedHosts()
|
|
167
|
-
console.log(interestedHosts)
|
|
168
167
|
if (Object.keys(interestedHosts).length === 0) {
|
|
169
168
|
return {
|
|
170
169
|
status: 'error',
|
|
@@ -620,118 +620,6 @@ describe('LookupResolver', () => {
|
|
|
620
620
|
])
|
|
621
621
|
})
|
|
622
622
|
|
|
623
|
-
it('should handle hosts returning different response types', async () => {
|
|
624
|
-
const slapHostKey1 = new PrivateKey(42)
|
|
625
|
-
const slapWallet1 = new CompletedProtoWallet(slapHostKey1)
|
|
626
|
-
const slapLib1 = new OverlayAdminTokenTemplate(slapWallet1)
|
|
627
|
-
const slapScript1 = await slapLib1.lock(
|
|
628
|
-
'SLAP',
|
|
629
|
-
'https://slaphost1.com',
|
|
630
|
-
'ls_foo'
|
|
631
|
-
)
|
|
632
|
-
const slapTx1 = new Transaction(
|
|
633
|
-
1,
|
|
634
|
-
[],
|
|
635
|
-
[
|
|
636
|
-
{
|
|
637
|
-
lockingScript: slapScript1,
|
|
638
|
-
satoshis: 1
|
|
639
|
-
}
|
|
640
|
-
],
|
|
641
|
-
0
|
|
642
|
-
)
|
|
643
|
-
|
|
644
|
-
const slapHostKey2 = new PrivateKey(43)
|
|
645
|
-
const slapWallet2 = new CompletedProtoWallet(slapHostKey2)
|
|
646
|
-
const slapLib2 = new OverlayAdminTokenTemplate(slapWallet2)
|
|
647
|
-
const slapScript2 = await slapLib2.lock(
|
|
648
|
-
'SLAP',
|
|
649
|
-
'https://slaphost2.com',
|
|
650
|
-
'ls_foo'
|
|
651
|
-
)
|
|
652
|
-
const slapTx2 = new Transaction(
|
|
653
|
-
1,
|
|
654
|
-
[],
|
|
655
|
-
[
|
|
656
|
-
{
|
|
657
|
-
lockingScript: slapScript2,
|
|
658
|
-
satoshis: 1
|
|
659
|
-
}
|
|
660
|
-
],
|
|
661
|
-
0
|
|
662
|
-
)
|
|
663
|
-
|
|
664
|
-
// SLAP tracker returns two hosts
|
|
665
|
-
mockFacilitator.lookup.mockReturnValueOnce({
|
|
666
|
-
type: 'output-list',
|
|
667
|
-
outputs: [
|
|
668
|
-
{ outputIndex: 0, beef: slapTx1.toBEEF() },
|
|
669
|
-
{ outputIndex: 0, beef: slapTx2.toBEEF() }
|
|
670
|
-
]
|
|
671
|
-
})
|
|
672
|
-
|
|
673
|
-
// First host returns 'freeform' response
|
|
674
|
-
mockFacilitator.lookup.mockReturnValueOnce({
|
|
675
|
-
type: 'freeform',
|
|
676
|
-
result: { message: 'Freeform response from host1' }
|
|
677
|
-
})
|
|
678
|
-
|
|
679
|
-
// Second host returns 'output-list' response
|
|
680
|
-
mockFacilitator.lookup.mockReturnValueOnce({
|
|
681
|
-
type: 'output-list',
|
|
682
|
-
outputs: [{ beef: sampleBeef3, outputIndex: 0 }]
|
|
683
|
-
})
|
|
684
|
-
|
|
685
|
-
const r = new LookupResolver({
|
|
686
|
-
facilitator: mockFacilitator,
|
|
687
|
-
slapTrackers: ['https://mock.slap']
|
|
688
|
-
})
|
|
689
|
-
|
|
690
|
-
const res = await r.query({
|
|
691
|
-
service: 'ls_foo',
|
|
692
|
-
query: { test: 1 }
|
|
693
|
-
})
|
|
694
|
-
|
|
695
|
-
// Since the first response is 'freeform', it should return that response
|
|
696
|
-
expect(res).toEqual({
|
|
697
|
-
type: 'freeform',
|
|
698
|
-
result: { message: 'Freeform response from host1' }
|
|
699
|
-
})
|
|
700
|
-
|
|
701
|
-
expect(mockFacilitator.lookup.mock.calls).toEqual([
|
|
702
|
-
[
|
|
703
|
-
'https://mock.slap',
|
|
704
|
-
{
|
|
705
|
-
service: 'ls_slap',
|
|
706
|
-
query: {
|
|
707
|
-
service: 'ls_foo'
|
|
708
|
-
}
|
|
709
|
-
},
|
|
710
|
-
5000
|
|
711
|
-
],
|
|
712
|
-
[
|
|
713
|
-
'https://slaphost1.com',
|
|
714
|
-
{
|
|
715
|
-
service: 'ls_foo',
|
|
716
|
-
query: {
|
|
717
|
-
test: 1
|
|
718
|
-
}
|
|
719
|
-
},
|
|
720
|
-
undefined
|
|
721
|
-
],
|
|
722
|
-
[
|
|
723
|
-
'https://slaphost2.com',
|
|
724
|
-
{
|
|
725
|
-
service: 'ls_foo',
|
|
726
|
-
query: {
|
|
727
|
-
test: 1
|
|
728
|
-
}
|
|
729
|
-
},
|
|
730
|
-
undefined
|
|
731
|
-
]
|
|
732
|
-
])
|
|
733
|
-
})
|
|
734
|
-
|
|
735
623
|
it('should ignore freeform responses when first response is output-list', async () => {
|
|
736
624
|
const slapHostKey1 = new PrivateKey(42)
|
|
737
625
|
const slapWallet1 = new CompletedProtoWallet(slapHostKey1)
|