@buildonspark/spark-sdk 0.3.7 → 0.3.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (84) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/dist/bare/index.cjs +8359 -7810
  3. package/dist/bare/index.d.cts +260 -208
  4. package/dist/bare/index.d.ts +260 -208
  5. package/dist/bare/index.js +8241 -7689
  6. package/dist/{chunk-P4HYYSMU.js → chunk-3LPEQGVJ.js} +1 -1
  7. package/dist/{chunk-J2P3KTQP.js → chunk-5ASXVNTM.js} +1 -1
  8. package/dist/{chunk-UYTT3C6H.js → chunk-5HU5W56H.js} +40 -213
  9. package/dist/{chunk-KDEVNW7C.js → chunk-FP2CRVQH.js} +3256 -2714
  10. package/dist/{chunk-SRPKOCG4.js → chunk-FXIESWE6.js} +8 -10
  11. package/dist/{chunk-IC4IUEOS.js → chunk-VFN34EOX.js} +56 -43
  12. package/dist/{chunk-XWLR6G5C.js → chunk-XI6FCNYG.js} +1 -1
  13. package/dist/{client-D9T58OY8.d.ts → client-By-N7oJS.d.ts} +2 -2
  14. package/dist/{client-Bcb7TUIp.d.cts → client-pNpGP15j.d.cts} +2 -2
  15. package/dist/debug.cjs +8371 -7822
  16. package/dist/debug.d.cts +12 -8
  17. package/dist/debug.d.ts +12 -8
  18. package/dist/debug.js +5 -5
  19. package/dist/graphql/objects/index.d.cts +3 -3
  20. package/dist/graphql/objects/index.d.ts +3 -3
  21. package/dist/index.cjs +6990 -6438
  22. package/dist/index.d.cts +8 -7
  23. package/dist/index.d.ts +8 -7
  24. package/dist/index.js +12 -6
  25. package/dist/index.node.cjs +6515 -6134
  26. package/dist/index.node.d.cts +8 -7
  27. package/dist/index.node.d.ts +8 -7
  28. package/dist/index.node.js +11 -5
  29. package/dist/{logging-JIaZZIbR.d.ts → logging-DMFVY384.d.ts} +10 -4
  30. package/dist/{logging-zkr4UlOi.d.cts → logging-DxLp34Xm.d.cts} +10 -4
  31. package/dist/native/{chunk-X2QXUON7.js → chunk-AFP5QR4O.js} +11 -8
  32. package/dist/native/index.react-native.cjs +6981 -6422
  33. package/dist/native/index.react-native.d.cts +91 -39
  34. package/dist/native/index.react-native.d.ts +91 -39
  35. package/dist/native/index.react-native.js +6925 -6366
  36. package/dist/native/{wasm-GKEDPGTM.js → wasm-D4TI35NF.js} +1 -1
  37. package/dist/proto/spark.cjs +56 -43
  38. package/dist/proto/spark.d.cts +1 -1
  39. package/dist/proto/spark.d.ts +1 -1
  40. package/dist/proto/spark.js +1 -1
  41. package/dist/proto/spark_token.d.cts +1 -1
  42. package/dist/proto/spark_token.d.ts +1 -1
  43. package/dist/proto/spark_token.js +2 -2
  44. package/dist/{spark-WA_4wcBr.d.cts → spark-By6yHsrk.d.cts} +31 -6
  45. package/dist/{spark-WA_4wcBr.d.ts → spark-By6yHsrk.d.ts} +31 -6
  46. package/dist/{spark-wallet.browser-BwYkkOBU.d.ts → spark-wallet.browser-C1dQknVj.d.ts} +8 -8
  47. package/dist/{spark-wallet.browser-DC3jdQPW.d.cts → spark-wallet.browser-CNMo3IvO.d.cts} +8 -8
  48. package/dist/{spark-wallet.node-CR_zNxmy.d.cts → spark-wallet.node-BZJhJZKq.d.cts} +9 -31
  49. package/dist/{spark-wallet.node-C9d2W-Nb.d.ts → spark-wallet.node-Og6__NMh.d.ts} +9 -31
  50. package/dist/tests/test-utils.cjs +8466 -8080
  51. package/dist/tests/test-utils.d.cts +7 -5
  52. package/dist/tests/test-utils.d.ts +7 -5
  53. package/dist/tests/test-utils.js +7 -7
  54. package/dist/{token-transactions-BZoJuvuE.d.ts → token-transactions-C7yefB2S.d.ts} +2 -2
  55. package/dist/{token-transactions-I_OFIoNH.d.cts → token-transactions-CLR3rnYi.d.cts} +2 -2
  56. package/dist/types/index.cjs +56 -43
  57. package/dist/types/index.d.cts +2 -2
  58. package/dist/types/index.d.ts +2 -2
  59. package/dist/types/index.js +2 -2
  60. package/dist/{spark-wallet-CE5PYiIb.d.ts → wallet-config-BoyMVa6n.d.ts} +290 -265
  61. package/dist/{spark-wallet-BuFrUWeE.d.cts → wallet-config-xom-9UFF.d.cts} +290 -265
  62. package/package.json +3 -3
  63. package/src/proto/mock.ts +0 -264
  64. package/src/proto/spark.ts +94 -51
  65. package/src/services/config.ts +5 -0
  66. package/src/services/connection/connection.browser.ts +27 -19
  67. package/src/services/connection/connection.node.ts +79 -24
  68. package/src/services/connection/connection.ts +395 -233
  69. package/src/services/lightning.ts +30 -4
  70. package/src/services/signing.ts +137 -0
  71. package/src/services/transfer.ts +116 -1
  72. package/src/services/wallet-config.ts +6 -0
  73. package/src/spark-wallet/proto-descriptors.ts +1 -1
  74. package/src/spark-wallet/spark-wallet.ts +70 -76
  75. package/src/spark_descriptors.pb +0 -0
  76. package/src/tests/connection.test.ts +537 -0
  77. package/src/tests/integration/connection.test.ts +39 -0
  78. package/src/tests/integration/lightning.test.ts +25 -11
  79. package/src/tests/integration/static_deposit.test.ts +11 -10
  80. package/src/tests/integration/transfer.test.ts +13 -1
  81. package/src/tests/isHermeticTest.ts +1 -1
  82. package/src/tests/utils/test-faucet.ts +53 -20
  83. package/src/utils/htlc-transactions.ts +224 -0
  84. package/src/utils/transaction.ts +36 -0
