Skip to content

Commit

Permalink
fix(transactions)!: adds versioned transaction schema
Browse files Browse the repository at this point in the history
  • Loading branch information
sdbondi committed Dec 23, 2024
1 parent dadfd5d commit acba850
Show file tree
Hide file tree
Showing 51 changed files with 784 additions and 534 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ pub struct ConcurrentMapSemaphoreGuard<'a, K: Hash + Eq> {
key: K,
}

impl<'a, K: Hash + Eq> ConcurrentMapSemaphoreGuard<'a, K> {
impl<K: Hash + Eq> ConcurrentMapSemaphoreGuard<'_, K> {
pub fn access(&self) -> MutexGuard<'_, ()> {
// Unwrap: only errors if the mutex is poisoned, which is a bug
self.map_mutex.lock().unwrap()
Expand Down
4 changes: 2 additions & 2 deletions applications/tari_dan_wallet_cli/src/table.rs
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ pub struct Table<'t, 's> {
is_row_count_enabled: bool,
}

impl<'t, 's> Table<'t, 's> {
impl<'t> Table<'t, '_> {
pub fn new() -> Self {
Self {
titles: None,
Expand Down Expand Up @@ -141,7 +141,7 @@ impl<'t, 's> Table<'t, 's> {
}
}

impl<'t, 's> Default for Table<'t, 's> {
impl Default for Table<'_, '_> {
fn default() -> Self {
Self::new()
}
Expand Down
20 changes: 16 additions & 4 deletions applications/tari_dan_wallet_web_ui/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
Expand Up @@ -23,12 +23,11 @@
import React from "react";
import FetchStatusCheck from "./FetchStatusCheck";
import { Table, TableBody, TableCell, TableContainer, TableHead, TableRow } from "@mui/material";
import type { ListAccountNftResponse } from "@tari-project/typescript-bindings/wallet-daemon-client";
import type { apiError } from "../api/helpers/types";
import { DataTableCell } from "./StyledComponents";
import { renderJson, toHexString } from "../utils/helpers";
import { toHexString } from "../utils/helpers";
import { IoCheckmarkOutline, IoCloseOutline } from "react-icons/io5";
import type { NonFungibleId, NonFungibleToken } from "@tari-project/typescript-bindings";
import type { NonFungibleId, NonFungibleToken, ListAccountNftResponse } from "@tari-project/typescript-bindings";
import { convertCborValue } from "../utils/cbor";

function NftsList({ nft }: { nft: NonFungibleToken }) {
Expand Down Expand Up @@ -96,7 +95,7 @@ export default function NFTList(props: NftListProps) {
</TableRow>
</TableHead>
<TableBody>
{nftsListData?.nfts.map((nft: NonFungibleToken, index) => <NftsList key={index} nft={nft} />)}
{nftsListData?.nfts.map((nft: NonFungibleToken, index: number) => <NftsList key={index} nft={nft} />)}
</TableBody>
</Table>
</TableContainer>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -34,8 +34,11 @@ import {
} from "../../utils/json_rpc";
import { apiError } from "../helpers/types";
import queryClient from "../queryClient";
import type { ComponentAccessRules, ConfidentialTransferInputSelection } from "@tari-project/typescript-bindings";
import type { ComponentAddressOrName } from "@tari-project/typescript-bindings/wallet-daemon-client";
import type {
ComponentAccessRules,
ConfidentialTransferInputSelection,
ComponentAddressOrName,
} from "@tari-project/typescript-bindings";

// Fees are passed as strings because Amount is tagged
export const useAccountsClaimBurn = (account: string, claimProof: string, fee: number) => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -31,13 +31,11 @@ import TableCell from "@mui/material/TableCell";
import TableBody from "@mui/material/TableBody";
import { useParams } from "react-router-dom";
import { useAccountsGetBalances, useAccountsGet, useAccountNFTsList } from "../../api/hooks/useAccounts";
import { renderJson, shortenString } from "../../utils/helpers";
import { shortenString } from "../../utils/helpers";
import { DataTableCell } from "../../Components/StyledComponents";
import CopyToClipboard from "../../Components/CopyToClipboard";
import FetchStatusCheck from "../../Components/FetchStatusCheck";
import { substateIdToString } from "@tari-project/typescript-bindings";
import type { BalanceEntry } from "@tari-project/typescript-bindings/wallet-daemon-client";
import { IoCheckmarkOutline, IoCloseOutline } from "react-icons/io5";
import { substateIdToString, BalanceEntry } from "@tari-project/typescript-bindings";
import NFTList from "../../Components/NFTList";

function BalanceRow(props: BalanceEntry) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,11 +37,10 @@ import { DataTableCell } from "../../../Components/StyledComponents";
import { useAccountNFTsList, useAccountsGetBalances } from "../../../api/hooks/useAccounts";
import useAccountStore from "../../../store/accountStore";
import { shortenString } from "../../../utils/helpers";
import type { BalanceEntry } from "@tari-project/typescript-bindings/wallet-daemon-client";
import NFTList from "../../../Components/NFTList";
import { Button } from "@mui/material";
import { SendMoneyDialog } from "./SendMoney";
import { ResourceAddress, ResourceType, VaultId } from "@tari-project/typescript-bindings";
import { ResourceAddress, ResourceType, VaultId, BalanceEntry } from "@tari-project/typescript-bindings";

interface TabPanelProps {
children?: React.ReactNode;
Expand Down Expand Up @@ -193,7 +192,7 @@ function Assets({ accountName }: { accountName: string }) {
token_symbol,
vault_address,
}: BalanceEntry,
i,
i: number,
) => (
<BalanceRow
key={i}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ import { useTheme } from "@mui/material/styles";
import { accountsClaimBurn } from "../../../utils/json_rpc";
import useAccountStore from "../../../store/accountStore";
import { useKeysList } from "../../../api/hooks/useKeys";
import type { AccountInfo } from "@tari-project/typescript-bindings/wallet-daemon-client";
import type { AccountInfo } from "@tari-project/typescript-bindings";

export default function ClaimBurn() {
const [open, setOpen] = useState(false);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,20 +23,18 @@
import { useState } from "react";
import { Form } from "react-router-dom";
import Button from "@mui/material/Button";
import CheckBox from "@mui/material/Checkbox";
import TextField from "@mui/material/TextField";
import Dialog from "@mui/material/Dialog";
import DialogContent from "@mui/material/DialogContent";
import DialogTitle from "@mui/material/DialogTitle";
import FormControlLabel from "@mui/material/FormControlLabel";
import Box from "@mui/material/Box";
import { useAccountsList, useAccountsTransfer } from "../../../api/hooks/useAccounts";
import { useAccountsList } from "../../../api/hooks/useAccounts";
import { useTheme } from "@mui/material/styles";
import useAccountStore from "../../../store/accountStore";
import { FormControl, InputLabel, MenuItem, Select, SelectChangeEvent } from "@mui/material";
import { useKeysList } from "../../../api/hooks/useKeys";
import { validatorsClaimFees } from "../../../utils/json_rpc";
import type { AccountInfo } from "@tari-project/typescript-bindings/wallet-daemon-client";
import type { AccountInfo } from "@tari-project/typescript-bindings";

export default function ClaimFees() {
const [open, setOpen] = useState(false);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ import Select, { SelectChangeEvent } from "@mui/material/Select";
import Dialog from "./AddAccount";
import useAccountStore from "../../../store/accountStore";
import { useAccountsList } from "../../../api/hooks/useAccounts";
import type { AccountInfo } from "@tari-project/typescript-bindings/wallet-daemon-client";
import type { AccountInfo } from "@tari-project/typescript-bindings";

function SelectAccount() {
const { accountName, setAccountName } = useAccountStore();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ import {
ResourceType,
ConfidentialTransferInputSelection,
TransactionResult,
BalanceEntry,
} from "@tari-project/typescript-bindings";
import InputLabel from "@mui/material/InputLabel";

Expand Down Expand Up @@ -98,8 +99,8 @@ export function SendMoneyDialog(props: SendMoneyDialogProps) {

const { data } = useAccountsGetBalances(accountName);
const badges = data?.balances
?.filter((b) => b.resource_type === "NonFungible" && b.balance > 0)
.map((b) => b.resource_address) as string[];
?.filter((b: BalanceEntry) => b.resource_type === "NonFungible" && b.balance > 0)
.map((b: BalanceEntry) => b.resource_address) as string[];

// TODO: we should have separate calls for confidential and non-confidential transfers
const { mutateAsync: sendIt } = useAccountsTransfer(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ import Box from "@mui/material/Box";
import { useTheme } from "@mui/material/styles";
import { Divider } from "@mui/material";
import { confidentialViewVaultBalance } from "../../../utils/json_rpc";
import { ConfidentialViewVaultBalanceRequest } from "@tari-project/typescript-bindings/wallet-daemon-client";
import { ConfidentialViewVaultBalanceRequest } from "@tari-project/typescript-bindings";

function ViewVaultBalanceForm() {
const [formState, setFormState] = useState({
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,7 @@ export default function TransactionDetails() {
const handleDownload = () => {
const json = JSON.stringify(data, null, 2);
const blob = new Blob([json], { type: "application/json" });
const filename = `tx-${data?.transaction?.id}.json` || "tx-unknown_id.json";
const filename = `tx-${data?.transaction?.V1?.id}.json` || "tx-unknown_id.json";
saveAs(blob, filename);
};

Expand All @@ -129,6 +129,8 @@ export default function TransactionDetails() {
}
};

const transaction = data.transaction.V1;

if (data.status === "Rejected" || data.status === "InvalidTransaction") {
return (
<>
Expand All @@ -137,7 +139,7 @@ export default function TransactionDetails() {
<TableBody>
<TableRow>
<TableCell>Transaction Hash</TableCell>
<DataTableCell>{data.transaction.id}</DataTableCell>
<DataTableCell>{transaction.id}</DataTableCell>
</TableRow>
<TableRow>
<TableCell>Timestamp</TableCell>
Expand Down Expand Up @@ -177,7 +179,7 @@ export default function TransactionDetails() {
<TableBody>
<TableRow>
<TableCell>Transaction Hash</TableCell>
<DataTableCell>{data.transaction.id}</DataTableCell>
<DataTableCell>{transaction.id}</DataTableCell>
</TableRow>
<TableRow>
<TableCell>Timestamp</TableCell>
Expand Down Expand Up @@ -258,8 +260,8 @@ export default function TransactionDetails() {
<Typography>Fee Instructions</Typography>
</AccordionSummary>
<AccordionDetails>
{data.transaction?.fee_instructions?.length ? (
<FeeInstructions data={data.transaction.fee_instructions} />
{transaction?.fee_instructions?.length ? (
<FeeInstructions data={transaction?.fee_instructions} />
) : (
<span>Empty</span>
)}
Expand All @@ -270,8 +272,8 @@ export default function TransactionDetails() {
<Typography>Instructions</Typography>
</AccordionSummary>
<AccordionDetails>
{data.transaction?.instructions?.length ? (
<Instructions data={data.transaction.instructions} />
{transaction?.instructions?.length ? (
<Instructions data={transaction.instructions} />
) : (
<span>Empty</span>
)}
Expand Down Expand Up @@ -312,11 +314,11 @@ export default function TransactionDetails() {
<Typography>Signers</Typography>
</AccordionSummary>
<AccordionDetails>
{data.transaction?.signatures?.length ? (
{transaction?.signatures?.length ? (
<TableContainer>
<Table>
<TableBody>
{data.transaction.signatures.map((item: TransactionSignature, i: number) => {
{transaction.signatures.map((item: TransactionSignature, i: number) => {
return (
<TableRow key={i}>
<DataTableCell>{item.public_key}</DataTableCell>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -77,40 +77,43 @@ export default function Transactions({ accountName }: { accountName: string }) {
<TableBody>
{data?.transactions
?.slice(page * rowsPerPage, page * rowsPerPage + rowsPerPage)
.map((t: [Transaction, FinalizeResult | null, TransactionStatus, string]) => {
if (t?.[0]?.id !== undefined) {
const hash = t[0].id;
return (
<TableRow key={hash}>
<DataTableCell>
<Link
to={`/transactions/${hash}`}
style={{
textDecoration: "none",
color: theme.palette.text.secondary,
}}
>
{hash}
</Link>
</DataTableCell>
<DataTableCell>
<StatusChip status={t[2]} showTitle />
</DataTableCell>
<DataTableCell>{t?.[1]?.fee_receipt.total_fees_paid || 0}</DataTableCell>
<DataTableCell>
<IconButton
component={Link}
to={`/transactions/${hash}`}
style={{
color: theme.palette.text.secondary,
}}
>
<ChevronRight />
</IconButton>
</DataTableCell>
</TableRow>
);
.map(([t, result, status, _s]: [Transaction, FinalizeResult | null, TransactionStatus, string]) => {
const tx = t.V1;
if (!tx?.id) {
return <></>;
}

const hash = tx.id;
return (
<TableRow key={hash}>
<DataTableCell>
<Link
to={`/transactions/${hash}`}
style={{
textDecoration: "none",
color: theme.palette.text.secondary,
}}
>
{hash}
</Link>
</DataTableCell>
<DataTableCell>
<StatusChip status={status} showTitle />
</DataTableCell>
<DataTableCell>{result?.fee_receipt.total_fees_paid || 0}</DataTableCell>
<DataTableCell>
<IconButton
component={Link}
to={`/transactions/${hash}`}
style={{
color: theme.palette.text.secondary,
}}
>
<ChevronRight />
</IconButton>
</DataTableCell>
</TableRow>
);
})}
{emptyRows(page, rowsPerPage, data?.transactions) > 0 && (
<TableRow
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -220,7 +220,7 @@ export default function AccessTokens() {
{data?.jwt
?.slice(page * rowsPerPage, page * rowsPerPage + rowsPerPage)
.map(({ id, name, permissions, exp }: Claims) => {
const date = new Date(exp * 1000);
const date = new Date(Number(exp * 1000n));
const formattedDate = `${date.toISOString().slice(0, 10)} ${date.toISOString().slice(11, 16)}`;
return (
<RowData key={id} id={id} name={name} permissions={permissions} formattedDate={formattedDate} />
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ import {
} from "../../../api/hooks/useAccounts";
import FetchStatusCheck from "../../../Components/FetchStatusCheck";
import queryClient from "../../../api/queryClient";
import type { AccountInfo } from "@tari-project/typescript-bindings/wallet-daemon-client";
import type { AccountInfo } from "@tari-project/typescript-bindings";

function Account(account: AccountInfo, index: number) {
const { pathname } = useLocation();
Expand Down
Loading

0 comments on commit acba850

Please sign in to comment.