Skip to content

feat(wallet): Add transaction history tab with pending/confirmed views#168

Merged
bucko13 merged 65 commits intocaravan-bitcoin:mainfrom
Legend101Zz:transactions-tab
Mar 25, 2025
Merged

feat(wallet): Add transaction history tab with pending/confirmed views#168
bucko13 merged 65 commits intocaravan-bitcoin:mainfrom
Legend101Zz:transactions-tab

Conversation

@Legend101Zz
Copy link
Contributor

@Legend101Zz Legend101Zz commented Jan 5, 2025

Add a new Transactions tab to the wallet interface that provides users with a detailed view of their transaction history. The tab includes:

Features

  • Split view for pending and confirmed transactions.
  • Transaction tables with key information:
    • Transaction ID with copy functionality.
    • Time/date of transaction.
    • Total fee.
    • Transaction size in vBytes.
    • Confirmation status.
    • Block height (for confirmed transactions).
  • Ability to view transaction details in a block explorer.
  • Auto-refresh capability for transaction status updates.
  • Clear loading states and error handling for a better user experience.

Technical Changes

  • Added new transaction state management in Redux.
  • Implemented transaction filtering by confirmation status.
  • Added data fetching logic for transaction details.
  • Included test coverage for:
    • Redux actions.
    • Reducers.
    • Component behavior.

Why This Change?

This enhancement improves the wallet's usability by providing users with:

  • Better visibility into their transaction history and statuses.
  • Easy access to key details for pending and confirmed transactions.
  • A more streamlined and informative transaction management experience.

Summary by CodeRabbit

  • New Features
    • Introduced a new "Transactions" view in the wallet, allowing you to easily switch between confirmed and pending transactions.
    • The transactions screen features a sortable table with details such as fees, size, and time, plus refresh and error indicators.
    • Enhanced transaction data retrieval ensures more consistent and reliable transaction information display.

@changeset-bot
Copy link

changeset-bot bot commented Jan 5, 2025

🦋 Changeset detected

Latest commit: f8ac83d

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 2 packages
Name Type
@caravan/clients Patch
caravan-coordinator Minor

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

@vercel
Copy link

vercel bot commented Jan 5, 2025

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Comments Updated (UTC)
caravan-coordinator ✅ Ready (Inspect) Visit Preview 💬 Add feedback Mar 24, 2025 8:34pm

@Legend101Zz
Copy link
Contributor Author

Here’s a preview of the new Transactions tab, showing the split view for pending and confirmed transactions:

Screenshot 2025-01-05 at 23 38 04

@Legend101Zz
Copy link
Contributor Author

Dependency Notice

This PR depends on #134 as it uses a newly added transaction method we will need here. So we need to ensure #134 is reviewed and merged first.

@bucko13
Copy link
Contributor

bucko13 commented Jan 5, 2025

Dependency Notice

This PR depends on #134 as it uses a newly added transaction method we will need here. So we need to ensure #134 is reviewed and merged first.

Submitted another review. Should be almost ready to go. I'll make sure to prioritize review and merge of #134 ASAP

Copy link
Contributor

@bucko13 bucko13 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I haven't been able to test because the client method isn't available, but excited for this change!

I think a lot of my requests for changes are due to you using old code as a reference for this change. Sorry for that confusion with the old code. Hopefully my comments give an idea of the preferred patterns though.