package/src/proto/mock.ts CHANGED
@@ -15,53 +15,6 @@ export interface CleanUpPreimageShareRequest {
15
15
  paymentHash: Uint8Array;
16
16
  }
17
17
 
18
- export interface InterruptTransferRequest {
19
- action: InterruptTransferRequest_InterruptTransferAction;
20
- }
21
-
22
- export enum InterruptTransferRequest_InterruptTransferAction {
23
- NONE = 0,
24
- INTERRUPT = 1,
25
- RESUME = 2,
26
- UNRECOGNIZED = -1,
27
- }
28
-
29
- export function interruptTransferRequest_InterruptTransferActionFromJSON(
30
- object: any,
31
- ): InterruptTransferRequest_InterruptTransferAction {
32
- switch (object) {
33
- case 0:
34
- case "NONE":
35
- return InterruptTransferRequest_InterruptTransferAction.NONE;
36
- case 1:
37
- case "INTERRUPT":
38
- return InterruptTransferRequest_InterruptTransferAction.INTERRUPT;
39
- case 2:
40
- case "RESUME":
41
- return InterruptTransferRequest_InterruptTransferAction.RESUME;
42
- case -1:
43
- case "UNRECOGNIZED":
44
- default:
45
- return InterruptTransferRequest_InterruptTransferAction.UNRECOGNIZED;
46
- }
47
- }
48
-
49
- export function interruptTransferRequest_InterruptTransferActionToJSON(
50
- object: InterruptTransferRequest_InterruptTransferAction,
51
- ): string {
52
- switch (object) {
53
- case InterruptTransferRequest_InterruptTransferAction.NONE:
54
- return "NONE";
55
- case InterruptTransferRequest_InterruptTransferAction.INTERRUPT:
56
- return "INTERRUPT";
57
- case InterruptTransferRequest_InterruptTransferAction.RESUME:
58
- return "RESUME";
59
- case InterruptTransferRequest_InterruptTransferAction.UNRECOGNIZED:
60
- default:
61
- return "UNRECOGNIZED";
62
- }
63
- }
64
-
65
18
  export interface UpdateNodesStatusRequest {
66
19
  nodeIds: string[];
67
20
  status: string;
@@ -72,55 +25,6 @@ export interface TriggerTaskRequest {
72
25
  taskName: string;
73
26
  }
74
27
 
75
- export interface InterruptCoopExitRequest {
76
- action: InterruptCoopExitRequest_InterruptCoopExitAction;
77
- /** optional, defaults to MockAction.TargetOperatorID */
78
- targetOperator: string;
79
- }
80
-
81
- export enum InterruptCoopExitRequest_InterruptCoopExitAction {
82
- NONE = 0,
83
- INTERRUPT = 1,
84
- RESUME = 2,
85
- UNRECOGNIZED = -1,
86
- }
87
-
88
- export function interruptCoopExitRequest_InterruptCoopExitActionFromJSON(
89
- object: any,
90
- ): InterruptCoopExitRequest_InterruptCoopExitAction {
91
- switch (object) {
92
- case 0:
93
- case "NONE":
94
- return InterruptCoopExitRequest_InterruptCoopExitAction.NONE;
95
- case 1:
96
- case "INTERRUPT":
97
- return InterruptCoopExitRequest_InterruptCoopExitAction.INTERRUPT;
98
- case 2:
99
- case "RESUME":
100
- return InterruptCoopExitRequest_InterruptCoopExitAction.RESUME;
101
- case -1:
102
- case "UNRECOGNIZED":
103
- default:
104
- return InterruptCoopExitRequest_InterruptCoopExitAction.UNRECOGNIZED;
105
- }
106
- }
107
-
108
- export function interruptCoopExitRequest_InterruptCoopExitActionToJSON(
109
- object: InterruptCoopExitRequest_InterruptCoopExitAction,
110
- ): string {
111
- switch (object) {
112
- case InterruptCoopExitRequest_InterruptCoopExitAction.NONE:
113
- return "NONE";
114
- case InterruptCoopExitRequest_InterruptCoopExitAction.INTERRUPT:
115
- return "INTERRUPT";
116
- case InterruptCoopExitRequest_InterruptCoopExitAction.RESUME:
117
- return "RESUME";
118
- case InterruptCoopExitRequest_InterruptCoopExitAction.UNRECOGNIZED:
119
- default:
120
- return "UNRECOGNIZED";
121
- }
122
- }
123
-
124
28
  function createBaseCleanUpPreimageShareRequest(): CleanUpPreimageShareRequest {
125
29
  return { paymentHash: new Uint8Array(0) };
126
30
  }
@@ -179,66 +83,6 @@ export const CleanUpPreimageShareRequest: MessageFns<CleanUpPreimageShareRequest
179
83
  },
