@tari-project/tarijs 0.3.0 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (105) hide show
  1. package/dist/index.d.ts +11 -10
  2. package/dist/index.js +10 -9
  3. package/dist/network.d.ts +8 -0
  4. package/dist/network.js +9 -0
  5. package/dist/templates/Account.d.ts +2 -2
  6. package/dist/templates/Pool.d.ts +1 -2
  7. package/dist/templates/Tariswap.d.ts +1 -2
  8. package/dist/templates/TemplateFactory.d.ts +1 -1
  9. package/dist/templates/TestFaucet.d.ts +1 -1
  10. package/package.json +20 -12
  11. package/README.md +0 -46
  12. package/dist/builders/helpers/index.d.ts +0 -2
  13. package/dist/builders/helpers/index.js +0 -2
  14. package/dist/builders/helpers/submitTransaction.d.ts +0 -13
  15. package/dist/builders/helpers/submitTransaction.js +0 -59
  16. package/dist/builders/helpers/workspace.d.ts +0 -23
  17. package/dist/builders/helpers/workspace.js +0 -29
  18. package/dist/builders/index.d.ts +0 -3
  19. package/dist/builders/index.js +0 -3
  20. package/dist/builders/transaction/TransactionBuilder.d.ts +0 -44
  21. package/dist/builders/transaction/TransactionBuilder.js +0 -164
  22. package/dist/builders/transaction/TransactionRequest.d.ts +0 -27
  23. package/dist/builders/transaction/TransactionRequest.js +0 -67
  24. package/dist/builders/transaction/index.d.ts +0 -2
  25. package/dist/builders/transaction/index.js +0 -2
  26. package/dist/builders/types/Amount.d.ts +0 -23
  27. package/dist/builders/types/Amount.js +0 -93
  28. package/dist/builders/types/Arg.d.ts +0 -1
  29. package/dist/builders/types/Arg.js +0 -1
  30. package/dist/builders/types/Builder.d.ts +0 -47
  31. package/dist/builders/types/Builder.js +0 -1
  32. package/dist/builders/types/ComponentAddress.d.ts +0 -1
  33. package/dist/builders/types/ComponentAddress.js +0 -1
  34. package/dist/builders/types/ConfidentialClaim.d.ts +0 -8
  35. package/dist/builders/types/ConfidentialClaim.js +0 -1
  36. package/dist/builders/types/ConfidentialOutput.d.ts +0 -8
  37. package/dist/builders/types/ConfidentialOutput.js +0 -1
  38. package/dist/builders/types/ConfidentialOutputStatement.d.ts +0 -9
  39. package/dist/builders/types/ConfidentialOutputStatement.js +0 -1
  40. package/dist/builders/types/ConfidentialStatement.d.ts +0 -8
  41. package/dist/builders/types/ConfidentialStatement.js +0 -1
  42. package/dist/builders/types/ConfidentialWithdrawProof.d.ts +0 -7
  43. package/dist/builders/types/ConfidentialWithdrawProof.js +0 -1
  44. package/dist/builders/types/ElgamalVerifiableBalance.d.ts +0 -4
  45. package/dist/builders/types/ElgamalVerifiableBalance.js +0 -1
  46. package/dist/builders/types/Epoch.d.ts +0 -1
  47. package/dist/builders/types/Epoch.js +0 -1
  48. package/dist/builders/types/FinalizeResult.d.ts +0 -20
  49. package/dist/builders/types/FinalizeResult.js +0 -1
  50. package/dist/builders/types/Instruction.d.ts +0 -56
  51. package/dist/builders/types/Instruction.js +0 -1
  52. package/dist/builders/types/ResourceAddress.d.ts +0 -1
  53. package/dist/builders/types/ResourceAddress.js +0 -2
  54. package/dist/builders/types/SubstateDiff.d.ts +0 -7
  55. package/dist/builders/types/SubstateDiff.js +0 -1
  56. package/dist/builders/types/SubstateRequirement.d.ts +0 -5
  57. package/dist/builders/types/SubstateRequirement.js +0 -1
  58. package/dist/builders/types/TemplateAddress.d.ts +0 -1
  59. package/dist/builders/types/TemplateAddress.js +0 -2
  60. package/dist/builders/types/Transaction.d.ts +0 -15
  61. package/dist/builders/types/Transaction.js +0 -1
  62. package/dist/builders/types/TransactionId.d.ts +0 -1
  63. package/dist/builders/types/TransactionId.js +0 -1
  64. package/dist/builders/types/TransactionResult.d.ts +0 -22
  65. package/dist/builders/types/TransactionResult.js +0 -10
  66. package/dist/builders/types/TransactionSignature.d.ts +0 -4
  67. package/dist/builders/types/TransactionSignature.js +0 -1
  68. package/dist/builders/types/UnsignedTransaction.d.ts +0 -12
  69. package/dist/builders/types/UnsignedTransaction.js +0 -1
  70. package/dist/builders/types/VersionedSubstateId.d.ts +0 -5
  71. package/dist/builders/types/VersionedSubstateId.js +0 -1
  72. package/dist/builders/types/ViewableBalanceProof.d.ts +0 -10
  73. package/dist/builders/types/ViewableBalanceProof.js +0 -2
  74. package/dist/builders/types/Workspace.d.ts +0 -3
  75. package/dist/builders/types/Workspace.js +0 -1
  76. package/dist/builders/types/index.d.ts +0 -24
  77. package/dist/builders/types/index.js +0 -2
  78. package/dist/providers/index.d.ts +0 -16
  79. package/dist/providers/index.js +0 -1
  80. package/dist/providers/metamask/index.d.ts +0 -30
  81. package/dist/providers/metamask/index.js +0 -168
  82. package/dist/providers/metamask/utils.d.ts +0 -38
  83. package/dist/providers/metamask/utils.js +0 -55
  84. package/dist/providers/tari_universe/index.d.ts +0 -3
  85. package/dist/providers/tari_universe/index.js +0 -3
  86. package/dist/providers/tari_universe/provider.d.ts +0 -23
  87. package/dist/providers/tari_universe/provider.js +0 -89
  88. package/dist/providers/tari_universe/types.d.ts +0 -30
  89. package/dist/providers/tari_universe/types.js +0 -1
  90. package/dist/providers/tari_universe/utils.d.ts +0 -2
  91. package/dist/providers/tari_universe/utils.js +0 -16
  92. package/dist/providers/types.d.ts +0 -66
  93. package/dist/providers/types.js +0 -10
  94. package/dist/providers/wallet_daemon/index.d.ts +0 -3
  95. package/dist/providers/wallet_daemon/index.js +0 -3
  96. package/dist/providers/wallet_daemon/provider.d.ts +0 -35
  97. package/dist/providers/wallet_daemon/provider.js +0 -173
  98. package/dist/providers/wallet_daemon/tari_permissions.d.ts +0 -216
  99. package/dist/providers/wallet_daemon/tari_permissions.js +0 -282
  100. package/dist/providers/wallet_daemon/webrtc.d.ts +0 -20
  101. package/dist/providers/wallet_daemon/webrtc.js +0 -201
  102. package/dist/providers/wallet_daemon/webrtc_transport.d.ts +0 -10
  103. package/dist/providers/wallet_daemon/webrtc_transport.js +0 -18
  104. package/dist/providers/walletconnect/index.d.ts +0 -23
  105. package/dist/providers/walletconnect/index.js +0 -217
