@arkade-os/sdk 0.3.13 → 0.4.0-next.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.
Files changed (270) hide show
  1. package/README.md +586 -54
  2. package/dist/cjs/asset/assetGroup.js +141 -0
  3. package/dist/cjs/asset/assetId.js +88 -0
  4. package/dist/cjs/asset/assetInput.js +204 -0
  5. package/dist/cjs/asset/assetOutput.js +159 -0
  6. package/dist/cjs/asset/assetRef.js +82 -0
  7. package/dist/cjs/asset/index.js +24 -0
  8. package/dist/cjs/asset/metadata.js +172 -0
  9. package/dist/cjs/asset/packet.js +164 -0
  10. package/dist/cjs/asset/types.js +25 -0
  11. package/dist/cjs/asset/utils.js +105 -0
  12. package/dist/cjs/bip322/index.js +270 -0
  13. package/dist/cjs/contracts/arkcontract.js +148 -0
  14. package/dist/cjs/contracts/contractManager.js +436 -0
  15. package/dist/cjs/contracts/contractWatcher.js +567 -0
  16. package/dist/cjs/contracts/handlers/default.js +85 -0
  17. package/dist/cjs/contracts/handlers/delegate.js +89 -0
  18. package/dist/cjs/contracts/handlers/helpers.js +105 -0
  19. package/dist/cjs/contracts/handlers/index.js +19 -0
  20. package/dist/cjs/contracts/handlers/registry.js +89 -0
  21. package/dist/cjs/contracts/handlers/vhtlc.js +193 -0
  22. package/dist/cjs/contracts/index.js +41 -0
  23. package/dist/cjs/contracts/types.js +2 -0
  24. package/dist/cjs/forfeit.js +12 -8
  25. package/dist/cjs/identity/index.js +1 -0
  26. package/dist/cjs/identity/seedIdentity.js +255 -0
  27. package/dist/cjs/index.js +72 -14
  28. package/dist/cjs/intent/index.js +47 -11
  29. package/dist/cjs/providers/ark.js +7 -0
  30. package/dist/cjs/providers/delegator.js +66 -0
  31. package/dist/cjs/providers/expoIndexer.js +5 -0
  32. package/dist/cjs/providers/indexer.js +68 -1
  33. package/dist/cjs/providers/utils.js +1 -0
  34. package/dist/cjs/repositories/contractRepository.js +0 -103
  35. package/dist/cjs/repositories/inMemory/contractRepository.js +55 -0
  36. package/dist/cjs/repositories/inMemory/walletRepository.js +80 -0
  37. package/dist/cjs/repositories/index.js +16 -0
  38. package/dist/cjs/repositories/indexedDB/contractRepository.js +187 -0
  39. package/dist/cjs/repositories/indexedDB/db.js +19 -0
  40. package/dist/cjs/repositories/indexedDB/manager.js +97 -0
  41. package/dist/cjs/repositories/indexedDB/schema.js +159 -0
  42. package/dist/cjs/repositories/indexedDB/walletRepository.js +338 -0
  43. package/dist/cjs/repositories/indexedDB/websqlAdapter.js +144 -0
  44. package/dist/cjs/repositories/migrations/contractRepositoryImpl.js +127 -0
  45. package/dist/cjs/repositories/migrations/fromStorageAdapter.js +66 -0
  46. package/dist/cjs/repositories/migrations/walletRepositoryImpl.js +180 -0
  47. package/dist/cjs/repositories/realm/contractRepository.js +120 -0
  48. package/dist/cjs/repositories/realm/index.js +9 -0
  49. package/dist/cjs/repositories/realm/schemas.js +108 -0
  50. package/dist/cjs/repositories/realm/types.js +7 -0
  51. package/dist/cjs/repositories/realm/walletRepository.js +273 -0
  52. package/dist/cjs/repositories/serialization.js +49 -0
  53. package/dist/cjs/repositories/sqlite/contractRepository.js +139 -0
  54. package/dist/cjs/repositories/sqlite/index.js +7 -0
  55. package/dist/cjs/repositories/sqlite/types.js +2 -0
  56. package/dist/cjs/repositories/sqlite/walletRepository.js +328 -0
  57. package/dist/cjs/repositories/walletRepository.js +0 -169
  58. package/dist/cjs/script/base.js +54 -0
  59. package/dist/cjs/script/delegate.js +49 -0
  60. package/dist/cjs/storage/asyncStorage.js +4 -1
  61. package/dist/cjs/storage/fileSystem.js +3 -0
  62. package/dist/cjs/storage/inMemory.js +3 -0
  63. package/dist/cjs/storage/indexedDB.js +5 -1
  64. package/dist/cjs/storage/localStorage.js +3 -0
  65. package/dist/cjs/utils/arkTransaction.js +16 -0
  66. package/dist/cjs/utils/transactionHistory.js +50 -0
  67. package/dist/cjs/wallet/asset-manager.js +338 -0
  68. package/dist/cjs/wallet/asset.js +117 -0
  69. package/dist/cjs/wallet/batch.js +1 -1
  70. package/dist/cjs/wallet/delegator.js +235 -0
  71. package/dist/cjs/wallet/expo/background.js +133 -0
  72. package/dist/cjs/wallet/expo/index.js +9 -0
  73. package/dist/cjs/wallet/expo/wallet.js +231 -0
  74. package/dist/cjs/wallet/serviceWorker/wallet-message-handler.js +568 -0
  75. package/dist/cjs/wallet/serviceWorker/wallet.js +383 -102
  76. package/dist/cjs/wallet/utils.js +58 -0
  77. package/dist/cjs/wallet/validation.js +151 -0
  78. package/dist/cjs/wallet/vtxo-manager.js +8 -1
  79. package/dist/cjs/wallet/wallet.js +702 -260
  80. package/dist/cjs/worker/browser/service-worker-manager.js +82 -0
  81. package/dist/cjs/{wallet/serviceWorker → worker/browser}/utils.js +2 -1
  82. package/dist/cjs/worker/expo/asyncStorageTaskQueue.js +78 -0
  83. package/dist/cjs/worker/expo/index.js +12 -0
  84. package/dist/cjs/worker/expo/processors/contractPollProcessor.js +61 -0
  85. package/dist/cjs/worker/expo/processors/index.js +6 -0
  86. package/dist/cjs/worker/expo/taskQueue.js +41 -0
  87. package/dist/cjs/worker/expo/taskRunner.js +57 -0
  88. package/dist/cjs/worker/messageBus.js +252 -0
  89. package/dist/esm/asset/assetGroup.js +137 -0
  90. package/dist/esm/asset/assetId.js +84 -0
  91. package/dist/esm/asset/assetInput.js +199 -0
  92. package/dist/esm/asset/assetOutput.js +154 -0
  93. package/dist/esm/asset/assetRef.js +78 -0
  94. package/dist/esm/asset/index.js +8 -0
  95. package/dist/esm/asset/metadata.js +167 -0
  96. package/dist/esm/asset/packet.js +159 -0
  97. package/dist/esm/asset/types.js +22 -0
  98. package/dist/esm/asset/utils.js +99 -0
  99. package/dist/esm/bip322/index.js +267 -0
  100. package/dist/esm/contracts/arkcontract.js +141 -0
  101. package/dist/esm/contracts/contractManager.js +432 -0
  102. package/dist/esm/contracts/contractWatcher.js +563 -0
  103. package/dist/esm/contracts/handlers/default.js +82 -0
  104. package/dist/esm/contracts/handlers/delegate.js +86 -0
  105. package/dist/esm/contracts/handlers/helpers.js +66 -0
  106. package/dist/esm/contracts/handlers/index.js +12 -0
  107. package/dist/esm/contracts/handlers/registry.js +86 -0
  108. package/dist/esm/contracts/handlers/vhtlc.js +190 -0
  109. package/dist/esm/contracts/index.js +13 -0
  110. package/dist/esm/contracts/types.js +1 -0
  111. package/dist/esm/forfeit.js +11 -8
  112. package/dist/esm/identity/index.js +1 -0
  113. package/dist/esm/identity/seedIdentity.js +249 -0
  114. package/dist/esm/index.js +28 -15
  115. package/dist/esm/intent/index.js +44 -9
  116. package/dist/esm/providers/ark.js +7 -0
  117. package/dist/esm/providers/delegator.js +62 -0
  118. package/dist/esm/providers/expoIndexer.js +5 -0
  119. package/dist/esm/providers/indexer.js +68 -1
  120. package/dist/esm/providers/utils.js +1 -0
  121. package/dist/esm/repositories/contractRepository.js +1 -101
  122. package/dist/esm/repositories/inMemory/contractRepository.js +51 -0
  123. package/dist/esm/repositories/inMemory/walletRepository.js +76 -0
  124. package/dist/esm/repositories/index.js +8 -0
  125. package/dist/esm/repositories/indexedDB/contractRepository.js +183 -0
  126. package/dist/esm/repositories/indexedDB/db.js +4 -0
  127. package/dist/esm/repositories/indexedDB/manager.js +92 -0
  128. package/dist/esm/repositories/indexedDB/schema.js +155 -0
  129. package/dist/esm/repositories/indexedDB/walletRepository.js +334 -0
  130. package/dist/esm/repositories/indexedDB/websqlAdapter.js +138 -0
  131. package/dist/esm/repositories/migrations/contractRepositoryImpl.js +121 -0
  132. package/dist/esm/repositories/migrations/fromStorageAdapter.js +58 -0
  133. package/dist/esm/repositories/migrations/walletRepositoryImpl.js +176 -0
  134. package/dist/esm/repositories/realm/contractRepository.js +116 -0
  135. package/dist/esm/repositories/realm/index.js +3 -0
  136. package/dist/esm/repositories/realm/schemas.js +105 -0
  137. package/dist/esm/repositories/realm/types.js +6 -0
  138. package/dist/esm/repositories/realm/walletRepository.js +269 -0
  139. package/dist/esm/repositories/serialization.js +40 -0
  140. package/dist/esm/repositories/sqlite/contractRepository.js +135 -0
  141. package/dist/esm/repositories/sqlite/index.js +2 -0
  142. package/dist/esm/repositories/sqlite/types.js +1 -0
  143. package/dist/esm/repositories/sqlite/walletRepository.js +324 -0
  144. package/dist/esm/repositories/walletRepository.js +1 -167
  145. package/dist/esm/script/base.js +21 -1
  146. package/dist/esm/script/delegate.js +46 -0
  147. package/dist/esm/storage/asyncStorage.js +4 -1
  148. package/dist/esm/storage/fileSystem.js +3 -0
  149. package/dist/esm/storage/inMemory.js +3 -0
  150. package/dist/esm/storage/indexedDB.js +5 -1
  151. package/dist/esm/storage/localStorage.js +3 -0
  152. package/dist/esm/utils/arkTransaction.js +15 -0
  153. package/dist/esm/utils/transactionHistory.js +50 -0
  154. package/dist/esm/wallet/asset-manager.js +333 -0
  155. package/dist/esm/wallet/asset.js +111 -0
  156. package/dist/esm/wallet/batch.js +1 -1
  157. package/dist/esm/wallet/delegator.js +231 -0
  158. package/dist/esm/wallet/expo/background.js +128 -0
  159. package/dist/esm/wallet/expo/index.js +2 -0
  160. package/dist/esm/wallet/expo/wallet.js +194 -0
  161. package/dist/esm/wallet/serviceWorker/wallet-message-handler.js +564 -0
  162. package/dist/esm/wallet/serviceWorker/wallet.js +382 -101
  163. package/dist/esm/wallet/utils.js +54 -0
  164. package/dist/esm/wallet/validation.js +139 -0
  165. package/dist/esm/wallet/vtxo-manager.js +8 -1
  166. package/dist/esm/wallet/wallet.js +704 -229
  167. package/dist/esm/worker/browser/service-worker-manager.js +76 -0
  168. package/dist/esm/{wallet/serviceWorker → worker/browser}/utils.js +2 -1
  169. package/dist/esm/worker/expo/asyncStorageTaskQueue.js +74 -0
  170. package/dist/esm/worker/expo/index.js +4 -0
  171. package/dist/esm/worker/expo/processors/contractPollProcessor.js +58 -0
  172. package/dist/esm/worker/expo/processors/index.js +1 -0
  173. package/dist/esm/worker/expo/taskQueue.js +37 -0
  174. package/dist/esm/worker/expo/taskRunner.js +54 -0
  175. package/dist/esm/worker/messageBus.js +248 -0
  176. package/dist/types/asset/assetGroup.d.ts +28 -0
  177. package/dist/types/asset/assetId.d.ts +19 -0
  178. package/dist/types/asset/assetInput.d.ts +46 -0
  179. package/dist/types/asset/assetOutput.d.ts +39 -0
  180. package/dist/types/asset/assetRef.d.ts +25 -0
  181. package/dist/types/asset/index.d.ts +8 -0
  182. package/dist/types/asset/metadata.d.ts +37 -0
  183. package/dist/types/asset/packet.d.ts +27 -0
  184. package/dist/types/asset/types.d.ts +18 -0
  185. package/dist/types/asset/utils.d.ts +21 -0
  186. package/dist/types/bip322/index.d.ts +55 -0
  187. package/dist/types/contracts/arkcontract.d.ts +101 -0
  188. package/dist/types/contracts/contractManager.d.ts +331 -0
  189. package/dist/types/contracts/contractWatcher.d.ts +192 -0
  190. package/dist/types/contracts/handlers/default.d.ts +19 -0
  191. package/dist/types/contracts/handlers/delegate.d.ts +21 -0
  192. package/dist/types/contracts/handlers/helpers.d.ts +18 -0
  193. package/dist/types/contracts/handlers/index.d.ts +7 -0
  194. package/dist/types/contracts/handlers/registry.d.ts +65 -0
  195. package/dist/types/contracts/handlers/vhtlc.d.ts +32 -0
  196. package/dist/types/contracts/index.d.ts +14 -0
  197. package/dist/types/contracts/types.d.ts +222 -0
  198. package/dist/types/forfeit.d.ts +2 -1
  199. package/dist/types/identity/index.d.ts +1 -0
  200. package/dist/types/identity/seedIdentity.d.ts +128 -0
  201. package/dist/types/index.d.ts +22 -12
  202. package/dist/types/intent/index.d.ts +15 -1
  203. package/dist/types/providers/ark.d.ts +11 -2
  204. package/dist/types/providers/delegator.d.ts +29 -0
  205. package/dist/types/providers/indexer.d.ts +11 -1
  206. package/dist/types/repositories/contractRepository.d.ts +30 -19
  207. package/dist/types/repositories/inMemory/contractRepository.d.ts +17 -0
  208. package/dist/types/repositories/inMemory/walletRepository.d.ts +26 -0
  209. package/dist/types/repositories/index.d.ts +7 -0
  210. package/dist/types/repositories/indexedDB/contractRepository.d.ts +21 -0
  211. package/dist/types/repositories/indexedDB/db.d.ts +4 -0
  212. package/dist/types/repositories/indexedDB/manager.d.ts +22 -0
  213. package/dist/types/repositories/indexedDB/schema.d.ts +8 -0
  214. package/dist/types/repositories/indexedDB/walletRepository.d.ts +25 -0
  215. package/dist/types/repositories/indexedDB/websqlAdapter.d.ts +49 -0
  216. package/dist/types/repositories/migrations/contractRepositoryImpl.d.ts +24 -0
  217. package/dist/types/repositories/migrations/fromStorageAdapter.d.ts +19 -0
  218. package/dist/types/repositories/migrations/walletRepositoryImpl.d.ts +27 -0
  219. package/dist/types/repositories/realm/contractRepository.d.ts +24 -0
  220. package/dist/types/repositories/realm/index.d.ts +4 -0
  221. package/dist/types/repositories/realm/schemas.d.ts +208 -0
  222. package/dist/types/repositories/realm/types.d.ts +16 -0
  223. package/dist/types/repositories/realm/walletRepository.d.ts +31 -0
  224. package/dist/types/repositories/serialization.d.ts +40 -0
  225. package/dist/types/repositories/sqlite/contractRepository.d.ts +33 -0
  226. package/dist/types/repositories/sqlite/index.d.ts +3 -0
  227. package/dist/types/repositories/sqlite/types.d.ts +18 -0
  228. package/dist/types/repositories/sqlite/walletRepository.d.ts +40 -0
  229. package/dist/types/repositories/walletRepository.d.ts +13 -24
  230. package/dist/types/script/base.d.ts +1 -0
  231. package/dist/types/script/delegate.d.ts +36 -0
  232. package/dist/types/storage/asyncStorage.d.ts +4 -0
  233. package/dist/types/storage/fileSystem.d.ts +3 -0
  234. package/dist/types/storage/inMemory.d.ts +3 -0
  235. package/dist/types/storage/index.d.ts +3 -0
  236. package/dist/types/storage/indexedDB.d.ts +3 -0
  237. package/dist/types/storage/localStorage.d.ts +3 -0
  238. package/dist/types/utils/arkTransaction.d.ts +6 -0
  239. package/dist/types/wallet/asset-manager.d.ts +78 -0
  240. package/dist/types/wallet/asset.d.ts +21 -0
  241. package/dist/types/wallet/batch.d.ts +1 -1
  242. package/dist/types/wallet/delegator.d.ts +24 -0
  243. package/dist/types/wallet/expo/background.d.ts +66 -0
  244. package/dist/types/wallet/expo/index.d.ts +4 -0
  245. package/dist/types/wallet/expo/wallet.d.ts +97 -0
  246. package/dist/types/wallet/index.d.ts +75 -2
  247. package/dist/types/wallet/serviceWorker/wallet-message-handler.d.ts +366 -0
  248. package/dist/types/wallet/serviceWorker/wallet.d.ts +20 -11
  249. package/dist/types/wallet/utils.d.ts +12 -1
  250. package/dist/types/wallet/validation.d.ts +24 -0
  251. package/dist/types/wallet/wallet.d.ts +111 -17
  252. package/dist/types/worker/browser/service-worker-manager.d.ts +21 -0
  253. package/dist/types/{wallet/serviceWorker → worker/browser}/utils.d.ts +2 -1
  254. package/dist/types/worker/expo/asyncStorageTaskQueue.d.ts +46 -0
  255. package/dist/types/worker/expo/index.d.ts +7 -0
  256. package/dist/types/worker/expo/processors/contractPollProcessor.d.ts +14 -0
  257. package/dist/types/worker/expo/processors/index.d.ts +1 -0
  258. package/dist/types/worker/expo/taskQueue.d.ts +50 -0
  259. package/dist/types/worker/expo/taskRunner.d.ts +42 -0
  260. package/dist/types/worker/messageBus.d.ts +109 -0
  261. package/package.json +69 -11
  262. package/dist/cjs/wallet/serviceWorker/request.js +0 -78
  263. package/dist/cjs/wallet/serviceWorker/response.js +0 -222
  264. package/dist/cjs/wallet/serviceWorker/worker.js +0 -655
  265. package/dist/esm/wallet/serviceWorker/request.js +0 -75
  266. package/dist/esm/wallet/serviceWorker/response.js +0 -219
  267. package/dist/esm/wallet/serviceWorker/worker.js +0 -651
  268. package/dist/types/wallet/serviceWorker/request.d.ts +0 -74
  269. package/dist/types/wallet/serviceWorker/response.d.ts +0 -123
  270. package/dist/types/wallet/serviceWorker/worker.d.ts +0 -53