180
84
  };
181
85
 
182
- function createBaseInterruptTransferRequest(): InterruptTransferRequest {
183
- return { action: 0 };
184
- }
185
-
186
- export const InterruptTransferRequest: MessageFns<InterruptTransferRequest> = {
187
- encode(message: InterruptTransferRequest, writer: BinaryWriter = new BinaryWriter()): BinaryWriter {
188
- if (message.action !== 0) {
189
- writer.uint32(8).int32(message.action);
190
- }
191
- return writer;
192
- },
193
-
194
- decode(input: BinaryReader | Uint8Array, length?: number): InterruptTransferRequest {
195
- const reader = input instanceof BinaryReader ? input : new BinaryReader(input);
196
- const end = length === undefined ? reader.len : reader.pos + length;
197
- const message = createBaseInterruptTransferRequest();
198
- while (reader.pos < end) {
199
- const tag = reader.uint32();
200
- switch (tag >>> 3) {
201
- case 1: {
202
- if (tag !== 8) {
203
- break;
204
- }
205
-
206
- message.action = reader.int32() as any;
207
- continue;
208
- }
209
- }
210
- if ((tag & 7) === 4 || tag === 0) {
211
- break;
212
- }
213
- reader.skip(tag & 7);
214
- }
215
- return message;
216
- },
217
-
218
- fromJSON(object: any): InterruptTransferRequest {
219
- return {
220
- action: isSet(object.action) ? interruptTransferRequest_InterruptTransferActionFromJSON(object.action) : 0,
221
- };
222
- },
223
-
224
- toJSON(message: InterruptTransferRequest): unknown {
225
- const obj: any = {};
226
- if (message.action !== 0) {
227
- obj.action = interruptTransferRequest_InterruptTransferActionToJSON(message.action);
228
- }
229
- return obj;
230
- },
231
-
232
- create(base?: DeepPartial<InterruptTransferRequest>): InterruptTransferRequest {
233
- return InterruptTransferRequest.fromPartial(base ?? {});
234
- },
235
- fromPartial(object: DeepPartial<InterruptTransferRequest>): InterruptTransferRequest {
236
- const message = createBaseInterruptTransferRequest();
237
- message.action = object.action ?? 0;
238
- return message;
239
- },
240
- };
241
-
242
86
  function createBaseUpdateNodesStatusRequest(): UpdateNodesStatusRequest {
243
87
  return { nodeIds: [], status: "" };
244
88
  }
@@ -373,82 +217,6 @@ export const TriggerTaskRequest: MessageFns<TriggerTaskRequest> = {
373
217
  },
374
218
  };
375
219
 