@@ -1,30 +0,0 @@
1
- import { TariProvider } from "../index";
2
- import { SubmitTransactionRequest, TransactionResult, SubmitTransactionResponse, VaultBalances, TemplateDefinition, Substate, ListSubstatesResponse } from "../types";
3
- import { MetaMaskInpageProvider } from "@metamask/providers";
4
- import { Snap } from "./utils";
5
- import { Account } from "../types";
6
- import { SubstateType } from "@tari-project/typescript-bindings";
7
- export declare const MetamaskNotInstalled = "METAMASK_NOT_INSTALLED";
8
- export declare const MetamaskIsNotFlask = "METAMASK_IS_NOT_FLASK";
9
- export declare const TariSnapNotInstalled = "TARI_SNAP_NOT_INSTALLED";
10
- export declare class MetamaskTariProvider implements TariProvider {
11
- providerName: string;
12
- snapId: string;
13
- snapVersion: string | undefined;
14
- metamask: MetaMaskInpageProvider;
15
- snap?: Snap;
16
- metamaskConnected: boolean;
17
- constructor(snapId: string, metamask: MetaMaskInpageProvider);
18
- connect(): Promise<void>;
19
- isConnected(): boolean;
20
- createFreeTestCoins(account_id: number): Promise<Account>;
21
- getAccount(): Promise<Account>;
22
- getSubstate(substate_address: string): Promise<Substate>;
23
- listSubstates(filter_by_template: string | null, filter_by_type: SubstateType | null, limit: number | null, offset: number | null): Promise<ListSubstatesResponse>;
24
- submitTransaction(req: SubmitTransactionRequest): Promise<SubmitTransactionResponse>;
25
- getTransactionResult(transactionId: string): Promise<TransactionResult>;
26
- getPublicKey(_branch: string, index: number): Promise<string>;
27
- getConfidentialVaultBalances(viewKeyId: number, vaultId: string, min?: number | null, max?: number | null): Promise<VaultBalances>;
28
- getTemplateDefinition(template_address: string): Promise<TemplateDefinition>;
29
- private metamaskRequest;
30
- }
@@ -1,168 +0,0 @@
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 }).then((resp) => {
130
- if (!resp) {
131
- throw new Error("Template not found");
132
- }
133
- return resp.definition;
134
- });
135
- }
136
- async metamaskRequest(method, params) {
137
- console.log("Metamask request:", method, params);
138
- const resp = await this.metamask.request({
139
- method: "wallet_invokeSnap",
140
- params: {
141
- snapId: this.snapId,
142
- request: {
143
- method,
144
- params,
145
- },
146
- },
147
- });
148
- console.log("Metamask response:", resp);
149
- if (!resp) {
150
- throw new Error("Metamask request failed: empty response");
151
- }
152
- return resp;
153
- }
154
- }
155
- function convertToStatus(result) {
156
- // Ref: https://github.com/tari-project/tari-dan/blob/bb0b31139b770aacd7bb49af865543aa4a9e2de4/dan_layer/wallet/sdk/src/apis/transaction.rs
157
- if (result.final_decision !== "Commit") {
158
- return TransactionStatus.Rejected;
159
- }
160
- // if (!result?.result?.Finalized) {
161
- // throw new Error("Transaction result was finalized but no result was returned");
162
- // }
163
- //
164
- // if (result.finalize.AcceptFeeRejectRest) {
165
- // return TransactionStatus.OnlyFeeAccepted;
166
- // }
167
- return TransactionStatus.Accepted;
168
- }
@@ -1,38 +0,0 @@
1
- import { MetaMaskInpageProvider } from '@metamask/providers';
2
- export type GetSnapsResponse = Record<string, Snap>;
3
- export type Snap = {
4
- permissionName: string;
5
- id: string;
6
- version: string;
7
- initialPermissions: Record<string, unknown>;
8
- };
9
- /**
10
- * Get the installed snaps in MetaMask.
11
- *
12
- * @param provider - The MetaMask inpage provider.
13
- * @returns The snaps installed in MetaMask.
14
- */
15
- export declare const getSnaps: (provider: MetaMaskInpageProvider) => Promise<GetSnapsResponse>;
16
- /**
17
- * Connect a snap to MetaMask.
18
- *
19
- * @param snapId - The ID of the snap.
20
- * @param params - The params to pass with the snap to connect.
21
- */
22
- export declare const connectSnap: (provider: MetaMaskInpageProvider, snaps: Record<string, {
23
- version?: string;
24
- }>) => Promise<void>;
25
- /**
26
- * Get the snap from MetaMask.
27
- *
28
- * @param version - The version of the snap to install (optional).
29
- * @returns The snap object returned by the extension.
30
- */
31
- export declare const getSnap: (provider: MetaMaskInpageProvider, snapId: string, version?: string) => Promise<Snap | undefined>;
32
- export declare const isLocalSnap: (snapId: string) => boolean;
33
- /**
34
- * Detect if the wallet injecting the ethereum object is MetaMask Flask.
35
- *
36
- * @returns True if the MetaMask version is Flask, false otherwise.
37
- */
38
- export declare const isFlask: (provider: MetaMaskInpageProvider) => Promise<boolean>;
@@ -1,55 +0,0 @@
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
- };
@@ -1,3 +0,0 @@
1
- export * from "../wallet_daemon/tari_permissions";
2
- export * from "./provider";
3
- export * from "./types";
@@ -1,3 +0,0 @@
1
- export * from "../wallet_daemon/tari_permissions";
2
- export * from "./provider";
3
- export * from "./types";
@@ -1,23 +0,0 @@
1
- import { SubmitTransactionRequest, TransactionResult, SubmitTransactionResponse, Account, Substate, TemplateDefinition, VaultBalances, ListSubstatesResponse } from "../types";
2
- import { TariUniverseProviderParameters, WindowSize } from "./types";
3
- import { TariProvider } from "../index";
4
- import { AccountsGetBalancesResponse, SubstateType } from "@tari-project/wallet_jrpc_client";
5
- export declare class TariUniverseProvider implements TariProvider {
6
- params: TariUniverseProviderParameters;
7
- providerName: string;
8
- private __id;
9
- constructor(params: TariUniverseProviderParameters);
10
- private sendRequest;
11
- isConnected(): boolean;
12
- getPublicKey(): Promise<string>;
13
- listSubstates(filter_by_template: string | null, filter_by_type: SubstateType | null, limit: number | null, offset: number | null): Promise<ListSubstatesResponse>;
14
- getConfidentialVaultBalances(viewKeyId: number, vaultId: string, min: number | null, max: number | null): Promise<VaultBalances>;
15
- createFreeTestCoins(): Promise<void>;
16
- requestParentSize(): Promise<WindowSize>;
17
- getAccount(): Promise<Account>;
18
- getAccountBalances(componentAddress: string): Promise<AccountsGetBalancesResponse>;
19
- getSubstate(substate_id: string): Promise<Substate>;
20
- submitTransaction(req: SubmitTransactionRequest): Promise<SubmitTransactionResponse>;
21
- getTransactionResult(transactionId: string): Promise<TransactionResult>;
22
- getTemplateDefinition(template_address: string): Promise<TemplateDefinition>;
23
- }
@@ -1,89 +0,0 @@
1
- import { sendProviderCall } from "./utils";
2
- export class TariUniverseProvider {
3
- params;
4
- providerName = "TariUniverse";
5
- __id = 0;
6
- constructor(params) {
7
- this.params = params;
8
- const filterResizeEvent = function (event) {
9
- if (event.data && event.data.type === "resize") {
10
- const resizeEvent = new CustomEvent("resize", {
11
- detail: { width: event.data.width, height: event.data.height },
12
- });
13
- window.dispatchEvent(resizeEvent);
14
- }
15
- };
16
- window.addEventListener("message", (event) => filterResizeEvent(event), false);
17
- }
18
- async sendRequest(req) {
19
- const id = ++this.__id;
20
- return sendProviderCall(req, id);
21
- }
22
- isConnected() {
23
- return true;
24
- }
25
- getPublicKey() {
26
- return this.sendRequest({ methodName: "getPublicKey", args: [] });
27
- }
28
- async listSubstates(filter_by_template, filter_by_type, limit, offset) {
29
- return this.sendRequest({
30
- methodName: "listSubstates",
31
- args: [filter_by_template, filter_by_type, limit, offset],
32
- });
33
- }
34
- getConfidentialVaultBalances(viewKeyId, vaultId, min, max) {
35
- return this.sendRequest({
36
- methodName: "getConfidentialVaultBalances",
37
- args: [viewKeyId, vaultId, min, max],
38
- });
39
- }
40
- async createFreeTestCoins() {
41
- return this.sendRequest({ methodName: "createFreeTestCoins", args: [] });
42
- }
43
- requestParentSize() {
44
- return this.sendRequest({ methodName: "requestParentSize", args: [] });
45
- }
46
- async getAccount() {
47
- const { account_id, address, public_key } = await this.sendRequest({ methodName: "getAccount", args: [] });
48
- const { balances } = await this.getAccountBalances(address);
49
- return {
50
- account_id,
51
- address,
52
- public_key,
53
- resources: balances.map((b) => ({
54
- type: b.resource_type,
55
- resource_address: b.resource_address,
56
- balance: b.balance + b.confidential_balance,
57
- vault_id: "Vault" in b.vault_address ? b.vault_address.Vault : b.vault_address,
58
- token_symbol: b.token_symbol,
59
- })),
60
- };
61
- }
62
- async getAccountBalances(componentAddress) {
63
- return this.sendRequest({
64
- methodName: "getAccountBalances",
65
- args: [componentAddress],
66
- });
67
- }
68
- async getSubstate(substate_id) {
69
- return this.sendRequest({
70
- methodName: "getSubstate",
71
- args: [substate_id],
72
- });
73
- }
74
- async submitTransaction(req) {
75
- return this.sendRequest({
76
- methodName: "submitTransaction",
77
- args: [req],
78
- });
79
- }
80
- async getTransactionResult(transactionId) {
81
- return this.sendRequest({
82
- methodName: "getTransactionResult",
83
- args: [transactionId],
84
- });
85
- }
86
- async getTemplateDefinition(template_address) {
87
- return this.sendRequest({ methodName: "getTemplateDefinition", args: [template_address] });
88
- }
89
- }
@@ -1,30 +0,0 @@
1
- import { TariPermissions } from "../wallet_daemon";
2
- import { TariUniverseProvider } from "./provider";
3
- export type TariUniverseProviderParameters = {
4
- permissions: TariPermissions;
5
- optionalPermissions: TariPermissions;
6
- name?: string;
7
- onConnection?: () => void;
8
- };
9
- export type WindowSize = {
10
- width: number;
11
- height: number;
12
- };
13
- export type PickMatching<T, V> = {
14
- [K in keyof T as T[K] extends V ? K : never]: T[K];
15
- };
16
- export type ExtractMethods<T> = PickMatching<T, Function>;
17
- export type ProviderMethods = ExtractMethods<TariUniverseProvider>;
18
- export type ProviderMethodNames = keyof ProviderMethods;
19
- export type ProviderReturnType<T extends ProviderMethodNames> = Awaited<ReturnType<ProviderMethods[T]>>;
20
- export type ProviderRequest<T extends ProviderMethodNames> = {
21
- id: number;
22
- methodName: T;
23
- args: Parameters<ProviderMethods[T]>;
24
- };
25
- export type ProviderResponse<T extends ProviderMethodNames> = {
26
- id: number;
27
- type: "provider-call";
28
- result: ProviderReturnType<T>;
29
- resultError?: string;
30
- };
@@ -1 +0,0 @@
1
- export {};
@@ -1,2 +0,0 @@
1
- import { ProviderMethodNames, ProviderRequest, ProviderReturnType } from "./types";
2
- export declare function sendProviderCall<MethodName extends ProviderMethodNames>(req: Omit<ProviderRequest<MethodName>, "id">, id: number): Promise<ProviderReturnType<MethodName>>;
@@ -1,16 +0,0 @@
1
- export function sendProviderCall(req, id) {
2
- return new Promise((resolve, reject) => {
3
- const event_ref = (resp) => {
4
- if (resp.data.resultError) {
5
- window.removeEventListener("message", event_ref);
6
- reject(resp.data.resultError);
7
- }
8
- if (resp && resp.data && resp.data.id && resp.data.id === id && resp.data.type === "provider-call") {
9
- window.removeEventListener("message", event_ref);
10
- resolve(resp.data.result);
11
- }
12
- };
13
- window.addEventListener("message", event_ref, false);
14
- window.parent.postMessage({ ...req, id, type: "provider-call" }, "*");
15
- });
16
- }
@@ -1,66 +0,0 @@
1
- import { FinalizeResult } from "@tari-project/typescript-bindings";
2
- export type SubstateMetadata = {
3
- substate_id: string;
4
- module_name: string | null;
5
- version: number;
6
- template_address: string | null;
7
- };
8
- export type SubstateRequirement = {
9
- substate_id: string;
10
- version?: number | null;
11
- };
12
- export type SubmitTransactionRequest = {
13
- account_id: number;
14
- instructions: object[];
15
- fee_instructions: object[];
16
- inputs: object[];
17
- input_refs: object[];
18
- required_substates: SubstateRequirement[];
19
- is_dry_run: boolean;
20
- min_epoch: number | null;
21
- max_epoch: number | null;
22
- };
23
- export type SubmitTransactionResponse = {
24
- transaction_id: string;
25
- };
26
- export type TransactionResult = {
27
- transaction_id: string;
28
- status: TransactionStatus;
29
- result: FinalizeResult | null;
30
- };
31
- export declare enum TransactionStatus {
32
- New = 0,
33
- DryRun = 1,
34
- Pending = 2,
35
- Accepted = 3,
36
- Rejected = 4,
37
- InvalidTransaction = 5,
38
- OnlyFeeAccepted = 6
39
- }
40
- export interface Account {
41
- account_id: number;
42
- address: string;
43
- public_key: string;
44
- resources: VaultData[];
45
- }
46
- export interface VaultData {
47
- type: string;
48
- balance: number;
49
- resource_address: string;
50
- }
51
- export interface VaultBalances {
52
- balances: Map<string, number | null>;
53
- }
54
- export interface TemplateDefinition {
55
- [key: string]: any;
56
- }
57
- export interface Substate {
58
- value: any;
59
- address: {
60
- substate_id: string;
61
- version: number;
62
- };
63
- }
64
- export type ListSubstatesResponse = {
65
- substates: Array<SubstateMetadata>;
66
- };
@@ -1,10 +0,0 @@
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 = {}));
@@ -1,3 +0,0 @@
1
- export { TariConnection } from "./webrtc";
2
- export * from "./tari_permissions";
3
- export * from "./provider";
@@ -1,3 +0,0 @@
1
- export { TariConnection } from "./webrtc";
2
- export * from "./tari_permissions";
3
- export * from "./provider";
@@ -1,35 +0,0 @@
1
- import { TariPermissions } from "./tari_permissions";
2
- import { TariProvider } from '../index';
3
- import { SubmitTransactionRequest, TransactionResult, SubmitTransactionResponse, VaultBalances, TemplateDefinition, Substate, ListSubstatesResponse } from "../types";
4
- import { Account } from "../types";
5
- import { WalletDaemonClient, SubstateType } from "@tari-project/wallet_jrpc_client";
6
- export declare const WalletDaemonNotConnected = "WALLET_DAEMON_NOT_CONNECTED";
7
- export declare const Unsupported = "UNSUPPORTED";
8
- export type WalletDaemonParameters = {
9
- signalingServerUrl?: string;
10
- permissions: TariPermissions;
11
- optionalPermissions: TariPermissions;
12
- webRtcConfig?: RTCConfiguration;
13
- name?: string;
14
- onConnection?: () => void;
15
- };
16
- export declare class WalletDaemonTariProvider implements TariProvider {
17
- providerName: string;
18
- params: WalletDaemonParameters;
19
- client: WalletDaemonClient;
20
- private constructor();
21
- static build(params: WalletDaemonParameters): Promise<WalletDaemonTariProvider>;
22
- get token(): string | undefined;
23
- get tokenUrl(): string | undefined;
24
- isConnected(): boolean;
25
- createFreeTestCoins(): Promise<Account>;
26
- getAccount(): Promise<Account>;
27
- getAccountBalances(componentAddress: string): Promise<unknown>;
28
- getSubstate(substate_id: string): Promise<Substate>;
29
- submitTransaction(req: SubmitTransactionRequest): Promise<SubmitTransactionResponse>;
30
- getTransactionResult(transactionId: string): Promise<TransactionResult>;
31
- getPublicKey(branch: string, index: number): Promise<string>;
32
- getTemplateDefinition(template_address: string): Promise<TemplateDefinition>;
33
- getConfidentialVaultBalances(viewKeyId: number, vaultId: string, min?: number | null, max?: number | null): Promise<VaultBalances>;
34
- listSubstates(filter_by_template: string | null, filter_by_type: SubstateType | null, limit: number | null, offset: number | null): Promise<ListSubstatesResponse>;
35
- }