@meshsdk/wallet 1.8.7 → 1.8.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs +39 -58
- package/dist/index.d.cts +29 -10
- package/dist/index.d.ts +29 -10
- package/dist/index.js +39 -58
- package/package.json +6 -8
package/dist/index.cjs
CHANGED
|
@@ -711,9 +711,22 @@ var EmbeddedWallet = class extends WalletStaticMethods {
|
|
|
711
711
|
}
|
|
712
712
|
return _account;
|
|
713
713
|
}
|
|
714
|
+
/**
|
|
715
|
+
* Get wallet network ID.
|
|
716
|
+
*
|
|
717
|
+
* @returns network ID
|
|
718
|
+
*/
|
|
714
719
|
getNetworkId() {
|
|
715
720
|
return this._networkId;
|
|
716
721
|
}
|
|
722
|
+
/**
|
|
723
|
+
* This endpoint utilizes the [CIP-8 - Message Signing](https://cips.cardano.org/cips/cip8/) to sign arbitrary data, to verify the data was signed by the owner of the private key.
|
|
724
|
+
*
|
|
725
|
+
* @param address - bech32 address to sign the data with
|
|
726
|
+
* @param payload - the data to be signed
|
|
727
|
+
* @param accountIndex account index (default: 0)
|
|
728
|
+
* @returns a signature
|
|
729
|
+
*/
|
|
717
730
|
signData(address, payload, accountIndex = 0, keyIndex = 0) {
|
|
718
731
|
try {
|
|
719
732
|
const { baseAddress, enterpriseAddress, rewardAddress, paymentKey } = this.getAccount(accountIndex, keyIndex);
|
|
@@ -734,6 +747,14 @@ var EmbeddedWallet = class extends WalletStaticMethods {
|
|
|
734
747
|
);
|
|
735
748
|
}
|
|
736
749
|
}
|
|
750
|
+
/**
|
|
751
|
+
* This endpoints sign the provided transaction (unsignedTx) with the private key of the owner.
|
|
752
|
+
*
|
|
753
|
+
* @param unsignedTx - a transaction in CBOR
|
|
754
|
+
* @param accountIndex account index (default: 0)
|
|
755
|
+
* @param keyIndex key index (default: 0)
|
|
756
|
+
* @returns VkeyWitness
|
|
757
|
+
*/
|
|
737
758
|
signTx(unsignedTx, accountIndex = 0, keyIndex = 0) {
|
|
738
759
|
try {
|
|
739
760
|
const txHash = (0, import_core_cst.deserializeTxHash)((0, import_core_cst.resolveTxHash)(unsignedTx));
|
|
@@ -847,7 +868,7 @@ var AppWallet = class {
|
|
|
847
868
|
);
|
|
848
869
|
return utxos.map((utxo) => (0, import_core_cst2.toTxUnspentOutput)(utxo));
|
|
849
870
|
}
|
|
850
|
-
signData(address, payload, accountIndex = 0, keyIndex = 0) {
|
|
871
|
+
async signData(address, payload, accountIndex = 0, keyIndex = 0) {
|
|
851
872
|
try {
|
|
852
873
|
return this._wallet.signData(address, payload, accountIndex, keyIndex);
|
|
853
874
|
} catch (error) {
|
|
@@ -856,7 +877,7 @@ var AppWallet = class {
|
|
|
856
877
|
);
|
|
857
878
|
}
|
|
858
879
|
}
|
|
859
|
-
signTx(unsignedTx, partialSign = false, accountIndex = 0, keyIndex = 0) {
|
|
880
|
+
async signTx(unsignedTx, partialSign = false, accountIndex = 0, keyIndex = 0) {
|
|
860
881
|
try {
|
|
861
882
|
const tx = (0, import_core_cst2.deserializeTx)(unsignedTx);
|
|
862
883
|
if (!partialSign && tx.witnessSet().vkeys() !== void 0 && tx.witnessSet().vkeys().size() !== 0)
|
|
@@ -901,46 +922,6 @@ var AppWallet = class {
|
|
|
901
922
|
var import_common2 = require("@meshsdk/common");
|
|
902
923
|
var import_core_csl = require("@meshsdk/core-csl");
|
|
903
924
|
var import_core_cst3 = require("@meshsdk/core-cst");
|
|
904
|
-
|
|
905
|
-
// src/browser/metamask.ts
|
|
906
|
-
var import_dapp_client_cardano = require("@nufi/dapp-client-cardano");
|
|
907
|
-
var import_dapp_client_core = __toESM(require("@nufi/dapp-client-core"), 1);
|
|
908
|
-
|
|
909
|
-
// src/types/nufisnap.ts
|
|
910
|
-
var nufiSnap = {
|
|
911
|
-
id: "nufiSnap",
|
|
912
|
-
name: "MetaMask",
|
|
913
|
-
icon: "data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz4KPHN2ZyBpZD0iTGF5ZXJfMiIgZGF0YS1uYW1lPSJMYXllciAyIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxNjkuMiAxNjMuNzEiPgogIDxkZWZzPgogICAgPHN0eWxlPgogICAgICAuY2xzLTEgewogICAgICAgIGZpbGw6ICNlMjc2MjU7CiAgICAgIH0KCiAgICAgIC5jbHMtMSwgLmNscy0yLCAuY2xzLTMsIC5jbHMtNCwgLmNscy01LCAuY2xzLTYsIC5jbHMtNywgLmNscy04LCAuY2xzLTkgewogICAgICAgIHN0cm9rZS13aWR0aDogMHB4OwogICAgICB9CgogICAgICAuY2xzLTIgewogICAgICAgIGZpbGw6ICM3NjNlMWE7CiAgICAgIH0KCiAgICAgIC5jbHMtMyB7CiAgICAgICAgZmlsbDogI2MwYWQ5ZTsKICAgICAgfQoKICAgICAgLmNscy00IHsKICAgICAgICBmaWxsOiAjMzQ2OGQxOwogICAgICB9CgogICAgICAuY2xzLTUgewogICAgICAgIGZpbGw6ICNjYzYyMjg7CiAgICAgIH0KCiAgICAgIC5jbHMtNiB7CiAgICAgICAgZmlsbDogI2Y1ODQxZjsKICAgICAgfQoKICAgICAgLmNscy03IHsKICAgICAgICBmaWxsOiAjZDdjMWIzOwogICAgICB9CgogICAgICAuY2xzLTggewogICAgICAgIGZpbGw6ICNmZmY7CiAgICAgICAgZmlsbC1ydWxlOiBldmVub2RkOwogICAgICB9CgogICAgICAuY2xzLTkgewogICAgICAgIGZpbGw6ICMyZjM0M2I7CiAgICAgIH0KICAgIDwvc3R5bGU+CiAgPC9kZWZzPgogIDxnIGlkPSJMYXllcl8xLTIiIGRhdGEtbmFtZT0iTGF5ZXIgMSI+CiAgICA8ZyBpZD0iTU1fSGVhZF9iYWNrZ3JvdW5kX0RvX25vdF9lZGl0XyIgZGF0YS1uYW1lPSJNTSBIZWFkIGJhY2tncm91bmQgKERvIG5vdCBlZGl0KSI+CiAgICAgIDxwYXRoIGNsYXNzPSJjbHMtNiIgZD0iTTE0MS44LDcwLjVsNi45LTguMS0zLTIuMiw0LjgtNC40LTMuNy0yLjgsNC44LTMuNi0zLjEtMi40LDUtMjQuNC03LjYtMjIuNk0xNDUuOSwwbC00OC44LDE4LjFoLTQwLjdMNy42LDBsLjMuMkw3LjYsMCwwLDIyLjZsNS4xLDI0LjQtMy4yLDIuNCw0LjksMy42LTMuNywyLjgsNC44LDQuNC0zLDIuMiw2LjksOC4xTDEuMywxMDIuOWgwbDkuNywzMy4xLDM0LjEtOS40di0uMS4xaDBsNi42LDUuNCwxMy41LDkuMmgyMy4xbDEzLjUtOS4yLDYuNi01LjRoMGwzNC4yLDkuNCw5LjgtMzMuMWgwbC0xMC42LTMyLjQiLz4KICAgIDwvZz4KICAgIDxnIGlkPSJMb2dvcyI+CiAgICAgIDxnPgogICAgICAgIDxwb2x5Z29uIGNsYXNzPSJjbHMtMSIgcG9pbnRzPSIxNDUuOSAwIDg2IDQ0LjEgOTcuMSAxOC4xIDE0NS45IDAiLz4KICAgICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTEiIHBvaW50cz0iNy42IDAgNjcgNDQuNSA1Ni40IDE4LjEgNy42IDAiLz4KICAgICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTEiIHBvaW50cz0iMTI0LjQgMTAyLjMgMTA4LjQgMTI2LjUgMTQyLjYgMTM1LjkgMTUyLjQgMTAyLjggMTI0LjQgMTAyLjMiLz4KICAgICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTEiIHBvaW50cz0iMS4zIDEwMi44IDExIDEzNS45IDQ1LjEgMTI2LjUgMjkuMiAxMDIuMyAxLjMgMTAyLjgiLz4KICAgICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTEiIHBvaW50cz0iNDMuMyA2MS4zIDMzLjggNzUuNiA2Ny42IDc3LjEgNjYuNSA0MC45IDQzLjMgNjEuMyIvPgogICAgICAgIDxwb2x5Z29uIGNsYXNzPSJjbHMtMSIgcG9pbnRzPSIxMTAuMyA2MS4zIDg2LjcgNDAuNSA4NiA3Ny4xIDExOS44IDc1LjYgMTEwLjMgNjEuMyIvPgogICAgICAgIDxwb2x5Z29uIGNsYXNzPSJjbHMtMSIgcG9pbnRzPSI0NS4xIDEyNi41IDY1LjYgMTE2LjcgNDcuOSAxMDMuMSA0NS4xIDEyNi41Ii8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy0xIiBwb2ludHM9Ijg4IDExNi43IDEwOC40IDEyNi41IDEwNS42IDEwMy4xIDg4IDExNi43Ii8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy03IiBwb2ludHM9IjEwOC40IDEyNi41IDg4IDExNi43IDg5LjcgMTI5LjkgODkuNSAxMzUuNSAxMDguNCAxMjYuNSIvPgogICAgICAgIDxwb2x5Z29uIGNsYXNzPSJjbHMtNyIgcG9pbnRzPSI0NS4xIDEyNi41IDY0LjEgMTM1LjUgNjQgMTI5LjkgNjUuNiAxMTYuNyA0NS4xIDEyNi41Ii8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy05IiBwb2ludHM9IjY0LjQgOTQuMyA0Ny41IDg5LjQgNTkuNSA4My45IDY0LjQgOTQuMyIvPgogICAgICAgIDxwb2x5Z29uIGNsYXNzPSJjbHMtOSIgcG9pbnRzPSI4OS4xIDk0LjMgOTQuMSA4My45IDEwNi4xIDg5LjQgODkuMSA5NC4zIi8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy01IiBwb2ludHM9IjQ1LjEgMTI2LjUgNDguMSAxMDIuMyAyOS4yIDEwMi44IDQ1LjEgMTI2LjUiLz4KICAgICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTUiIHBvaW50cz0iMTA1LjUgMTAyLjMgMTA4LjQgMTI2LjUgMTI0LjQgMTAyLjggMTA1LjUgMTAyLjMiLz4KICAgICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTUiIHBvaW50cz0iMTE5LjggNzUuNiA4NiA3Ny4xIDg5LjEgOTQuMyA5NC4xIDgzLjkgMTA2LjEgODkuNCAxMTkuOCA3NS42Ii8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy01IiBwb2ludHM9IjQ3LjUgODkuNCA1OS41IDgzLjkgNjQuNCA5NC4zIDY3LjYgNzcuMSAzMy44IDc1LjYgNDcuNSA4OS40Ii8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy0xIiBwb2ludHM9IjMzLjggNzUuNiA0Ny45IDEwMy4xIDQ3LjUgODkuNCAzMy44IDc1LjYiLz4KICAgICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTEiIHBvaW50cz0iMTA2LjEgODkuNCAxMDUuNiAxMDMuMSAxMTkuOCA3NS42IDEwNi4xIDg5LjQiLz4KICAgICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTEiIHBvaW50cz0iNjcuNiA3Ny4xIDY0LjQgOTQuMyA2OC40IDExNC43IDY5LjMgODcuOSA2Ny42IDc3LjEiLz4KICAgICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTEiIHBvaW50cz0iODYgNzcuMSA4NC4zIDg3LjggODUuMSAxMTQuNyA4OS4xIDk0LjMgODYgNzcuMSIvPgogICAgICAgIDxwb2x5Z29uIGNsYXNzPSJjbHMtNiIgcG9pbnRzPSI4OS4xIDk0LjMgODUuMSAxMTQuNyA4OCAxMTYuNyAxMDUuNiAxMDMuMSAxMDYuMSA4OS40IDg5LjEgOTQuMyIvPgogICAgICAgIDxwb2x5Z29uIGNsYXNzPSJjbHMtNiIgcG9pbnRzPSI0Ny41IDg5LjQgNDcuOSAxMDMuMSA2NS42IDExNi43IDY4LjQgMTE0LjcgNjQuNCA5NC4zIDQ3LjUgODkuNCIvPgogICAgICAgIDxwb2x5Z29uIGNsYXNzPSJjbHMtMyIgcG9pbnRzPSI4OS41IDEzNS41IDg5LjcgMTI5LjkgODguMSAxMjguNiA2NS40IDEyOC42IDY0IDEyOS45IDY0LjEgMTM1LjUgNDUuMSAxMjYuNSA1MS43IDEzMS45IDY1LjIgMTQxLjIgODguMyAxNDEuMiAxMDEuOCAxMzEuOSAxMDguNCAxMjYuNSA4OS41IDEzNS41Ii8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy05IiBwb2ludHM9Ijg4IDExNi43IDg1LjEgMTE0LjcgNjguNCAxMTQuNyA2NS42IDExNi43IDY0IDEyOS45IDY1LjQgMTI4LjYgODguMSAxMjguNiA4OS43IDEyOS45IDg4IDExNi43Ii8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy0yIiBwb2ludHM9IjE0OC41IDQ3IDE1My41IDIyLjYgMTQ1LjkgMCA4OCA0Mi42IDExMC4zIDYxLjMgMTQxLjggNzAuNSAxNDguNyA2Mi40IDE0NS43IDYwLjIgMTUwLjUgNTUuOSAxNDYuOCA1MyAxNTEuNiA0OS40IDE0OC41IDQ3Ii8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy0yIiBwb2ludHM9IjAgMjIuNiA1LjEgNDcgMS45IDQ5LjQgNi43IDUzLjEgMyA1NS45IDcuOCA2MC4yIDQuOCA2Mi40IDExLjggNzAuNSA0My4zIDYxLjMgNjUuNiA0Mi42IDcuNiAwIDAgMjIuNiIvPgogICAgICAgIDxwb2x5Z29uIGNsYXNzPSJjbHMtNiIgcG9pbnRzPSIxNDEuOCA3MC41IDExMC4zIDYxLjMgMTE5LjggNzUuNiAxMDUuNiAxMDMuMSAxMjQuNCAxMDIuOCAxNTIuNCAxMDIuOCAxNDEuOCA3MC41Ii8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy02IiBwb2ludHM9IjQzLjMgNjEuMyAxMS44IDcwLjUgMS4zIDEwMi44IDI5LjIgMTAyLjggNDcuOSAxMDMuMSAzMy44IDc1LjYgNDMuMyA2MS4zIi8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy02IiBwb2ludHM9Ijg2IDc3LjEgODggNDIuNiA5Ny4xIDE4LjEgNTYuNCAxOC4xIDY1LjYgNDIuNiA2Ny42IDc3LjEgNjguNCA4Ny45IDY4LjQgMTE0LjcgODUuMSAxMTQuNyA4NS4yIDg3LjkgODYgNzcuMSIvPgogICAgICA8L2c+CiAgICA8L2c+CiAgICA8ZyBpZD0iY2FyZGFub19hZGEiIGRhdGEtbmFtZT0iY2FyZGFubyBhZGEiPgogICAgICA8ZyBpZD0iY2FyZGFub19hZGEtMiIgZGF0YS1uYW1lPSJjYXJkYW5vIGFkYS0yIj4KICAgICAgICA8Y2lyY2xlIGlkPSJf0K3Qu9C70LjQv9GBXzYiIGRhdGEtbmFtZT0i0K3Qu9C70LjQv9GBIDYiIGNsYXNzPSJjbHMtNCIgY3g9IjEyOC4wNSIgY3k9IjEyMi41NiIgcj0iNDEuMTUiLz4KICAgICAgICA8cGF0aCBpZD0iX9Ct0LvQu9C40L/RgV82X9C60L7Qv9C40Y9fMjkiIGRhdGEtbmFtZT0i0K3Qu9C70LjQv9GBIDYg0LrQvtC/0LjRjyAyOSIgY2xhc3M9ImNscy04IiBkPSJNMTIzLjQ2LDEwOS45M2MyLjI1LDAsNC4wNywxLjgyLDQuMDcsNC4wNywwLDIuMjUtMS44Miw0LjA3LTQuMDcsNC4wNy0yLjI1LDAtNC4wNy0xLjgyLTQuMDctNC4wNywwLTIuMjUsMS44Mi00LjA3LDQuMDctNC4wN1pNMTMzLjI4LDEwOS45M2MyLjI1LDAsNC4wNywxLjgyLDQuMDcsNC4wNywwLDIuMjUtMS44Miw0LjA3LTQuMDcsNC4wNy0yLjI1LDAtNC4wNy0xLjgyLTQuMDctNC4wNywwLTIuMjUsMS44Mi00LjA3LDQuMDctNC4wN2gwWk0xMzMuMjgsMTI3LjA1YzIuMjUsMCw0LjA3LDEuODIsNC4wNyw0LjA3LDAsMi4yNS0xLjgyLDQuMDctNC4wNyw0LjA3LTIuMjUsMC00LjA3LTEuODItNC4wNy00LjA3LDAtMi4yNSwxLjgyLTQuMDcsNC4wNy00LjA3aDAsMFpNMTIzLjQ2LDEyNy4wNWMyLjI1LDAsNC4wNywxLjgyLDQuMDcsNC4wNywwLDIuMjUtMS44Miw0LjA3LTQuMDcsNC4wNy0yLjI1LDAtNC4wNy0xLjgyLTQuMDctNC4wNywwLTIuMjUsMS44Mi00LjA3LDQuMDctNC4wN1pNMTE4LjQxLDExOC42M2MyLjI1LDAsNC4wNywxLjgyLDQuMDcsNC4wNywwLDIuMjUtMS44Miw0LjA3LTQuMDcsNC4wNy0yLjI1LDAtNC4wNy0xLjgyLTQuMDctNC4wNywwLTIuMjUsMS44Mi00LjA3LDQuMDctNC4wN2gwWk0xMzguMzMsMTE4LjYzYzIuMjUsMCw0LjA3LDEuODIsNC4wNyw0LjA3LDAsMi4yNS0xLjgyLDQuMDctNC4wNyw0LjA3LTIuMjUsMC00LjA3LTEuODItNC4wNy00LjA3LDAtMi4yNSwxLjgyLTQuMDcsNC4wNy00LjA3aDBaTTE0Mi45NiwxMTEuNjJjMS4zOSwwLDIuNTIsMS4xMywyLjUyLDIuNTMsMCwxLjM5LTEuMTMsMi41Mi0yLjUzLDIuNTItMS4zOSwwLTIuNTItMS4xMy0yLjUyLTIuNTJzMS4xMy0yLjUyLDIuNTItMi41MmgwWk0xNDIuOTYsMTI4LjQ1YzEuMzksMCwyLjUyLDEuMTMsMi41MiwyLjUzLDAsMS4zOS0xLjEzLDIuNTItMi41MywyLjUyLTEuMzksMC0yLjUyLTEuMTMtMi41Mi0yLjUyczEuMTMtMi41MiwyLjUyLTIuNTJoMFpNMTEzLjc4LDEyOC40NWMxLjM5LDAsMi41MiwxLjEzLDIuNTIsMi41MywwLDEuMzktMS4xMywyLjUyLTIuNTMsMi41Mi0xLjM5LDAtMi41Mi0xLjEzLTIuNTItMi41MiwwLTEuMzksMS4xMy0yLjUyLDIuNTMtMi41MmgwWk0xMTMuNzgsMTExLjYyYzEuMzksMCwyLjUyLDEuMTMsMi41MiwyLjUzLDAsMS4zOS0xLjEzLDIuNTItMi41MywyLjUyLTEuMzksMC0yLjUyLTEuMTMtMi41Mi0yLjUyLDAtMS4zOSwxLjEzLTIuNTIsMi41My0yLjUyaDBaTTEyOC4zNywxMDMuMmMxLjM5LDAsMi41MiwxLjEzLDIuNTIsMi41MywwLDEuMzktMS4xMywyLjUyLTIuNTMsMi41Mi0xLjM5LDAtMi41Mi0xLjEzLTIuNTItMi41MnMxLjEzLTIuNTIsMi41Mi0yLjUyaDBaTTEyOC4zNywxMzYuODZjMS4zOSwwLDIuNTIsMS4xMywyLjUyLDIuNTMsMCwxLjM5LTEuMTMsMi41Mi0yLjUzLDIuNTItMS4zOSwwLTIuNTItMS4xMy0yLjUyLTIuNTJzMS4xMy0yLjUyLDIuNTItMi41MmgwWk0xMzkuMTcsMTM5LjM5YzEuMTYsMCwyLjEuOTQsMi4xLDIuMSwwLDEuMTYtLjk0LDIuMS0yLjEsMi4xLTEuMTYsMC0yLjEtLjk0LTIuMS0yLjFzLjk0LTIuMSwyLjEtMi4xaDBaTTExNy41NywxMzkuMzljMS4xNiwwLDIuMS45NCwyLjEsMi4xLDAsMS4xNi0uOTQsMi4xLTIuMSwyLjEtMS4xNiwwLTIuMS0uOTQtMi4xLTIuMXMuOTQtMi4xLDIuMS0yLjFoMFpNMTE3LjU3LDEwMS41MmMxLjE2LDAsMi4xLjk0LDIuMSwyLjEsMCwxLjE2LS45NCwyLjEtMi4xLDIuMS0xLjE2LDAtMi4xLS45NC0yLjEtMi4xcy45NC0yLjEsMi4xLTIuMWgwWk0xMzkuMTcsMTAxLjUyYzEuMTYsMCwyLjEuOTQsMi4xLDIuMSwwLDEuMTYtLjk0LDIuMS0yLjEsMi4xLTEuMTYsMC0yLjEtLjk0LTIuMS0yLjFzLjk0LTIuMSwyLjEtMi4xaDBaTTE1MC4xMSwxMjAuMzFjMS4xNiwwLDIuMS45NCwyLjEsMi4xLDAsMS4xNi0uOTQsMi4xLTIuMSwyLjEtMS4xNiwwLTIuMS0uOTQtMi4xLTIuMSwwLTEuMTYuOTQtMi4xLDIuMS0yLjFoMFpNMTA2LjYyLDEyMC4zMWMxLjE2LDAsMi4xLjk0LDIuMSwyLjEsMCwxLjE2LS45NCwyLjEtMi4xLDIuMS0xLjE2LDAtMi4xLS45NC0yLjEtMi4xcy45NC0yLjEsMi4xLTIuMWgwWk0xMDUuMDgsMTA3LjQxYy45MywwLDEuNjguNzUsMS42OCwxLjY4cy0uNzUsMS42OC0xLjY4LDEuNjgtMS42OC0uNzUtMS42OC0xLjY4aDBjMC0uOTMuNzUtMS42OCwxLjY4LTEuNjhoMFpNMTA1LjA4LDEzNC4zNGMuOTMsMCwxLjY4Ljc1LDEuNjgsMS42OHMtLjc1LDEuNjgtMS42OCwxLjY4LTEuNjgtLjc1LTEuNjgtMS42OGgwYzAtLjkzLjc1LTEuNjgsMS42OC0xLjY4aDBaTTE1MS42NiwxMzQuMzRjLjkzLDAsMS42OC43NSwxLjY4LDEuNjgsMCwuOTMtLjc1LDEuNjgtMS42OCwxLjY4cy0xLjY4LS43NS0xLjY4LTEuNjhoMGMwLS45My43NS0xLjY4LDEuNjgtMS42OGgwWk0xNTEuNjYsMTA3LjQxYy45MywwLDEuNjguNzUsMS42OCwxLjY4LDAsLjkzLS43NSwxLjY4LTEuNjgsMS42OHMtMS42OC0uNzUtMS42OC0xLjY4aDBjMC0uOTMuNzUtMS42OCwxLjY4LTEuNjhoMFpNMTI4LjM3LDkzLjk0Yy45MywwLDEuNjguNzUsMS42OCwxLjY4LDAsLjkzLS43NSwxLjY4LTEuNjgsMS42OC0uOTMsMC0xLjY4LS43NS0xLjY4LTEuNjhoMGMwLS45My43NS0xLjY4LDEuNjgtMS42OGgwWk0xMjguMzcsMTQ3LjhjLjkzLDAsMS42OC43NSwxLjY4LDEuNjgsMCwuOTMtLjc1LDEuNjgtMS42OCwxLjY4LS45MywwLTEuNjgtLjc1LTEuNjgtMS42OHMuNzUtMS42OCwxLjY4LTEuNjhoMFpNMTQzLjI0LDE0Ni42OGMuNzcsMCwxLjQuNjMsMS40LDEuNCwwLC43Ny0uNjMsMS40LTEuNCwxLjRzLTEuNC0uNjMtMS40LTEuNGgwYzAtLjc3LjYzLTEuNCwxLjQtMS40Wk0xMTMuNSwxNDYuNjhjLjc3LDAsMS40LjYzLDEuNCwxLjRzLS42MywxLjQtMS40LDEuNC0xLjQtLjYzLTEuNC0xLjRoMGMwLS43Ny42My0xLjQsMS40LTEuNFpNMTEzLjUsOTUuNjNjLjc3LDAsMS40LjYzLDEuNCwxLjRzLS42MywxLjQtMS40LDEuNC0xLjQtLjYzLTEuNC0xLjRoMGMwLS43Ny42My0xLjQsMS40LTEuNGgwWk0xNDMuMjQsOTUuNjNjLjc3LDAsMS40LjYzLDEuNCwxLjQsMCwuNzctLjYzLDEuNC0xLjQsMS40cy0xLjQtLjYzLTEuNC0xLjRoMGMwLS43Ny42My0xLjQsMS40LTEuNGgwWk0xNTcuODMsMTIxLjE2Yy43NywwLDEuNC42MywxLjQsMS40LDAsLjc3LS42MywxLjQtMS40LDEuNHMtMS40LS42My0xLjQtMS40aDBjMC0uNzguNjMtMS40LDEuNC0xLjRoMFpNOTguOTEsMTIxLjE2Yy43NywwLDEuNC42MywxLjQsMS40cy0uNjMsMS40LTEuNCwxLjQtMS40LS42My0xLjQtMS40aDBjMC0uNzguNjMtMS40LDEuNC0xLjRoMFoiLz4KICAgICAgPC9nPgogICAgPC9nPgogIDwvZz4KPC9zdmc+",
|
|
914
|
-
version: "version"
|
|
915
|
-
};
|
|
916
|
-
|
|
917
|
-
// src/browser/metamask.ts
|
|
918
|
-
var nufiDomain = {
|
|
919
|
-
production: "https://wallet.nu.fi",
|
|
920
|
-
mainnet: "https://wallet-staging.nu.fi",
|
|
921
|
-
preprod: "https://wallet-testnet-staging.nu.fi",
|
|
922
|
-
preview: "https://wallet-preview-staging.nu.fi"
|
|
923
|
-
};
|
|
924
|
-
async function checkIfMetamaskInstalled(network = "preprod") {
|
|
925
|
-
try {
|
|
926
|
-
const _nufiCoreSdk = import_dapp_client_core.default.default;
|
|
927
|
-
if (Object.keys(nufiDomain).includes(network)) {
|
|
928
|
-
_nufiCoreSdk.init(nufiDomain[network]);
|
|
929
|
-
} else {
|
|
930
|
-
_nufiCoreSdk.init(network);
|
|
931
|
-
}
|
|
932
|
-
const metamask = window.ethereum._metamask;
|
|
933
|
-
if (metamask) {
|
|
934
|
-
(0, import_dapp_client_cardano.initNufiDappCardanoSdk)(_nufiCoreSdk, "snap");
|
|
935
|
-
return nufiSnap;
|
|
936
|
-
}
|
|
937
|
-
return void 0;
|
|
938
|
-
} catch (err) {
|
|
939
|
-
return Promise.resolve(void 0);
|
|
940
|
-
}
|
|
941
|
-
}
|
|
942
|
-
|
|
943
|
-
// src/browser/browser-wallet.ts
|
|
944
925
|
var BrowserWallet = class _BrowserWallet {
|
|
945
926
|
constructor(_walletInstance, _walletName) {
|
|
946
927
|
this._walletInstance = _walletInstance;
|
|
@@ -957,10 +938,10 @@ var BrowserWallet = class _BrowserWallet {
|
|
|
957
938
|
* @returns a list of wallet names
|
|
958
939
|
*/
|
|
959
940
|
static async getAvailableWallets({
|
|
960
|
-
|
|
941
|
+
injectFn = void 0
|
|
961
942
|
} = {}) {
|
|
962
943
|
if (window === void 0) return [];
|
|
963
|
-
if (
|
|
944
|
+
if (injectFn) await injectFn();
|
|
964
945
|
return _BrowserWallet.getInstalledWallets();
|
|
965
946
|
}
|
|
966
947
|
/**
|
|
@@ -998,7 +979,7 @@ var BrowserWallet = class _BrowserWallet {
|
|
|
998
979
|
*
|
|
999
980
|
* Query BrowserWallet.getInstalledWallets() to get a list of available wallets, then provide the wallet name for which wallet the user would like to connect with.
|
|
1000
981
|
*
|
|
1001
|
-
* @param walletName - the name of the wallet to enable (e.g. "eternl", "begin"
|
|
982
|
+
* @param walletName - the name of the wallet to enable (e.g. "eternl", "begin")
|
|
1002
983
|
* @param extensions - optional, a list of CIPs that the wallet should support
|
|
1003
984
|
* @returns WalletInstance
|
|
1004
985
|
*/
|
|
@@ -1468,7 +1449,7 @@ async function login({
|
|
|
1468
1449
|
serverUrl,
|
|
1469
1450
|
username
|
|
1470
1451
|
}) {
|
|
1471
|
-
const initAuthRes = await fetch(`${serverUrl}/init
|
|
1452
|
+
const initAuthRes = await fetch(`${serverUrl}/auth-init`, {
|
|
1472
1453
|
credentials: "include",
|
|
1473
1454
|
method: "POST",
|
|
1474
1455
|
headers: {
|
|
@@ -1486,9 +1467,9 @@ async function login({
|
|
|
1486
1467
|
errorCode: initAuth.errorCode
|
|
1487
1468
|
};
|
|
1488
1469
|
}
|
|
1489
|
-
const optionsJSON = initAuth.optionsJSON;
|
|
1470
|
+
const optionsJSON = initAuth.data.optionsJSON;
|
|
1490
1471
|
const authJSON = await (0, import_browser.startAuthentication)({ optionsJSON });
|
|
1491
|
-
const verifyAuthRes = await fetch(`${serverUrl}/verify
|
|
1472
|
+
const verifyAuthRes = await fetch(`${serverUrl}/auth-verify`, {
|
|
1492
1473
|
credentials: "include",
|
|
1493
1474
|
method: "POST",
|
|
1494
1475
|
headers: {
|
|
@@ -1500,7 +1481,7 @@ async function login({
|
|
|
1500
1481
|
if (!verifyAuthRes.ok) {
|
|
1501
1482
|
return { success: false, error: verifyAuth.error };
|
|
1502
1483
|
}
|
|
1503
|
-
if (verifyAuth.verified) {
|
|
1484
|
+
if (verifyAuth.data.verified) {
|
|
1504
1485
|
return { success: true, authJSON };
|
|
1505
1486
|
} else {
|
|
1506
1487
|
return { success: false, error: "Failed to log in" };
|
|
@@ -1513,7 +1494,7 @@ async function register({
|
|
|
1513
1494
|
serverUrl,
|
|
1514
1495
|
username
|
|
1515
1496
|
}) {
|
|
1516
|
-
const initRegisterRes = await fetch(`${serverUrl}/init
|
|
1497
|
+
const initRegisterRes = await fetch(`${serverUrl}/register-init`, {
|
|
1517
1498
|
credentials: "include",
|
|
1518
1499
|
method: "POST",
|
|
1519
1500
|
headers: {
|
|
@@ -1531,9 +1512,9 @@ async function register({
|
|
|
1531
1512
|
errorCode: initRegister.errorCode
|
|
1532
1513
|
};
|
|
1533
1514
|
}
|
|
1534
|
-
const optionsJSON = initRegister.optionsJSON;
|
|
1515
|
+
const optionsJSON = initRegister.data.optionsJSON;
|
|
1535
1516
|
const registrationJSON = await (0, import_browser2.startRegistration)({ optionsJSON });
|
|
1536
|
-
const verifyResponse = await fetch(`${serverUrl}/verify
|
|
1517
|
+
const verifyResponse = await fetch(`${serverUrl}/register-verify`, {
|
|
1537
1518
|
credentials: "include",
|
|
1538
1519
|
method: "POST",
|
|
1539
1520
|
headers: {
|
|
@@ -1550,7 +1531,7 @@ async function register({
|
|
|
1550
1531
|
errorCode: verifyData.errorCode
|
|
1551
1532
|
};
|
|
1552
1533
|
}
|
|
1553
|
-
if (verifyData.verified) {
|
|
1534
|
+
if (verifyData.data.verified) {
|
|
1554
1535
|
console.log(`Successfully registered ${username}`);
|
|
1555
1536
|
return { success: true };
|
|
1556
1537
|
} else {
|
|
@@ -1566,7 +1547,7 @@ async function connect({
|
|
|
1566
1547
|
serverUrl
|
|
1567
1548
|
}) {
|
|
1568
1549
|
const responseRegister = await register({ serverUrl, username });
|
|
1569
|
-
if (responseRegister.success || responseRegister.errorCode == ERRORCODES.USEREXISTS) {
|
|
1550
|
+
if (responseRegister.success || responseRegister.error.errorCode == ERRORCODES.USEREXISTS) {
|
|
1570
1551
|
const loginRes = await handleLogin({ serverUrl, username });
|
|
1571
1552
|
if (loginRes.success && loginRes.authJSON) {
|
|
1572
1553
|
const wallet = await buildWalletFromPasskey(
|
|
@@ -1819,7 +1800,7 @@ var MeshWallet = class {
|
|
|
1819
1800
|
* @param address - the address to use for signing (optional)
|
|
1820
1801
|
* @returns a signature
|
|
1821
1802
|
*/
|
|
1822
|
-
signData(payload, address) {
|
|
1803
|
+
async signData(payload, address) {
|
|
1823
1804
|
if (!this._wallet) {
|
|
1824
1805
|
throw new Error(
|
|
1825
1806
|
"[MeshWallet] Read only wallet does not support signing data."
|
|
@@ -1842,7 +1823,7 @@ var MeshWallet = class {
|
|
|
1842
1823
|
* @param partialSign - if the transaction is partially signed (default: false)
|
|
1843
1824
|
* @returns a signed transaction in CBOR
|
|
1844
1825
|
*/
|
|
1845
|
-
signTx(unsignedTx, partialSign = false) {
|
|
1826
|
+
async signTx(unsignedTx, partialSign = false) {
|
|
1846
1827
|
if (!this._wallet) {
|
|
1847
1828
|
throw new Error(
|
|
1848
1829
|
"[MeshWallet] Read only wallet does not support signing data."
|
|
@@ -1868,7 +1849,7 @@ var MeshWallet = class {
|
|
|
1868
1849
|
* @param partialSign - if the transactions are signed partially
|
|
1869
1850
|
* @returns array of signed transactions CborHex string
|
|
1870
1851
|
*/
|
|
1871
|
-
signTxs(unsignedTxs, partialSign = false) {
|
|
1852
|
+
async signTxs(unsignedTxs, partialSign = false) {
|
|
1872
1853
|
if (!this._wallet) {
|
|
1873
1854
|
throw new Error(
|
|
1874
1855
|
"[MeshWallet] Read only wallet does not support signing data."
|
|
@@ -1876,7 +1857,7 @@ var MeshWallet = class {
|
|
|
1876
1857
|
}
|
|
1877
1858
|
const signedTxs = [];
|
|
1878
1859
|
for (const unsignedTx of unsignedTxs) {
|
|
1879
|
-
const signedTx = this.signTx(unsignedTx, partialSign);
|
|
1860
|
+
const signedTx = await this.signTx(unsignedTx, partialSign);
|
|
1880
1861
|
signedTxs.push(signedTx);
|
|
1881
1862
|
}
|
|
1882
1863
|
return signedTxs;
|
package/dist/index.d.cts
CHANGED
|
@@ -91,8 +91,8 @@ declare class AppWallet implements ISigner, ISubmitter {
|
|
|
91
91
|
getNetworkId(): number;
|
|
92
92
|
getUsedAddress(accountIndex?: number, keyIndex?: number, addressType?: GetAddressType): Address;
|
|
93
93
|
getUnspentOutputs(accountIndex?: number, addressType?: GetAddressType): Promise<TransactionUnspentOutput[]>;
|
|
94
|
-
signData(address: string, payload: string, accountIndex?: number, keyIndex?: number): DataSignature
|
|
95
|
-
signTx(unsignedTx: string, partialSign?: boolean, accountIndex?: number, keyIndex?: number): string
|
|
94
|
+
signData(address: string, payload: string, accountIndex?: number, keyIndex?: number): Promise<DataSignature>;
|
|
95
|
+
signTx(unsignedTx: string, partialSign?: boolean, accountIndex?: number, keyIndex?: number): Promise<string>;
|
|
96
96
|
signTxSync(unsignedTx: string, partialSign?: boolean, accountIndex?: number, keyIndex?: number): string;
|
|
97
97
|
signTxs(unsignedTxs: string[], partialSign: boolean): Promise<string[]>;
|
|
98
98
|
submitTx(tx: string): Promise<string>;
|
|
@@ -127,10 +127,8 @@ declare class BrowserWallet implements IWallet {
|
|
|
127
127
|
*
|
|
128
128
|
* @returns a list of wallet names
|
|
129
129
|
*/
|
|
130
|
-
static getAvailableWallets({
|
|
131
|
-
|
|
132
|
-
network: string;
|
|
133
|
-
};
|
|
130
|
+
static getAvailableWallets({ injectFn, }?: {
|
|
131
|
+
injectFn?: () => Promise<void>;
|
|
134
132
|
}): Promise<Wallet[]>;
|
|
135
133
|
/**
|
|
136
134
|
* Returns a list of wallets installed on user's device. Each wallet is an object with the following properties:
|
|
@@ -146,7 +144,7 @@ declare class BrowserWallet implements IWallet {
|
|
|
146
144
|
*
|
|
147
145
|
* Query BrowserWallet.getInstalledWallets() to get a list of available wallets, then provide the wallet name for which wallet the user would like to connect with.
|
|
148
146
|
*
|
|
149
|
-
* @param walletName - the name of the wallet to enable (e.g. "eternl", "begin"
|
|
147
|
+
* @param walletName - the name of the wallet to enable (e.g. "eternl", "begin")
|
|
150
148
|
* @param extensions - optional, a list of CIPs that the wallet should support
|
|
151
149
|
* @returns WalletInstance
|
|
152
150
|
*/
|
|
@@ -435,8 +433,29 @@ declare class EmbeddedWallet extends WalletStaticMethods {
|
|
|
435
433
|
private readonly _networkId;
|
|
436
434
|
constructor(options: CreateEmbeddedWalletOptions);
|
|
437
435
|
getAccount(accountIndex?: number, keyIndex?: number): Account;
|
|
436
|
+
/**
|
|
437
|
+
* Get wallet network ID.
|
|
438
|
+
*
|
|
439
|
+
* @returns network ID
|
|
440
|
+
*/
|
|
438
441
|
getNetworkId(): number;
|
|
442
|
+
/**
|
|
443
|
+
* This endpoint utilizes the [CIP-8 - Message Signing](https://cips.cardano.org/cips/cip8/) to sign arbitrary data, to verify the data was signed by the owner of the private key.
|
|
444
|
+
*
|
|
445
|
+
* @param address - bech32 address to sign the data with
|
|
446
|
+
* @param payload - the data to be signed
|
|
447
|
+
* @param accountIndex account index (default: 0)
|
|
448
|
+
* @returns a signature
|
|
449
|
+
*/
|
|
439
450
|
signData(address: string, payload: string, accountIndex?: number, keyIndex?: number): DataSignature;
|
|
451
|
+
/**
|
|
452
|
+
* This endpoints sign the provided transaction (unsignedTx) with the private key of the owner.
|
|
453
|
+
*
|
|
454
|
+
* @param unsignedTx - a transaction in CBOR
|
|
455
|
+
* @param accountIndex account index (default: 0)
|
|
456
|
+
* @param keyIndex key index (default: 0)
|
|
457
|
+
* @returns VkeyWitness
|
|
458
|
+
*/
|
|
440
459
|
signTx(unsignedTx: string, accountIndex?: number, keyIndex?: number): VkeyWitness;
|
|
441
460
|
}
|
|
442
461
|
|
|
@@ -619,7 +638,7 @@ declare class MeshWallet implements IWallet {
|
|
|
619
638
|
* @param address - the address to use for signing (optional)
|
|
620
639
|
* @returns a signature
|
|
621
640
|
*/
|
|
622
|
-
signData(payload: string, address?: string): DataSignature
|
|
641
|
+
signData(payload: string, address?: string): Promise<DataSignature>;
|
|
623
642
|
/**
|
|
624
643
|
* Requests user to sign the provided transaction (tx). The wallet should ask the user for permission, and if given, try to sign the supplied body and return a signed transaction. partialSign should be true if the transaction provided requires multiple signatures.
|
|
625
644
|
*
|
|
@@ -627,7 +646,7 @@ declare class MeshWallet implements IWallet {
|
|
|
627
646
|
* @param partialSign - if the transaction is partially signed (default: false)
|
|
628
647
|
* @returns a signed transaction in CBOR
|
|
629
648
|
*/
|
|
630
|
-
signTx(unsignedTx: string, partialSign?: boolean): string
|
|
649
|
+
signTx(unsignedTx: string, partialSign?: boolean): Promise<string>;
|
|
631
650
|
/**
|
|
632
651
|
* Experimental feature - sign multiple transactions at once.
|
|
633
652
|
*
|
|
@@ -635,7 +654,7 @@ declare class MeshWallet implements IWallet {
|
|
|
635
654
|
* @param partialSign - if the transactions are signed partially
|
|
636
655
|
* @returns array of signed transactions CborHex string
|
|
637
656
|
*/
|
|
638
|
-
signTxs(unsignedTxs: string[], partialSign?: boolean): string[]
|
|
657
|
+
signTxs(unsignedTxs: string[], partialSign?: boolean): Promise<string[]>;
|
|
639
658
|
/**
|
|
640
659
|
* Submits the signed transaction to the blockchain network.
|
|
641
660
|
*
|
package/dist/index.d.ts
CHANGED
|
@@ -91,8 +91,8 @@ declare class AppWallet implements ISigner, ISubmitter {
|
|
|
91
91
|
getNetworkId(): number;
|
|
92
92
|
getUsedAddress(accountIndex?: number, keyIndex?: number, addressType?: GetAddressType): Address;
|
|
93
93
|
getUnspentOutputs(accountIndex?: number, addressType?: GetAddressType): Promise<TransactionUnspentOutput[]>;
|
|
94
|
-
signData(address: string, payload: string, accountIndex?: number, keyIndex?: number): DataSignature
|
|
95
|
-
signTx(unsignedTx: string, partialSign?: boolean, accountIndex?: number, keyIndex?: number): string
|
|
94
|
+
signData(address: string, payload: string, accountIndex?: number, keyIndex?: number): Promise<DataSignature>;
|
|
95
|
+
signTx(unsignedTx: string, partialSign?: boolean, accountIndex?: number, keyIndex?: number): Promise<string>;
|
|
96
96
|
signTxSync(unsignedTx: string, partialSign?: boolean, accountIndex?: number, keyIndex?: number): string;
|
|
97
97
|
signTxs(unsignedTxs: string[], partialSign: boolean): Promise<string[]>;
|
|
98
98
|
submitTx(tx: string): Promise<string>;
|
|
@@ -127,10 +127,8 @@ declare class BrowserWallet implements IWallet {
|
|
|
127
127
|
*
|
|
128
128
|
* @returns a list of wallet names
|
|
129
129
|
*/
|
|
130
|
-
static getAvailableWallets({
|
|
131
|
-
|
|
132
|
-
network: string;
|
|
133
|
-
};
|
|
130
|
+
static getAvailableWallets({ injectFn, }?: {
|
|
131
|
+
injectFn?: () => Promise<void>;
|
|
134
132
|
}): Promise<Wallet[]>;
|
|
135
133
|
/**
|
|
136
134
|
* Returns a list of wallets installed on user's device. Each wallet is an object with the following properties:
|
|
@@ -146,7 +144,7 @@ declare class BrowserWallet implements IWallet {
|
|
|
146
144
|
*
|
|
147
145
|
* Query BrowserWallet.getInstalledWallets() to get a list of available wallets, then provide the wallet name for which wallet the user would like to connect with.
|
|
148
146
|
*
|
|
149
|
-
* @param walletName - the name of the wallet to enable (e.g. "eternl", "begin"
|
|
147
|
+
* @param walletName - the name of the wallet to enable (e.g. "eternl", "begin")
|
|
150
148
|
* @param extensions - optional, a list of CIPs that the wallet should support
|
|
151
149
|
* @returns WalletInstance
|
|
152
150
|
*/
|
|
@@ -435,8 +433,29 @@ declare class EmbeddedWallet extends WalletStaticMethods {
|
|
|
435
433
|
private readonly _networkId;
|
|
436
434
|
constructor(options: CreateEmbeddedWalletOptions);
|
|
437
435
|
getAccount(accountIndex?: number, keyIndex?: number): Account;
|
|
436
|
+
/**
|
|
437
|
+
* Get wallet network ID.
|
|
438
|
+
*
|
|
439
|
+
* @returns network ID
|
|
440
|
+
*/
|
|
438
441
|
getNetworkId(): number;
|
|
442
|
+
/**
|
|
443
|
+
* This endpoint utilizes the [CIP-8 - Message Signing](https://cips.cardano.org/cips/cip8/) to sign arbitrary data, to verify the data was signed by the owner of the private key.
|
|
444
|
+
*
|
|
445
|
+
* @param address - bech32 address to sign the data with
|
|
446
|
+
* @param payload - the data to be signed
|
|
447
|
+
* @param accountIndex account index (default: 0)
|
|
448
|
+
* @returns a signature
|
|
449
|
+
*/
|
|
439
450
|
signData(address: string, payload: string, accountIndex?: number, keyIndex?: number): DataSignature;
|
|
451
|
+
/**
|
|
452
|
+
* This endpoints sign the provided transaction (unsignedTx) with the private key of the owner.
|
|
453
|
+
*
|
|
454
|
+
* @param unsignedTx - a transaction in CBOR
|
|
455
|
+
* @param accountIndex account index (default: 0)
|
|
456
|
+
* @param keyIndex key index (default: 0)
|
|
457
|
+
* @returns VkeyWitness
|
|
458
|
+
*/
|
|
440
459
|
signTx(unsignedTx: string, accountIndex?: number, keyIndex?: number): VkeyWitness;
|
|
441
460
|
}
|
|
442
461
|
|
|
@@ -619,7 +638,7 @@ declare class MeshWallet implements IWallet {
|
|
|
619
638
|
* @param address - the address to use for signing (optional)
|
|
620
639
|
* @returns a signature
|
|
621
640
|
*/
|
|
622
|
-
signData(payload: string, address?: string): DataSignature
|
|
641
|
+
signData(payload: string, address?: string): Promise<DataSignature>;
|
|
623
642
|
/**
|
|
624
643
|
* Requests user to sign the provided transaction (tx). The wallet should ask the user for permission, and if given, try to sign the supplied body and return a signed transaction. partialSign should be true if the transaction provided requires multiple signatures.
|
|
625
644
|
*
|
|
@@ -627,7 +646,7 @@ declare class MeshWallet implements IWallet {
|
|
|
627
646
|
* @param partialSign - if the transaction is partially signed (default: false)
|
|
628
647
|
* @returns a signed transaction in CBOR
|
|
629
648
|
*/
|
|
630
|
-
signTx(unsignedTx: string, partialSign?: boolean): string
|
|
649
|
+
signTx(unsignedTx: string, partialSign?: boolean): Promise<string>;
|
|
631
650
|
/**
|
|
632
651
|
* Experimental feature - sign multiple transactions at once.
|
|
633
652
|
*
|
|
@@ -635,7 +654,7 @@ declare class MeshWallet implements IWallet {
|
|
|
635
654
|
* @param partialSign - if the transactions are signed partially
|
|
636
655
|
* @returns array of signed transactions CborHex string
|
|
637
656
|
*/
|
|
638
|
-
signTxs(unsignedTxs: string[], partialSign?: boolean): string[]
|
|
657
|
+
signTxs(unsignedTxs: string[], partialSign?: boolean): Promise<string[]>;
|
|
639
658
|
/**
|
|
640
659
|
* Submits the signed transaction to the blockchain network.
|
|
641
660
|
*
|
package/dist/index.js
CHANGED
|
@@ -720,9 +720,22 @@ var EmbeddedWallet = class extends WalletStaticMethods {
|
|
|
720
720
|
}
|
|
721
721
|
return _account;
|
|
722
722
|
}
|
|
723
|
+
/**
|
|
724
|
+
* Get wallet network ID.
|
|
725
|
+
*
|
|
726
|
+
* @returns network ID
|
|
727
|
+
*/
|
|
723
728
|
getNetworkId() {
|
|
724
729
|
return this._networkId;
|
|
725
730
|
}
|
|
731
|
+
/**
|
|
732
|
+
* This endpoint utilizes the [CIP-8 - Message Signing](https://cips.cardano.org/cips/cip8/) to sign arbitrary data, to verify the data was signed by the owner of the private key.
|
|
733
|
+
*
|
|
734
|
+
* @param address - bech32 address to sign the data with
|
|
735
|
+
* @param payload - the data to be signed
|
|
736
|
+
* @param accountIndex account index (default: 0)
|
|
737
|
+
* @returns a signature
|
|
738
|
+
*/
|
|
726
739
|
signData(address, payload, accountIndex = 0, keyIndex = 0) {
|
|
727
740
|
try {
|
|
728
741
|
const { baseAddress, enterpriseAddress, rewardAddress, paymentKey } = this.getAccount(accountIndex, keyIndex);
|
|
@@ -743,6 +756,14 @@ var EmbeddedWallet = class extends WalletStaticMethods {
|
|
|
743
756
|
);
|
|
744
757
|
}
|
|
745
758
|
}
|
|
759
|
+
/**
|
|
760
|
+
* This endpoints sign the provided transaction (unsignedTx) with the private key of the owner.
|
|
761
|
+
*
|
|
762
|
+
* @param unsignedTx - a transaction in CBOR
|
|
763
|
+
* @param accountIndex account index (default: 0)
|
|
764
|
+
* @param keyIndex key index (default: 0)
|
|
765
|
+
* @returns VkeyWitness
|
|
766
|
+
*/
|
|
746
767
|
signTx(unsignedTx, accountIndex = 0, keyIndex = 0) {
|
|
747
768
|
try {
|
|
748
769
|
const txHash = deserializeTxHash(resolveTxHash(unsignedTx));
|
|
@@ -856,7 +877,7 @@ var AppWallet = class {
|
|
|
856
877
|
);
|
|
857
878
|
return utxos.map((utxo) => toTxUnspentOutput(utxo));
|
|
858
879
|
}
|
|
859
|
-
signData(address, payload, accountIndex = 0, keyIndex = 0) {
|
|
880
|
+
async signData(address, payload, accountIndex = 0, keyIndex = 0) {
|
|
860
881
|
try {
|
|
861
882
|
return this._wallet.signData(address, payload, accountIndex, keyIndex);
|
|
862
883
|
} catch (error) {
|
|
@@ -865,7 +886,7 @@ var AppWallet = class {
|
|
|
865
886
|
);
|
|
866
887
|
}
|
|
867
888
|
}
|
|
868
|
-
signTx(unsignedTx, partialSign = false, accountIndex = 0, keyIndex = 0) {
|
|
889
|
+
async signTx(unsignedTx, partialSign = false, accountIndex = 0, keyIndex = 0) {
|
|
869
890
|
try {
|
|
870
891
|
const tx = deserializeTx2(unsignedTx);
|
|
871
892
|
if (!partialSign && tx.witnessSet().vkeys() !== void 0 && tx.witnessSet().vkeys().size() !== 0)
|
|
@@ -930,46 +951,6 @@ import {
|
|
|
930
951
|
Transaction as Transaction2,
|
|
931
952
|
VkeyWitness as VkeyWitness2
|
|
932
953
|
} from "@meshsdk/core-cst";
|
|
933
|
-
|
|
934
|
-
// src/browser/metamask.ts
|
|
935
|
-
import { initNufiDappCardanoSdk } from "@nufi/dapp-client-cardano";
|
|
936
|
-
import publicNufiCoreSdk from "@nufi/dapp-client-core";
|
|
937
|
-
|
|
938
|
-
// src/types/nufisnap.ts
|
|
939
|
-
var nufiSnap = {
|
|
940
|
-
id: "nufiSnap",
|
|
941
|
-
name: "MetaMask",
|
|
942
|
-
icon: "data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz4KPHN2ZyBpZD0iTGF5ZXJfMiIgZGF0YS1uYW1lPSJMYXllciAyIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxNjkuMiAxNjMuNzEiPgogIDxkZWZzPgogICAgPHN0eWxlPgogICAgICAuY2xzLTEgewogICAgICAgIGZpbGw6ICNlMjc2MjU7CiAgICAgIH0KCiAgICAgIC5jbHMtMSwgLmNscy0yLCAuY2xzLTMsIC5jbHMtNCwgLmNscy01LCAuY2xzLTYsIC5jbHMtNywgLmNscy04LCAuY2xzLTkgewogICAgICAgIHN0cm9rZS13aWR0aDogMHB4OwogICAgICB9CgogICAgICAuY2xzLTIgewogICAgICAgIGZpbGw6ICM3NjNlMWE7CiAgICAgIH0KCiAgICAgIC5jbHMtMyB7CiAgICAgICAgZmlsbDogI2MwYWQ5ZTsKICAgICAgfQoKICAgICAgLmNscy00IHsKICAgICAgICBmaWxsOiAjMzQ2OGQxOwogICAgICB9CgogICAgICAuY2xzLTUgewogICAgICAgIGZpbGw6ICNjYzYyMjg7CiAgICAgIH0KCiAgICAgIC5jbHMtNiB7CiAgICAgICAgZmlsbDogI2Y1ODQxZjsKICAgICAgfQoKICAgICAgLmNscy03IHsKICAgICAgICBmaWxsOiAjZDdjMWIzOwogICAgICB9CgogICAgICAuY2xzLTggewogICAgICAgIGZpbGw6ICNmZmY7CiAgICAgICAgZmlsbC1ydWxlOiBldmVub2RkOwogICAgICB9CgogICAgICAuY2xzLTkgewogICAgICAgIGZpbGw6ICMyZjM0M2I7CiAgICAgIH0KICAgIDwvc3R5bGU+CiAgPC9kZWZzPgogIDxnIGlkPSJMYXllcl8xLTIiIGRhdGEtbmFtZT0iTGF5ZXIgMSI+CiAgICA8ZyBpZD0iTU1fSGVhZF9iYWNrZ3JvdW5kX0RvX25vdF9lZGl0XyIgZGF0YS1uYW1lPSJNTSBIZWFkIGJhY2tncm91bmQgKERvIG5vdCBlZGl0KSI+CiAgICAgIDxwYXRoIGNsYXNzPSJjbHMtNiIgZD0iTTE0MS44LDcwLjVsNi45LTguMS0zLTIuMiw0LjgtNC40LTMuNy0yLjgsNC44LTMuNi0zLjEtMi40LDUtMjQuNC03LjYtMjIuNk0xNDUuOSwwbC00OC44LDE4LjFoLTQwLjdMNy42LDBsLjMuMkw3LjYsMCwwLDIyLjZsNS4xLDI0LjQtMy4yLDIuNCw0LjksMy42LTMuNywyLjgsNC44LDQuNC0zLDIuMiw2LjksOC4xTDEuMywxMDIuOWgwbDkuNywzMy4xLDM0LjEtOS40di0uMS4xaDBsNi42LDUuNCwxMy41LDkuMmgyMy4xbDEzLjUtOS4yLDYuNi01LjRoMGwzNC4yLDkuNCw5LjgtMzMuMWgwbC0xMC42LTMyLjQiLz4KICAgIDwvZz4KICAgIDxnIGlkPSJMb2dvcyI+CiAgICAgIDxnPgogICAgICAgIDxwb2x5Z29uIGNsYXNzPSJjbHMtMSIgcG9pbnRzPSIxNDUuOSAwIDg2IDQ0LjEgOTcuMSAxOC4xIDE0NS45IDAiLz4KICAgICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTEiIHBvaW50cz0iNy42IDAgNjcgNDQuNSA1Ni40IDE4LjEgNy42IDAiLz4KICAgICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTEiIHBvaW50cz0iMTI0LjQgMTAyLjMgMTA4LjQgMTI2LjUgMTQyLjYgMTM1LjkgMTUyLjQgMTAyLjggMTI0LjQgMTAyLjMiLz4KICAgICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTEiIHBvaW50cz0iMS4zIDEwMi44IDExIDEzNS45IDQ1LjEgMTI2LjUgMjkuMiAxMDIuMyAxLjMgMTAyLjgiLz4KICAgICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTEiIHBvaW50cz0iNDMuMyA2MS4zIDMzLjggNzUuNiA2Ny42IDc3LjEgNjYuNSA0MC45IDQzLjMgNjEuMyIvPgogICAgICAgIDxwb2x5Z29uIGNsYXNzPSJjbHMtMSIgcG9pbnRzPSIxMTAuMyA2MS4zIDg2LjcgNDAuNSA4NiA3Ny4xIDExOS44IDc1LjYgMTEwLjMgNjEuMyIvPgogICAgICAgIDxwb2x5Z29uIGNsYXNzPSJjbHMtMSIgcG9pbnRzPSI0NS4xIDEyNi41IDY1LjYgMTE2LjcgNDcuOSAxMDMuMSA0NS4xIDEyNi41Ii8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy0xIiBwb2ludHM9Ijg4IDExNi43IDEwOC40IDEyNi41IDEwNS42IDEwMy4xIDg4IDExNi43Ii8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy03IiBwb2ludHM9IjEwOC40IDEyNi41IDg4IDExNi43IDg5LjcgMTI5LjkgODkuNSAxMzUuNSAxMDguNCAxMjYuNSIvPgogICAgICAgIDxwb2x5Z29uIGNsYXNzPSJjbHMtNyIgcG9pbnRzPSI0NS4xIDEyNi41IDY0LjEgMTM1LjUgNjQgMTI5LjkgNjUuNiAxMTYuNyA0NS4xIDEyNi41Ii8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy05IiBwb2ludHM9IjY0LjQgOTQuMyA0Ny41IDg5LjQgNTkuNSA4My45IDY0LjQgOTQuMyIvPgogICAgICAgIDxwb2x5Z29uIGNsYXNzPSJjbHMtOSIgcG9pbnRzPSI4OS4xIDk0LjMgOTQuMSA4My45IDEwNi4xIDg5LjQgODkuMSA5NC4zIi8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy01IiBwb2ludHM9IjQ1LjEgMTI2LjUgNDguMSAxMDIuMyAyOS4yIDEwMi44IDQ1LjEgMTI2LjUiLz4KICAgICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTUiIHBvaW50cz0iMTA1LjUgMTAyLjMgMTA4LjQgMTI2LjUgMTI0LjQgMTAyLjggMTA1LjUgMTAyLjMiLz4KICAgICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTUiIHBvaW50cz0iMTE5LjggNzUuNiA4NiA3Ny4xIDg5LjEgOTQuMyA5NC4xIDgzLjkgMTA2LjEgODkuNCAxMTkuOCA3NS42Ii8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy01IiBwb2ludHM9IjQ3LjUgODkuNCA1OS41IDgzLjkgNjQuNCA5NC4zIDY3LjYgNzcuMSAzMy44IDc1LjYgNDcuNSA4OS40Ii8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy0xIiBwb2ludHM9IjMzLjggNzUuNiA0Ny45IDEwMy4xIDQ3LjUgODkuNCAzMy44IDc1LjYiLz4KICAgICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTEiIHBvaW50cz0iMTA2LjEgODkuNCAxMDUuNiAxMDMuMSAxMTkuOCA3NS42IDEwNi4xIDg5LjQiLz4KICAgICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTEiIHBvaW50cz0iNjcuNiA3Ny4xIDY0LjQgOTQuMyA2OC40IDExNC43IDY5LjMgODcuOSA2Ny42IDc3LjEiLz4KICAgICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTEiIHBvaW50cz0iODYgNzcuMSA4NC4zIDg3LjggODUuMSAxMTQuNyA4OS4xIDk0LjMgODYgNzcuMSIvPgogICAgICAgIDxwb2x5Z29uIGNsYXNzPSJjbHMtNiIgcG9pbnRzPSI4OS4xIDk0LjMgODUuMSAxMTQuNyA4OCAxMTYuNyAxMDUuNiAxMDMuMSAxMDYuMSA4OS40IDg5LjEgOTQuMyIvPgogICAgICAgIDxwb2x5Z29uIGNsYXNzPSJjbHMtNiIgcG9pbnRzPSI0Ny41IDg5LjQgNDcuOSAxMDMuMSA2NS42IDExNi43IDY4LjQgMTE0LjcgNjQuNCA5NC4zIDQ3LjUgODkuNCIvPgogICAgICAgIDxwb2x5Z29uIGNsYXNzPSJjbHMtMyIgcG9pbnRzPSI4OS41IDEzNS41IDg5LjcgMTI5LjkgODguMSAxMjguNiA2NS40IDEyOC42IDY0IDEyOS45IDY0LjEgMTM1LjUgNDUuMSAxMjYuNSA1MS43IDEzMS45IDY1LjIgMTQxLjIgODguMyAxNDEuMiAxMDEuOCAxMzEuOSAxMDguNCAxMjYuNSA4OS41IDEzNS41Ii8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy05IiBwb2ludHM9Ijg4IDExNi43IDg1LjEgMTE0LjcgNjguNCAxMTQuNyA2NS42IDExNi43IDY0IDEyOS45IDY1LjQgMTI4LjYgODguMSAxMjguNiA4OS43IDEyOS45IDg4IDExNi43Ii8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy0yIiBwb2ludHM9IjE0OC41IDQ3IDE1My41IDIyLjYgMTQ1LjkgMCA4OCA0Mi42IDExMC4zIDYxLjMgMTQxLjggNzAuNSAxNDguNyA2Mi40IDE0NS43IDYwLjIgMTUwLjUgNTUuOSAxNDYuOCA1MyAxNTEuNiA0OS40IDE0OC41IDQ3Ii8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy0yIiBwb2ludHM9IjAgMjIuNiA1LjEgNDcgMS45IDQ5LjQgNi43IDUzLjEgMyA1NS45IDcuOCA2MC4yIDQuOCA2Mi40IDExLjggNzAuNSA0My4zIDYxLjMgNjUuNiA0Mi42IDcuNiAwIDAgMjIuNiIvPgogICAgICAgIDxwb2x5Z29uIGNsYXNzPSJjbHMtNiIgcG9pbnRzPSIxNDEuOCA3MC41IDExMC4zIDYxLjMgMTE5LjggNzUuNiAxMDUuNiAxMDMuMSAxMjQuNCAxMDIuOCAxNTIuNCAxMDIuOCAxNDEuOCA3MC41Ii8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy02IiBwb2ludHM9IjQzLjMgNjEuMyAxMS44IDcwLjUgMS4zIDEwMi44IDI5LjIgMTAyLjggNDcuOSAxMDMuMSAzMy44IDc1LjYgNDMuMyA2MS4zIi8+CiAgICAgICAgPHBvbHlnb24gY2xhc3M9ImNscy02IiBwb2ludHM9Ijg2IDc3LjEgODggNDIuNiA5Ny4xIDE4LjEgNTYuNCAxOC4xIDY1LjYgNDIuNiA2Ny42IDc3LjEgNjguNCA4Ny45IDY4LjQgMTE0LjcgODUuMSAxMTQuNyA4NS4yIDg3LjkgODYgNzcuMSIvPgogICAgICA8L2c+CiAgICA8L2c+CiAgICA8ZyBpZD0iY2FyZGFub19hZGEiIGRhdGEtbmFtZT0iY2FyZGFubyBhZGEiPgogICAgICA8ZyBpZD0iY2FyZGFub19hZGEtMiIgZGF0YS1uYW1lPSJjYXJkYW5vIGFkYS0yIj4KICAgICAgICA8Y2lyY2xlIGlkPSJf0K3Qu9C70LjQv9GBXzYiIGRhdGEtbmFtZT0i0K3Qu9C70LjQv9GBIDYiIGNsYXNzPSJjbHMtNCIgY3g9IjEyOC4wNSIgY3k9IjEyMi41NiIgcj0iNDEuMTUiLz4KICAgICAgICA8cGF0aCBpZD0iX9Ct0LvQu9C40L/RgV82X9C60L7Qv9C40Y9fMjkiIGRhdGEtbmFtZT0i0K3Qu9C70LjQv9GBIDYg0LrQvtC/0LjRjyAyOSIgY2xhc3M9ImNscy04IiBkPSJNMTIzLjQ2LDEwOS45M2MyLjI1LDAsNC4wNywxLjgyLDQuMDcsNC4wNywwLDIuMjUtMS44Miw0LjA3LTQuMDcsNC4wNy0yLjI1LDAtNC4wNy0xLjgyLTQuMDctNC4wNywwLTIuMjUsMS44Mi00LjA3LDQuMDctNC4wN1pNMTMzLjI4LDEwOS45M2MyLjI1LDAsNC4wNywxLjgyLDQuMDcsNC4wNywwLDIuMjUtMS44Miw0LjA3LTQuMDcsNC4wNy0yLjI1LDAtNC4wNy0xLjgyLTQuMDctNC4wNywwLTIuMjUsMS44Mi00LjA3LDQuMDctNC4wN2gwWk0xMzMuMjgsMTI3LjA1YzIuMjUsMCw0LjA3LDEuODIsNC4wNyw0LjA3LDAsMi4yNS0xLjgyLDQuMDctNC4wNyw0LjA3LTIuMjUsMC00LjA3LTEuODItNC4wNy00LjA3LDAtMi4yNSwxLjgyLTQuMDcsNC4wNy00LjA3aDAsMFpNMTIzLjQ2LDEyNy4wNWMyLjI1LDAsNC4wNywxLjgyLDQuMDcsNC4wNywwLDIuMjUtMS44Miw0LjA3LTQuMDcsNC4wNy0yLjI1LDAtNC4wNy0xLjgyLTQuMDctNC4wNywwLTIuMjUsMS44Mi00LjA3LDQuMDctNC4wN1pNMTE4LjQxLDExOC42M2MyLjI1LDAsNC4wNywxLjgyLDQuMDcsNC4wNywwLDIuMjUtMS44Miw0LjA3LTQuMDcsNC4wNy0yLjI1LDAtNC4wNy0xLjgyLTQuMDctNC4wNywwLTIuMjUsMS44Mi00LjA3LDQuMDctNC4wN2gwWk0xMzguMzMsMTE4LjYzYzIuMjUsMCw0LjA3LDEuODIsNC4wNyw0LjA3LDAsMi4yNS0xLjgyLDQuMDctNC4wNyw0LjA3LTIuMjUsMC00LjA3LTEuODItNC4wNy00LjA3LDAtMi4yNSwxLjgyLTQuMDcsNC4wNy00LjA3aDBaTTE0Mi45NiwxMTEuNjJjMS4zOSwwLDIuNTIsMS4xMywyLjUyLDIuNTMsMCwxLjM5LTEuMTMsMi41Mi0yLjUzLDIuNTItMS4zOSwwLTIuNTItMS4xMy0yLjUyLTIuNTJzMS4xMy0yLjUyLDIuNTItMi41MmgwWk0xNDIuOTYsMTI4LjQ1YzEuMzksMCwyLjUyLDEuMTMsMi41MiwyLjUzLDAsMS4zOS0xLjEzLDIuNTItMi41MywyLjUyLTEuMzksMC0yLjUyLTEuMTMtMi41Mi0yLjUyczEuMTMtMi41MiwyLjUyLTIuNTJoMFpNMTEzLjc4LDEyOC40NWMxLjM5LDAsMi41MiwxLjEzLDIuNTIsMi41MywwLDEuMzktMS4xMywyLjUyLTIuNTMsMi41Mi0xLjM5LDAtMi41Mi0xLjEzLTIuNTItMi41MiwwLTEuMzksMS4xMy0yLjUyLDIuNTMtMi41MmgwWk0xMTMuNzgsMTExLjYyYzEuMzksMCwyLjUyLDEuMTMsMi41MiwyLjUzLDAsMS4zOS0xLjEzLDIuNTItMi41MywyLjUyLTEuMzksMC0yLjUyLTEuMTMtMi41Mi0yLjUyLDAtMS4zOSwxLjEzLTIuNTIsMi41My0yLjUyaDBaTTEyOC4zNywxMDMuMmMxLjM5LDAsMi41MiwxLjEzLDIuNTIsMi41MywwLDEuMzktMS4xMywyLjUyLTIuNTMsMi41Mi0xLjM5LDAtMi41Mi0xLjEzLTIuNTItMi41MnMxLjEzLTIuNTIsMi41Mi0yLjUyaDBaTTEyOC4zNywxMzYuODZjMS4zOSwwLDIuNTIsMS4xMywyLjUyLDIuNTMsMCwxLjM5LTEuMTMsMi41Mi0yLjUzLDIuNTItMS4zOSwwLTIuNTItMS4xMy0yLjUyLTIuNTJzMS4xMy0yLjUyLDIuNTItMi41MmgwWk0xMzkuMTcsMTM5LjM5YzEuMTYsMCwyLjEuOTQsMi4xLDIuMSwwLDEuMTYtLjk0LDIuMS0yLjEsMi4xLTEuMTYsMC0yLjEtLjk0LTIuMS0yLjFzLjk0LTIuMSwyLjEtMi4xaDBaTTExNy41NywxMzkuMzljMS4xNiwwLDIuMS45NCwyLjEsMi4xLDAsMS4xNi0uOTQsMi4xLTIuMSwyLjEtMS4xNiwwLTIuMS0uOTQtMi4xLTIuMXMuOTQtMi4xLDIuMS0yLjFoMFpNMTE3LjU3LDEwMS41MmMxLjE2LDAsMi4xLjk0LDIuMSwyLjEsMCwxLjE2LS45NCwyLjEtMi4xLDIuMS0xLjE2LDAtMi4xLS45NC0yLjEtMi4xcy45NC0yLjEsMi4xLTIuMWgwWk0xMzkuMTcsMTAxLjUyYzEuMTYsMCwyLjEuOTQsMi4xLDIuMSwwLDEuMTYtLjk0LDIuMS0yLjEsMi4xLTEuMTYsMC0yLjEtLjk0LTIuMS0yLjFzLjk0LTIuMSwyLjEtMi4xaDBaTTE1MC4xMSwxMjAuMzFjMS4xNiwwLDIuMS45NCwyLjEsMi4xLDAsMS4xNi0uOTQsMi4xLTIuMSwyLjEtMS4xNiwwLTIuMS0uOTQtMi4xLTIuMSwwLTEuMTYuOTQtMi4xLDIuMS0yLjFoMFpNMTA2LjYyLDEyMC4zMWMxLjE2LDAsMi4xLjk0LDIuMSwyLjEsMCwxLjE2LS45NCwyLjEtMi4xLDIuMS0xLjE2LDAtMi4xLS45NC0yLjEtMi4xcy45NC0yLjEsMi4xLTIuMWgwWk0xMDUuMDgsMTA3LjQxYy45MywwLDEuNjguNzUsMS42OCwxLjY4cy0uNzUsMS42OC0xLjY4LDEuNjgtMS42OC0uNzUtMS42OC0xLjY4aDBjMC0uOTMuNzUtMS42OCwxLjY4LTEuNjhoMFpNMTA1LjA4LDEzNC4zNGMuOTMsMCwxLjY4Ljc1LDEuNjgsMS42OHMtLjc1LDEuNjgtMS42OCwxLjY4LTEuNjgtLjc1LTEuNjgtMS42OGgwYzAtLjkzLjc1LTEuNjgsMS42OC0xLjY4aDBaTTE1MS42NiwxMzQuMzRjLjkzLDAsMS42OC43NSwxLjY4LDEuNjgsMCwuOTMtLjc1LDEuNjgtMS42OCwxLjY4cy0xLjY4LS43NS0xLjY4LTEuNjhoMGMwLS45My43NS0xLjY4LDEuNjgtMS42OGgwWk0xNTEuNjYsMTA3LjQxYy45MywwLDEuNjguNzUsMS42OCwxLjY4LDAsLjkzLS43NSwxLjY4LTEuNjgsMS42OHMtMS42OC0uNzUtMS42OC0xLjY4aDBjMC0uOTMuNzUtMS42OCwxLjY4LTEuNjhoMFpNMTI4LjM3LDkzLjk0Yy45MywwLDEuNjguNzUsMS42OCwxLjY4LDAsLjkzLS43NSwxLjY4LTEuNjgsMS42OC0uOTMsMC0xLjY4LS43NS0xLjY4LTEuNjhoMGMwLS45My43NS0xLjY4LDEuNjgtMS42OGgwWk0xMjguMzcsMTQ3LjhjLjkzLDAsMS42OC43NSwxLjY4LDEuNjgsMCwuOTMtLjc1LDEuNjgtMS42OCwxLjY4LS45MywwLTEuNjgtLjc1LTEuNjgtMS42OHMuNzUtMS42OCwxLjY4LTEuNjhoMFpNMTQzLjI0LDE0Ni42OGMuNzcsMCwxLjQuNjMsMS40LDEuNCwwLC43Ny0uNjMsMS40LTEuNCwxLjRzLTEuNC0uNjMtMS40LTEuNGgwYzAtLjc3LjYzLTEuNCwxLjQtMS40Wk0xMTMuNSwxNDYuNjhjLjc3LDAsMS40LjYzLDEuNCwxLjRzLS42MywxLjQtMS40LDEuNC0xLjQtLjYzLTEuNC0xLjRoMGMwLS43Ny42My0xLjQsMS40LTEuNFpNMTEzLjUsOTUuNjNjLjc3LDAsMS40LjYzLDEuNCwxLjRzLS42MywxLjQtMS40LDEuNC0xLjQtLjYzLTEuNC0xLjRoMGMwLS43Ny42My0xLjQsMS40LTEuNGgwWk0xNDMuMjQsOTUuNjNjLjc3LDAsMS40LjYzLDEuNCwxLjQsMCwuNzctLjYzLDEuNC0xLjQsMS40cy0xLjQtLjYzLTEuNC0xLjRoMGMwLS43Ny42My0xLjQsMS40LTEuNGgwWk0xNTcuODMsMTIxLjE2Yy43NywwLDEuNC42MywxLjQsMS40LDAsLjc3LS42MywxLjQtMS40LDEuNHMtMS40LS42My0xLjQtMS40aDBjMC0uNzguNjMtMS40LDEuNC0xLjRoMFpNOTguOTEsMTIxLjE2Yy43NywwLDEuNC42MywxLjQsMS40cy0uNjMsMS40LTEuNCwxLjQtMS40LS42My0xLjQtMS40aDBjMC0uNzguNjMtMS40LDEuNC0xLjRoMFoiLz4KICAgICAgPC9nPgogICAgPC9nPgogIDwvZz4KPC9zdmc+",
|
|
943
|
-
version: "version"
|
|
944
|
-
};
|
|
945
|
-
|
|
946
|
-
// src/browser/metamask.ts
|
|
947
|
-
var nufiDomain = {
|
|
948
|
-
production: "https://wallet.nu.fi",
|
|
949
|
-
mainnet: "https://wallet-staging.nu.fi",
|
|
950
|
-
preprod: "https://wallet-testnet-staging.nu.fi",
|
|
951
|
-
preview: "https://wallet-preview-staging.nu.fi"
|
|
952
|
-
};
|
|
953
|
-
async function checkIfMetamaskInstalled(network = "preprod") {
|
|
954
|
-
try {
|
|
955
|
-
const _nufiCoreSdk = publicNufiCoreSdk.default;
|
|
956
|
-
if (Object.keys(nufiDomain).includes(network)) {
|
|
957
|
-
_nufiCoreSdk.init(nufiDomain[network]);
|
|
958
|
-
} else {
|
|
959
|
-
_nufiCoreSdk.init(network);
|
|
960
|
-
}
|
|
961
|
-
const metamask = window.ethereum._metamask;
|
|
962
|
-
if (metamask) {
|
|
963
|
-
initNufiDappCardanoSdk(_nufiCoreSdk, "snap");
|
|
964
|
-
return nufiSnap;
|
|
965
|
-
}
|
|
966
|
-
return void 0;
|
|
967
|
-
} catch (err) {
|
|
968
|
-
return Promise.resolve(void 0);
|
|
969
|
-
}
|
|
970
|
-
}
|
|
971
|
-
|
|
972
|
-
// src/browser/browser-wallet.ts
|
|
973
954
|
var BrowserWallet = class _BrowserWallet {
|
|
974
955
|
constructor(_walletInstance, _walletName) {
|
|
975
956
|
this._walletInstance = _walletInstance;
|
|
@@ -986,10 +967,10 @@ var BrowserWallet = class _BrowserWallet {
|
|
|
986
967
|
* @returns a list of wallet names
|
|
987
968
|
*/
|
|
988
969
|
static async getAvailableWallets({
|
|
989
|
-
|
|
970
|
+
injectFn = void 0
|
|
990
971
|
} = {}) {
|
|
991
972
|
if (window === void 0) return [];
|
|
992
|
-
if (
|
|
973
|
+
if (injectFn) await injectFn();
|
|
993
974
|
return _BrowserWallet.getInstalledWallets();
|
|
994
975
|
}
|
|
995
976
|
/**
|
|
@@ -1027,7 +1008,7 @@ var BrowserWallet = class _BrowserWallet {
|
|
|
1027
1008
|
*
|
|
1028
1009
|
* Query BrowserWallet.getInstalledWallets() to get a list of available wallets, then provide the wallet name for which wallet the user would like to connect with.
|
|
1029
1010
|
*
|
|
1030
|
-
* @param walletName - the name of the wallet to enable (e.g. "eternl", "begin"
|
|
1011
|
+
* @param walletName - the name of the wallet to enable (e.g. "eternl", "begin")
|
|
1031
1012
|
* @param extensions - optional, a list of CIPs that the wallet should support
|
|
1032
1013
|
* @returns WalletInstance
|
|
1033
1014
|
*/
|
|
@@ -1497,7 +1478,7 @@ async function login({
|
|
|
1497
1478
|
serverUrl,
|
|
1498
1479
|
username
|
|
1499
1480
|
}) {
|
|
1500
|
-
const initAuthRes = await fetch(`${serverUrl}/init
|
|
1481
|
+
const initAuthRes = await fetch(`${serverUrl}/auth-init`, {
|
|
1501
1482
|
credentials: "include",
|
|
1502
1483
|
method: "POST",
|
|
1503
1484
|
headers: {
|
|
@@ -1515,9 +1496,9 @@ async function login({
|
|
|
1515
1496
|
errorCode: initAuth.errorCode
|
|
1516
1497
|
};
|
|
1517
1498
|
}
|
|
1518
|
-
const optionsJSON = initAuth.optionsJSON;
|
|
1499
|
+
const optionsJSON = initAuth.data.optionsJSON;
|
|
1519
1500
|
const authJSON = await startAuthentication({ optionsJSON });
|
|
1520
|
-
const verifyAuthRes = await fetch(`${serverUrl}/verify
|
|
1501
|
+
const verifyAuthRes = await fetch(`${serverUrl}/auth-verify`, {
|
|
1521
1502
|
credentials: "include",
|
|
1522
1503
|
method: "POST",
|
|
1523
1504
|
headers: {
|
|
@@ -1529,7 +1510,7 @@ async function login({
|
|
|
1529
1510
|
if (!verifyAuthRes.ok) {
|
|
1530
1511
|
return { success: false, error: verifyAuth.error };
|
|
1531
1512
|
}
|
|
1532
|
-
if (verifyAuth.verified) {
|
|
1513
|
+
if (verifyAuth.data.verified) {
|
|
1533
1514
|
return { success: true, authJSON };
|
|
1534
1515
|
} else {
|
|
1535
1516
|
return { success: false, error: "Failed to log in" };
|
|
@@ -1542,7 +1523,7 @@ async function register({
|
|
|
1542
1523
|
serverUrl,
|
|
1543
1524
|
username
|
|
1544
1525
|
}) {
|
|
1545
|
-
const initRegisterRes = await fetch(`${serverUrl}/init
|
|
1526
|
+
const initRegisterRes = await fetch(`${serverUrl}/register-init`, {
|
|
1546
1527
|
credentials: "include",
|
|
1547
1528
|
method: "POST",
|
|
1548
1529
|
headers: {
|
|
@@ -1560,9 +1541,9 @@ async function register({
|
|
|
1560
1541
|
errorCode: initRegister.errorCode
|
|
1561
1542
|
};
|
|
1562
1543
|
}
|
|
1563
|
-
const optionsJSON = initRegister.optionsJSON;
|
|
1544
|
+
const optionsJSON = initRegister.data.optionsJSON;
|
|
1564
1545
|
const registrationJSON = await startRegistration({ optionsJSON });
|
|
1565
|
-
const verifyResponse = await fetch(`${serverUrl}/verify
|
|
1546
|
+
const verifyResponse = await fetch(`${serverUrl}/register-verify`, {
|
|
1566
1547
|
credentials: "include",
|
|
1567
1548
|
method: "POST",
|
|
1568
1549
|
headers: {
|
|
@@ -1579,7 +1560,7 @@ async function register({
|
|
|
1579
1560
|
errorCode: verifyData.errorCode
|
|
1580
1561
|
};
|
|
1581
1562
|
}
|
|
1582
|
-
if (verifyData.verified) {
|
|
1563
|
+
if (verifyData.data.verified) {
|
|
1583
1564
|
console.log(`Successfully registered ${username}`);
|
|
1584
1565
|
return { success: true };
|
|
1585
1566
|
} else {
|
|
@@ -1595,7 +1576,7 @@ async function connect({
|
|
|
1595
1576
|
serverUrl
|
|
1596
1577
|
}) {
|
|
1597
1578
|
const responseRegister = await register({ serverUrl, username });
|
|
1598
|
-
if (responseRegister.success || responseRegister.errorCode == ERRORCODES.USEREXISTS) {
|
|
1579
|
+
if (responseRegister.success || responseRegister.error.errorCode == ERRORCODES.USEREXISTS) {
|
|
1599
1580
|
const loginRes = await handleLogin({ serverUrl, username });
|
|
1600
1581
|
if (loginRes.success && loginRes.authJSON) {
|
|
1601
1582
|
const wallet = await buildWalletFromPasskey(
|
|
@@ -1863,7 +1844,7 @@ var MeshWallet = class {
|
|
|
1863
1844
|
* @param address - the address to use for signing (optional)
|
|
1864
1845
|
* @returns a signature
|
|
1865
1846
|
*/
|
|
1866
|
-
signData(payload, address) {
|
|
1847
|
+
async signData(payload, address) {
|
|
1867
1848
|
if (!this._wallet) {
|
|
1868
1849
|
throw new Error(
|
|
1869
1850
|
"[MeshWallet] Read only wallet does not support signing data."
|
|
@@ -1886,7 +1867,7 @@ var MeshWallet = class {
|
|
|
1886
1867
|
* @param partialSign - if the transaction is partially signed (default: false)
|
|
1887
1868
|
* @returns a signed transaction in CBOR
|
|
1888
1869
|
*/
|
|
1889
|
-
signTx(unsignedTx, partialSign = false) {
|
|
1870
|
+
async signTx(unsignedTx, partialSign = false) {
|
|
1890
1871
|
if (!this._wallet) {
|
|
1891
1872
|
throw new Error(
|
|
1892
1873
|
"[MeshWallet] Read only wallet does not support signing data."
|
|
@@ -1912,7 +1893,7 @@ var MeshWallet = class {
|
|
|
1912
1893
|
* @param partialSign - if the transactions are signed partially
|
|
1913
1894
|
* @returns array of signed transactions CborHex string
|
|
1914
1895
|
*/
|
|
1915
|
-
signTxs(unsignedTxs, partialSign = false) {
|
|
1896
|
+
async signTxs(unsignedTxs, partialSign = false) {
|
|
1916
1897
|
if (!this._wallet) {
|
|
1917
1898
|
throw new Error(
|
|
1918
1899
|
"[MeshWallet] Read only wallet does not support signing data."
|
|
@@ -1920,7 +1901,7 @@ var MeshWallet = class {
|
|
|
1920
1901
|
}
|
|
1921
1902
|
const signedTxs = [];
|
|
1922
1903
|
for (const unsignedTx of unsignedTxs) {
|
|
1923
|
-
const signedTx = this.signTx(unsignedTx, partialSign);
|
|
1904
|
+
const signedTx = await this.signTx(unsignedTx, partialSign);
|
|
1924
1905
|
signedTxs.push(signedTx);
|
|
1925
1906
|
}
|
|
1926
1907
|
return signedTxs;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@meshsdk/wallet",
|
|
3
|
-
"version": "1.8.
|
|
3
|
+
"version": "1.8.9",
|
|
4
4
|
"description": "Wallets - https://meshjs.dev/apis/wallets",
|
|
5
5
|
"main": "./dist/index.cjs",
|
|
6
6
|
"browser": "./dist/index.js",
|
|
@@ -35,12 +35,10 @@
|
|
|
35
35
|
"typescript": "^5.3.3"
|
|
36
36
|
},
|
|
37
37
|
"dependencies": {
|
|
38
|
-
"@meshsdk/common": "1.8.
|
|
39
|
-
"@meshsdk/core-csl": "1.8.
|
|
40
|
-
"@meshsdk/core-cst": "1.8.
|
|
41
|
-
"@meshsdk/transaction": "1.8.
|
|
42
|
-
"@nufi/dapp-client-cardano": "0.3.5",
|
|
43
|
-
"@nufi/dapp-client-core": "0.3.5",
|
|
38
|
+
"@meshsdk/common": "1.8.9",
|
|
39
|
+
"@meshsdk/core-csl": "1.8.9",
|
|
40
|
+
"@meshsdk/core-cst": "1.8.9",
|
|
41
|
+
"@meshsdk/transaction": "1.8.9",
|
|
44
42
|
"@simplewebauthn/browser": "^13.0.0"
|
|
45
43
|
},
|
|
46
44
|
"prettier": "@meshsdk/configs/prettier",
|
|
@@ -55,4 +53,4 @@
|
|
|
55
53
|
"blockchain",
|
|
56
54
|
"sdk"
|
|
57
55
|
]
|
|
58
|
-
}
|
|
56
|
+
}
|