376
- function createBaseInterruptCoopExitRequest(): InterruptCoopExitRequest {
377
- return { action: 0, targetOperator: "" };
378
- }
379
-
380
- export const InterruptCoopExitRequest: MessageFns<InterruptCoopExitRequest> = {
381
- encode(message: InterruptCoopExitRequest, writer: BinaryWriter = new BinaryWriter()): BinaryWriter {
382
- if (message.action !== 0) {
383
- writer.uint32(8).int32(message.action);
384
- }
385
- if (message.targetOperator !== "") {
386
- writer.uint32(18).string(message.targetOperator);
387
- }
388
- return writer;
389
- },
390
-
391
- decode(input: BinaryReader | Uint8Array, length?: number): InterruptCoopExitRequest {
392
- const reader = input instanceof BinaryReader ? input : new BinaryReader(input);
393
- const end = length === undefined ? reader.len : reader.pos + length;
394
- const message = createBaseInterruptCoopExitRequest();
395
- while (reader.pos < end) {
396
- const tag = reader.uint32();
397
- switch (tag >>> 3) {
398
- case 1: {
399
- if (tag !== 8) {
400
- break;
401
- }
402
-
403
- message.action = reader.int32() as any;
404
- continue;
405
- }
406
- case 2: {
407
- if (tag !== 18) {
408
- break;
409
- }
410
-
411
- message.targetOperator = reader.string();
412
- continue;
413
- }
414
- }
415
- if ((tag & 7) === 4 || tag === 0) {
416
- break;
417
- }
418
- reader.skip(tag & 7);
419
- }
420
- return message;
421
- },
422
-
423
- fromJSON(object: any): InterruptCoopExitRequest {
424
- return {
425
- action: isSet(object.action) ? interruptCoopExitRequest_InterruptCoopExitActionFromJSON(object.action) : 0,
426
- targetOperator: isSet(object.targetOperator) ? globalThis.String(object.targetOperator) : "",
427
- };
428
- },
429
-
430
- toJSON(message: InterruptCoopExitRequest): unknown {
431
- const obj: any = {};
432
- if (message.action !== 0) {
433
- obj.action = interruptCoopExitRequest_InterruptCoopExitActionToJSON(message.action);
434
- }
435
- if (message.targetOperator !== "") {
436
- obj.targetOperator = message.targetOperator;
437
- }
438
- return obj;
439
- },
440
-
441
- create(base?: DeepPartial<InterruptCoopExitRequest>): InterruptCoopExitRequest {
442
- return InterruptCoopExitRequest.fromPartial(base ?? {});
443
- },
444
- fromPartial(object: DeepPartial<InterruptCoopExitRequest>): InterruptCoopExitRequest {
445
- const message = createBaseInterruptCoopExitRequest();
446
- message.action = object.action ?? 0;
447
- message.targetOperator = object.targetOperator ?? "";
448
- return message;
449
- },
450
- };
451
-
452
220
  export type MockServiceDefinition = typeof MockServiceDefinition;
