@talken/talkenkit 2.3.14 → 2.3.15
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/LICENSE +9 -0
- package/dist/chunk-UWHLB4MJ.js +226 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +151 -335
- package/dist/secure-SSSSQ4NA.js +8 -0
- package/dist/wallets/walletConnectors/abcWallet/abcApi.js +2 -2
- package/dist/wallets/walletConnectors/abcWallet/abcBitcoinConnector.js +1 -1
- package/dist/wallets/walletConnectors/abcWallet/abcConnector.js +3 -3
- package/dist/wallets/walletConnectors/abcWallet/abcSolProvider.js +2 -2
- package/dist/wallets/walletConnectors/abcWallet/abcSolanaWallet.js +3 -3
- package/dist/wallets/walletConnectors/abcWallet/abcWallet.d.ts +7 -0
- package/dist/wallets/walletConnectors/abcWallet/abcWallet.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/api/SigningApi.js +1 -1
- package/dist/wallets/walletConnectors/abcWallet/api/SolanaApi.js +2 -2
- package/dist/wallets/walletConnectors/abcWallet/api/WalletApi.js +2 -2
- package/dist/wallets/walletConnectors/abcWallet/api/index.js +5 -5
- package/dist/wallets/walletConnectors/abcWallet/index.d.ts +1 -0
- package/dist/wallets/walletConnectors/abcWallet/index.js +21 -10
- package/dist/wallets/walletConnectors/abcWallet/networkConfig.d.ts +45 -30
- package/dist/wallets/walletConnectors/abcWallet/networkConfig.js +9 -5
- package/dist/wallets/walletConnectors/abcWallet/types.d.ts +6 -0
- package/dist/wallets/walletConnectors/{chunk-4H6TSGD7.js → chunk-2XZBPMQJ.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-4QPXFUDC.js → chunk-3ZE57J3R.js} +4 -1
- package/dist/wallets/walletConnectors/{chunk-5AAIZIND.js → chunk-3ZZXE7EL.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-636QKXSN.js → chunk-4MF5RSML.js} +4 -1
- package/dist/wallets/walletConnectors/{chunk-4VO5XDCV.js → chunk-4N6JD6LY.js} +9 -9
- package/dist/wallets/walletConnectors/{chunk-2RVWT7N7.js → chunk-4YJWX7I3.js} +4 -1
- package/dist/wallets/walletConnectors/chunk-5CCU7PNU.js +194 -0
- package/dist/wallets/walletConnectors/chunk-5TDZSXJ4.js +345 -0
- package/dist/wallets/walletConnectors/{chunk-4YKA5OIT.js → chunk-75RN2RLT.js} +5 -5
- package/dist/wallets/walletConnectors/{chunk-JXPLBYVW.js → chunk-7DEZCGNV.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-ZX6LABEF.js → chunk-A7FIBI6X.js} +30 -13
- package/dist/wallets/walletConnectors/{chunk-2E2TVL4A.js → chunk-AVPBPELO.js} +6 -6
- package/dist/wallets/walletConnectors/{chunk-F2LC3G36.js → chunk-BJHGC546.js} +18 -3
- package/dist/wallets/walletConnectors/{chunk-BPLIASJE.js → chunk-BL57XWJY.js} +4 -1
- package/dist/wallets/walletConnectors/{chunk-AKYC5VZG.js → chunk-BSBRWKNG.js} +7 -7
- package/dist/wallets/walletConnectors/{chunk-DPL5VRGJ.js → chunk-CYYBGUSO.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-F5Q4VDER.js → chunk-EEY5CXKO.js} +2 -2
- package/dist/wallets/walletConnectors/{chunk-MT2QHWYE.js → chunk-EGOIRXTV.js} +1 -1
- package/dist/wallets/walletConnectors/chunk-F5P2INHS.js +474 -0
- package/dist/wallets/walletConnectors/chunk-G7PEFBL6.js +309 -0
- package/dist/wallets/walletConnectors/{chunk-XZHB7HU4.js → chunk-GHLLVM7O.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-2XFKRGDK.js → chunk-GXGRTWJM.js} +10 -10
- package/dist/wallets/walletConnectors/chunk-H2MX4NAL.js +293 -0
- package/dist/wallets/walletConnectors/{chunk-75NE2OUD.js → chunk-HVPQO6ZG.js} +16 -1
- package/dist/wallets/walletConnectors/{chunk-LOP2R3QJ.js → chunk-JR2C4XXX.js} +2 -52
- package/dist/wallets/walletConnectors/{chunk-V3XKL7AD.js → chunk-KKPINUPY.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-5VL7T6AY.js → chunk-LENPUTNQ.js} +18 -3
- package/dist/wallets/walletConnectors/{chunk-25LLSYLN.js → chunk-N4FOYXQD.js} +5 -5
- package/dist/wallets/walletConnectors/{chunk-CNI3U6UK.js → chunk-NEXFU6BZ.js} +4 -4
- package/dist/wallets/walletConnectors/chunk-O6EAIC4G.js +482 -0
- package/dist/wallets/walletConnectors/{chunk-KZG5KU7A.js → chunk-OC2O4BHA.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-DU6M25IR.js → chunk-P2GV6NQG.js} +16 -1
- package/dist/wallets/walletConnectors/{chunk-CGLM5KXH.js → chunk-PPIFAF7N.js} +7 -7
- package/dist/wallets/walletConnectors/{chunk-76O6JH3T.js → chunk-QEHZXKRF.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-A7KV643A.js → chunk-QI2VB7LL.js} +4 -4
- package/dist/wallets/walletConnectors/chunk-RLR4Y5WO.js +481 -0
- package/dist/wallets/walletConnectors/chunk-T6KJZAPR.js +47 -0
- package/dist/wallets/walletConnectors/chunk-UBCMBPX3.js +58 -0
- package/dist/wallets/walletConnectors/chunk-UGQXI3RN.js +284 -0
- package/dist/wallets/walletConnectors/{chunk-2PDAR5KA.js → chunk-X4WUD7PF.js} +5 -5
- package/dist/wallets/walletConnectors/{chunk-T7NXVYE6.js → chunk-XPSCFUX6.js} +1 -1
- package/dist/wallets/walletConnectors/chunk-Y3LWEDF6.js +63 -0
- package/dist/wallets/walletConnectors/index.js +21 -21
- package/package.json +11 -12
- package/dist/wallets/walletConnectors/chunk-2GODJ6NU.js +0 -398
- package/dist/wallets/walletConnectors/chunk-2ZFMD7GF.js +0 -419
- package/dist/wallets/walletConnectors/chunk-3OYZYIBX.js +0 -361
- package/dist/wallets/walletConnectors/chunk-3WRALPTT.js +0 -403
- package/dist/wallets/walletConnectors/chunk-43LPUTHW.js +0 -157
- package/dist/wallets/walletConnectors/chunk-4OPIMV4N.js +0 -376
- package/dist/wallets/walletConnectors/chunk-4TFDVNMF.js +0 -370
- package/dist/wallets/walletConnectors/chunk-5KCTAEQB.js +0 -391
- package/dist/wallets/walletConnectors/chunk-5OKJZU3F.js +0 -63
- package/dist/wallets/walletConnectors/chunk-5PBZRTEM.js +0 -63
- package/dist/wallets/walletConnectors/chunk-5SLXMCS2.js +0 -34
- package/dist/wallets/walletConnectors/chunk-62ZC3BGR.js +0 -39
- package/dist/wallets/walletConnectors/chunk-6DMWYDIO.js +0 -390
- package/dist/wallets/walletConnectors/chunk-6KO5WQ5C.js +0 -156
- package/dist/wallets/walletConnectors/chunk-6URAISNZ.js +0 -388
- package/dist/wallets/walletConnectors/chunk-6V3335LE.js +0 -63
- package/dist/wallets/walletConnectors/chunk-7UHZX522.js +0 -369
- package/dist/wallets/walletConnectors/chunk-ADMITKUE.js +0 -63
- package/dist/wallets/walletConnectors/chunk-AL7R7JQU.js +0 -124
- package/dist/wallets/walletConnectors/chunk-AY4TMZG6.js +0 -39
- package/dist/wallets/walletConnectors/chunk-AZRYTD6J.js +0 -63
- package/dist/wallets/walletConnectors/chunk-B23AX3U3.js +0 -269
- package/dist/wallets/walletConnectors/chunk-CB4CSXNY.js +0 -63
- package/dist/wallets/walletConnectors/chunk-CSLAM3IH.js +0 -39
- package/dist/wallets/walletConnectors/chunk-CTSR4YUH.js +0 -376
- package/dist/wallets/walletConnectors/chunk-D6MSZOEN.js +0 -357
- package/dist/wallets/walletConnectors/chunk-DA7TFV7F.js +0 -1683
- package/dist/wallets/walletConnectors/chunk-DHVD2NUK.js +0 -156
- package/dist/wallets/walletConnectors/chunk-DSEWXHE6.js +0 -44
- package/dist/wallets/walletConnectors/chunk-E3PO2XKJ.js +0 -433
- package/dist/wallets/walletConnectors/chunk-E5YF2QC2.js +0 -63
- package/dist/wallets/walletConnectors/chunk-ENAFVPRZ.js +0 -374
- package/dist/wallets/walletConnectors/chunk-ENHE6LS7.js +0 -368
- package/dist/wallets/walletConnectors/chunk-EPUITAK3.js +0 -63
- package/dist/wallets/walletConnectors/chunk-EQZ6IAAM.js +0 -39
- package/dist/wallets/walletConnectors/chunk-F5HCFRTK.js +0 -1683
- package/dist/wallets/walletConnectors/chunk-GUUGKRZB.js +0 -63
- package/dist/wallets/walletConnectors/chunk-GZ55OZIT.js +0 -157
- package/dist/wallets/walletConnectors/chunk-H7SRDBPI.js +0 -384
- package/dist/wallets/walletConnectors/chunk-HDXHEBGM.js +0 -403
- package/dist/wallets/walletConnectors/chunk-HGI3FA2A.js +0 -157
- package/dist/wallets/walletConnectors/chunk-HMSFBY7V.js +0 -39
- package/dist/wallets/walletConnectors/chunk-IABRLMSP.js +0 -63
- package/dist/wallets/walletConnectors/chunk-IL52SYJK.js +0 -44
- package/dist/wallets/walletConnectors/chunk-IXPVDDZD.js +0 -365
- package/dist/wallets/walletConnectors/chunk-JNKT32C7.js +0 -63
- package/dist/wallets/walletConnectors/chunk-JW4RQLJT.js +0 -156
- package/dist/wallets/walletConnectors/chunk-K6BNM6VP.js +0 -63
- package/dist/wallets/walletConnectors/chunk-KEV4GPRY.js +0 -63
- package/dist/wallets/walletConnectors/chunk-KN4I4DKC.js +0 -157
- package/dist/wallets/walletConnectors/chunk-KNK6YFEK.js +0 -63
- package/dist/wallets/walletConnectors/chunk-KSKNDJYL.js +0 -63
- package/dist/wallets/walletConnectors/chunk-KYA553D7.js +0 -371
- package/dist/wallets/walletConnectors/chunk-L57JYRQZ.js +0 -63
- package/dist/wallets/walletConnectors/chunk-LB3ISYMC.js +0 -44
- package/dist/wallets/walletConnectors/chunk-LLFZ4GNK.js +0 -266
- package/dist/wallets/walletConnectors/chunk-LLJELGMX.js +0 -63
- package/dist/wallets/walletConnectors/chunk-LTX3ZSQI.js +0 -39
- package/dist/wallets/walletConnectors/chunk-MF46Q5RP.js +0 -44
- package/dist/wallets/walletConnectors/chunk-MGPMSUFB.js +0 -372
- package/dist/wallets/walletConnectors/chunk-MK45L6B7.js +0 -123
- package/dist/wallets/walletConnectors/chunk-MOJC7LE6.js +0 -63
- package/dist/wallets/walletConnectors/chunk-N6CRHH2H.js +0 -400
- package/dist/wallets/walletConnectors/chunk-N6QHQDQP.js +0 -381
- package/dist/wallets/walletConnectors/chunk-NALBGCUS.js +0 -63
- package/dist/wallets/walletConnectors/chunk-NOD2A4Q7.js +0 -430
- package/dist/wallets/walletConnectors/chunk-NOL7MBZU.js +0 -1683
- package/dist/wallets/walletConnectors/chunk-OA5K3AQN.js +0 -370
- package/dist/wallets/walletConnectors/chunk-Q3LW5UK5.js +0 -135
- package/dist/wallets/walletConnectors/chunk-QDCXRBX6.js +0 -63
- package/dist/wallets/walletConnectors/chunk-QHHR2DQK.js +0 -269
- package/dist/wallets/walletConnectors/chunk-QIDXRXV6.js +0 -63
- package/dist/wallets/walletConnectors/chunk-QNY3A52P.js +0 -156
- package/dist/wallets/walletConnectors/chunk-QQEXHPNE.js +0 -385
- package/dist/wallets/walletConnectors/chunk-RASK6XWI.js +0 -436
- package/dist/wallets/walletConnectors/chunk-RFMJC64I.js +0 -364
- package/dist/wallets/walletConnectors/chunk-RVJ32DTM.js +0 -373
- package/dist/wallets/walletConnectors/chunk-S64JWSGA.js +0 -63
- package/dist/wallets/walletConnectors/chunk-SG6KN7NJ.js +0 -377
- package/dist/wallets/walletConnectors/chunk-SGLHM6AU.js +0 -157
- package/dist/wallets/walletConnectors/chunk-SK2XYNK4.js +0 -44
- package/dist/wallets/walletConnectors/chunk-SKBQVOZL.js +0 -1683
- package/dist/wallets/walletConnectors/chunk-SQAILDYS.js +0 -1683
- package/dist/wallets/walletConnectors/chunk-SRTBTRBU.js +0 -372
- package/dist/wallets/walletConnectors/chunk-T23ZNPHL.js +0 -269
- package/dist/wallets/walletConnectors/chunk-T3AL3VAQ.js +0 -44
- package/dist/wallets/walletConnectors/chunk-T4QIWLWU.js +0 -357
- package/dist/wallets/walletConnectors/chunk-THQEUSX4.js +0 -63
- package/dist/wallets/walletConnectors/chunk-TLJSBPMQ.js +0 -63
- package/dist/wallets/walletConnectors/chunk-TPGMXU6M.js +0 -63
- package/dist/wallets/walletConnectors/chunk-UBDYVLI4.js +0 -370
- package/dist/wallets/walletConnectors/chunk-UH6AUMQQ.js +0 -63
- package/dist/wallets/walletConnectors/chunk-UTPJPY4R.js +0 -44
- package/dist/wallets/walletConnectors/chunk-VIH2AOMF.js +0 -63
- package/dist/wallets/walletConnectors/chunk-VIRHJPFQ.js +0 -269
- package/dist/wallets/walletConnectors/chunk-VQI2B7XW.js +0 -269
- package/dist/wallets/walletConnectors/chunk-VQYANLI2.js +0 -44
- package/dist/wallets/walletConnectors/chunk-VRTDF4O3.js +0 -63
- package/dist/wallets/walletConnectors/chunk-VRUPSQK4.js +0 -269
- package/dist/wallets/walletConnectors/chunk-VWZP7KJD.js +0 -157
- package/dist/wallets/walletConnectors/chunk-VZCI2K6Y.js +0 -124
- package/dist/wallets/walletConnectors/chunk-WIZH35IC.js +0 -39
- package/dist/wallets/walletConnectors/chunk-WOZ5REMN.js +0 -436
- package/dist/wallets/walletConnectors/chunk-WPEGBCDE.js +0 -157
- package/dist/wallets/walletConnectors/chunk-WPJESUNP.js +0 -379
- package/dist/wallets/walletConnectors/chunk-WZ322AWR.js +0 -44
- package/dist/wallets/walletConnectors/chunk-WZAIQD3G.js +0 -156
- package/dist/wallets/walletConnectors/chunk-XC5EXBMU.js +0 -385
- package/dist/wallets/walletConnectors/chunk-XWCS76ZC.js +0 -1683
- package/dist/wallets/walletConnectors/chunk-Y5677NVB.js +0 -285
- package/dist/wallets/walletConnectors/chunk-YC73LM6F.js +0 -63
- package/dist/wallets/walletConnectors/chunk-YHWQOKFW.js +0 -39
- package/dist/wallets/walletConnectors/chunk-YIB6VMOF.js +0 -156
- package/dist/wallets/walletConnectors/chunk-YPL4NJGA.js +0 -156
- package/dist/wallets/walletConnectors/chunk-YQP7DZ7T.js +0 -269
- package/dist/wallets/walletConnectors/chunk-ZBMGJDJA.js +0 -436
|
@@ -4,7 +4,7 @@ import {
|
|
|
4
4
|
} from "./chunk-G2LI5MVX.js";
|
|
5
5
|
import {
|
|
6
6
|
getSolanaNetwork
|
|
7
|
-
} from "./chunk-
|
|
7
|
+
} from "./chunk-A7FIBI6X.js";
|
|
8
8
|
import {
|
|
9
9
|
calculateExpiryTimestamp,
|
|
10
10
|
createAbcError,
|
|
@@ -412,11 +412,6 @@ var AbcWaasClient = class {
|
|
|
412
412
|
const talkenApiUrl = process.env.NEXT_PUBLIC_API_SERVER || "https://dev.walletapi.talken.io";
|
|
413
413
|
const url = `${talkenApiUrl}/abc/emailCheck?email=${encodeURIComponent(email)}`;
|
|
414
414
|
const method = "GET";
|
|
415
|
-
console.log("[AbcWaasClient] \u{1F4EC} Checking email:", {
|
|
416
|
-
email,
|
|
417
|
-
url,
|
|
418
|
-
apiServer: talkenApiUrl
|
|
419
|
-
});
|
|
420
415
|
try {
|
|
421
416
|
const response = await fetch(url, {
|
|
422
417
|
method,
|
|
@@ -458,11 +453,6 @@ var AbcWaasClient = class {
|
|
|
458
453
|
*/
|
|
459
454
|
async sendOtpCode(email) {
|
|
460
455
|
const endpoint = `/member/mail-service/${encodeURIComponent(email)}/sendcode`;
|
|
461
|
-
console.log("[AbcWaasClient] \u{1F4E7} Sending OTP code:", {
|
|
462
|
-
email,
|
|
463
|
-
endpoint,
|
|
464
|
-
fullUrl: `${this.baseURL}${endpoint}`
|
|
465
|
-
});
|
|
466
456
|
const response = await this.request(endpoint, {
|
|
467
457
|
method: "GET",
|
|
468
458
|
skipAuth: true
|
|
@@ -489,21 +479,11 @@ var AbcWaasClient = class {
|
|
|
489
479
|
serviceid: ABC_AUDIENCE
|
|
490
480
|
// 'https://mw.myabcwallet.com'
|
|
491
481
|
};
|
|
492
|
-
console.log("[AbcWaasClient] \u{1F510} Verifying OTP code:", {
|
|
493
|
-
email,
|
|
494
|
-
code: `${code.substring(0, 2)}****`,
|
|
495
|
-
// Mask OTP for security
|
|
496
|
-
serviceid: ABC_AUDIENCE,
|
|
497
|
-
endpoint,
|
|
498
|
-
fullUrl: `${this.baseURL}${endpoint}`,
|
|
499
|
-
requestBody
|
|
500
|
-
});
|
|
501
482
|
const response = await this.request(endpoint, {
|
|
502
483
|
method: "POST",
|
|
503
484
|
body: requestBody,
|
|
504
485
|
skipAuth: true
|
|
505
486
|
});
|
|
506
|
-
console.log("[verifyOtpCodeSignup] Response:", response);
|
|
507
487
|
const isSuccess = response.status === "success" || response.status === 200 || response.message === "success";
|
|
508
488
|
if (isSuccess) {
|
|
509
489
|
return response;
|
|
@@ -523,13 +503,6 @@ var AbcWaasClient = class {
|
|
|
523
503
|
async snsLogin(params) {
|
|
524
504
|
const talkenApiUrl = process.env.NEXT_PUBLIC_API_SERVER || "https://dev.walletapi.talken.io";
|
|
525
505
|
const url = `${talkenApiUrl}/abc/snsLogin`;
|
|
526
|
-
console.log("[AbcWaasClient] \u{1F510} SNS Login:", {
|
|
527
|
-
service: params.service,
|
|
528
|
-
email: params.email,
|
|
529
|
-
audience: params.audience,
|
|
530
|
-
hasToken: !!params.token,
|
|
531
|
-
url
|
|
532
|
-
});
|
|
533
506
|
try {
|
|
534
507
|
const response = await fetch(url, {
|
|
535
508
|
method: "POST",
|
|
@@ -562,7 +535,6 @@ var AbcWaasClient = class {
|
|
|
562
535
|
{ service: params.service, response: data }
|
|
563
536
|
);
|
|
564
537
|
}
|
|
565
|
-
console.log("[AbcWaasClient] \u2705 SNS login successful:", params.email);
|
|
566
538
|
return {
|
|
567
539
|
uid: "",
|
|
568
540
|
// Will be fetched later via info() API
|
|
@@ -592,14 +564,6 @@ var AbcWaasClient = class {
|
|
|
592
564
|
const talkenApiUrl = process.env.NEXT_PUBLIC_API_SERVER || "https://dev.walletapi.talken.io";
|
|
593
565
|
const url = `${talkenApiUrl}/abc/adduser`;
|
|
594
566
|
const method = "POST";
|
|
595
|
-
console.log("[AbcWaasClient] \u{1F4DD} Registering user:", {
|
|
596
|
-
username: params.username,
|
|
597
|
-
name: params.name,
|
|
598
|
-
hasPassword: !!params.password,
|
|
599
|
-
hasSecureChannel: !!params.secureChannel,
|
|
600
|
-
hasEmailCode: !!params.emailCode,
|
|
601
|
-
url
|
|
602
|
-
});
|
|
603
567
|
try {
|
|
604
568
|
const response = await fetch(url, {
|
|
605
569
|
method,
|
|
@@ -648,12 +612,6 @@ var AbcWaasClient = class {
|
|
|
648
612
|
const talkenApiUrl = process.env.NEXT_PUBLIC_API_SERVER || "https://dev.walletapi.talken.io";
|
|
649
613
|
const url = `${talkenApiUrl}/abc/snsAdduser`;
|
|
650
614
|
const method = "POST";
|
|
651
|
-
console.log("[AbcWaasClient] \u{1F4DD} Registering SNS user:", {
|
|
652
|
-
username: params.username,
|
|
653
|
-
name: params.name,
|
|
654
|
-
hasOtp: !!params.sixCode,
|
|
655
|
-
url
|
|
656
|
-
});
|
|
657
615
|
try {
|
|
658
616
|
const response = await fetch(url, {
|
|
659
617
|
method,
|
|
@@ -681,7 +639,6 @@ var AbcWaasClient = class {
|
|
|
681
639
|
}
|
|
682
640
|
});
|
|
683
641
|
}
|
|
684
|
-
console.log("[AbcWaasClient] \u2705 SNS user registered successfully");
|
|
685
642
|
return data;
|
|
686
643
|
} catch (error) {
|
|
687
644
|
if (error.name === "AbortError") {
|
|
@@ -703,13 +660,6 @@ var AbcWaasClient = class {
|
|
|
703
660
|
const talkenApiUrl = process.env.NEXT_PUBLIC_API_SERVER || "https://dev.walletapi.talken.io";
|
|
704
661
|
const url = `${talkenApiUrl}/abc/initpassword`;
|
|
705
662
|
const method = "POST";
|
|
706
|
-
console.log("[AbcWaasClient] \u{1F510} Setting password:", {
|
|
707
|
-
username: params.username,
|
|
708
|
-
hasPassword: !!params.password,
|
|
709
|
-
hasSecureChannel: !!params.secureChannel,
|
|
710
|
-
hasEmailCode: !!params.emailCode,
|
|
711
|
-
url
|
|
712
|
-
});
|
|
713
663
|
try {
|
|
714
664
|
const response = await fetch(url, {
|
|
715
665
|
method,
|
|
@@ -1100,7 +1050,7 @@ var AbcWaasClient = class {
|
|
|
1100
1050
|
);
|
|
1101
1051
|
}
|
|
1102
1052
|
const ethers = await import("ethers");
|
|
1103
|
-
const messageHash = ethers.
|
|
1053
|
+
const messageHash = ethers.utils.hashMessage(params.message);
|
|
1104
1054
|
const hash = messageHash.startsWith("0x") ? messageHash.slice(2) : messageHash;
|
|
1105
1055
|
const encryptedDevicePassword = await this.secure.getEncryptPlain(
|
|
1106
1056
|
wallet.encryptDevicePassword
|
|
@@ -140,7 +140,7 @@ var SigningApi = class extends BaseApiClient {
|
|
|
140
140
|
);
|
|
141
141
|
}
|
|
142
142
|
const ethers = await import("ethers");
|
|
143
|
-
const messageHash = ethers.
|
|
143
|
+
const messageHash = ethers.utils.hashMessage(params.message);
|
|
144
144
|
const hash = messageHash.startsWith("0x") ? messageHash.slice(2) : messageHash;
|
|
145
145
|
const encryptedDevicePassword = await this.secure.getEncryptPlain(
|
|
146
146
|
wallet.encryptDevicePassword
|
|
@@ -1,10 +1,15 @@
|
|
|
1
1
|
"use client";
|
|
2
|
-
import {
|
|
3
|
-
createAbcWaasClient
|
|
4
|
-
} from "./chunk-AKYC5VZG.js";
|
|
5
2
|
import {
|
|
6
3
|
createAbcEvmProvider
|
|
7
4
|
} from "./chunk-ZIYAL44B.js";
|
|
5
|
+
import {
|
|
6
|
+
createAbcWaasClient
|
|
7
|
+
} from "./chunk-PPIFAF7N.js";
|
|
8
|
+
import {
|
|
9
|
+
setGlobalDefaultBitcoinNetwork,
|
|
10
|
+
setGlobalDefaultChainId,
|
|
11
|
+
setGlobalDefaultSolanaNetwork
|
|
12
|
+
} from "./chunk-A7FIBI6X.js";
|
|
8
13
|
import {
|
|
9
14
|
clearAuthState,
|
|
10
15
|
clearEncryptedTokens,
|
|
@@ -18,6 +23,15 @@ import {
|
|
|
18
23
|
import { createConnector } from "wagmi";
|
|
19
24
|
function abcConnector(options) {
|
|
20
25
|
const { config } = options;
|
|
26
|
+
if (config.defaultChainId) {
|
|
27
|
+
setGlobalDefaultChainId(config.defaultChainId);
|
|
28
|
+
}
|
|
29
|
+
if (config.defaultSolanaNetwork) {
|
|
30
|
+
setGlobalDefaultSolanaNetwork(config.defaultSolanaNetwork);
|
|
31
|
+
}
|
|
32
|
+
if (config.defaultBitcoinNetwork) {
|
|
33
|
+
setGlobalDefaultBitcoinNetwork(config.defaultBitcoinNetwork);
|
|
34
|
+
}
|
|
21
35
|
return createConnector((wagmiConfig) => {
|
|
22
36
|
const client = createAbcWaasClient(config);
|
|
23
37
|
const provider = createAbcEvmProvider(client);
|
|
@@ -46,6 +60,7 @@ function abcConnector(options) {
|
|
|
46
60
|
provider.setWallet(authState.wallet);
|
|
47
61
|
console.log("\u2705 Provider wallet set:", {
|
|
48
62
|
address: authState.wallet.address,
|
|
63
|
+
chainId: authState.wallet.chainId,
|
|
49
64
|
hasPIN: !!authState.pin
|
|
50
65
|
});
|
|
51
66
|
const accounts = await provider.request({
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
"use client";
|
|
2
|
-
import {
|
|
3
|
-
SolanaApi
|
|
4
|
-
} from "./chunk-A7KV643A.js";
|
|
5
2
|
import {
|
|
6
3
|
TransactionApi
|
|
7
4
|
} from "./chunk-FGBDWBWQ.js";
|
|
5
|
+
import {
|
|
6
|
+
SolanaApi
|
|
7
|
+
} from "./chunk-GHLLVM7O.js";
|
|
8
8
|
import {
|
|
9
9
|
AuthApi
|
|
10
10
|
} from "./chunk-MZOFZ2NQ.js";
|
|
@@ -13,10 +13,10 @@ import {
|
|
|
13
13
|
} from "./chunk-BNSBK5PQ.js";
|
|
14
14
|
import {
|
|
15
15
|
SigningApi
|
|
16
|
-
} from "./chunk-
|
|
16
|
+
} from "./chunk-OC2O4BHA.js";
|
|
17
17
|
import {
|
|
18
18
|
WalletApi
|
|
19
|
-
} from "./chunk-
|
|
19
|
+
} from "./chunk-CYYBGUSO.js";
|
|
20
20
|
|
|
21
21
|
// src/wallets/walletConnectors/abcWallet/api/index.ts
|
|
22
22
|
var AbcWaasApiClient = class {
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
"use client";
|
|
2
|
-
import {
|
|
3
|
-
createAbcSolanaConnector
|
|
4
|
-
} from "./chunk-RY4RAB3D.js";
|
|
5
2
|
import {
|
|
6
3
|
createAbcSolanaProvider
|
|
7
4
|
} from "./chunk-FROV5VDF.js";
|
|
5
|
+
import {
|
|
6
|
+
createAbcSolanaConnector
|
|
7
|
+
} from "./chunk-RY4RAB3D.js";
|
|
8
8
|
import {
|
|
9
9
|
createAbcWaasClient
|
|
10
|
-
} from "./chunk-
|
|
10
|
+
} from "./chunk-PPIFAF7N.js";
|
|
11
11
|
|
|
12
12
|
// src/wallets/walletConnectors/abcWallet/abcSolanaWallet.ts
|
|
13
13
|
var abcSolanaWallet = (options) => ({
|
|
@@ -0,0 +1,482 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
|
|
3
|
+
// src/wallets/walletConnectors/abcWallet/abcBitcoinProvider.ts
|
|
4
|
+
var EventEmitter = class {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.events = /* @__PURE__ */ new Map();
|
|
7
|
+
}
|
|
8
|
+
on(event, listener) {
|
|
9
|
+
if (!this.events.has(event)) {
|
|
10
|
+
this.events.set(event, []);
|
|
11
|
+
}
|
|
12
|
+
this.events.get(event).push(listener);
|
|
13
|
+
return this;
|
|
14
|
+
}
|
|
15
|
+
off(event, listener) {
|
|
16
|
+
const listeners = this.events.get(event);
|
|
17
|
+
if (listeners) {
|
|
18
|
+
const index = listeners.indexOf(listener);
|
|
19
|
+
if (index !== -1) {
|
|
20
|
+
listeners.splice(index, 1);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
return this;
|
|
24
|
+
}
|
|
25
|
+
removeListener(event, listener) {
|
|
26
|
+
return this.off(event, listener);
|
|
27
|
+
}
|
|
28
|
+
emit(event, ...args) {
|
|
29
|
+
const listeners = this.events.get(event);
|
|
30
|
+
if (listeners) {
|
|
31
|
+
for (const listener of listeners) {
|
|
32
|
+
listener(...args);
|
|
33
|
+
}
|
|
34
|
+
return true;
|
|
35
|
+
}
|
|
36
|
+
return false;
|
|
37
|
+
}
|
|
38
|
+
removeAllListeners(event) {
|
|
39
|
+
if (event) {
|
|
40
|
+
this.events.delete(event);
|
|
41
|
+
} else {
|
|
42
|
+
this.events.clear();
|
|
43
|
+
}
|
|
44
|
+
return this;
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
var BitcoinErrorCode = {
|
|
48
|
+
USER_REJECTED: 4001,
|
|
49
|
+
UNAUTHORIZED: 4100,
|
|
50
|
+
UNSUPPORTED_METHOD: 4200,
|
|
51
|
+
DISCONNECTED: 4900,
|
|
52
|
+
INVALID_PARAMS: -32602,
|
|
53
|
+
INTERNAL_ERROR: -32603,
|
|
54
|
+
INSUFFICIENT_FUNDS: 5001,
|
|
55
|
+
UTXO_NOT_FOUND: 5002
|
|
56
|
+
};
|
|
57
|
+
var BitcoinProviderError = class extends Error {
|
|
58
|
+
constructor(code, message, data) {
|
|
59
|
+
super(message);
|
|
60
|
+
this.code = code;
|
|
61
|
+
this.data = data;
|
|
62
|
+
this.name = "BitcoinProviderError";
|
|
63
|
+
}
|
|
64
|
+
};
|
|
65
|
+
var BITCOIN_NETWORKS = {
|
|
66
|
+
mainnet: {
|
|
67
|
+
name: "Bitcoin Mainnet",
|
|
68
|
+
type: "bitcoin",
|
|
69
|
+
explorer: "https://blockstream.info"
|
|
70
|
+
},
|
|
71
|
+
testnet: {
|
|
72
|
+
name: "Bitcoin Testnet",
|
|
73
|
+
type: "bitcoin_testnet",
|
|
74
|
+
explorer: "https://blockstream.info/testnet"
|
|
75
|
+
}
|
|
76
|
+
};
|
|
77
|
+
var AbcBitcoinProvider = class extends EventEmitter {
|
|
78
|
+
// 1 minute
|
|
79
|
+
constructor(client) {
|
|
80
|
+
super();
|
|
81
|
+
this.wallet = null;
|
|
82
|
+
this.network = BITCOIN_NETWORKS.testnet;
|
|
83
|
+
this.connected = false;
|
|
84
|
+
this.utxoCache = /* @__PURE__ */ new Map();
|
|
85
|
+
this.cacheExpiry = /* @__PURE__ */ new Map();
|
|
86
|
+
this.CACHE_TTL = 6e4;
|
|
87
|
+
this.client = client;
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Set wallet information
|
|
91
|
+
*/
|
|
92
|
+
setWallet(wallet) {
|
|
93
|
+
const previousAddress = this.wallet?.address;
|
|
94
|
+
this.wallet = wallet;
|
|
95
|
+
this.connected = true;
|
|
96
|
+
if (wallet.network === "bitcoin") {
|
|
97
|
+
this.network = BITCOIN_NETWORKS.mainnet;
|
|
98
|
+
} else {
|
|
99
|
+
this.network = BITCOIN_NETWORKS.testnet;
|
|
100
|
+
}
|
|
101
|
+
if (previousAddress !== wallet.address) {
|
|
102
|
+
this.emit("accountsChanged", [wallet.address]);
|
|
103
|
+
this.clearUtxoCache();
|
|
104
|
+
}
|
|
105
|
+
this.emit("connect", {
|
|
106
|
+
address: wallet.address,
|
|
107
|
+
network: this.network.type
|
|
108
|
+
});
|
|
109
|
+
console.log("[BitcoinProvider] \u2705 Wallet restored:", wallet.address);
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* Clear wallet (disconnect)
|
|
113
|
+
*/
|
|
114
|
+
clearWallet() {
|
|
115
|
+
this.wallet = null;
|
|
116
|
+
this.connected = false;
|
|
117
|
+
this.clearUtxoCache();
|
|
118
|
+
this.emit("disconnect");
|
|
119
|
+
this.emit("accountsChanged", []);
|
|
120
|
+
console.log("[BitcoinProvider] \u{1F50C} Wallet disconnected");
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Set PIN request callback for transaction signing
|
|
124
|
+
*/
|
|
125
|
+
setRequestPinCallback(callback) {
|
|
126
|
+
this.requestPinCallback = callback;
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* Request PIN from user
|
|
130
|
+
* First tries global callback, then falls back to manual callback
|
|
131
|
+
*/
|
|
132
|
+
async requestPin() {
|
|
133
|
+
const globalRequestPin = window.__TALKENKIT_REQUEST_PIN__;
|
|
134
|
+
if (globalRequestPin && typeof globalRequestPin === "function") {
|
|
135
|
+
return globalRequestPin("transaction");
|
|
136
|
+
}
|
|
137
|
+
if (!this.requestPinCallback) {
|
|
138
|
+
throw new BitcoinProviderError(
|
|
139
|
+
BitcoinErrorCode.INTERNAL_ERROR,
|
|
140
|
+
"PIN request callback not configured. Make sure RainbowKitProvider is rendered."
|
|
141
|
+
);
|
|
142
|
+
}
|
|
143
|
+
return this.requestPinCallback();
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* Set network
|
|
147
|
+
*/
|
|
148
|
+
setNetwork(networkKey) {
|
|
149
|
+
const newNetwork = BITCOIN_NETWORKS[networkKey];
|
|
150
|
+
if (!newNetwork) {
|
|
151
|
+
throw new BitcoinProviderError(
|
|
152
|
+
BitcoinErrorCode.INVALID_PARAMS,
|
|
153
|
+
`Unknown network: ${networkKey}`
|
|
154
|
+
);
|
|
155
|
+
}
|
|
156
|
+
const previousType = this.network.type;
|
|
157
|
+
this.network = newNetwork;
|
|
158
|
+
if (previousType !== newNetwork.type) {
|
|
159
|
+
this.emit("networkChanged", newNetwork.type);
|
|
160
|
+
this.clearUtxoCache();
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
/**
|
|
164
|
+
* Get current network
|
|
165
|
+
*/
|
|
166
|
+
getNetwork() {
|
|
167
|
+
return this.network;
|
|
168
|
+
}
|
|
169
|
+
/**
|
|
170
|
+
* Check if connected
|
|
171
|
+
*/
|
|
172
|
+
isConnected() {
|
|
173
|
+
return this.connected && this.wallet !== null;
|
|
174
|
+
}
|
|
175
|
+
/**
|
|
176
|
+
* Get Bitcoin address
|
|
177
|
+
*/
|
|
178
|
+
async getAddress() {
|
|
179
|
+
if (!this.wallet) {
|
|
180
|
+
throw new BitcoinProviderError(
|
|
181
|
+
BitcoinErrorCode.DISCONNECTED,
|
|
182
|
+
"Wallet not connected"
|
|
183
|
+
);
|
|
184
|
+
}
|
|
185
|
+
return this.wallet.address;
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* Get compressed public key (33 bytes)
|
|
189
|
+
*/
|
|
190
|
+
async getPublicKey() {
|
|
191
|
+
if (!this.wallet) {
|
|
192
|
+
throw new BitcoinProviderError(
|
|
193
|
+
BitcoinErrorCode.DISCONNECTED,
|
|
194
|
+
"Wallet not connected"
|
|
195
|
+
);
|
|
196
|
+
}
|
|
197
|
+
return this.wallet.publicKey;
|
|
198
|
+
}
|
|
199
|
+
/**
|
|
200
|
+
* Get address type (bech32, p2pkh, etc.)
|
|
201
|
+
*/
|
|
202
|
+
getAddressType() {
|
|
203
|
+
if (!this.wallet) {
|
|
204
|
+
throw new BitcoinProviderError(
|
|
205
|
+
BitcoinErrorCode.DISCONNECTED,
|
|
206
|
+
"Wallet not connected"
|
|
207
|
+
);
|
|
208
|
+
}
|
|
209
|
+
return this.wallet.addressType;
|
|
210
|
+
}
|
|
211
|
+
/**
|
|
212
|
+
* Clear UTXO cache
|
|
213
|
+
*/
|
|
214
|
+
clearUtxoCache() {
|
|
215
|
+
this.utxoCache.clear();
|
|
216
|
+
this.cacheExpiry.clear();
|
|
217
|
+
}
|
|
218
|
+
/**
|
|
219
|
+
* Check if cache is valid
|
|
220
|
+
*/
|
|
221
|
+
isCacheValid(address) {
|
|
222
|
+
const expiry = this.cacheExpiry.get(address);
|
|
223
|
+
if (!expiry)
|
|
224
|
+
return false;
|
|
225
|
+
return Date.now() < expiry;
|
|
226
|
+
}
|
|
227
|
+
/**
|
|
228
|
+
* Get UTXOs for address (with caching)
|
|
229
|
+
*/
|
|
230
|
+
async getUtxos(forceRefresh = false) {
|
|
231
|
+
if (!this.wallet) {
|
|
232
|
+
throw new BitcoinProviderError(
|
|
233
|
+
BitcoinErrorCode.DISCONNECTED,
|
|
234
|
+
"Wallet not connected"
|
|
235
|
+
);
|
|
236
|
+
}
|
|
237
|
+
const address = this.wallet.address;
|
|
238
|
+
if (!forceRefresh && this.isCacheValid(address)) {
|
|
239
|
+
const cached = this.utxoCache.get(address);
|
|
240
|
+
if (cached) {
|
|
241
|
+
console.log(
|
|
242
|
+
`[BitcoinProvider] \u{1F4E6} Using cached UTXOs (${cached.length} items)`
|
|
243
|
+
);
|
|
244
|
+
return cached;
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
try {
|
|
248
|
+
console.log("[BitcoinProvider] \u{1F50D} Fetching UTXOs from network...");
|
|
249
|
+
const utxos = await this.client.bitcoin.getUtxos(
|
|
250
|
+
address,
|
|
251
|
+
this.network.type
|
|
252
|
+
);
|
|
253
|
+
this.utxoCache.set(address, utxos);
|
|
254
|
+
this.cacheExpiry.set(address, Date.now() + this.CACHE_TTL);
|
|
255
|
+
console.log(`[BitcoinProvider] \u2705 Fetched ${utxos.length} UTXOs`);
|
|
256
|
+
return utxos;
|
|
257
|
+
} catch (error) {
|
|
258
|
+
console.error(
|
|
259
|
+
"[BitcoinProvider] \u274C Failed to fetch UTXOs:",
|
|
260
|
+
error.message
|
|
261
|
+
);
|
|
262
|
+
throw new BitcoinProviderError(
|
|
263
|
+
BitcoinErrorCode.INTERNAL_ERROR,
|
|
264
|
+
"Failed to fetch UTXOs",
|
|
265
|
+
error
|
|
266
|
+
);
|
|
267
|
+
}
|
|
268
|
+
}
|
|
269
|
+
/**
|
|
270
|
+
* Get total balance (sum of all UTXOs)
|
|
271
|
+
* Returns balance in satoshis
|
|
272
|
+
*/
|
|
273
|
+
async getBalance(forceRefresh = false) {
|
|
274
|
+
const utxos = await this.getUtxos(forceRefresh);
|
|
275
|
+
const balance = utxos.reduce((sum, utxo) => sum + utxo.value, 0);
|
|
276
|
+
console.log(
|
|
277
|
+
`[BitcoinProvider] \u{1F4B0} Balance: ${balance} satoshis (${balance / 1e8} BTC)`
|
|
278
|
+
);
|
|
279
|
+
return balance;
|
|
280
|
+
}
|
|
281
|
+
/**
|
|
282
|
+
* Estimate transaction fee
|
|
283
|
+
* Returns fee rate in satoshis per byte
|
|
284
|
+
*/
|
|
285
|
+
async estimateFee(targetBlocks = 6) {
|
|
286
|
+
try {
|
|
287
|
+
const feeRate = await this.client.bitcoin.estimateFee(
|
|
288
|
+
this.network.type,
|
|
289
|
+
targetBlocks
|
|
290
|
+
);
|
|
291
|
+
console.log(`[BitcoinProvider] \u26FD Fee rate: ${feeRate} sat/byte`);
|
|
292
|
+
return feeRate;
|
|
293
|
+
} catch (_error) {
|
|
294
|
+
console.error("[BitcoinProvider] \u26A0\uFE0F Fee estimation failed, using default");
|
|
295
|
+
return 1;
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
/**
|
|
299
|
+
* Sign Bitcoin message (BIP-322)
|
|
300
|
+
* NOTE: Currently not supported - Bitcoin uses v2 API which doesn't have message signing endpoint
|
|
301
|
+
* Only transaction signing is supported via PSBT
|
|
302
|
+
*
|
|
303
|
+
* @param _message - Message to sign (string) - unused, always throws error
|
|
304
|
+
* @returns Signature in base64 format
|
|
305
|
+
*/
|
|
306
|
+
async signMessage(_message) {
|
|
307
|
+
console.log("[BitcoinProvider] \u26A0\uFE0F Bitcoin message signing requested");
|
|
308
|
+
throw new BitcoinProviderError(
|
|
309
|
+
BitcoinErrorCode.UNSUPPORTED_METHOD,
|
|
310
|
+
"Bitcoin message signing is not supported. Bitcoin uses v2 API which only supports transaction signing (PSBT). Use signTransaction() instead."
|
|
311
|
+
);
|
|
312
|
+
}
|
|
313
|
+
/**
|
|
314
|
+
* High-level transaction sending (like Solana pattern)
|
|
315
|
+
* Creates, signs, and broadcasts transaction
|
|
316
|
+
*
|
|
317
|
+
* @param params - Transaction parameters
|
|
318
|
+
* @param params.toAddress - Recipient Bitcoin address
|
|
319
|
+
* @param params.amount - Amount in BTC (will be converted to satoshis)
|
|
320
|
+
* @returns Transaction hash
|
|
321
|
+
*/
|
|
322
|
+
async sendTransaction(params) {
|
|
323
|
+
if (!this.wallet) {
|
|
324
|
+
throw new BitcoinProviderError(
|
|
325
|
+
BitcoinErrorCode.DISCONNECTED,
|
|
326
|
+
"Wallet not connected"
|
|
327
|
+
);
|
|
328
|
+
}
|
|
329
|
+
try {
|
|
330
|
+
console.log("[BitcoinProvider] \u{1F4B8} Starting high-level transaction...");
|
|
331
|
+
const authStateKey = "talkenkit_abc_auth_state";
|
|
332
|
+
const authState = typeof window !== "undefined" ? localStorage.getItem(authStateKey) : null;
|
|
333
|
+
if (!authState) {
|
|
334
|
+
throw new BitcoinProviderError(
|
|
335
|
+
BitcoinErrorCode.UNAUTHORIZED,
|
|
336
|
+
"Not authenticated - auth state not found"
|
|
337
|
+
);
|
|
338
|
+
}
|
|
339
|
+
const parsed = JSON.parse(authState);
|
|
340
|
+
const evmWallet = parsed.wallet;
|
|
341
|
+
if (!evmWallet?.uid || !evmWallet?.sid || !evmWallet?.pvencstr || !evmWallet?.wid) {
|
|
342
|
+
throw new BitcoinProviderError(
|
|
343
|
+
BitcoinErrorCode.UNAUTHORIZED,
|
|
344
|
+
"EVM wallet data not found (required for Bitcoin signing)"
|
|
345
|
+
);
|
|
346
|
+
}
|
|
347
|
+
console.log(
|
|
348
|
+
"[BitcoinProvider] \u{1F510} Requesting PIN for Bitcoin transaction..."
|
|
349
|
+
);
|
|
350
|
+
const pin = await this.requestPin();
|
|
351
|
+
const encoder = new TextEncoder();
|
|
352
|
+
const data = encoder.encode(pin);
|
|
353
|
+
const hashBuffer = await crypto.subtle.digest("SHA-256", data);
|
|
354
|
+
const hashArray = Array.from(new Uint8Array(hashBuffer));
|
|
355
|
+
const pinHash = hashArray.map((b) => b.toString(16).padStart(2, "0")).join("");
|
|
356
|
+
const satoshis = Math.floor(params.amount * 1e8);
|
|
357
|
+
const SecureService = (await import("./abcWallet/secure.js")).default;
|
|
358
|
+
const secureService = new SecureService(this.client.bitcoin.getBaseURL());
|
|
359
|
+
const walletData = {
|
|
360
|
+
address: evmWallet.address,
|
|
361
|
+
keyId: evmWallet.keyId,
|
|
362
|
+
encryptedShare: evmWallet.encryptedShare,
|
|
363
|
+
uid: evmWallet.uid,
|
|
364
|
+
sid: evmWallet.sid,
|
|
365
|
+
wid: evmWallet.wid,
|
|
366
|
+
pvencstr: evmWallet.pvencstr,
|
|
367
|
+
encryptDevicePassword: evmWallet.encryptDevicePassword,
|
|
368
|
+
pubkey: evmWallet.pubkey
|
|
369
|
+
};
|
|
370
|
+
const txHash = await this.client.bitcoin.sendTransaction(
|
|
371
|
+
{
|
|
372
|
+
amount: satoshis.toString(),
|
|
373
|
+
to: params.toAddress,
|
|
374
|
+
pubkey: this.wallet.publicKey,
|
|
375
|
+
network: this.network.type
|
|
376
|
+
},
|
|
377
|
+
walletData,
|
|
378
|
+
pinHash,
|
|
379
|
+
secureService
|
|
380
|
+
);
|
|
381
|
+
console.log("[BitcoinProvider] \u2705 Transaction complete:", txHash);
|
|
382
|
+
this.emit("transactionBroadcasted", {
|
|
383
|
+
txHash,
|
|
384
|
+
explorerUrl: `${this.network.explorer}/tx/${txHash}`
|
|
385
|
+
});
|
|
386
|
+
this.clearUtxoCache();
|
|
387
|
+
return txHash;
|
|
388
|
+
} catch (error) {
|
|
389
|
+
if (error.message?.includes("cancelled") || error.message?.includes("rejected")) {
|
|
390
|
+
console.log("[BitcoinProvider] \u2139\uFE0F User cancelled transaction");
|
|
391
|
+
throw new BitcoinProviderError(
|
|
392
|
+
BitcoinErrorCode.USER_REJECTED,
|
|
393
|
+
"User rejected transaction",
|
|
394
|
+
error
|
|
395
|
+
);
|
|
396
|
+
}
|
|
397
|
+
console.error("[BitcoinProvider] \u274C Transaction failed:", error.message);
|
|
398
|
+
if (error.message?.includes("insufficient")) {
|
|
399
|
+
throw new BitcoinProviderError(
|
|
400
|
+
BitcoinErrorCode.INSUFFICIENT_FUNDS,
|
|
401
|
+
"Insufficient BTC balance",
|
|
402
|
+
error
|
|
403
|
+
);
|
|
404
|
+
}
|
|
405
|
+
this.emit("error", error);
|
|
406
|
+
throw new BitcoinProviderError(
|
|
407
|
+
BitcoinErrorCode.INTERNAL_ERROR,
|
|
408
|
+
"Failed to send transaction",
|
|
409
|
+
error
|
|
410
|
+
);
|
|
411
|
+
}
|
|
412
|
+
}
|
|
413
|
+
/**
|
|
414
|
+
* Broadcast signed transaction to network
|
|
415
|
+
*
|
|
416
|
+
* @param rawTransaction - Raw transaction in hex format
|
|
417
|
+
* @param psbt - Optional finalized PSBT
|
|
418
|
+
* @returns Transaction hash
|
|
419
|
+
*/
|
|
420
|
+
async broadcastTransaction(rawTransaction, psbt) {
|
|
421
|
+
if (!this.wallet) {
|
|
422
|
+
throw new BitcoinProviderError(
|
|
423
|
+
BitcoinErrorCode.DISCONNECTED,
|
|
424
|
+
"Wallet not connected"
|
|
425
|
+
);
|
|
426
|
+
}
|
|
427
|
+
try {
|
|
428
|
+
console.log("[BitcoinProvider] \u{1F4E1} Broadcasting transaction...");
|
|
429
|
+
const result = await this.client.bitcoin.sendBitcoinTransaction({
|
|
430
|
+
network: this.network.type,
|
|
431
|
+
rawTransaction,
|
|
432
|
+
...psbt && { psbt }
|
|
433
|
+
});
|
|
434
|
+
console.log(
|
|
435
|
+
"[BitcoinProvider] \u2705 Transaction broadcasted:",
|
|
436
|
+
result.txHash
|
|
437
|
+
);
|
|
438
|
+
this.emit("transactionBroadcasted", {
|
|
439
|
+
txHash: result.txHash,
|
|
440
|
+
explorerUrl: `${this.network.explorer}/tx/${result.txHash}`
|
|
441
|
+
});
|
|
442
|
+
this.clearUtxoCache();
|
|
443
|
+
return result.txHash;
|
|
444
|
+
} catch (error) {
|
|
445
|
+
console.error(
|
|
446
|
+
"[BitcoinProvider] \u274C Transaction broadcast failed:",
|
|
447
|
+
error.message
|
|
448
|
+
);
|
|
449
|
+
this.emit("error", error);
|
|
450
|
+
throw new BitcoinProviderError(
|
|
451
|
+
BitcoinErrorCode.INTERNAL_ERROR,
|
|
452
|
+
"Failed to broadcast transaction",
|
|
453
|
+
error
|
|
454
|
+
);
|
|
455
|
+
}
|
|
456
|
+
}
|
|
457
|
+
/**
|
|
458
|
+
* Get wallet info
|
|
459
|
+
*/
|
|
460
|
+
getWalletInfo() {
|
|
461
|
+
if (!this.wallet)
|
|
462
|
+
return null;
|
|
463
|
+
return {
|
|
464
|
+
address: this.wallet.address,
|
|
465
|
+
publicKey: this.wallet.publicKey,
|
|
466
|
+
addressType: this.wallet.addressType,
|
|
467
|
+
network: this.network.type
|
|
468
|
+
};
|
|
469
|
+
}
|
|
470
|
+
/**
|
|
471
|
+
* Refresh UTXO cache
|
|
472
|
+
*/
|
|
473
|
+
async refreshUtxos() {
|
|
474
|
+
return this.getUtxos(true);
|
|
475
|
+
}
|
|
476
|
+
};
|
|
477
|
+
|
|
478
|
+
export {
|
|
479
|
+
BitcoinProviderError,
|
|
480
|
+
BITCOIN_NETWORKS,
|
|
481
|
+
AbcBitcoinProvider
|
|
482
|
+
};
|