// Helper function to fetch individual transaction details
const fetchTransactionDetails = async (client, txid) => {
try {
const txDetails = await client.getTransaction(txid);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If you built this branch ontop of the #134 changes then we could test this in the vercel deployment

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the suggestion ... I have now rebased the current branch to use #134 as base branch

const [mounted, setMounted] = useState(true);

// Helper function to fetch individual transaction details
const fetchTransactionDetails = async (client, txid) => {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

you can also just use getBlockchainClient directly in the function since it's in the scope already rather than pass it around. Not a huge deal though, this is fine too if you prefer.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

tsx for all new components please.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

refactoring done

);
}

TransactionsTab.propTypes = {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's use typescript instead of proptypes .

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

refactoring done

setTransactions,
setTransactionsLoading,
setTransactionsError,
};
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

even if you do use redux you should be able to use the newer hook pattern to dispatch actions and get props from the store: useDispatch and useSelector. Take a look at the WalletDescriptorImporter component for an example of how "modern" components should be written with newer patterns (I know it's hard in caravan because of all the legacy code still. sorry about that)

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

removed the unecessary redux states

: [];

// Render the transaction table
const renderTransactionTable = (txs) => (
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is a pattern from our legacy code that we'd really like to move away from. It's kind of an anti-pattern for react. This should just be a component <TransactionTable txs={txs} />. This way you get react rendering optimizations, type safety, and a cleaner parent component because you can pull this out as a standalone component.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

changes done

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

is there a reason this needs to be in redux? Are there any other components that need to use this outside of the component tree you've added? If you need to pass this data down through multiple children, you can also use context instead of redux. You'll still have access to what you need from the store use useSelector or useDispatch as needed. If we can avoid adding to our redux code that's preferable (when possible).

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ahh ... yes I realise it now ... maybe I over-thought of having the use of redux for passing the states onto the CPFP/RBF components ... but now that you have mentioned that you'd refer not to use redux and rely on modern react practices... I revert back to the version I wrote without the use of redux :)

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

changes done

This commit adds a getTransaction method to the BlockchainClient class,
which provides a consistent structure for fetching transaction details across different data providers (Bitcoin Core, Blockstream, Mempool).

Changes:
 - Add `TransactionDetails` interface for unified transaction data
 - Implement `getTransaction` method
 - Add `normalizeTransactionData` to standardize response
Introduce a new Transactions tab to the wallet interface, allowing users to view
and filter their transaction history by confirmation status (pending or confirmed).

- Added transaction state management in Redux
- Implemented filtering functionality for pending and confirmed transactions
- Added logic to fetch detailed transaction data
- Included test coverage for new Redux actions and reducers

This enhancement improves the wallet's usability by providing users with better
visibility into transaction statuses, including key details such as fee rate,
amount sent, and blocks confirmed.
@bucko13
Copy link
Contributor

bucko13 commented Jan 8, 2025

FYI: we'll need a changeset for the coordinator as well.

- Moved transaction table logic to a separate `TransactionTable.tsx` component
- Implemented sortable table columns for better UX
- Handled missing `tx.fee` values to prevent crashes
- Displayed timestamps in "time ago" format using `date-fns`
- Added option to toggle between Block Explorer and self-hosted node for transaction links
- Improved code readability and performance by removing inline render functions
@coderabbitai
Copy link

coderabbitai bot commented Feb 21, 2025

Walkthrough

This update introduces a new transaction retrieval method in the BlockchainClient along with its normalization logic and corresponding tests. Changes have been made to add a new wallet mode and associated React components to support transaction viewing within the coordinator app. Additionally, state management for transactions is expanded in the reducer. In the caravan-clients package, the legacy Bitcoind JavaScript file is removed and replaced by a comprehensive TypeScript implementation including new type definitions. Minor adjustments, such as adding constant imports and TypeScript error suppression comments, are also included.

Changes

File(s) Change Summary
@caravan/clients
client.ts, client.test.ts
Added getTransaction and normalizeTransactionData in BlockchainClient; updated tests for transaction retrieval and data normalization.
@caravan/clients
types.ts
Introduced multiple new interfaces/types for raw transactions, transaction details, RPC interactions, and Bitcoin node parameters.
@caravan/clients
bitcoind.js (removed), bitcoind.ts
Removed legacy Bitcoind JS file; added a new TypeScript file with functions for RPC calls, error handling, and transaction data handling.
@caravan/clients
wallet.ts
Added TypeScript error suppression comments in callBitcoindWallet and bitcoindListUnspent functions.
apps/coordinator/src/actions/transactionActions.js
walletActions.js
Added new import of DUST_IN_BTC and introduced a new TRANSACTIONS mode with value 3 for wallet actions.
apps/coordinator/src/components/Wallet/TransactionsTab.tsx
TransactionsTable.tsx
Created new React components (TransactionsTab, TransactionTable) with interfaces, state management, and Redux connections to display and manage blockchain transactions.
apps/coordinator/src/components/Wallet/WalletControl.jsx Integrated a new "Transactions" tab in the wallet, with conditional rendering to load the TransactionsTab component when selected.
apps/coordinator/src/reducers/transactionReducer.js Expanded the initial state to include a structured transactions object with properties for transaction data, loading state, errors, and timestamp.

Sequence Diagram(s)

sequenceDiagram
    participant U as User
    participant WC as WalletControl
    participant TT as TransactionsTab
    participant BC as BlockchainClient
    participant B as bitcoind.ts

    U->>WC: Select "Transactions" tab
    WC->>TT: Render TransactionsTab component
    TT->>BC: Call fetchTransactions() → getTransaction(txid)
    BC->>B: Make RPC call for raw transaction data
    B-->>BC: Return raw transaction data
    BC->>BC: Normalize transaction data
    BC-->>TT: Return TransactionDetails
    TT->>U: Display updated transactions
Loading

Poem

I'm a rabbit, hopping through the code,
With transactions bright, my whiskers explode.
New tabs and tests in every byte,
A burrow of features shining so light.
CodeRabbit cheers with a joyful hop,
In this realm of updates, I never want to stop!
🐰💻✨ Enjoy the new digital crop!

Warning

There were issues while running some tools. Please review the errors and either fix the tool’s configuration or disable the tool if it’s a critical failure.

🔧 ESLint

If the error stems from missing dependencies, add them to the package.json file. For unrecoverable errors (e.g., due to private dependencies), disable the tool in the CodeRabbit configuration.

apps/coordinator/src/components/Wallet/TransactionsTab.tsx

Oops! Something went wrong! :(

ESLint: 7.32.0

ESLint couldn't find the plugin "eslint-plugin-testing-library".

(The package "eslint-plugin-testing-library" was not found when loaded as a Node module from the directory "/apps/coordinator".)

It's likely that the plugin isn't installed correctly. Try reinstalling by running the following:

npm install eslint-plugin-testing-library@latest --save-dev

The plugin "eslint-plugin-testing-library" was referenced from the config file in "apps/coordinator/.eslintrc.cjs » @caravan/eslint-config/app.js".

If you still can't figure out the problem, please stop by https://eslint.org/chat/help to chat with the team.

apps/coordinator/src/actions/transactionActions.js

Oops! Something went wrong! :(

ESLint: 7.32.0

ESLint couldn't find the plugin "eslint-plugin-testing-library".

(The package "eslint-plugin-testing-library" was not found when loaded as a Node module from the directory "/apps/coordinator".)

It's likely that the plugin isn't installed correctly. Try reinstalling by running the following:

npm install eslint-plugin-testing-library@latest --save-dev

The plugin "eslint-plugin-testing-library" was referenced from the config file in "apps/coordinator/.eslintrc.cjs » @caravan/eslint-config/app.js".

If you still can't figure out the problem, please stop by https://eslint.org/chat/help to chat with the team.

apps/coordinator/src/actions/walletActions.js

Oops! Something went wrong! :(

ESLint: 7.32.0

ESLint couldn't find the plugin "eslint-plugin-testing-library".

(The package "eslint-plugin-testing-library" was not found when loaded as a Node module from the directory "/apps/coordinator".)

It's likely that the plugin isn't installed correctly. Try reinstalling by running the following:

npm install eslint-plugin-testing-library@latest --save-dev

The plugin "eslint-plugin-testing-library" was referenced from the config file in "apps/coordinator/.eslintrc.cjs » @caravan/eslint-config/app.js".

If you still can't figure out the problem, please stop by https://eslint.org/chat/help to chat with the team.

  • 8 others
✨ Finishing Touches
  • 📝 Generate Docstrings (Beta)

🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai generate docstrings to generate docstrings for this PR. (Beta)
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

CodeRabbit Configuration File (.coderabbit.yaml)

  • You can programmatically configure CodeRabbit by adding a .coderabbit.yaml file to the root of your repository.
  • Please see the configuration documentation for more information.
  • If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: # yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

…flat files to a structured directory with separated concerns, seperated hooks, types and UI logic
Copy link
Contributor

@bucko13 bucko13 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

just a couple nits but a really nice cleanup!

…by the client package for the private note, the "fees" column has been dropped
@jevidon
Copy link
Contributor

jevidon commented Mar 21, 2025

I checked the latest vercel preview, and it looks good to me as a starting point to build on. Happy to see this merged.

…in this implementation due to unspent UTXO tracking difficulty for private nodes
});
} else if (node.addressUsed) {
// Address has been used but has no UTXOs (spent)
addressesWithSpentUTXOs.add(node.multisig.address);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

curious why this was necessary?

@bucko13 bucko13 merged commit accc093 into caravan-bitcoin:main Mar 25, 2025
4 checks passed
This was referenced Mar 25, 2025
@Legend101Zz Legend101Zz deleted the transactions-tab branch March 25, 2025 17:10
bucko13 added a commit that referenced this pull request Mar 26, 2025
* fix: multisig support for indirect keystore interactions (#120)

* Version Packages (#121)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* Caravan Health Package (beta) (#112)

Signed-off-by: Harshil-Jani <harshiljani2002@gmail.com>
Co-authored-by: buck <buck@unchained.com>

* Version Packages (#123)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* Tweaks to SegWit PSBT Inputs/Outputs (#124)

* fix: supply witness script when generating multisig

* fix: include non witness utxo in segwit inputs

* fix: add unsignedPSBT to state on finalizeOutputs

* fix: variable names and pass psbt to direct sig importer

* update fixture shape and psbts to include non witness utxos

* tweak fixture shape and add non witness utxos to psbts

* hackish injection of non witness utxos for tests

* include nonwitness utxo for segwit in caravan bitcoin; update base64 encoded psbts in fixtures for less testing hackery

* include multisig obj in caravan bitcoin fixtures

---------

Co-authored-by: buck <buck@unchained.com>

* Feat: bip32 package with blinded xpub support (#126)

* cleanup and fix generator templates

* init bip32 package with paths utils

* fix: eslint and add import ordering

* split up key and path modules and add tests

* custom util for getting random ints in node or browser

* use custom random int for blinded paths

* util for getting blinded xpub from source

* feat: blind xpub support for text input

* make new bip32 package publishable

* feat: reused functionality extracted to a utility for getting relative child sequence

* Fix hermit selection (#127)

* convert HermitReader and SignatureImporter to typescript

* adding height on hermit reader

* convert HermitReader to functional and use new QrReader api

* fix falsey bug

* styling cleanup

---------

Co-authored-by: Justin Moore <11jmoore@pm.me>

* caravan/bip32 publish access public (#129)

* tweak to package.json (#130)

* Version Packages (#128)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* unsignedPsbt in redux store should include global xpubs (#132)

* bump for coordinator (#138)

* Version Packages (#139)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* Fee bumping Package (#114)

* feat: Initialize @caravan/feebumping package

Create a new package for fee bumping functionality in Caravan. This package
provides modular and reusable utilities for implementing RBF (Replace-By-Fee)
and CPFP (Child-Pays-For-Parent) fee bumping strategies.

Key additions:
- Basic package structure and configuration files
- Core modules for RBF and CPFP implementations
- Fee estimation utilities
- Type definitions for fee bumping operations
- Constants and utility functions

This package aims to enhance Caravan's transaction management capabilities
by providing a flexible and extensible fee bumping solution that can be
easily integrated into the Caravan coordinator wallet and other Bitcoin
projects.

* update package-lock (#143)

* Version Packages (#144)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* add support for the BitBox02 hardware wallet (#117)

* add support for the BitBox02 hardware wallet

Using the `bitbox-api` NPM package, which loads a WASM module.

Note about CJS:
Currently the `bitbox-api` package is an ESM package with a `module:
...` entrypoint, so it is not compatible with the `cjs` target of
caravan-wallets. The only workaround that I could find where
compilation succeeds and the package works in the browser is to mark
bitbox-api as external in tsup.config.ts.

Note about signing tests:

- The BitBox02 requires the previous transaction of each input to be
present in the PSBT (`PSBT_IN_NON_WITNESS_UTXO`), so it can verify the
input amount and avoid fee attacks. The signing test fixtures are
missing these, so they fail.

- The BitBox02 uses the anti-klepto (anti-exfil) protocol to mitigate
covert nonce exfil attacks. This results in random signatures. The
unit test fixtures hardcode the expected signatures, assuming they are
always the same. As a result, also here the tests fail. To fix this,
the tests should rather verify the ECDSA signatures against the
transaction sighash for each input.

* hide BitBox02 menu item for P2SH

BitBox02 does not support legacy P2SH.

* bitbox: display pairing code

The BitBox, if not paired yet, will show a pairing code for
confirmation. This can happen in any BitBox interaction.

This commit adds a `showPairingCode` param to all BitBox
interactions. If not provided, a default implementation is used which
shows the pairing code in a browser popup.

The current `messages()` system is not a good fit, as the client does
not know when to call `messagesFor()` to display it. Having a separate
UI button to pair the BitBox is not good UX (why should the user be
bothered to click a "pair" button first? What if the user doesn't) and
also fragile (a re-pairing could be needed at any time).

* add regtest support for BitBox02

---------

Co-authored-by: buck <buck@unchained.com>

* Version Packages (#145)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* fix: fees package private (#146)

* Translate segwit psbt (#147)

* chore: fix turbo.json for test runner

* update deps

* feat: dds support for translatePSBT for segwit PSBTs

* pass key details to sig interaction just in case

* Version Packages (#148)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* fix: move bitbox to normal dependency (#149)

* Version Packages (#150)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* fix(wallets): bundle internal dependencies with production bundle (#151)

* Version Packages (#152)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* fix: @caravan/bitcoin shouldn't be noExternal (#153)

* Version Packages (#154)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* fix: unknown network error for regtest (#156)

* support regtest network in coldcard and custom interactions

* add changeset

* Version Packages (#157)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* include addressType for valid PSBT translation in SignMultisigTransaction (#159)

* Version Packages (#160)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* chore(deps-dev): bump gh-pages from 3.2.3 to 5.0.0

Bumps [gh-pages](https://github.com/tschaub/gh-pages) from 3.2.3 to 5.0.0.
- [Release notes](https://github.com/tschaub/gh-pages/releases)
- [Changelog](https://github.com/tschaub/gh-pages/blob/main/changelog.md)
- [Commits](tschaub/gh-pages@v3.2.3...v5.0.0)

---
updated-dependencies:
- dependency-name: gh-pages
  dependency-type: direct:development
...

Signed-off-by: dependabot[bot] <support@github.com>

* fix: turbo dev depends on build w/ esbuild noExternal (#164)

* Add sparrow to allowed method of importing pubkeys (#166)

Signed-off-by: Harshil Jani <harshiljani2002@gmail.com>

* bump @trezor/connect-web from 9.1.12 to 9.4.7 (#163)

Co-authored-by: dylan-thompson <141655089+dylan-thompson@users.noreply.github.com>

* Version Packages (#169)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* chore(deps): bump axios from 1.6.7 to 1.7.4 in /packages/caravan-wallets

Bumps [axios](https://github.com/axios/axios) from 1.6.7 to 1.7.4.
- [Release notes](https://github.com/axios/axios/releases)
- [Changelog](https://github.com/axios/axios/blob/v1.x/CHANGELOG.md)
- [Commits](axios/axios@v1.6.7...v1.7.4)

---
updated-dependencies:
- dependency-name: axios
  dependency-type: direct:production
...

Signed-off-by: dependabot[bot] <support@github.com>

* PsbtV2.toV0(): Convert a PsbtV2 class to its serialized PSBTv0 counterpart (#158)

* feat: PsbtV2.toV0()

* chore: changeset

* fix: remove log

* test: add more tests for PsbtV2.toV0

* chore: update package-lock to match package.json (#171)

* Version Packages (#173)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* fix: replace npm install with npm ci in CI workflows (#175)

* fix(psbt): lock dependency of caravan-bitcoin (#174)

* Version Packages

* chore(deps): bump axios from 1.6.7 to 1.7.4

Bumps [axios](https://github.com/axios/axios) from 1.6.7 to 1.7.4.
- [Release notes](https://github.com/axios/axios/releases)
- [Changelog](https://github.com/axios/axios/blob/v1.x/CHANGELOG.md)
- [Commits](axios/axios@v1.6.7...v1.7.4)

---
updated-dependencies:
- dependency-name: axios
  dependency-type: direct:production
...

Signed-off-by: dependabot[bot] <support@github.com>

* chore(deps-dev): bump vite from 4.5.5 to 4.5.6

Bumps [vite](https://github.com/vitejs/vite/tree/HEAD/packages/vite) from 4.5.5 to 4.5.6.
- [Release notes](https://github.com/vitejs/vite/releases)
- [Changelog](https://github.com/vitejs/vite/blob/v4.5.6/packages/vite/CHANGELOG.md)
- [Commits](https://github.com/vitejs/vite/commits/v4.5.6/packages/vite)

---
updated-dependencies:
- dependency-name: vite
  dependency-type: direct:development
...

Signed-off-by: dependabot[bot] <support@github.com>

* chore(turbo): add build as lint task dependency (#178)

* chore(wallets): bump trezor connect dependency (#183)

* Version Packages (#184)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* Fix/docker updates (#185)

* fix(docker): add multi-platform support for coordinator Dockerfile

* chore(changeset): changeset for multi-platform Dockerfile change

* docs(dockerfile): clarify platform-agnostic comment for coordinator app

* feat: Add getTransaction method to BlockchainClient (#134)

* feat: Add getTransaction method to BlockchainClient

This commit adds a getTransaction method to the BlockchainClient class,
which provides a consistent structure for fetching transaction details across different data providers (Bitcoin Core, Blockstream, Mempool).

Changes:
 - Add `TransactionDetails` interface for unified transaction data
 - Implement `getTransaction` method
 - Add `normalizeTransactionData` to standardize response

* REVIEW-CHANGES : changes in bitcoind.js and tests

* refactor: move transaction normalization to standalone utility

* refactor: update TransactionDetails to use camelCase naming

* refactor(bitcoind): convert bitcoind.js to TypeScript

* feat(bitcoind): update ListTransactionsItem interface to match RPC spec

* fix(client): handle different transaction response formats properly for the getTransaction method

* fix: update test mocks to match RPC response types

* changes to fix broken tests

* refactor(block-explorer): Convert to TypeScript with improved type safety

* refactor(blockchain): Migrate to TypeScript and enhance error handling

* revert: revert: undo recent changes to bitcoind.ts

* fixes: Type fixes in bitcoind

* fix: remove async promise executor in callBitcoind

* doc-strings: added doc strings to callBitcoind method

* refactor: add TypeScript type annotations to bitcoindParams function

* Added detailed docstrings to the `bitcoindListUnspent` method

* Added detailed docstrings to the `bitcoindGetAddressStatus` method

* Added detailed docstrings to the `bitcoindEstimateSmartFee` method

* refactor: improve typing and error handling in bitcoindSendRawTransaction

* refactor: improve typing and added doc-strings in bitcoindRawTxData

* revert: undo recent changes to block_explorer.ts

* fixes-types: Partial type fixes in block_explorer.ts to pass type errors

* fixes-type-block_explorer: Fixed blockExplorerGetAddresesUTXOs function

* fixes-type-block_explorer: Fixed blockExplorerGetAddressStatus function

* fixes-type-block_explorer: Fixed blockExplorerGetFeeEstimate function

* fixes-type-block_explorer: Fixed blockExplorerBroadcastTransaction function

* revert: undo recent changes to blockchain.ts

* fixes-types: Partial type fixes in blockchain.ts to pass type errors

* fixes-type-blockchain: Fixed fetchAddressUTXOsUnsorted function

* fixes-type-blockchain: Fixed fetchAddressUTXOs function

* fixes-type-blockchain: Fixed getAddressStatus function

* fixes-type-blockchain: Fixed fetchFeeEstimate function

* fixes-type-blockchain: Fixed broadcastTransaction function

* TO-DO: any error eslint disable to-do

* chore(changeset): Update changeset to include TypeScript migration

* refactor(bitcoind): standardize Bitcoin RPC parameters by introducing `BaseBitcoindArgs`, updating function signatures

* refactor(bitcoind): `bitcoindRawTxData` to use standardize Bitcoin RPC function parameters

* chore: rename block_explorer.ts to blockExplorer.ts for consistency

---------

Co-authored-by: buck <buck@unchained.com>

* Version Packages (#186)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* Allow a PsbtV2 to be constructed with a psbtv2 which has been forceably set to have PSBT_GLOBAL_TX_VERSION === 1 (#188)

* feat: allowTxnVersion1 on instantiation

* chore: changeset

* Version Packages (#189)

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>

* fix: fixed the private node rpc calls bug in clients `getTransaction` method (#196)

* Version Packages (#197)

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>

* feat(wallet): Add pending transaction tab  (#168)

* fix: workflow failure fixes

* fix: tests failures fixed

---------

Signed-off-by: Harshil-Jani <harshiljani2002@gmail.com>
Signed-off-by: dependabot[bot] <support@github.com>
Signed-off-by: Harshil Jani <harshiljani2002@gmail.com>
Co-authored-by: chadchapnick <143517546+chadchapnick@users.noreply.github.com>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
Co-authored-by: Harshil Jani <harshiljani2002@gmail.com>
Co-authored-by: buck <buck@unchained.com>
Co-authored-by: Justin Moore <11jmoore@pm.me>
Co-authored-by: Mrigesh Thakur <96632943+Legend101Zz@users.noreply.github.com>
Co-authored-by: benma <m@mben.ch>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Robert Shuford <75178461+robertshuford@users.noreply.github.com>
Co-authored-by: kimlwh <kimlwh@proton.me>
Co-authored-by: dylan-thompson <141655089+dylan-thompson@users.noreply.github.com>
Co-authored-by: Jack D <shadouts@hotmail.com>
bucko13 added a commit that referenced this pull request Apr 2, 2025
* fix: multisig support for indirect keystore interactions (#120)

* Version Packages (#121)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* Caravan Health Package (beta) (#112)

Signed-off-by: Harshil-Jani <harshiljani2002@gmail.com>
Co-authored-by: buck <buck@unchained.com>

* Version Packages (#123)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* Tweaks to SegWit PSBT Inputs/Outputs (#124)

* fix: supply witness script when generating multisig

* fix: include non witness utxo in segwit inputs

* fix: add unsignedPSBT to state on finalizeOutputs

* fix: variable names and pass psbt to direct sig importer

* update fixture shape and psbts to include non witness utxos

* tweak fixture shape and add non witness utxos to psbts

* hackish injection of non witness utxos for tests

* include nonwitness utxo for segwit in caravan bitcoin; update base64 encoded psbts in fixtures for less testing hackery

* include multisig obj in caravan bitcoin fixtures

---------

Co-authored-by: buck <buck@unchained.com>

* Feat: bip32 package with blinded xpub support (#126)

* cleanup and fix generator templates

* init bip32 package with paths utils

* fix: eslint and add import ordering

* split up key and path modules and add tests

* custom util for getting random ints in node or browser

* use custom random int for blinded paths

* util for getting blinded xpub from source

* feat: blind xpub support for text input

* make new bip32 package publishable

* feat: reused functionality extracted to a utility for getting relative child sequence

* Fix hermit selection (#127)

* convert HermitReader and SignatureImporter to typescript

* adding height on hermit reader

* convert HermitReader to functional and use new QrReader api

* fix falsey bug

* styling cleanup

---------

Co-authored-by: Justin Moore <11jmoore@pm.me>

* caravan/bip32 publish access public (#129)

* tweak to package.json (#130)

* Version Packages (#128)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* unsignedPsbt in redux store should include global xpubs (#132)

* bump for coordinator (#138)

* Version Packages (#139)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* Fee bumping Package (#114)

* feat: Initialize @caravan/feebumping package

Create a new package for fee bumping functionality in Caravan. This package
provides modular and reusable utilities for implementing RBF (Replace-By-Fee)
and CPFP (Child-Pays-For-Parent) fee bumping strategies.

Key additions:
- Basic package structure and configuration files
- Core modules for RBF and CPFP implementations
- Fee estimation utilities
- Type definitions for fee bumping operations
- Constants and utility functions

This package aims to enhance Caravan's transaction management capabilities
by providing a flexible and extensible fee bumping solution that can be
easily integrated into the Caravan coordinator wallet and other Bitcoin
projects.

* update package-lock (#143)

* Version Packages (#144)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* add support for the BitBox02 hardware wallet (#117)

* add support for the BitBox02 hardware wallet

Using the `bitbox-api` NPM package, which loads a WASM module.

Note about CJS:
Currently the `bitbox-api` package is an ESM package with a `module:
...` entrypoint, so it is not compatible with the `cjs` target of
caravan-wallets. The only workaround that I could find where
compilation succeeds and the package works in the browser is to mark
bitbox-api as external in tsup.config.ts.

Note about signing tests:

- The BitBox02 requires the previous transaction of each input to be
present in the PSBT (`PSBT_IN_NON_WITNESS_UTXO`), so it can verify the
input amount and avoid fee attacks. The signing test fixtures are
missing these, so they fail.

- The BitBox02 uses the anti-klepto (anti-exfil) protocol to mitigate
covert nonce exfil attacks. This results in random signatures. The
unit test fixtures hardcode the expected signatures, assuming they are
always the same. As a result, also here the tests fail. To fix this,
the tests should rather verify the ECDSA signatures against the
transaction sighash for each input.

* hide BitBox02 menu item for P2SH

BitBox02 does not support legacy P2SH.

* bitbox: display pairing code

The BitBox, if not paired yet, will show a pairing code for
confirmation. This can happen in any BitBox interaction.

This commit adds a `showPairingCode` param to all BitBox
interactions. If not provided, a default implementation is used which
shows the pairing code in a browser popup.

The current `messages()` system is not a good fit, as the client does
not know when to call `messagesFor()` to display it. Having a separate
UI button to pair the BitBox is not good UX (why should the user be
bothered to click a "pair" button first? What if the user doesn't) and
also fragile (a re-pairing could be needed at any time).

* add regtest support for BitBox02

---------

Co-authored-by: buck <buck@unchained.com>

* Version Packages (#145)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* fix: fees package private (#146)

* Translate segwit psbt (#147)

* chore: fix turbo.json for test runner

* update deps

* feat: dds support for translatePSBT for segwit PSBTs

* pass key details to sig interaction just in case

* Version Packages (#148)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* fix: move bitbox to normal dependency (#149)

* Version Packages (#150)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* fix(wallets): bundle internal dependencies with production bundle (#151)

* Version Packages (#152)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* fix: @caravan/bitcoin shouldn't be noExternal (#153)

* Version Packages (#154)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* fix: unknown network error for regtest (#156)

* support regtest network in coldcard and custom interactions

* add changeset

* Version Packages (#157)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* include addressType for valid PSBT translation in SignMultisigTransaction (#159)

* Version Packages (#160)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* chore(deps-dev): bump gh-pages from 3.2.3 to 5.0.0

Bumps [gh-pages](https://github.com/tschaub/gh-pages) from 3.2.3 to 5.0.0.
- [Release notes](https://github.com/tschaub/gh-pages/releases)
- [Changelog](https://github.com/tschaub/gh-pages/blob/main/changelog.md)
- [Commits](tschaub/gh-pages@v3.2.3...v5.0.0)

---
updated-dependencies:
- dependency-name: gh-pages
  dependency-type: direct:development
...

Signed-off-by: dependabot[bot] <support@github.com>

* fix: turbo dev depends on build w/ esbuild noExternal (#164)

* Add sparrow to allowed method of importing pubkeys (#166)

Signed-off-by: Harshil Jani <harshiljani2002@gmail.com>

* bump @trezor/connect-web from 9.1.12 to 9.4.7 (#163)

Co-authored-by: dylan-thompson <141655089+dylan-thompson@users.noreply.github.com>

* Version Packages (#169)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* chore(deps): bump axios from 1.6.7 to 1.7.4 in /packages/caravan-wallets

Bumps [axios](https://github.com/axios/axios) from 1.6.7 to 1.7.4.
- [Release notes](https://github.com/axios/axios/releases)
- [Changelog](https://github.com/axios/axios/blob/v1.x/CHANGELOG.md)
- [Commits](axios/axios@v1.6.7...v1.7.4)

---
updated-dependencies:
- dependency-name: axios
  dependency-type: direct:production
...

Signed-off-by: dependabot[bot] <support@github.com>

* PsbtV2.toV0(): Convert a PsbtV2 class to its serialized PSBTv0 counterpart (#158)

* feat: PsbtV2.toV0()

* chore: changeset

* fix: remove log

* test: add more tests for PsbtV2.toV0

* chore: update package-lock to match package.json (#171)

* Version Packages (#173)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* fix: replace npm install with npm ci in CI workflows (#175)

* fix(psbt): lock dependency of caravan-bitcoin (#174)

* Version Packages

* chore(deps): bump axios from 1.6.7 to 1.7.4

Bumps [axios](https://github.com/axios/axios) from 1.6.7 to 1.7.4.
- [Release notes](https://github.com/axios/axios/releases)
- [Changelog](https://github.com/axios/axios/blob/v1.x/CHANGELOG.md)
- [Commits](axios/axios@v1.6.7...v1.7.4)

---
updated-dependencies:
- dependency-name: axios
  dependency-type: direct:production
...

Signed-off-by: dependabot[bot] <support@github.com>

* chore(deps-dev): bump vite from 4.5.5 to 4.5.6

Bumps [vite](https://github.com/vitejs/vite/tree/HEAD/packages/vite) from 4.5.5 to 4.5.6.
- [Release notes](https://github.com/vitejs/vite/releases)
- [Changelog](https://github.com/vitejs/vite/blob/v4.5.6/packages/vite/CHANGELOG.md)
- [Commits](https://github.com/vitejs/vite/commits/v4.5.6/packages/vite)

---
updated-dependencies:
- dependency-name: vite
  dependency-type: direct:development
...

Signed-off-by: dependabot[bot] <support@github.com>

* chore(turbo): add build as lint task dependency (#178)

* chore(wallets): bump trezor connect dependency (#183)

* Version Packages (#184)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* Fix/docker updates (#185)

* fix(docker): add multi-platform support for coordinator Dockerfile

* chore(changeset): changeset for multi-platform Dockerfile change

* docs(dockerfile): clarify platform-agnostic comment for coordinator app

* feat: Add getTransaction method to BlockchainClient (#134)

* feat: Add getTransaction method to BlockchainClient

This commit adds a getTransaction method to the BlockchainClient class,
which provides a consistent structure for fetching transaction details across different data providers (Bitcoin Core, Blockstream, Mempool).

Changes:
 - Add `TransactionDetails` interface for unified transaction data
 - Implement `getTransaction` method
 - Add `normalizeTransactionData` to standardize response

* REVIEW-CHANGES : changes in bitcoind.js and tests

* refactor: move transaction normalization to standalone utility

* refactor: update TransactionDetails to use camelCase naming

* refactor(bitcoind): convert bitcoind.js to TypeScript

* feat(bitcoind): update ListTransactionsItem interface to match RPC spec

* fix(client): handle different transaction response formats properly for the getTransaction method

* fix: update test mocks to match RPC response types

* changes to fix broken tests

* refactor(block-explorer): Convert to TypeScript with improved type safety

* refactor(blockchain): Migrate to TypeScript and enhance error handling

* revert: revert: undo recent changes to bitcoind.ts

* fixes: Type fixes in bitcoind

* fix: remove async promise executor in callBitcoind

* doc-strings: added doc strings to callBitcoind method

* refactor: add TypeScript type annotations to bitcoindParams function

* Added detailed docstrings to the `bitcoindListUnspent` method

* Added detailed docstrings to the `bitcoindGetAddressStatus` method

* Added detailed docstrings to the `bitcoindEstimateSmartFee` method

* refactor: improve typing and error handling in bitcoindSendRawTransaction

* refactor: improve typing and added doc-strings in bitcoindRawTxData

* revert: undo recent changes to block_explorer.ts

* fixes-types: Partial type fixes in block_explorer.ts to pass type errors

* fixes-type-block_explorer: Fixed blockExplorerGetAddresesUTXOs function

* fixes-type-block_explorer: Fixed blockExplorerGetAddressStatus function

* fixes-type-block_explorer: Fixed blockExplorerGetFeeEstimate function

* fixes-type-block_explorer: Fixed blockExplorerBroadcastTransaction function

* revert: undo recent changes to blockchain.ts

* fixes-types: Partial type fixes in blockchain.ts to pass type errors

* fixes-type-blockchain: Fixed fetchAddressUTXOsUnsorted function

* fixes-type-blockchain: Fixed fetchAddressUTXOs function

* fixes-type-blockchain: Fixed getAddressStatus function

* fixes-type-blockchain: Fixed fetchFeeEstimate function

* fixes-type-blockchain: Fixed broadcastTransaction function

* TO-DO: any error eslint disable to-do

* chore(changeset): Update changeset to include TypeScript migration

* refactor(bitcoind): standardize Bitcoin RPC parameters by introducing `BaseBitcoindArgs`, updating function signatures

* refactor(bitcoind): `bitcoindRawTxData` to use standardize Bitcoin RPC function parameters

* chore: rename block_explorer.ts to blockExplorer.ts for consistency

---------

Co-authored-by: buck <buck@unchained.com>

* Version Packages (#186)

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* Allow a PsbtV2 to be constructed with a psbtv2 which has been forceably set to have PSBT_GLOBAL_TX_VERSION === 1 (#188)

* feat: allowTxnVersion1 on instantiation

* chore: changeset

* Version Packages (#189)

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>

* fix: fixed the private node rpc calls bug in clients `getTransaction` method (#196)

* Version Packages (#197)

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>

* feat(wallet): Add pending transaction tab  (#168)

* UI cleanup: Remove redundant header and focus on pending transactions (#205)

* UI cleanup: Remove redundant header and focus on pending transactions

* added changeset

* fix: rm req of PSBT_GLOBAL_FALLBACK_LOCKTIME on isReadyForConstructor (#199)

Co-authored-by: buck <buck@unchained.com>

* Version Packages (#203)

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>

* Feat/add get wallet transaction (#206)

* Add-RPC-Call:Added `bitcoindGetWalletTransaction` function for direct RPC access

* add-type: WalletTransactionResponse

* fix: WalletTransactionResponse as per docs

* add-utility-fn: transformWalletTransactionToRawTransactionData added

* add-method: Added `getWalletTransaction` method to the BlockchainClient class

* tests: added bitcoindGetWalletTransaction tests

* tests: added transformWalletTransactionToRawTransactionData tests

* test: added getWalletTransaction tests

* added changeset

* refactor :  update getTransaction method

* UI(Transaction-Tab): added back the fee-display component

* fixes: to handle category(send/receive) of tx

* fix:error checking for category details of tx

* fix:error checking for category details of tx-2

* test-fix: fixes to handle the new added category type

* Version Packages (#217)

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>

* chore: updated readme (#218)

* fix for code scanning

---------

Signed-off-by: Harshil-Jani <harshiljani2002@gmail.com>
Signed-off-by: dependabot[bot] <support@github.com>
Signed-off-by: Harshil Jani <harshiljani2002@gmail.com>
Co-authored-by: chadchapnick <143517546+chadchapnick@users.noreply.github.com>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
Co-authored-by: Harshil Jani <harshiljani2002@gmail.com>
Co-authored-by: buck <buck@unchained.com>
Co-authored-by: Justin Moore <11jmoore@pm.me>
Co-authored-by: Mrigesh Thakur <96632943+Legend101Zz@users.noreply.github.com>
Co-authored-by: benma <m@mben.ch>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Robert Shuford <75178461+robertshuford@users.noreply.github.com>
Co-authored-by: kimlwh <kimlwh@proton.me>
Co-authored-by: dylan-thompson <141655089+dylan-thompson@users.noreply.github.com>
Co-authored-by: Jack D <shadouts@hotmail.com>
Co-authored-by: Jack D <jack@unchained.com>
Co-authored-by: Narasimha <129654598+narasimha-1511@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants