@tari-project/tarijs 0.1.20 → 0.1.22
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/builders/helpers/index.d.ts +2 -0
- package/dist/builders/helpers/index.js +2 -0
- package/dist/builders/helpers/submitTransaction.d.ts +13 -0
- package/dist/builders/helpers/submitTransaction.js +59 -0
- package/dist/builders/helpers/workspace.d.ts +23 -0
- package/dist/builders/helpers/workspace.js +29 -0
- package/dist/builders/index.d.ts +3 -0
- package/dist/builders/index.js +3 -0
- package/dist/builders/transaction/TransactionBuilder.d.ts +44 -0
- package/dist/builders/transaction/TransactionBuilder.js +164 -0
- package/dist/builders/transaction/TransactionRequest.d.ts +27 -0
- package/dist/builders/transaction/TransactionRequest.js +67 -0
- package/dist/builders/transaction/index.d.ts +2 -0
- package/dist/builders/transaction/index.js +2 -0
- package/dist/builders/types/Amount.d.ts +23 -0
- package/dist/builders/types/Amount.js +93 -0
- package/dist/builders/types/Arg.d.ts +1 -0
- package/dist/builders/types/Arg.js +1 -0
- package/dist/builders/types/Builder.d.ts +47 -0
- package/dist/builders/types/Builder.js +1 -0
- package/dist/builders/types/ComponentAddress.js +1 -0
- package/dist/builders/types/ConfidentialClaim.d.ts +8 -0
- package/dist/builders/types/ConfidentialClaim.js +1 -0
- package/dist/{node_modules/@tari-project/typescript-bindings/src → builders}/types/ConfidentialOutput.d.ts +3 -3
- package/dist/builders/types/ConfidentialOutput.js +1 -0
- package/dist/builders/types/ConfidentialOutputStatement.d.ts +9 -0
- package/dist/builders/types/ConfidentialOutputStatement.js +1 -0
- package/dist/builders/types/ConfidentialStatement.d.ts +8 -0
- package/dist/builders/types/ConfidentialStatement.js +1 -0
- package/dist/{node_modules/@tari-project/typescript-bindings/src → builders}/types/ConfidentialWithdrawProof.d.ts +3 -3
- package/dist/builders/types/ConfidentialWithdrawProof.js +1 -0
- package/dist/builders/types/ElgamalVerifiableBalance.js +1 -0
- package/dist/builders/types/Epoch.js +1 -0
- package/dist/builders/types/FinalizeResult.d.ts +20 -0
- package/dist/builders/types/FinalizeResult.js +1 -0
- package/dist/builders/types/Instruction.d.ts +56 -0
- package/dist/builders/types/Instruction.js +1 -0
- package/dist/builders/types/ResourceAddress.js +2 -0
- package/dist/builders/types/SubstateDiff.d.ts +7 -0
- package/dist/builders/types/SubstateDiff.js +1 -0
- package/dist/builders/types/SubstateRequirement.d.ts +5 -0
- package/dist/builders/types/SubstateRequirement.js +1 -0
- package/dist/builders/types/TemplateAddress.d.ts +1 -0
- package/dist/builders/types/TemplateAddress.js +2 -0
- package/dist/builders/types/Transaction.d.ts +15 -0
- package/dist/builders/types/Transaction.js +1 -0
- package/dist/builders/types/TransactionId.d.ts +1 -0
- package/dist/builders/types/TransactionId.js +1 -0
- package/dist/builders/types/TransactionResult.d.ts +22 -0
- package/dist/builders/types/TransactionResult.js +10 -0
- package/dist/builders/types/TransactionSignature.js +1 -0
- package/dist/builders/types/UnsignedTransaction.d.ts +12 -0
- package/dist/builders/types/UnsignedTransaction.js +1 -0
- package/dist/builders/types/VersionedSubstateId.d.ts +5 -0
- package/dist/builders/types/VersionedSubstateId.js +1 -0
- package/dist/builders/types/ViewableBalanceProof.js +2 -0
- package/dist/builders/types/Workspace.d.ts +3 -0
- package/dist/builders/types/Workspace.js +1 -0
- package/dist/builders/types/index.d.ts +24 -0
- package/dist/builders/types/index.js +2 -0
- package/dist/{src/index.d.ts → index.d.ts} +5 -1
- package/dist/index.js +12 -1063
- package/dist/providers/index.js +1 -0
- package/dist/providers/metamask/index.js +169 -0
- package/dist/providers/metamask/utils.js +55 -0
- package/dist/providers/tari_universe/index.js +3 -0
- package/dist/providers/tari_universe/provider.js +88 -0
- package/dist/providers/tari_universe/types.js +1 -0
- package/dist/{src/providers → providers}/types.d.ts +2 -1
- package/dist/providers/types.js +10 -0
- package/dist/providers/wallet_daemon/index.js +3 -0
- package/dist/providers/wallet_daemon/provider.js +173 -0
- package/dist/providers/wallet_daemon/tari_permissions.js +282 -0
- package/dist/providers/wallet_daemon/webrtc.js +201 -0
- package/dist/providers/wallet_daemon/webrtc_transport.js +18 -0
- package/dist/providers/walletconnect/index.d.ts +23 -0
- package/dist/providers/walletconnect/index.js +217 -0
- package/dist/templates/Account.d.ts +65 -0
- package/dist/templates/Account.js +31 -0
- package/dist/templates/Pool.d.ts +30 -0
- package/dist/templates/Pool.js +20 -0
- package/dist/templates/Tariswap.d.ts +65 -0
- package/dist/templates/Tariswap.js +36 -0
- package/dist/templates/TemplateFactory.d.ts +9 -0
- package/dist/templates/TemplateFactory.js +18 -0
- package/dist/templates/TestFaucet.d.ts +49 -0
- package/dist/templates/TestFaucet.js +31 -0
- package/dist/templates/index.d.ts +4 -0
- package/dist/templates/index.js +4 -0
- package/dist/utils.js +22 -0
- package/package.json +14 -13
- package/dist/index.js.map +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/index.d.ts +0 -111
- package/dist/node_modules/@tari-project/typescript-bindings/src/helpers/helpers.d.ts +0 -11
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/AccessRule.d.ts +0 -4
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Account.d.ts +0 -7
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Amount.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Arg.d.ts +0 -5
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ArgDef.d.ts +0 -5
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/AuthHook.d.ts +0 -5
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Block.d.ts +0 -31
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/BucketId.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Claims.d.ts +0 -7
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Command.d.ts +0 -13
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Committee.d.ts +0 -3
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/CommitteeInfo.d.ts +0 -5
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/CommitteeShardInfo.d.ts +0 -10
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ComponentAccessRules.d.ts +0 -5
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ComponentBody.d.ts +0 -3
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ComponentHeader.d.ts +0 -13
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ComponentKey.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ConfidentialClaim.d.ts +0 -8
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ConfidentialOutputStatement.d.ts +0 -9
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ConfidentialStatement.d.ts +0 -8
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ConfidentialTransferInputSelection.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Decision.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/EntityId.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Event.d.ts +0 -9
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Evidence.d.ts +0 -5
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ExecuteResult.d.ts +0 -4
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ExecutedTransaction.d.ts +0 -21
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/FeeBreakdown.d.ts +0 -5
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/FeeClaim.d.ts +0 -6
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/FeeClaimAddress.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/FeeCostBreakdown.d.ts +0 -6
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/FeeReceipt.d.ts +0 -7
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/FeeSource.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/FinalizeResult.d.ts +0 -13
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ForeignProposal.d.ts +0 -10
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ForeignProposalState.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/FunctionDef.d.ts +0 -8
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/IndexedValue.d.ts +0 -5
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/IndexedWellKnownTypes.d.ts +0 -18
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Instruction.d.ts +0 -40
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/InstructionResult.d.ts +0 -6
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/JrpcPermission.d.ts +0 -14
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/JrpcPermissions.d.ts +0 -2
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/LeaderFee.d.ts +0 -4
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/LockFlag.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/LogEntry.d.ts +0 -5
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/LogLevel.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Metadata.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/NetworkCommitteeInfo.d.ts +0 -6
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/NodeHeight.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/NonFungible.d.ts +0 -4
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/NonFungibleAddress.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/NonFungibleAddressContents.d.ts +0 -6
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/NonFungibleContainer.d.ts +0 -2
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/NonFungibleId.d.ts +0 -9
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/NonFungibleIndex.d.ts +0 -4
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/NonFungibleIndexAddress.d.ts +0 -5
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/NonFungibleToken.d.ts +0 -9
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Ordering.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/OwnerRule.d.ts +0 -6
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/PeerAddress.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ProofId.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/QuorumCertificate.d.ts +0 -15
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/QuorumDecision.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/RejectReason.d.ts +0 -11
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/RequireRule.d.ts +0 -8
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Resource.d.ts +0 -16
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ResourceAccessRules.d.ts +0 -9
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ResourceContainer.d.ts +0 -25
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ResourceType.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/RestrictedAccessRule.d.ts +0 -8
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/RuleRequirement.d.ts +0 -12
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Shard.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ShardEvidence.d.ts +0 -5
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Substate.d.ts +0 -5
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/SubstateAddress.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/SubstateDestroyed.d.ts +0 -9
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/SubstateDiff.d.ts +0 -6
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/SubstateId.d.ts +0 -24
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/SubstateLockFlag.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/SubstateRecord.d.ts +0 -19
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/SubstateRequirement.d.ts +0 -5
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/SubstateType.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/SubstateValue.d.ts +0 -25
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/TemplateDef.d.ts +0 -4
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/TemplateDefV1.d.ts +0 -6
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Transaction.d.ts +0 -15
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/TransactionAtom.d.ts +0 -10
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/TransactionPoolRecord.d.ts +0 -16
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/TransactionPoolStage.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/TransactionReceipt.d.ts +0 -9
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/TransactionReceiptAddress.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/TransactionResult.d.ts +0 -9
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/TransactionStatus.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Type.d.ts +0 -9
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/UnclaimedConfidentialOutput.d.ts +0 -4
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/UnsignedTransaction.d.ts +0 -10
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/ValidatorSignature.d.ts +0 -7
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/Vault.d.ts +0 -4
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/VaultId.d.ts +0 -1
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/VersionedSubstateId.d.ts +0 -5
- package/dist/node_modules/@tari-project/typescript-bindings/src/types/VersionedSubstateIdLockIntent.d.ts +0 -6
- /package/dist/{node_modules/@tari-project/typescript-bindings/src → builders}/types/ComponentAddress.d.ts +0 -0
- /package/dist/{node_modules/@tari-project/typescript-bindings/src → builders}/types/ElgamalVerifiableBalance.d.ts +0 -0
- /package/dist/{node_modules/@tari-project/typescript-bindings/src → builders}/types/Epoch.d.ts +0 -0
- /package/dist/{node_modules/@tari-project/typescript-bindings/src → builders}/types/ResourceAddress.d.ts +0 -0
- /package/dist/{node_modules/@tari-project/typescript-bindings/src → builders}/types/TransactionSignature.d.ts +0 -0
- /package/dist/{node_modules/@tari-project/typescript-bindings/src → builders}/types/ViewableBalanceProof.d.ts +0 -0
- /package/dist/{src/providers → providers}/index.d.ts +0 -0
- /package/dist/{src/providers → providers}/metamask/index.d.ts +0 -0
- /package/dist/{src/providers → providers}/metamask/utils.d.ts +0 -0
- /package/dist/{src/providers → providers}/tari_universe/index.d.ts +0 -0
- /package/dist/{src/providers → providers}/tari_universe/provider.d.ts +0 -0
- /package/dist/{src/providers → providers}/tari_universe/types.d.ts +0 -0
- /package/dist/{src/providers → providers}/wallet_daemon/index.d.ts +0 -0
- /package/dist/{src/providers → providers}/wallet_daemon/provider.d.ts +0 -0
- /package/dist/{src/providers → providers}/wallet_daemon/tari_permissions.d.ts +0 -0
- /package/dist/{src/providers → providers}/wallet_daemon/webrtc.d.ts +0 -0
- /package/dist/{src/providers → providers}/wallet_daemon/webrtc_transport.d.ts +0 -0
- /package/dist/{src/utils.d.ts → utils.d.ts} +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
import { TransactionStatus, } from "../types";
|
|
2
|
+
import { connectSnap, getSnap, isFlask } from "./utils";
|
|
3
|
+
export const MetamaskNotInstalled = 'METAMASK_NOT_INSTALLED';
|
|
4
|
+
export const MetamaskIsNotFlask = 'METAMASK_IS_NOT_FLASK';
|
|
5
|
+
export const TariSnapNotInstalled = 'TARI_SNAP_NOT_INSTALLED';
|
|
6
|
+
export class MetamaskTariProvider {
|
|
7
|
+
providerName = "Metamask";
|
|
8
|
+
snapId;
|
|
9
|
+
snapVersion;
|
|
10
|
+
metamask;
|
|
11
|
+
snap;
|
|
12
|
+
metamaskConnected;
|
|
13
|
+
constructor(snapId, metamask) {
|
|
14
|
+
this.snapId = snapId;
|
|
15
|
+
this.snapVersion = undefined;
|
|
16
|
+
this.metamask = metamask;
|
|
17
|
+
this.metamaskConnected = false;
|
|
18
|
+
}
|
|
19
|
+
async connect() {
|
|
20
|
+
// check that the metamask provider is valid
|
|
21
|
+
if (!this.metamask || !this.metamask.isMetaMask) {
|
|
22
|
+
throw MetamaskNotInstalled;
|
|
23
|
+
}
|
|
24
|
+
// check that flask is installed
|
|
25
|
+
if (!isFlask(this.metamask)) {
|
|
26
|
+
throw MetamaskIsNotFlask;
|
|
27
|
+
}
|
|
28
|
+
// connect to the tari snap
|
|
29
|
+
// this will request MetaMask the installation of the tari snap if it's not already installed
|
|
30
|
+
await connectSnap(this.metamask, { [this.snapId]: { version: this.snapVersion } });
|
|
31
|
+
// store the tari snap reference
|
|
32
|
+
const snap = await getSnap(this.metamask, this.snapId);
|
|
33
|
+
if (!snap) {
|
|
34
|
+
// this should olny happen if the user didn't accept the tari snap in the previous step
|
|
35
|
+
throw TariSnapNotInstalled;
|
|
36
|
+
}
|
|
37
|
+
this.snap = snap;
|
|
38
|
+
this.metamaskConnected = true;
|
|
39
|
+
}
|
|
40
|
+
isConnected() {
|
|
41
|
+
return this.metamaskConnected;
|
|
42
|
+
}
|
|
43
|
+
async createFreeTestCoins(account_id) {
|
|
44
|
+
const res = await this.metamaskRequest('getFreeTestCoins', {
|
|
45
|
+
amount: 1000000,
|
|
46
|
+
account_id,
|
|
47
|
+
fee: 2000
|
|
48
|
+
});
|
|
49
|
+
return {
|
|
50
|
+
account_id,
|
|
51
|
+
address: res.address,
|
|
52
|
+
public_key: res.public_key,
|
|
53
|
+
resources: []
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
async getAccount() {
|
|
57
|
+
return await this.metamaskRequest('getAccountData', { account_id: 0 });
|
|
58
|
+
}
|
|
59
|
+
async getSubstate(substate_address) {
|
|
60
|
+
const { substate, address: substate_id, version } = await this.metamaskRequest('getSubstate', { substate_address });
|
|
61
|
+
return { value: substate, address: { substate_id, version } };
|
|
62
|
+
}
|
|
63
|
+
async listSubstates(filter_by_template, filter_by_type, limit, offset) {
|
|
64
|
+
const res = await this.metamaskRequest('listSubstates', {
|
|
65
|
+
filter_by_template,
|
|
66
|
+
filter_by_type,
|
|
67
|
+
limit,
|
|
68
|
+
offset,
|
|
69
|
+
});
|
|
70
|
+
return res;
|
|
71
|
+
}
|
|
72
|
+
async submitTransaction(req) {
|
|
73
|
+
const params = {
|
|
74
|
+
instructions: req.instructions,
|
|
75
|
+
fee_instructions: req.fee_instructions,
|
|
76
|
+
input_refs: req.input_refs,
|
|
77
|
+
required_substates: req.required_substates || [],
|
|
78
|
+
is_dry_run: req.is_dry_run,
|
|
79
|
+
};
|
|
80
|
+
const resp = await this.metamaskRequest('sendTransaction', params);
|
|
81
|
+
if (!resp) {
|
|
82
|
+
throw new Error("Failed to submit transaction to metamask snap: empty response");
|
|
83
|
+
}
|
|
84
|
+
if (resp.error) {
|
|
85
|
+
throw new Error(`Failed to submit transaction to metamask snap: ${resp.error}`);
|
|
86
|
+
}
|
|
87
|
+
return { transaction_id: resp.transaction_id };
|
|
88
|
+
}
|
|
89
|
+
async getTransactionResult(transactionId) {
|
|
90
|
+
// This request returns the response from the indexer get_transaction_result request
|
|
91
|
+
const resp = await this.metamaskRequest('getTransactionResult', { transaction_id: transactionId });
|
|
92
|
+
if (!resp) {
|
|
93
|
+
throw new Error("Failed to get transaction result from metamask snap: empty response");
|
|
94
|
+
}
|
|
95
|
+
if (resp.result === "Pending") {
|
|
96
|
+
return {
|
|
97
|
+
transaction_id: transactionId,
|
|
98
|
+
status: TransactionStatus.Pending,
|
|
99
|
+
result: null
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
if (!resp?.result?.Finalized) {
|
|
103
|
+
throw new Error("Transaction result was not pending nor finalized");
|
|
104
|
+
}
|
|
105
|
+
const newStatus = convertToStatus(resp.result.Finalized);
|
|
106
|
+
return {
|
|
107
|
+
transaction_id: transactionId,
|
|
108
|
+
status: newStatus,
|
|
109
|
+
result: resp.result.Finalized.execution_result.finalize
|
|
110
|
+
};
|
|
111
|
+
}
|
|
112
|
+
async getPublicKey(_branch, index) {
|
|
113
|
+
const resp = await this.metamaskRequest('getPublicKey', { index });
|
|
114
|
+
if (!resp) {
|
|
115
|
+
throw new Error("Failed to get public key from metamask snap: empty response");
|
|
116
|
+
}
|
|
117
|
+
return resp.public_key;
|
|
118
|
+
}
|
|
119
|
+
async getConfidentialVaultBalances(viewKeyId, vaultId, min = null, max = null) {
|
|
120
|
+
const res = await this.metamaskRequest('getConfidentialVaultBalances', {
|
|
121
|
+
view_key_id: viewKeyId,
|
|
122
|
+
vault_id: vaultId,
|
|
123
|
+
minimum_expected_value: min,
|
|
124
|
+
maximum_expected_value: max,
|
|
125
|
+
});
|
|
126
|
+
return { balances: res };
|
|
127
|
+
}
|
|
128
|
+
getTemplateDefinition(template_address) {
|
|
129
|
+
return this.metamaskRequest('getTemplateDefinition', { template_address })
|
|
130
|
+
.then(resp => {
|
|
131
|
+
if (!resp) {
|
|
132
|
+
throw new Error("Template not found");
|
|
133
|
+
}
|
|
134
|
+
return resp.definition;
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
async metamaskRequest(method, params) {
|
|
138
|
+
console.log("Metamask request:", method, params);
|
|
139
|
+
const resp = await this.metamask.request({
|
|
140
|
+
method: 'wallet_invokeSnap',
|
|
141
|
+
params: {
|
|
142
|
+
snapId: this.snapId,
|
|
143
|
+
request: {
|
|
144
|
+
method,
|
|
145
|
+
params
|
|
146
|
+
}
|
|
147
|
+
},
|
|
148
|
+
});
|
|
149
|
+
console.log("Metamask response:", resp);
|
|
150
|
+
if (!resp) {
|
|
151
|
+
throw new Error("Metamask request failed: empty response");
|
|
152
|
+
}
|
|
153
|
+
return resp;
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
function convertToStatus(result) {
|
|
157
|
+
// Ref: https://github.com/tari-project/tari-dan/blob/bb0b31139b770aacd7bb49af865543aa4a9e2de4/dan_layer/wallet/sdk/src/apis/transaction.rs
|
|
158
|
+
if (result.final_decision !== "Commit") {
|
|
159
|
+
return TransactionStatus.Rejected;
|
|
160
|
+
}
|
|
161
|
+
// if (!result?.result?.Finalized) {
|
|
162
|
+
// throw new Error("Transaction result was finalized but no result was returned");
|
|
163
|
+
// }
|
|
164
|
+
//
|
|
165
|
+
// if (result.finalize.AcceptFeeRejectRest) {
|
|
166
|
+
// return TransactionStatus.OnlyFeeAccepted;
|
|
167
|
+
// }
|
|
168
|
+
return TransactionStatus.Accepted;
|
|
169
|
+
}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Get the installed snaps in MetaMask.
|
|
3
|
+
*
|
|
4
|
+
* @param provider - The MetaMask inpage provider.
|
|
5
|
+
* @returns The snaps installed in MetaMask.
|
|
6
|
+
*/
|
|
7
|
+
export const getSnaps = async (provider) => (await provider.request({
|
|
8
|
+
method: 'wallet_getSnaps',
|
|
9
|
+
}));
|
|
10
|
+
/**
|
|
11
|
+
* Connect a snap to MetaMask.
|
|
12
|
+
*
|
|
13
|
+
* @param snapId - The ID of the snap.
|
|
14
|
+
* @param params - The params to pass with the snap to connect.
|
|
15
|
+
*/
|
|
16
|
+
export const connectSnap = async (provider, snaps) => {
|
|
17
|
+
await provider.request({
|
|
18
|
+
method: 'wallet_requestSnaps',
|
|
19
|
+
params: snaps,
|
|
20
|
+
});
|
|
21
|
+
};
|
|
22
|
+
/**
|
|
23
|
+
* Get the snap from MetaMask.
|
|
24
|
+
*
|
|
25
|
+
* @param version - The version of the snap to install (optional).
|
|
26
|
+
* @returns The snap object returned by the extension.
|
|
27
|
+
*/
|
|
28
|
+
export const getSnap = async (provider, snapId, version) => {
|
|
29
|
+
try {
|
|
30
|
+
const snaps = await getSnaps(provider);
|
|
31
|
+
return Object.values(snaps).find((snap) => snap.id === snapId && (!version || snap.version === version));
|
|
32
|
+
}
|
|
33
|
+
catch (e) {
|
|
34
|
+
console.log('Failed to obtain installed snap', e);
|
|
35
|
+
return undefined;
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
export const isLocalSnap = (snapId) => snapId.startsWith('local:');
|
|
39
|
+
/**
|
|
40
|
+
* Detect if the wallet injecting the ethereum object is MetaMask Flask.
|
|
41
|
+
*
|
|
42
|
+
* @returns True if the MetaMask version is Flask, false otherwise.
|
|
43
|
+
*/
|
|
44
|
+
export const isFlask = async (provider) => {
|
|
45
|
+
try {
|
|
46
|
+
const clientVersion = await provider.request({
|
|
47
|
+
method: 'web3_clientVersion',
|
|
48
|
+
});
|
|
49
|
+
const isFlaskDetected = clientVersion?.includes('flask');
|
|
50
|
+
return Boolean(provider && isFlaskDetected);
|
|
51
|
+
}
|
|
52
|
+
catch {
|
|
53
|
+
return false;
|
|
54
|
+
}
|
|
55
|
+
};
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
export class TariUniverseProvider {
|
|
2
|
+
params;
|
|
3
|
+
providerName = "TariUniverse";
|
|
4
|
+
__id = 0;
|
|
5
|
+
constructor(params) {
|
|
6
|
+
this.params = params;
|
|
7
|
+
const filterResizeEvent = function (event) {
|
|
8
|
+
if (event.data && event.data.type === "resize") {
|
|
9
|
+
const resizeEvent = new CustomEvent("resize", {
|
|
10
|
+
detail: { width: event.data.width, height: event.data.height },
|
|
11
|
+
});
|
|
12
|
+
window.dispatchEvent(resizeEvent);
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
window.addEventListener("message", (event) => filterResizeEvent(event), false);
|
|
16
|
+
}
|
|
17
|
+
async sendRequest(req) {
|
|
18
|
+
const id = ++this.__id;
|
|
19
|
+
return new Promise(function (resolve, reject) {
|
|
20
|
+
const event_ref = function (resp) {
|
|
21
|
+
if (resp.data.resultError) {
|
|
22
|
+
window.removeEventListener("message", event_ref);
|
|
23
|
+
reject(resp.data.resultError);
|
|
24
|
+
}
|
|
25
|
+
if (resp && resp.data && resp.data.id && resp.data.id == id && resp.data.type === "provider-call") {
|
|
26
|
+
window.removeEventListener("message", event_ref);
|
|
27
|
+
resolve(resp.data.result);
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
window.addEventListener("message", event_ref, false);
|
|
31
|
+
window.parent.postMessage({ ...req, id, type: "provider-call" }, "*");
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
isConnected() {
|
|
35
|
+
return true;
|
|
36
|
+
}
|
|
37
|
+
getPublicKey() {
|
|
38
|
+
return this.sendRequest({ methodName: "getPublicKey", args: [] });
|
|
39
|
+
}
|
|
40
|
+
async listSubstates(filter_by_template, filter_by_type, limit, offset) {
|
|
41
|
+
return this.sendRequest({
|
|
42
|
+
methodName: "listSubstates",
|
|
43
|
+
args: [filter_by_template, filter_by_type, limit, offset],
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
getConfidentialVaultBalances(viewKeyId, vaultId, min, max) {
|
|
47
|
+
return this.sendRequest({
|
|
48
|
+
methodName: "getConfidentialVaultBalances",
|
|
49
|
+
args: [viewKeyId, vaultId, min, max],
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
async createFreeTestCoins() {
|
|
53
|
+
return this.sendRequest({ methodName: "createFreeTestCoins", args: [] });
|
|
54
|
+
}
|
|
55
|
+
requestParentSize() {
|
|
56
|
+
return this.sendRequest({ methodName: "requestParentSize", args: [] });
|
|
57
|
+
}
|
|
58
|
+
async getAccount() {
|
|
59
|
+
return this.sendRequest({ methodName: "getAccount", args: [] });
|
|
60
|
+
}
|
|
61
|
+
async getAccountBalances(componentAddress) {
|
|
62
|
+
return this.sendRequest({
|
|
63
|
+
methodName: "getAccountBalances",
|
|
64
|
+
args: [componentAddress],
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
async getSubstate(substate_id) {
|
|
68
|
+
return this.sendRequest({
|
|
69
|
+
methodName: "getSubstate",
|
|
70
|
+
args: [substate_id],
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
async submitTransaction(req) {
|
|
74
|
+
return this.sendRequest({
|
|
75
|
+
methodName: "submitTransaction",
|
|
76
|
+
args: [req],
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
async getTransactionResult(transactionId) {
|
|
80
|
+
return this.sendRequest({
|
|
81
|
+
methodName: "getTransactionResult",
|
|
82
|
+
args: [transactionId],
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
async getTemplateDefinition(template_address) {
|
|
86
|
+
return this.sendRequest({ methodName: "getTemplateDefinition", args: [template_address] });
|
|
87
|
+
}
|
|
88
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { FinalizeResult } from "@tari-project/typescript-bindings";
|
|
1
2
|
export type SubstateMetadata = {
|
|
2
3
|
substate_id: string;
|
|
3
4
|
module_name: string | null;
|
|
@@ -25,7 +26,7 @@ export type SubmitTransactionResponse = {
|
|
|
25
26
|
export type TransactionResult = {
|
|
26
27
|
transaction_id: string;
|
|
27
28
|
status: TransactionStatus;
|
|
28
|
-
result:
|
|
29
|
+
result: FinalizeResult | null;
|
|
29
30
|
};
|
|
30
31
|
export declare enum TransactionStatus {
|
|
31
32
|
New = 0,
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export var TransactionStatus;
|
|
2
|
+
(function (TransactionStatus) {
|
|
3
|
+
TransactionStatus[TransactionStatus["New"] = 0] = "New";
|
|
4
|
+
TransactionStatus[TransactionStatus["DryRun"] = 1] = "DryRun";
|
|
5
|
+
TransactionStatus[TransactionStatus["Pending"] = 2] = "Pending";
|
|
6
|
+
TransactionStatus[TransactionStatus["Accepted"] = 3] = "Accepted";
|
|
7
|
+
TransactionStatus[TransactionStatus["Rejected"] = 4] = "Rejected";
|
|
8
|
+
TransactionStatus[TransactionStatus["InvalidTransaction"] = 5] = "InvalidTransaction";
|
|
9
|
+
TransactionStatus[TransactionStatus["OnlyFeeAccepted"] = 6] = "OnlyFeeAccepted";
|
|
10
|
+
})(TransactionStatus || (TransactionStatus = {}));
|
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
import { TariPermissions, } from "./tari_permissions";
|
|
2
|
+
import { TariConnection } from "./webrtc";
|
|
3
|
+
import { TransactionStatus, } from "../types";
|
|
4
|
+
import { WalletDaemonClient, stringToSubstateId, substateIdToString, } from "@tari-project/wallet_jrpc_client";
|
|
5
|
+
import { WebRtcRpcTransport } from "./webrtc_transport";
|
|
6
|
+
export const WalletDaemonNotConnected = 'WALLET_DAEMON_NOT_CONNECTED';
|
|
7
|
+
export const Unsupported = 'UNSUPPORTED';
|
|
8
|
+
export class WalletDaemonTariProvider {
|
|
9
|
+
providerName = "WalletDaemon";
|
|
10
|
+
params;
|
|
11
|
+
client;
|
|
12
|
+
constructor(params, connection) {
|
|
13
|
+
this.params = params;
|
|
14
|
+
this.client = connection;
|
|
15
|
+
}
|
|
16
|
+
static async build(params) {
|
|
17
|
+
const allPermissions = new TariPermissions();
|
|
18
|
+
allPermissions.addPermissions(params.permissions);
|
|
19
|
+
allPermissions.addPermissions(params.optionalPermissions);
|
|
20
|
+
console.log({ allPermissions });
|
|
21
|
+
let connection = new TariConnection(params.signalingServerUrl, params.webRtcConfig);
|
|
22
|
+
const client = WalletDaemonClient.new(WebRtcRpcTransport.new(connection));
|
|
23
|
+
await connection.init(allPermissions, (conn) => {
|
|
24
|
+
params.onConnection?.();
|
|
25
|
+
if (conn.token) {
|
|
26
|
+
client.setToken(conn.token);
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
return new WalletDaemonTariProvider(params, client);
|
|
30
|
+
}
|
|
31
|
+
get token() {
|
|
32
|
+
return this.client.getTransport().token();
|
|
33
|
+
}
|
|
34
|
+
get tokenUrl() {
|
|
35
|
+
if (!this.token) {
|
|
36
|
+
return undefined;
|
|
37
|
+
}
|
|
38
|
+
const name = this.params.name && encodeURIComponent(this.params.name) || '';
|
|
39
|
+
const token = this.token;
|
|
40
|
+
const permissions = JSON.stringify(this.params.permissions);
|
|
41
|
+
const optionalPermissions = JSON.stringify(this.params.optionalPermissions);
|
|
42
|
+
return `tari://${name}/${token}/${permissions}/${optionalPermissions}`;
|
|
43
|
+
}
|
|
44
|
+
isConnected() {
|
|
45
|
+
return this.client.getTransport().isConnected();
|
|
46
|
+
}
|
|
47
|
+
async createFreeTestCoins() {
|
|
48
|
+
const res = await this.client.createFreeTestCoins({
|
|
49
|
+
account: { Name: "template_web" },
|
|
50
|
+
amount: 1000000,
|
|
51
|
+
max_fee: null,
|
|
52
|
+
key_id: 0
|
|
53
|
+
});
|
|
54
|
+
return {
|
|
55
|
+
account_id: res.account.key_index,
|
|
56
|
+
address: res.account.address.Component,
|
|
57
|
+
public_key: res.public_key,
|
|
58
|
+
resources: []
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
async getAccount() {
|
|
62
|
+
const { account, public_key } = await this.client.accountsGetDefault({});
|
|
63
|
+
const { balances } = await this.client.accountsGetBalances({ account: { ComponentAddress: account.address.Component }, refresh: false });
|
|
64
|
+
return {
|
|
65
|
+
account_id: account.key_index,
|
|
66
|
+
address: account.address.Component,
|
|
67
|
+
public_key,
|
|
68
|
+
// TODO: should be vaults not resources
|
|
69
|
+
resources: balances.map((b) => ({
|
|
70
|
+
type: b.resource_type,
|
|
71
|
+
resource_address: b.resource_address,
|
|
72
|
+
balance: b.balance + b.confidential_balance,
|
|
73
|
+
vault_id: ('Vault' in b.vault_address) ? b.vault_address.Vault : b.vault_address,
|
|
74
|
+
token_symbol: b.token_symbol,
|
|
75
|
+
}))
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
async getAccountBalances(componentAddress) {
|
|
79
|
+
return await this.client.accountsGetBalances({ account: { ComponentAddress: componentAddress }, refresh: true });
|
|
80
|
+
}
|
|
81
|
+
async getSubstate(substate_id) {
|
|
82
|
+
const substateId = stringToSubstateId(substate_id);
|
|
83
|
+
const { value, record } = await this.client.substatesGet({ substate_id: substateId });
|
|
84
|
+
return {
|
|
85
|
+
value,
|
|
86
|
+
address: {
|
|
87
|
+
substate_id: substateIdToString(record.substate_id),
|
|
88
|
+
version: record.version
|
|
89
|
+
}
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
async submitTransaction(req) {
|
|
93
|
+
const params = {
|
|
94
|
+
transaction: null,
|
|
95
|
+
signing_key_index: req.account_id,
|
|
96
|
+
fee_instructions: req.fee_instructions,
|
|
97
|
+
instructions: req.instructions,
|
|
98
|
+
inputs: req.required_substates.map((s) => ({
|
|
99
|
+
// TODO: Hmm The bindings want a SubstateId object, but the wallet only wants a string. Any is used to skip type checking here
|
|
100
|
+
substate_id: s.substate_id,
|
|
101
|
+
version: s.version
|
|
102
|
+
})),
|
|
103
|
+
input_refs: [],
|
|
104
|
+
override_inputs: false,
|
|
105
|
+
is_dry_run: req.is_dry_run,
|
|
106
|
+
proof_ids: [],
|
|
107
|
+
min_epoch: null,
|
|
108
|
+
max_epoch: null,
|
|
109
|
+
};
|
|
110
|
+
const res = await this.client.submitTransaction(params);
|
|
111
|
+
return { transaction_id: res.transaction_id };
|
|
112
|
+
}
|
|
113
|
+
async getTransactionResult(transactionId) {
|
|
114
|
+
const res = await this.client.getTransactionResult({ transaction_id: transactionId });
|
|
115
|
+
return {
|
|
116
|
+
transaction_id: transactionId,
|
|
117
|
+
status: convertStringToTransactionStatus(res.status),
|
|
118
|
+
result: res.result,
|
|
119
|
+
};
|
|
120
|
+
}
|
|
121
|
+
async getPublicKey(branch, index) {
|
|
122
|
+
const res = await this.client.createKey({ branch: branch, specific_index: index });
|
|
123
|
+
return res.public_key;
|
|
124
|
+
}
|
|
125
|
+
async getTemplateDefinition(template_address) {
|
|
126
|
+
let resp = await this.client.templatesGet({ template_address });
|
|
127
|
+
return resp.template_definition;
|
|
128
|
+
}
|
|
129
|
+
async getConfidentialVaultBalances(viewKeyId, vaultId, min = null, max = null) {
|
|
130
|
+
const res = await this.client.viewVaultBalance({
|
|
131
|
+
view_key_id: viewKeyId,
|
|
132
|
+
vault_id: vaultId,
|
|
133
|
+
minimum_expected_value: min,
|
|
134
|
+
maximum_expected_value: max,
|
|
135
|
+
});
|
|
136
|
+
return { balances: res.balances };
|
|
137
|
+
}
|
|
138
|
+
async listSubstates(filter_by_template, filter_by_type, limit, offset) {
|
|
139
|
+
const resp = await this.client.substatesList({
|
|
140
|
+
filter_by_template,
|
|
141
|
+
filter_by_type,
|
|
142
|
+
limit,
|
|
143
|
+
offset
|
|
144
|
+
});
|
|
145
|
+
const substates = resp.substates.map((s) => ({
|
|
146
|
+
substate_id: substateIdToString(s.substate_id),
|
|
147
|
+
module_name: s.module_name,
|
|
148
|
+
version: s.version,
|
|
149
|
+
template_address: s.template_address
|
|
150
|
+
}));
|
|
151
|
+
return { substates };
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
function convertStringToTransactionStatus(status) {
|
|
155
|
+
switch (status) {
|
|
156
|
+
case "New":
|
|
157
|
+
return TransactionStatus.New;
|
|
158
|
+
case "DryRun":
|
|
159
|
+
return TransactionStatus.DryRun;
|
|
160
|
+
case "Pending":
|
|
161
|
+
return TransactionStatus.Pending;
|
|
162
|
+
case "Accepted":
|
|
163
|
+
return TransactionStatus.Accepted;
|
|
164
|
+
case "Rejected":
|
|
165
|
+
return TransactionStatus.Rejected;
|
|
166
|
+
case "InvalidTransaction":
|
|
167
|
+
return TransactionStatus.InvalidTransaction;
|
|
168
|
+
case "OnlyFeeAccepted":
|
|
169
|
+
return TransactionStatus.OnlyFeeAccepted;
|
|
170
|
+
default:
|
|
171
|
+
throw new Error(`Unknown status: ${status}`);
|
|
172
|
+
}
|
|
173
|
+
}
|