@@ -0,0 +1,89 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DelegateContractHandler = void 0;
4
+ const base_1 = require("@scure/base");
5
+ const delegate_1 = require("../../script/delegate");
6
+ const default_1 = require("../../script/default");
7
+ const helpers_1 = require("./helpers");
8
+ /**
9
+ * Handler for delegate wallet VTXOs.
10
+ *
11
+ * Delegate contracts extend the default tapscript with an additional delegate path:
12
+ * - forfeit: (Alice + Server) multisig for collaborative spending
13
+ * - exit: (Alice) + CSV timelock for unilateral exit
14
+ * - delegate: (Alice + Delegate + Server) multisig for delegated renewal
15
+ */
16
+ exports.DelegateContractHandler = {
17
+ type: "delegate",
18
+ createScript(params) {
19
+ const typed = this.deserializeParams(params);
20
+ return new delegate_1.DelegateVtxo.Script(typed);
21
+ },
22
+ serializeParams(params) {
23
+ return {
24
+ pubKey: base_1.hex.encode(params.pubKey),
25
+ serverPubKey: base_1.hex.encode(params.serverPubKey),
26
+ delegatePubKey: base_1.hex.encode(params.delegatePubKey),
27
+ csvTimelock: (0, helpers_1.timelockToSequence)(params.csvTimelock).toString(),
28
+ };
29
+ },
30
+ deserializeParams(params) {
31
+ const csvTimelock = params.csvTimelock
32
+ ? (0, helpers_1.sequenceToTimelock)(Number(params.csvTimelock))
33
+ : default_1.DefaultVtxo.Script.DEFAULT_TIMELOCK;
34
+ return {
35
+ pubKey: base_1.hex.decode(params.pubKey),
36
+ serverPubKey: base_1.hex.decode(params.serverPubKey),
37
+ delegatePubKey: base_1.hex.decode(params.delegatePubKey),
38
+ csvTimelock,
39
+ };
40
+ },
41
+ selectPath(script, contract, context) {
42
+ if (context.collaborative) {
43
+ return { leaf: script.forfeit() };
44
+ }
45
+ const sequence = contract.params.csvTimelock
46
+ ? Number(contract.params.csvTimelock)
47
+ : undefined;
48
+ if (!(0, helpers_1.isCsvSpendable)(context, sequence)) {
49
+ return null;
50
+ }
51
+ return {
52
+ leaf: script.exit(),
53
+ sequence,
54
+ };
55
+ },
56
+ getAllSpendingPaths(script, contract, context) {
57
+ const paths = [];
58
+ if (context.collaborative) {
59
+ paths.push({ leaf: script.forfeit() });
60
+ }
61
+ const exitPath = { leaf: script.exit() };
62
+ if (contract.params.csvTimelock) {
63
+ exitPath.sequence = Number(contract.params.csvTimelock);
64
+ }
65
+ paths.push(exitPath);
66
+ // Delegate path (Alice + Delegate + Server) — collaborative only
67
+ if (context.collaborative) {
68
+ paths.push({ leaf: script.delegate() });
69
+ }
70
+ return paths;
71
+ },
72
+ getSpendablePaths(script, contract, context) {
73
+ const paths = [];
74
+ if (context.collaborative) {
75
+ paths.push({ leaf: script.forfeit() });
76
+ }
77
+ const exitSequence = contract.params.csvTimelock
78
+ ? Number(contract.params.csvTimelock)
79
+ : undefined;
80
+ if ((0, helpers_1.isCsvSpendable)(context, exitSequence)) {
81
+ const exitPath = { leaf: script.exit() };
82
+ if (exitSequence !== undefined) {
83
+ exitPath.sequence = exitSequence;
84
+ }
85
+ paths.push(exitPath);
86
+ }
87
+ return paths;
88
+ },
89
+ };
@@ -0,0 +1,105 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.timelockToSequence = timelockToSequence;
37
+ exports.sequenceToTimelock = sequenceToTimelock;
38
+ exports.resolveRole = resolveRole;
39
+ exports.isCsvSpendable = isCsvSpendable;
40
+ const bip68 = __importStar(require("bip68"));
41
+ /**
42
+ * Convert RelativeTimelock to BIP68 sequence number.
43
+ */
44
+ function timelockToSequence(timelock) {
45
+ return bip68.encode(timelock.type === "blocks"
46
+ ? { blocks: Number(timelock.value) }
47
+ : { seconds: Number(timelock.value) });
48
+ }
49
+ /**
50
+ * Convert BIP68 sequence number back to RelativeTimelock.
51
+ */
52
+ function sequenceToTimelock(sequence) {
53
+ const decoded = bip68.decode(sequence);
54
+ if ("blocks" in decoded && decoded.blocks !== undefined) {
55
+ return { type: "blocks", value: BigInt(decoded.blocks) };
56
+ }
57
+ if ("seconds" in decoded && decoded.seconds !== undefined) {
58
+ return { type: "seconds", value: BigInt(decoded.seconds) };
59
+ }
60
+ throw new Error(`Invalid BIP68 sequence: ${sequence}`);
61
+ }
62
+ /**
63
+ * Resolve wallet's role from explicit role or by matching pubkey.
64
+ */
65
+ function resolveRole(contract, context) {
66
+ // Explicit role takes precedence
67
+ if (context.role === "sender" || context.role === "receiver") {
68
+ return context.role;
69
+ }
70
+ // Try to match wallet pubkey against contract params
71
+ if (context.walletPubKey) {
72
+ if (context.walletPubKey === contract.params.sender) {
73
+ return "sender";
74
+ }
75
+ if (context.walletPubKey === contract.params.receiver) {
76
+ return "receiver";
77
+ }
78
+ }
79
+ return undefined;
80
+ }
81
+ /**
82
+ * Check if a CSV timelock is currently satisfied for the given context/VTXO.
83
+ */
84
+ function isCsvSpendable(context, sequence) {
85
+ if (sequence === undefined)
86
+ return true;
87
+ if (!context.vtxo)
88
+ return false;
89
+ const timelock = sequenceToTimelock(sequence);
90
+ if (timelock.type === "blocks") {
91
+ if (context.blockHeight === undefined ||
92
+ context.vtxo.status.block_height === undefined) {
93
+ return false;
94
+ }
95
+ return (context.blockHeight - context.vtxo.status.block_height >=
96
+ Number(timelock.value));
97
+ }
98
+ if (timelock.type === "seconds") {
99
+ const blockTime = context.vtxo.status.block_time;
100
+ if (blockTime === undefined)
101
+ return false;
102
+ return context.currentTime / 1000 - blockTime >= Number(timelock.value);
103
+ }
104
+ return false;
105
+ }
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.VHTLCContractHandler = exports.DelegateContractHandler = exports.DefaultContractHandler = exports.contractHandlers = void 0;
4
+ var registry_1 = require("./registry");
5
+ Object.defineProperty(exports, "contractHandlers", { enumerable: true, get: function () { return registry_1.contractHandlers; } });
6
+ var default_1 = require("./default");
7
+ Object.defineProperty(exports, "DefaultContractHandler", { enumerable: true, get: function () { return default_1.DefaultContractHandler; } });
8
+ var delegate_1 = require("./delegate");
9
+ Object.defineProperty(exports, "DelegateContractHandler", { enumerable: true, get: function () { return delegate_1.DelegateContractHandler; } });
10
+ var vhtlc_1 = require("./vhtlc");
11
+ Object.defineProperty(exports, "VHTLCContractHandler", { enumerable: true, get: function () { return vhtlc_1.VHTLCContractHandler; } });
12
+ // Register built-in handlers
13
+ const registry_2 = require("./registry");
14
+ const default_2 = require("./default");
15
+ const delegate_2 = require("./delegate");
16
+ const vhtlc_2 = require("./vhtlc");
17
+ registry_2.contractHandlers.register(default_2.DefaultContractHandler);
18
+ registry_2.contractHandlers.register(delegate_2.DelegateContractHandler);
19
+ registry_2.contractHandlers.register(vhtlc_2.VHTLCContractHandler);
@@ -0,0 +1,89 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.contractHandlers = void 0;
4
+ /**
5
+ * Registry for contract handlers.
6
+ *
7
+ * Each contract type ("default", "vhtlc", etc.) has a handler that knows
8
+ * how to create VtxoScripts, serialize params, and select spending paths.
9
+ *
10
+ * @example
11
+ * ```typescript
12
+ * // Register a custom handler
13
+ * contractHandlers.register(myCustomHandler);
14
+ *
15
+ * // Get handler for a type
16
+ * const handler = contractHandlers.get("vhtlc");
17
+ * const script = handler.createScript(contract.params);
18
+ * ```
19
+ */
20
+ class ContractHandlerRegistry {
21
+ constructor() {
22
+ this.handlers = new Map();
23
+ }
24
+ /**
25
+ * Register a contract handler.
26
+ *
27
+ * @param handler - The handler to register
28
+ * @throws If a handler for this type is already registered
29
+ */
30
+ register(handler) {
31
+ if (this.handlers.has(handler.type)) {
32
+ throw new Error(`Contract handler for type '${handler.type}' is already registered`);
33
+ }
34
+ this.handlers.set(handler.type, handler);
35
+ }
36
+ /**
37
+ * Get a handler by type.
38
+ *
39
+ * @param type - The contract type
40
+ * @returns The handler, or undefined if not found
41
+ */
42
+ get(type) {
43
+ return this.handlers.get(type);
44
+ }
45
+ /**
46
+ * Get a handler by type, throwing if not found.
47
+ *
48
+ * @param type - The contract type
49
+ * @returns The handler
50
+ * @throws If no handler is registered for this type
51
+ */
52
+ getOrThrow(type) {
53
+ const handler = this.get(type);
54
+ if (!handler) {
55
+ throw new Error(`No contract handler registered for type '${type}'`);
56
+ }
57
+ return handler;
58
+ }
59
+ /**
60
+ * Check if a handler is registered.
61
+ *
62
+ * @param type - The contract type
63
+ */
64
+ has(type) {
65
+ return this.handlers.has(type);
66
+ }
67
+ /**
68
+ * Get all registered types.
69
+ */
70
+ getRegisteredTypes() {
71
+ return Array.from(this.handlers.keys());
72
+ }
73
+ /**
74
+ * Unregister a handler (mainly for testing).
75
+ */
76
+ unregister(type) {
77
+ return this.handlers.delete(type);
78
+ }
79
+ /**
80
+ * Clear all handlers (mainly for testing).
81
+ */
82
+ clear() {
83
+ this.handlers.clear();
84
+ }
85
+ }
86
+ /**
87
+ * Global registry of contract handlers.
88
+ */
89
+ exports.contractHandlers = new ContractHandlerRegistry();
@@ -0,0 +1,193 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.VHTLCContractHandler = void 0;
4
+ const base_1 = require("@scure/base");
5
+ const vhtlc_1 = require("../../script/vhtlc");
6
+ const helpers_1 = require("./helpers");
7
+ /**
8
+ * Handler for Virtual Hash Time Lock Contract (VHTLC).
9
+ *
10
+ * VHTLC supports multiple spending paths:
11
+ *
12
+ * Collaborative paths (with server):
13
+ * - claim: Receiver + Server with preimage
14
+ * - refund: Sender + Receiver + Server
15
+ * - refundWithoutReceiver: Sender + Server after CLTV locktime
16
+ *
17
+ * Unilateral paths (without server):
18
+ * - unilateralClaim: Receiver with preimage after CSV delay
19
+ * - unilateralRefund: Sender + Receiver after CSV delay
20
+ * - unilateralRefundWithoutReceiver: Sender after CSV delay
21
+ */
22
+ exports.VHTLCContractHandler = {
23
+ type: "vhtlc",
24
+ createScript(params) {
25
+ const typed = this.deserializeParams(params);
26
+ return new vhtlc_1.VHTLC.Script(typed);
27
+ },
28
+ serializeParams(params) {
29
+ return {
30
+ sender: base_1.hex.encode(params.sender),
31
+ receiver: base_1.hex.encode(params.receiver),
32
+ server: base_1.hex.encode(params.server),
33
+ hash: base_1.hex.encode(params.preimageHash),
34
+ refundLocktime: params.refundLocktime.toString(),
35
+ claimDelay: (0, helpers_1.timelockToSequence)(params.unilateralClaimDelay).toString(),
36
+ refundDelay: (0, helpers_1.timelockToSequence)(params.unilateralRefundDelay).toString(),
37
+ refundNoReceiverDelay: (0, helpers_1.timelockToSequence)(params.unilateralRefundWithoutReceiverDelay).toString(),
38
+ };
39
+ },
40
+ deserializeParams(params) {
41
+ return {
42
+ sender: base_1.hex.decode(params.sender),
43
+ receiver: base_1.hex.decode(params.receiver),
44
+ server: base_1.hex.decode(params.server),
45
+ preimageHash: base_1.hex.decode(params.hash),
46
+ refundLocktime: BigInt(params.refundLocktime),
47
+ unilateralClaimDelay: (0, helpers_1.sequenceToTimelock)(Number(params.claimDelay)),
48
+ unilateralRefundDelay: (0, helpers_1.sequenceToTimelock)(Number(params.refundDelay)),
49
+ unilateralRefundWithoutReceiverDelay: (0, helpers_1.sequenceToTimelock)(Number(params.refundNoReceiverDelay)),
50
+ };
51
+ },
52
+ /**
53
+ * Select spending path based on context.
54
+ *
55
+ * Role is determined from `context.role` or by matching `context.walletPubKey`
56
+ * against sender/receiver in contract params.
57
+ */
58
+ selectPath(script, contract, context) {
59
+ const role = (0, helpers_1.resolveRole)(contract, context);
60
+ const preimage = contract.params?.preimage;
61
+ const refundLocktime = BigInt(contract.params.refundLocktime);
62
+ const currentTimeSec = Math.floor(context.currentTime / 1000);
63
+ if (!role) {
64
+ return null;
65
+ }
66
+ if (context.collaborative) {
67
+ if (role === "receiver" && preimage) {
68
+ return {
69
+ leaf: script.claim(),
70
+ extraWitness: [base_1.hex.decode(preimage)],
71
+ };
72
+ }
73
+ if (role === "sender" && BigInt(currentTimeSec) >= refundLocktime) {
74
+ return {
75
+ leaf: script.refundWithoutReceiver(),
76
+ };
77
+ }
78
+ return null;
79
+ }
80
+ // Unilateral paths
81
+ if (role === "receiver" && preimage) {
82
+ const sequence = Number(contract.params.claimDelay);
83
+ if (!(0, helpers_1.isCsvSpendable)(context, sequence))
84
+ return null;
85
+ return {
86
+ leaf: script.unilateralClaim(),
87
+ extraWitness: [base_1.hex.decode(preimage)],
88
+ sequence,
89
+ };
90
+ }
91
+ if (role === "sender") {
92
+ const sequence = Number(contract.params.refundNoReceiverDelay);
93
+ if (!(0, helpers_1.isCsvSpendable)(context, sequence))
94
+ return null;
95
+ return {
96
+ leaf: script.unilateralRefundWithoutReceiver(),
97
+ sequence,
98
+ };
99
+ }
100
+ return null;
101
+ },
102
+ /**
103
+ * Get all possible spending paths (no timelock checks).
104
+ *
105
+ * Role is determined from `context.role` or by matching `context.walletPubKey`
106
+ * against sender/receiver in contract params.
107
+ */
108
+ getAllSpendingPaths(script, contract, context) {
109
+ const role = (0, helpers_1.resolveRole)(contract, context);
110
+ const paths = [];
111
+ if (!role) {
112
+ return paths;
113
+ }
114
+ const preimage = contract.params?.preimage;
115
+ if (context.collaborative) {
116
+ // Collaborative paths (no timelock checks)
117
+ if (role === "receiver" && preimage) {
118
+ paths.push({
119
+ leaf: script.claim(),
120
+ extraWitness: [base_1.hex.decode(preimage)],
121
+ });
122
+ }
123
+ if (role === "sender") {
124
+ paths.push({
125
+ leaf: script.refundWithoutReceiver(),
126
+ });
127
+ }
128
+ }
129
+ else {
130
+ // Unilateral paths (no timelock checks)
131
+ if (role === "receiver" && preimage) {
132
+ const sequence = Number(contract.params.claimDelay);
133
+ paths.push({
134
+ leaf: script.unilateralClaim(),
135
+ extraWitness: [base_1.hex.decode(preimage)],
136
+ sequence,
137
+ });
138
+ }
139
+ if (role === "sender") {
140
+ const sequence = Number(contract.params.refundNoReceiverDelay);
141
+ paths.push({
142
+ leaf: script.unilateralRefundWithoutReceiver(),
143
+ sequence,
144
+ });
145
+ }
146
+ }
147
+ return paths;
148
+ },
149
+ getSpendablePaths(script, contract, context) {
150
+ const role = (0, helpers_1.resolveRole)(contract, context);
151
+ const paths = [];
152
+ if (!role) {
153
+ return paths;
154
+ }
155
+ const preimage = contract.params?.preimage;
156
+ const refundLocktime = BigInt(contract.params.refundLocktime);
157
+ const currentTimeSec = Math.floor(context.currentTime / 1000);
158
+ if (context.collaborative) {
159
+ if (role === "receiver" && preimage) {
160
+ paths.push({
161
+ leaf: script.claim(),
162
+ extraWitness: [base_1.hex.decode(preimage)],
163
+ });
164
+ }
165
+ if (role === "sender" && BigInt(currentTimeSec) >= refundLocktime) {
166
+ paths.push({
167
+ leaf: script.refundWithoutReceiver(),
168
+ });
169
+ }
170
+ return paths;
171
+ }
172
+ if (role === "receiver" && preimage) {
173
+ const sequence = Number(contract.params.claimDelay);
174
+ if ((0, helpers_1.isCsvSpendable)(context, sequence)) {
175
+ paths.push({
176
+ leaf: script.unilateralClaim(),
177
+ extraWitness: [base_1.hex.decode(preimage)],
178
+ sequence,
179
+ });
180
+ }
181
+ }
182
+ if (role === "sender") {
183
+ const sequence = Number(contract.params.refundNoReceiverDelay);
184
+ if ((0, helpers_1.isCsvSpendable)(context, sequence)) {
185
+ paths.push({
186
+ leaf: script.unilateralRefundWithoutReceiver(),
187
+ sequence,
188
+ });
189
+ }
190
+ }
191
+ return paths;
192
+ },
193
+ };
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.ContractManager = exports.ContractWatcher = exports.isArkContract = exports.contractFromArkContractWithAddress = exports.contractFromArkContract = exports.decodeArkContract = exports.encodeArkContract = exports.VHTLCContractHandler = exports.DelegateContractHandler = exports.DefaultContractHandler = exports.contractHandlers = void 0;
18
+ // Types
19
+ __exportStar(require("./types"), exports);
20
+ // Contract handlers
21
+ var handlers_1 = require("./handlers");
22
+ Object.defineProperty(exports, "contractHandlers", { enumerable: true, get: function () { return handlers_1.contractHandlers; } });
23
+ var handlers_2 = require("./handlers");
24
+ Object.defineProperty(exports, "DefaultContractHandler", { enumerable: true, get: function () { return handlers_2.DefaultContractHandler; } });
25
+ var handlers_3 = require("./handlers");
26
+ Object.defineProperty(exports, "DelegateContractHandler", { enumerable: true, get: function () { return handlers_3.DelegateContractHandler; } });
27
+ var handlers_4 = require("./handlers");
28
+ Object.defineProperty(exports, "VHTLCContractHandler", { enumerable: true, get: function () { return handlers_4.VHTLCContractHandler; } });
29
+ // arkcontract string codec
30
+ var arkcontract_1 = require("./arkcontract");
31
+ Object.defineProperty(exports, "encodeArkContract", { enumerable: true, get: function () { return arkcontract_1.encodeArkContract; } });
32
+ Object.defineProperty(exports, "decodeArkContract", { enumerable: true, get: function () { return arkcontract_1.decodeArkContract; } });
33
+ Object.defineProperty(exports, "contractFromArkContract", { enumerable: true, get: function () { return arkcontract_1.contractFromArkContract; } });
34
+ Object.defineProperty(exports, "contractFromArkContractWithAddress", { enumerable: true, get: function () { return arkcontract_1.contractFromArkContractWithAddress; } });
35
+ Object.defineProperty(exports, "isArkContract", { enumerable: true, get: function () { return arkcontract_1.isArkContract; } });
36
+ // Contract watcher
37
+ var contractWatcher_1 = require("./contractWatcher");
38
+ Object.defineProperty(exports, "ContractWatcher", { enumerable: true, get: function () { return contractWatcher_1.ContractWatcher; } });
39
+ // Contract manager
40
+ var contractManager_1 = require("./contractManager");
41
+ Object.defineProperty(exports, "ContractManager", { enumerable: true, get: function () { return contractManager_1.ContractManager; } });
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,27 +1,31 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.buildForfeitTx = buildForfeitTx;
4
+ exports.buildForfeitTxWithOutput = buildForfeitTxWithOutput;
4
5
  const transaction_1 = require("./utils/transaction");
