summaryrefslogtreecommitdiff
path: root/impls/monero.ts/src/pending_transaction.ts
diff options
context:
space:
mode:
authorKonstantin Ullrich <konstantinullrich12@gmail.com>2024-10-07 12:37:30 +0200
committerKonstantin Ullrich <konstantinullrich12@gmail.com>2024-10-07 12:37:30 +0200
commit98272ee381bd07081502dd426226f58c879300a6 (patch)
tree672f6f06727dbc1c84270973ce13e9403913e481 /impls/monero.ts/src/pending_transaction.ts
parent04b29d84a2c368c677cf5ec946269203622ca170 (diff)
parent67f4baa015a4407d096e35b6e5a81d72932fb55f (diff)
Merge branch 'master' into ledger
# Conflicts: # .github/workflows/full_check.yaml # impls/monero.dart/lib/monero.dart # impls/monero.dart/pubspec.yaml # patches/monero/0016-add-dummy-device-for-ledger.patch
Diffstat (limited to 'impls/monero.ts/src/pending_transaction.ts')
-rw-r--r--impls/monero.ts/src/pending_transaction.ts81
1 files changed, 81 insertions, 0 deletions
diff --git a/impls/monero.ts/src/pending_transaction.ts b/impls/monero.ts/src/pending_transaction.ts
new file mode 100644
index 0000000..cf48721
--- /dev/null
+++ b/impls/monero.ts/src/pending_transaction.ts
@@ -0,0 +1,81 @@
+import { dylib } from "./bindings.ts";
+import { CString, readCString, type Sanitizer } from "./utils.ts";
+
+export type PendingTransactionPtr = Deno.PointerObject<"transactionInfo">;
+
+export class PendingTransaction {
+ #pendingTxPtr: PendingTransactionPtr;
+ sanitizer?: Sanitizer;
+
+ constructor(pendingTxPtr: PendingTransactionPtr, sanitizer?: Sanitizer) {
+ this.sanitizer = sanitizer;
+ this.#pendingTxPtr = pendingTxPtr;
+ }
+
+ async status(): Promise<number> {
+ return await dylib.symbols.MONERO_PendingTransaction_status(this.#pendingTxPtr);
+ }
+
+ async errorString(): Promise<string | null> {
+ if (!await this.status()) return null;
+
+ const error = await dylib.symbols.MONERO_PendingTransaction_errorString(this.#pendingTxPtr);
+ if (!error) return null;
+
+ return await readCString(error) || null;
+ }
+
+ async throwIfError(sanitize = true): Promise<void> {
+ const maybeError = await this.errorString();
+ if (maybeError) {
+ if (sanitize) this.sanitizer?.();
+ throw new Error(maybeError);
+ }
+ }
+
+ async commit(fileName: string, overwrite: boolean, sanitize = true): Promise<boolean> {
+ const bool = await dylib.symbols.MONERO_PendingTransaction_commit(
+ this.#pendingTxPtr,
+ CString(fileName),
+ overwrite,
+ );
+ await this.throwIfError(sanitize);
+ return bool;
+ }
+
+ async commitUR(maxFragmentLength: number): Promise<string | null> {
+ const result = await dylib.symbols.MONERO_PendingTransaction_commitUR(
+ this.#pendingTxPtr,
+ maxFragmentLength,
+ );
+ if (!result) return null;
+ await this.throwIfError();
+ return await readCString(result) || null;
+ }
+
+ async amount(): Promise<bigint> {
+ return await dylib.symbols.MONERO_PendingTransaction_amount(this.#pendingTxPtr);
+ }
+
+ async dust(): Promise<bigint> {
+ return await dylib.symbols.MONERO_PendingTransaction_dust(this.#pendingTxPtr);
+ }
+
+ async fee(): Promise<bigint> {
+ return await dylib.symbols.MONERO_PendingTransaction_fee(this.#pendingTxPtr);
+ }
+
+ async txid(separator: string, sanitize = true): Promise<string | null> {
+ const result = await dylib.symbols.MONERO_PendingTransaction_txid(
+ this.#pendingTxPtr,
+ CString(separator),
+ );
+ if (!result) return null;
+ await this.throwIfError(sanitize);
+ return await readCString(result) || null;
+ }
+
+ async txCount(): Promise<bigint> {
+ return await dylib.symbols.MONERO_PendingTransaction_txCount(this.#pendingTxPtr);
+ }
+}