Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/leionion/utxo-optimization-template
UTXO Splitting, merging, sending with optimized fee according to user's selection (contains 3 levels)
https://github.com/leionion/utxo-optimization-template
bitcoin psbt typescript utxo
Last synced: 2 months ago
JSON representation
UTXO Splitting, merging, sending with optimized fee according to user's selection (contains 3 levels)
- Host: GitHub
- URL: https://github.com/leionion/utxo-optimization-template
- Owner: leionion
- Created: 2024-05-30T16:42:47.000Z (8 months ago)
- Default Branch: main
- Last Pushed: 2024-06-12T10:47:18.000Z (7 months ago)
- Last Synced: 2024-07-08T13:55:55.964Z (6 months ago)
- Topics: bitcoin, psbt, typescript, utxo
- Language: TypeScript
- Homepage:
- Size: 17.6 KB
- Stars: 4
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
Awesome Lists containing this project
README
# UTXO Management Project
This guide provides explaining how to utilize them effectively for managing UTXOs (Unspent Transaction Outputs) in a Bitcoin-based application.
## Scripts Description
### `npm run split`- **Purpose**: Splits a larger UTXO into multiple 546 sats UTXOs. This is useful for transaction privacy and for creating denominations that are easier to split UTXO accurately.
- **Usage**: Run `npm run split` to divide a large UTXO into small ones according to specified criteria.### `npm run merge`
- **Purpose**: Designed to merge multiple UTXOs into a single UTXO, which can be beneficial for simplifying wallet management and reducing the cost of future transactions.
- **Usage**: Execute `npm run merge` to combine several small UTXOs into one.### `npm run send`
- **Purpose**: Facilitates the sending of Bitcoins from one address to another. This script likely handles the creation and broadcasting of the transaction to the Bitcoin network.
- **Usage**: Use `npm run send` to specify the details (e.g., recipient's address) and send the UTXO.## Installation
To set up and run this project locally, follow these steps:
1. **Clone the Repository**: First, clone this repository to your local machine using:
```bash
git clone https://github.com/bitmapers/utxo-management.git
```2. **Install Dependencies**: Navigate into your project directory and install the required dependencies:
```bash
cd utxo-management
npm install
```3. **Setup Environment Variables**: Copy the `.env.example` file to `.env` and fill in the necessary Bitcoin network details and key management options.
```bash
cp .env.example .env
```4. **Run Scripts**: Use the npm run commands listed above to perform different operations like merging, sending, or splitting UTXOs.
## Dependencies
- **External Modules**:
- `axios`: For making HTTP requests.
- `bip32`, `bip39`: For generating Bitcoin wallet addresses from a hierarchical deterministic (HD) path.
- `bitcoinjs-lib`: A library for Bitcoin protocol functions.
- `dotenv`: Loads environment variables from a `.env` file.
- `ecpair`: Represents an elliptic curve pair.
- `tiny-secp256k1`: For elliptic curve cryptography operations.- **Development Modules**:
- `@types/node`: TypeScript type definitions for Node.js.
- `ts-node`: TypeScript execution environment and REPL for Node.js.
- `typescript`: The TypeScript compiler.## File Structure
Briefly describe the folder and file structure.
```plaintext
/ - Root directory
|__ /utils - Utility scripts
|__ utxo.ts - Fetch UTXOs for a given address.
|__ wallet.ts - Represents a Bitcoin wallet functionality.
|__ config.ts - Configuration including to Bitcoin network.
|__ index.ts - Main script for executing transactions.
|__ sendUTXO.ts - Send UTXO to other bitcoin address.
|__ splitUTXO.ts - Split UTXO into smaller UTXOs with big UTXO.
|__ mergeUTXO.ts - Merge UTXO into one big UTXO with small UTXOs.
```## Utils Functions
### Interfaces
- **IUtxo:** Interface for Unspent Transaction Outputs which include:
- **txid:** Transaction ID.
- **vout:** Output number in the transaction.
- **value:** Value of the output in satoshis.### Functions
#### getScriptPubkey(tx: string, address: string): Promise
Fetches the script pubkey associated with a specific output address in a transaction.
**Parameters:**
- `tx`: The transaction ID as a string.
- `address`: The Bitcoin address as a string.**Returns:** A promise that resolves to the script pubkey as a string.
#### getUtxos(address: string): Promise
Retrieves all UTXOs for a given Bitcoin address.
**Parameters:**
- `address`: The Bitcoin address as a string.**Returns:** A promise that resolves to an array of UTXOs.
#### pushBTCpmt(rawtx: any): Promise
Pushes a raw Bitcoin transaction to the network.
**Parameters:**
- `rawtx`: The raw transaction data.**Returns:** A promise that resolves to the transaction ID.
#### postData(url: string, json: any, content_type?: string, apikey?: string): Promise
General function to send POST requests. Handles error retries related to specific blockchain-related errors.
**Parameters:**
- `url`: The API endpoint.
- `json`: The JSON payload for the post request.
- `content_type`: (Optional) Content type of the request, defaults to `"text/plain"`.
- `apikey`: (Optional) API key for authenticated requests.**Returns:** A promise that resolves to the response data as a string or undefined in case of specific errors.
### Usage Example
#### Getting UTXOs for a Bitcoin Address
```typescript
import { getUtxos } from './path_to_module';async function displayUtxos() {
const address = 'bitcoin_address_here';
const utxos = await getUtxos(address);
console.log(utxos);
}displayUtxos();
```#### Pushing a Bitcoin Transaction
```typescript
import { pushBTCpmt } from './path_to_module';async function sendTransaction() {
const rawTransaction = 'raw_transaction_data_here';
const txid = await pushBTCpmt(rawTransaction);
console.log(`Transaction ID: ${txid}`);
}sendTransaction();
```## Calculation Fee Function: `calculateTxFee`
#### Purpose:
Calculates the estimated transaction fee for a given PSBT and fee rate. The fee rate is typically expressed in satoshis per byte.
#### Parameters:
- `psbt` (Bitcoin.Psbt): The partially signed Bitcoin transaction.
- `feeRate` (number): The fee rate in satoshis per byte.#### Implementation Details:
1. **Mock Output Script Creation**:
- A dummy output script (`MOCK_OUTPUT_SCRIPT`) and value (`MOCK_OUTPUT_VALUE`) are used to mimic a real transaction condition by adding an additional output. This helps in more accurately estimating the size of the final transaction.2. **Transaction Construction**:
- A new Bitcoin transaction is instantiated.
- Inputs and their corresponding witness data from the PSBT are added to this new transaction.
- All outputs (from the PSBT and the mock output) are added to the transaction.3. **Size Calculation and Fee Estimation**:
- The virtual size of the transaction is calculated. The virtual size is a more accurate measure for fee calculation as it considers the weight of witness data.
- The transaction's virtual size is multiplied by the provided fee rate to estimate the fee in satoshis.#### Returns:
- (number): The calculated transaction fee in satoshis.
### Example Usage
```javascript
const feeRate = 1; // 1 satoshi per byte
const estimatedFee = calculateTxFee(psbt, feeRate);
console.log(`Estimated Transaction Fee: ${estimatedFee} satoshis`);
```## Send UTXO Function
`main(sendToAddress: string)`: this asynchronous function takes a single parameter, `sendToAddress`, which is the Bitcoin address where the funds will be sent.
#### Detailed Workflow
1. **Wallet Initialization**
- Create an instance of the `Wallet` from the `utils/wallet` module.
- Log the wallet's address to the console.2. **UTXO Retrieval**
- Fetch UTXOs (Unspent Transaction Outputs) associated with the wallet’s address using the `getUtxos` function from `utils/utxo`.
- Find a suitable UTXO that has a value greater than 10,000 satoshis. If no such UTXO is found, the function throws an error.3. **PSBT Creation**
- Initialize a new PSBT (Partially Signed Bitcoin Transaction) specifying the Bitcoin testnet.
- Add the selected UTXO as an input to the PSBT.
- Define the transaction outputs:
- One output sending the intended amount (UTXO value minus initial fee) to `sendToAddress`.
- Another output to send the remaining balance (initial fee minus calculated transaction fee) back to the wallet's address as a change.4. **Transaction Fee Calculation**
- Calculate the transaction fee using the transaction’s virtual size and a predefined testnet fee rate.5. **Transaction Signing**
- Sign the PSBT using the wallet’s private keys.6. **Transaction Extraction and Broadcast**
- Extract the signed transaction from the PSBT.
- Convert the transaction to its hexadecimal representation.
- Broadcast the transaction to the Bitcoin testnet using the `pushBTCpmt` function.
## Split UTXO Function`main()`: this asynchronous function with no parameter
#### Detailed Workflow
1. **Create Wallet Instance**:
- Instantiate a new wallet, which will autogenerate a new address and keypair.2. **Fetch UTXOs**:
- Retrieve all available UTXOs for the wallet address that have a balance greater than a specified amount (10,000 satoshis in this script).3. **Transaction Construction**:
- Create a new `Psbt` (Partially Signed Bitcoin Transaction).
- Add inputs and outputs to the `Psbt`. Each output sends a fixed amount (546 satoshis in this example) to the wallet address.
- Calculate and subtract the transaction fees and send the remaining balance back to the wallet address.4. **Signing the Transaction**:
- The transaction is signed using the wallet's private key.5. **Broadcast Transaction**:
- The transaction, once signed, is converted to hexadecimal format and broadcasted to the network, returning a transaction ID.## Merge UTXO Function
`main()`: this asynchronous function with no parameter
#### Detailed Workflow
1. **Initialize Wallet**:
- Creates a new wallet instance which will be used to gather UTXOs and sign the transaction.
2. **Fetch UTXOs**:
- Calls `getUtxos` to retrieve UTXOs for the wallet address.3. **Prepare Partially Signed Bitcoin Transaction (PSBT)**:
- Initializes a PSBT object specific to the Bitcoin testnet.
- Adds inputs for each retrieved UTXO including the necessary details like wallet public key for taproot spend.4. **Calculate Transaction Fee**:
- Uses a mock output and fee rate to calculate an appropriate transaction fee based on the virtual size of the transaction.5. **Add Output**:
- Adds an output to the transaction, subtracting the calculated fee from the total input value to set the output value.6. **Sign PSBT**:
- The wallet signs the PSBT.7. **Broadcast Transaction**:
- Extracts the full transaction from PSBT, converts it to hexadecimal, and pushes it to the Bitcoin testnet using `pushBTCpmt`.
# Conclusion
The UTXO Management Project is designed to provide a comprehensive suite of utilities to facilitate efficient handling of Bitcoin transactions, ideally suited for developers and organizations involved in cryptocurrency management. By utilizing the `split`, `merge`, and `send` scripts, users can optimize their transaction processes, whether for enhancing privacy, simplifying wallet management, or executing precise fund transfers.