5
6
  const anchor_1 = require("./utils/anchor");
6
7
  function buildForfeitTx(inputs, forfeitPkScript, txLocktime) {
7
- const tx = new transaction_1.Transaction({
8
- version: 3,
9
- lockTime: txLocktime,
10
- });
11
8
  let amount = 0n;
12
9
  for (const input of inputs) {
13
10
  if (!input.witnessUtxo) {
14
11
  throw new Error("input needs witness utxo");
15
12
  }
16
13
  amount += input.witnessUtxo.amount;
17
- tx.addInput(input);
18
14
  }
19
- // Add main output to server
20
- tx.addOutput({
15
+ return buildForfeitTxWithOutput(inputs, {
21
16
  script: forfeitPkScript,
22
17
  amount,
18
+ }, txLocktime);
19
+ }
20
+ function buildForfeitTxWithOutput(inputs, output, txLocktime) {
21
+ const tx = new transaction_1.Transaction({
22
+ version: 3,
23
+ lockTime: txLocktime,
23
24
  });
24
- // Add P2A output
25
+ for (const input of inputs) {
26
+ tx.addInput(input);
27
+ }
28
+ tx.addOutput(output);
25
29
  tx.addOutput(anchor_1.P2A);
26
30
  return tx;
27
31
  }
@@ -15,3 +15,4 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
17
  __exportStar(require("./singleKey"), exports);
18
+ __exportStar(require("./seedIdentity"), exports);