453
221
  export const MockServiceDefinition = {
454
222
  name: "MockService",
@@ -462,22 +230,6 @@ export const MockServiceDefinition = {
462
230
  responseStream: false,
463
231
  options: {},
464
232
  },
465
- interrupt_transfer: {
466
- name: "interrupt_transfer",
467
- requestType: InterruptTransferRequest,
468
- requestStream: false,
469
- responseType: Empty,
470
- responseStream: false,
471
- options: {},
472
- },
473
- interrupt_coop_exit: {
474
- name: "interrupt_coop_exit",
475
- requestType: InterruptCoopExitRequest,
476
- requestStream: false,
477
- responseType: Empty,
478
- responseStream: false,
479
- options: {},
480
- },
481
233
  update_nodes_status: {
482
234
  name: "update_nodes_status",
483
235
  requestType: UpdateNodesStatusRequest,
@@ -503,14 +255,6 @@ export interface MockServiceImplementation<CallContextExt = {}> {
503
255
  request: CleanUpPreimageShareRequest,
504
256
  context: CallContext & CallContextExt,
505
257
  ): Promise<DeepPartial<Empty>>;
506
- interrupt_transfer(
507
- request: InterruptTransferRequest,
508
- context: CallContext & CallContextExt,
509
- ): Promise<DeepPartial<Empty>>;
510
- interrupt_coop_exit(
511
- request: InterruptCoopExitRequest,
512
- context: CallContext & CallContextExt,
513
- ): Promise<DeepPartial<Empty>>;
514
258
  update_nodes_status(
515
259
  request: UpdateNodesStatusRequest,
516
260
  context: CallContext & CallContextExt,
@@ -524,14 +268,6 @@ export interface MockServiceClient<CallOptionsExt = {}> {
524
268
  request: DeepPartial<CleanUpPreimageShareRequest>,
525
269
  options?: CallOptions & CallOptionsExt,
526
270
  ): Promise<Empty>;
527
- interrupt_transfer(
528
- request: DeepPartial<InterruptTransferRequest>,
529
- options?: CallOptions & CallOptionsExt,
530
- ): Promise<Empty>;
531
- interrupt_coop_exit(
532
- request: DeepPartial<InterruptCoopExitRequest>,
533
- options?: CallOptions & CallOptionsExt,
534
- ): Promise<Empty>;
535
271
  update_nodes_status(
536
272
  request: DeepPartial<UpdateNodesStatusRequest>,
537
273
  options?: CallOptions & CallOptionsExt,
@@ -628,7 +628,6 @@ export interface SigningResult_SignatureSharesEntry {
628
628
 
629
629
  export interface RenewLeafRequest {
630
630
  leafId: string;
631
- ownerIdentityPublicKey: Uint8Array;
632
631
  signingJobs?:
633
632
  | //
634
633
  /**
@@ -694,9 +693,9 @@ export interface RenewRefundTimelockSigningJob {
694
693
  }
695
694
 
696
695
  export interface RenewLeafResponse {
697
- renewResult?: { $case: "extendResult"; extendResult: RenewNodeTimelockResult } | {
698
- $case: "refreshResult";
699
- refreshResult: RenewRefundTimelockResult;
696
+ renewResult?: { $case: "renewNodeTimelockResult"; renewNodeTimelockResult: RenewNodeTimelockResult } | {
697
+ $case: "renewRefundTimelockResult";
698
+ renewRefundTimelockResult: RenewRefundTimelockResult;
700
699
  } | undefined;
701
700
  }
702
701
 
@@ -1378,15 +1377,28 @@ export interface RequestedSigningCommitments_SigningNonceCommitmentsEntry {
1378
1377
  }
1379
1378
 
1380
1379
  export interface GetSigningCommitmentsRequest {
1380
+ /** The node IDs for which to get signing commitments. */
1381
1381
  nodeIds: string[];
1382
+ /** The number of signing commitments to get per node ID. */
1382
1383
  count: number;
1383
1384
  }
1384
1385
 
1385
1386
  export interface GetSigningCommitmentsResponse {
1387
+ /**
1388
+ * A list of signing commitments for each requested node ID. The signing commitments will be
1389
+ * ordered in the same order as the requested node IDs, repeated for the number of commitments
1390
+ * requested. For example, if node_ids = [A, B] and count = 2, the response will contain:
1391
+ *
1392
+ * [commitment_A1, commitment_B1, commitment_A2, commitment_B2]
1393
+ */
1386
1394
  signingCommitments: RequestedSigningCommitments[];
1387
1395
  }
1388
1396
 
1389
1397
  export interface SigningCommitments {
1398
+ /**
1399
+ * A map of signing operator ID (i.e. 000...01) to the signing commitment provided by that
1400
+ * operator.
1401
+ */
1390
1402
  signingCommitments: { [key: string]: SigningCommitment };
1391
1403
  }
1392
1404
 
@@ -1420,6 +1432,7 @@ export interface InitiatePreimageSwapRequest {
1420
1432
  transfer: StartUserSignedTransferRequest | undefined;
1421
1433
  receiverIdentityPublicKey: Uint8Array;
1422
1434
  feeSats: number;
1435
+ transferRequest: StartTransferRequest | undefined;
1423
1436
  }
1424
1437
 
1425
1438
  export enum InitiatePreimageSwapRequest_Reason {
@@ -4026,7 +4039,7 @@ export const SigningResult_SignatureSharesEntry: MessageFns<SigningResult_Signat
4026
4039
  };
4027
4040
 
4028
4041
  function createBaseRenewLeafRequest(): RenewLeafRequest {
4029
- return { leafId: "", ownerIdentityPublicKey: new Uint8Array(0), signingJobs: undefined };
4042
+ return { leafId: "", signingJobs: undefined };
4030
4043
  }
4031
4044
 
4032
4045
  export const RenewLeafRequest: MessageFns<RenewLeafRequest> = {
@@ -4034,18 +4047,15 @@ export const RenewLeafRequest: MessageFns<RenewLeafRequest> = {
4034
4047
  if (message.leafId !== "") {
4035
4048
  writer.uint32(10).string(message.leafId);
4036
4049
  }
4037
- if (message.ownerIdentityPublicKey.length !== 0) {
4038
- writer.uint32(18).bytes(message.ownerIdentityPublicKey);
4039
- }
4040
4050
  switch (message.signingJobs?.$case) {
4041
4051
  case "renewNodeTimelockSigningJob":
4042
- RenewNodeTimelockSigningJob.encode(message.signingJobs.renewNodeTimelockSigningJob, writer.uint32(26).fork())
4052
+ RenewNodeTimelockSigningJob.encode(message.signingJobs.renewNodeTimelockSigningJob, writer.uint32(18).fork())
4043
4053
  .join();
4044
4054
  break;
4045
4055
  case "renewRefundTimelockSigningJob":
4046
4056
  RenewRefundTimelockSigningJob.encode(
4047
4057
  message.signingJobs.renewRefundTimelockSigningJob,
4048
- writer.uint32(34).fork(),
4058
+ writer.uint32(26).fork(),
4049
4059
  ).join();
4050
4060
  break;
4051
4061
  }
@@ -4072,22 +4082,14 @@ export const RenewLeafRequest: MessageFns<RenewLeafRequest> = {
4072
4082
  break;
4073
4083
  }
4074
4084
 
4075
- message.ownerIdentityPublicKey = reader.bytes();
4076
- continue;
4077
- }
4078
- case 3: {
4079
- if (tag !== 26) {
4080
- break;
4081
- }
4082
-
4083
4085
  message.signingJobs = {
4084
4086
  $case: "renewNodeTimelockSigningJob",
4085
4087
  renewNodeTimelockSigningJob: RenewNodeTimelockSigningJob.decode(reader, reader.uint32()),
4086
4088
  };
4087
4089
  continue;
4088
4090
  }
4089
- case 4: {
4090
- if (tag !== 34) {
4091
+ case 3: {
4092
+ if (tag !== 26) {
4091
4093
  break;
4092
4094
  }
4093
4095
 
@@ -4109,9 +4111,6 @@ export const RenewLeafRequest: MessageFns<RenewLeafRequest> = {
4109
4111
  fromJSON(object: any): RenewLeafRequest {
4110
4112
  return {
4111
4113
  leafId: isSet(object.leafId) ? globalThis.String(object.leafId) : "",
4112
- ownerIdentityPublicKey: isSet(object.ownerIdentityPublicKey)
4113
- ? bytesFromBase64(object.ownerIdentityPublicKey)
4114
- : new Uint8Array(0),
4115
4114
  signingJobs: isSet(object.renewNodeTimelockSigningJob)
4116
4115
  ? {
4117
4116
  $case: "renewNodeTimelockSigningJob",
@@ -4131,9 +4130,6 @@ export const RenewLeafRequest: MessageFns<RenewLeafRequest> = {
4131
4130
  if (message.leafId !== "") {
4132
4131
  obj.leafId = message.leafId;
4133
4132
  }
4134
- if (message.ownerIdentityPublicKey.length !== 0) {
4135
- obj.ownerIdentityPublicKey = base64FromBytes(message.ownerIdentityPublicKey);
4136
- }
4137
4133
  if (message.signingJobs?.$case === "renewNodeTimelockSigningJob") {
4138
4134
  obj.renewNodeTimelockSigningJob = RenewNodeTimelockSigningJob.toJSON(
4139
4135
  message.signingJobs.renewNodeTimelockSigningJob,
@@ -4152,7 +4148,6 @@ export const RenewLeafRequest: MessageFns<RenewLeafRequest> = {
4152
4148
  fromPartial(object: DeepPartial<RenewLeafRequest>): RenewLeafRequest {
4153
4149
  const message = createBaseRenewLeafRequest();
4154
4150
  message.leafId = object.leafId ?? "";
4155
- message.ownerIdentityPublicKey = object.ownerIdentityPublicKey ?? new Uint8Array(0);
4156
4151
  switch (object.signingJobs?.$case) {
4157
4152
  case "renewNodeTimelockSigningJob": {
4158
4153
  if (
@@ -4544,11 +4539,12 @@ function createBaseRenewLeafResponse(): RenewLeafResponse {
4544
4539
  export const RenewLeafResponse: MessageFns<RenewLeafResponse> = {
4545
4540
  encode(message: RenewLeafResponse, writer: BinaryWriter = new BinaryWriter()): BinaryWriter {
4546
4541
  switch (message.renewResult?.$case) {
4547
- case "extendResult":
4548
- RenewNodeTimelockResult.encode(message.renewResult.extendResult, writer.uint32(10).fork()).join();
4542
+ case "renewNodeTimelockResult":
4543
+ RenewNodeTimelockResult.encode(message.renewResult.renewNodeTimelockResult, writer.uint32(10).fork()).join();
4549
4544
  break;
4550
- case "refreshResult":
4551
- RenewRefundTimelockResult.encode(message.renewResult.refreshResult, writer.uint32(18).fork()).join();
4545
+ case "renewRefundTimelockResult":
4546
+ RenewRefundTimelockResult.encode(message.renewResult.renewRefundTimelockResult, writer.uint32(18).fork())
4547
+ .join();
4552
4548
  break;
4553
4549
  }
4554
4550
  return writer;
@@ -4567,8 +4563,8 @@ export const RenewLeafResponse: MessageFns<RenewLeafResponse> = {
4567
4563
  }
4568
4564
 
4569
4565
  message.renewResult = {
4570
- $case: "extendResult",
4571
- extendResult: RenewNodeTimelockResult.decode(reader, reader.uint32()),
4566
+ $case: "renewNodeTimelockResult",
4567
+ renewNodeTimelockResult: RenewNodeTimelockResult.decode(reader, reader.uint32()),
4572
4568
  };
4573
4569
  continue;
4574
4570
  }
@@ -4578,8 +4574,8 @@ export const RenewLeafResponse: MessageFns<RenewLeafResponse> = {
4578
4574
  }
4579
4575
 
4580
4576
  message.renewResult = {
4581
- $case: "refreshResult",
4582
- refreshResult: RenewRefundTimelockResult.decode(reader, reader.uint32()),
4577
+ $case: "renewRefundTimelockResult",
4578
+ renewRefundTimelockResult: RenewRefundTimelockResult.decode(reader, reader.uint32()),
4583
4579
  };
4584
4580
  continue;
4585
4581
  }
@@ -4594,20 +4590,26 @@ export const RenewLeafResponse: MessageFns<RenewLeafResponse> = {
4594
4590
 
4595
4591
  fromJSON(object: any): RenewLeafResponse {
4596
4592
  return {
4597
- renewResult: isSet(object.extendResult)
4598
- ? { $case: "extendResult", extendResult: RenewNodeTimelockResult.fromJSON(object.extendResult) }
4599
- : isSet(object.refreshResult)
4600
- ? { $case: "refreshResult", refreshResult: RenewRefundTimelockResult.fromJSON(object.refreshResult) }
4593
+ renewResult: isSet(object.renewNodeTimelockResult)
4594
+ ? {
4595
+ $case: "renewNodeTimelockResult",
4596
+ renewNodeTimelockResult: RenewNodeTimelockResult.fromJSON(object.renewNodeTimelockResult),
4597
+ }
4598
+ : isSet(object.renewRefundTimelockResult)
4599
+ ? {
4600
+ $case: "renewRefundTimelockResult",
4601
+ renewRefundTimelockResult: RenewRefundTimelockResult.fromJSON(object.renewRefundTimelockResult),
4602
+ }
4601
4603
  : undefined,
4602
4604
  };
4603
4605
  },
4604
4606
 
4605
4607
  toJSON(message: RenewLeafResponse): unknown {
4606
4608
  const obj: any = {};
4607
- if (message.renewResult?.$case === "extendResult") {
4608
- obj.extendResult = RenewNodeTimelockResult.toJSON(message.renewResult.extendResult);
4609
- } else if (message.renewResult?.$case === "refreshResult") {
4610
- obj.refreshResult = RenewRefundTimelockResult.toJSON(message.renewResult.refreshResult);
4609
+ if (message.renewResult?.$case === "renewNodeTimelockResult") {
4610
+ obj.renewNodeTimelockResult = RenewNodeTimelockResult.toJSON(message.renewResult.renewNodeTimelockResult);
4611
+ } else if (message.renewResult?.$case === "renewRefundTimelockResult") {
4612
+ obj.renewRefundTimelockResult = RenewRefundTimelockResult.toJSON(message.renewResult.renewRefundTimelockResult);
4611
4613
  }
4612
4614
  return obj;
4613
4615
  },
@@ -4618,20 +4620,28 @@ export const RenewLeafResponse: MessageFns<RenewLeafResponse> = {
4618
4620
  fromPartial(object: DeepPartial<RenewLeafResponse>): RenewLeafResponse {
4619
4621
  const message = createBaseRenewLeafResponse();
4620
4622
  switch (object.renewResult?.$case) {
4621
- case "extendResult": {
4622
- if (object.renewResult?.extendResult !== undefined && object.renewResult?.extendResult !== null) {
4623
+ case "renewNodeTimelockResult": {
4624
+ if (
4625
+ object.renewResult?.renewNodeTimelockResult !== undefined &&
4626
+ object.renewResult?.renewNodeTimelockResult !== null
4627
+ ) {
4623
4628
  message.renewResult = {
4624
- $case: "extendResult",
4625
- extendResult: RenewNodeTimelockResult.fromPartial(object.renewResult.extendResult),
4629
+ $case: "renewNodeTimelockResult",
4630
+ renewNodeTimelockResult: RenewNodeTimelockResult.fromPartial(object.renewResult.renewNodeTimelockResult),
4626
4631
  };
4627
4632
  }
4628
4633
  break;
4629
4634
  }
4630
- case "refreshResult": {
4631
- if (object.renewResult?.refreshResult !== undefined && object.renewResult?.refreshResult !== null) {
4635
+ case "renewRefundTimelockResult": {
4636
+ if (
4637
+ object.renewResult?.renewRefundTimelockResult !== undefined &&
4638
+ object.renewResult?.renewRefundTimelockResult !== null
4639
+ ) {
4632
4640
  message.renewResult = {
4633
- $case: "refreshResult",
4634
- refreshResult: RenewRefundTimelockResult.fromPartial(object.renewResult.refreshResult),
4641
+ $case: "renewRefundTimelockResult",
4642
+ renewRefundTimelockResult: RenewRefundTimelockResult.fromPartial(
4643
+ object.renewResult.renewRefundTimelockResult,
4644
+ ),
4635
4645
  };
4636
4646
  }
4637
4647
  break;
@@ -12972,6 +12982,7 @@ function createBaseInitiatePreimageSwapRequest(): InitiatePreimageSwapRequest {
12972
12982
  transfer: undefined,
12973
12983
  receiverIdentityPublicKey: new Uint8Array(0),
12974
12984
  feeSats: 0,
12985
+ transferRequest: undefined,
12975
12986
  };
12976
12987
  }
12977
12988
 
@@ -12995,6 +13006,9 @@ export const InitiatePreimageSwapRequest: MessageFns<InitiatePreimageSwapRequest
12995
13006
  if (message.feeSats !== 0) {
12996
13007
  writer.uint32(48).uint64(message.feeSats);
12997
13008
  }
13009
+ if (message.transferRequest !== undefined) {
13010
+ StartTransferRequest.encode(message.transferRequest, writer.uint32(58).fork()).join();
13011
+ }
12998
13012
  return writer;
12999
13013
  },
13000
13014
 
@@ -13053,6 +13067,14 @@ export const InitiatePreimageSwapRequest: MessageFns<InitiatePreimageSwapRequest
13053
13067
  message.feeSats = longToNumber(reader.uint64());
13054
13068
  continue;
13055
13069
  }
13070
+ case 7: {
13071
+ if (tag !== 58) {
13072
+ break;
13073
+ }
13074
+
13075
+ message.transferRequest = StartTransferRequest.decode(reader, reader.uint32());
13076
+ continue;
13077
+ }
13056
13078
  }
13057
13079
  if ((tag & 7) === 4 || tag === 0) {
13058
13080
  break;
@@ -13072,6 +13094,9 @@ export const InitiatePreimageSwapRequest: MessageFns<InitiatePreimageSwapRequest
13072
13094
  ? bytesFromBase64(object.receiverIdentityPublicKey)
13073
13095
  : new Uint8Array(0),
13074
13096
  feeSats: isSet(object.feeSats) ? globalThis.Number(object.feeSats) : 0,
13097
+ transferRequest: isSet(object.transferRequest)
13098
+ ? StartTransferRequest.fromJSON(object.transferRequest)
13099
+ : undefined,
13075
13100
  };
13076
13101
  },
13077
13102
 
@@ -13095,6 +13120,9 @@ export const InitiatePreimageSwapRequest: MessageFns<InitiatePreimageSwapRequest
13095
13120
  if (message.feeSats !== 0) {
13096
13121
  obj.feeSats = Math.round(message.feeSats);
13097
13122
  }
13123
+ if (message.transferRequest !== undefined) {
13124
+ obj.transferRequest = StartTransferRequest.toJSON(message.transferRequest);
13125
+ }
13098
13126
  return obj;
13099
13127
  },
13100
13128
 
@@ -13113,6 +13141,9 @@ export const InitiatePreimageSwapRequest: MessageFns<InitiatePreimageSwapRequest
13113
13141
  : undefined;
13114
13142
  message.receiverIdentityPublicKey = object.receiverIdentityPublicKey ?? new Uint8Array(0);
13115
13143
  message.feeSats = object.feeSats ?? 0;
13144
+ message.transferRequest = (object.transferRequest !== undefined && object.transferRequest !== null)
13145
+ ? StartTransferRequest.fromPartial(object.transferRequest)
13146
+ : undefined;
13116
13147
  return message;
13117
13148
  },
13118
13149
  };
@@ -19900,6 +19931,10 @@ export const SparkServiceDefinition = {
19900
19931
  responseStream: false,
19901
19932
  options: {},
19902
19933
  },
19934
+ /**
19935
+ * Gets a specified number of signing commmitments for a set of nodes, which can be used as
19936
+ * part of a transfer package.
19937
+ */
19903
19938
  get_signing_commitments: {
19904
19939
  name: "get_signing_commitments",
19905
19940
  requestType: GetSigningCommitmentsRequest,
@@ -20330,6 +20365,10 @@ export interface SparkServiceImplementation<CallContextExt = {}> {
20330
20365
  request: StorePreimageShareRequest,
20331
20366
  context: CallContext & CallContextExt,
20332
20367
  ): Promise<DeepPartial<Empty>>;
20368
+ /**
20369
+ * Gets a specified number of signing commmitments for a set of nodes, which can be used as
20370
+ * part of a transfer package.
20371
+ */
20333
20372
  get_signing_commitments(
20334
20373
  request: GetSigningCommitmentsRequest,
20335
20374
  context: CallContext & CallContextExt,
@@ -20596,6 +20635,10 @@ export interface SparkServiceClient<CallOptionsExt = {}> {
20596
20635
  request: DeepPartial<StorePreimageShareRequest>,
20597
20636
  options?: CallOptions & CallOptionsExt,
20598
20637
  ): Promise<Empty>;
20638
+ /**
20639
+ * Gets a specified number of signing commmitments for a set of nodes, which can be used as
20640
+ * part of a transfer package.
20641
+ */
20599
20642
  get_signing_commitments(
20600
20643
  request: DeepPartial<GetSigningCommitmentsRequest>,
20601
20644
  options?: CallOptions & CallOptionsExt,
@@ -9,6 +9,7 @@ import {
9
9
  ConsoleOptions,
10
10
  } from "./wallet-config.js";
11
11
  import { ConfigurationError } from "../errors/types.js";
12
+ import { SparkWalletEvents } from "../spark-wallet/types.js";
12
13
 
13
14
  export class WalletConfigService implements HasSspClientOptions {
14
15
  private readonly config: Required<ConfigOptions>;
@@ -122,4 +123,8 @@ export class WalletConfigService implements HasSspClientOptions {
122
123
  ...this.config.console,
123
124
  };
124
125
  }
126
+
127
+ public getEvents(): Partial<SparkWalletEvents> {
128
+ return this.config.events;
129
+ }
125
130
  }