mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-06-28 20:39:51 +00:00
* Initial Payjoin * Initial Payjoin * More payjoin stuff * Minor fixes * Minor fixes * Minor cleanup * Minor cleanup * Minor cleanup * Minor cleanup * Minor cleanup * Minor cleanup * Fix minor bug causes by data inconsistency in the btc utxos * Minor cleanup * Minor cleanup * Minor cleanup * Minor cleanup * Initial Payjoin * Initial Payjoin * More payjoin stuff * Minor fixes * Minor fixes * Minor cleanup * Minor cleanup * Minor cleanup * Minor cleanup * Minor cleanup * Minor cleanup * Fix minor bug causes by data inconsistency in the btc utxos * Minor cleanup * Minor cleanup * Minor cleanup * Minor cleanup * Fix Rebase issues * Move PJ Receiver to isolate * Add Payjoin Setting * Payjoin Sender are now isolated * Added Payjoin sessions to tx overview. Fix Fee issue with payjoin * Clean up code * Fix taproot for payjoin * Fix CI Errors * Add Payjoin UI elements and details page * Add Payjoin UI elements and details page * Fix Translations * feat: Detect Payjoin URIs in pasted text and show to the User sending Payjoin * feat: rename pjUri to payjoinURI for more code clarity * Update res/values/strings_pl.arb Co-authored-by: cyan <cyjan@mrcyjanek.net> * Update cw_bitcoin/lib/payjoin/manager.dart Co-authored-by: cyan <cyjan@mrcyjanek.net> * Update cw_bitcoin/lib/payjoin/manager.dart Co-authored-by: cyan <cyjan@mrcyjanek.net> * feat: Disable Payjoin per default * feat: Disable Payjoin fully if disabled or no Inputs available * feat: Resume Payjoin if app comes back to foreground * chore: Revert overly aggressive code formats * feat: show correct Payjoin amount for receivers * feat: Improved payjoin status * feat: Show payjoin errors on payjoin details screen * deps: update flutter to 3.27.4 * feat: Revert localisations * bug: Remove duplicate transaction id on payjoin details * style: remove double await in payjoin sender * refactor(cw_bitcoin): Refactor method signatures and convert constructor to factory * refactor(cw_bitcoin): Refactor wallet service and PSBT signer for cleaner code Removed unnecessary `CakeHive` dependency and refactored `BitcoinWallet` initialization to use `payjoinSessionSource`. Improved code readability in `PsbtSigner` by reformatting lines and simplifying constructor methods for `UtxoWithPrivateKey`. * fix: Resume Payjoin Sessions and load PJUri after sleep * feat: Add "Copy Payjoin URL button" to receive screen * fix: Add "Payjoin enabled"-Box below QR Code on the receive screen * fix: Set payjoin_enabled color to black independent of the theme * refactor: Payjoin session management and cleanup unused code. --------- Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com> Co-authored-by: cyan <cyjan@mrcyjanek.net>
52 lines
2.1 KiB
Dart
52 lines
2.1 KiB
Dart
import 'package:bitcoin_base/bitcoin_base.dart';
|
|
import 'package:blockchain_utils/blockchain_utils.dart';
|
|
import 'package:flutter/foundation.dart';
|
|
import 'package:ledger_bitcoin/psbt.dart';
|
|
import 'package:ledger_bitcoin/src/psbt/map_extension.dart';
|
|
import 'package:ledger_bitcoin/src/utils/buffer_reader.dart';
|
|
import 'package:ledger_bitcoin/src/utils/uint8list_extension.dart' as ext;
|
|
|
|
extension PsbtSigner on PsbtV2 {
|
|
|
|
void deserializeV0(Uint8List psbt) {
|
|
final bufferReader = BufferReader(psbt);
|
|
if (!listEquals(bufferReader.readSlice(5), Uint8List.fromList([0x70, 0x73, 0x62, 0x74, 0xff]))) {
|
|
throw Exception("Invalid magic bytes");
|
|
}
|
|
while (_readKeyPair(globalMap, bufferReader)) {}
|
|
|
|
final tx = BtcTransaction.fromRaw(BytesUtils.toHexString(globalMap['00']!));
|
|
|
|
setGlobalInputCount(tx.inputs.length);
|
|
setGlobalOutputCount(tx.outputs.length);
|
|
setGlobalTxVersion(Uint8List.fromList(tx.version).readUint32LE(0));
|
|
|
|
for (var i = 0; i < getGlobalInputCount(); i++) {
|
|
inputMaps.insert(i, <String, Uint8List>{});
|
|
while (_readKeyPair(inputMaps[i], bufferReader)) {}
|
|
final input = tx.inputs[i];
|
|
setInputOutputIndex(i, input.txIndex);
|
|
setInputPreviousTxId(i, Uint8List.fromList(BytesUtils.fromHexString(input.txId).reversed.toList()));
|
|
setInputSequence(i, Uint8List.fromList(input.sequence).readUint32LE(0));
|
|
}
|
|
for (var i = 0; i < getGlobalOutputCount(); i++) {
|
|
outputMaps.insert(i, <String, Uint8List>{});
|
|
while (_readKeyPair(outputMaps[i], bufferReader)) {}
|
|
final output = tx.outputs[i];
|
|
setOutputAmount(i, output.amount.toInt());
|
|
setOutputScript(i, Uint8List.fromList(output.scriptPubKey.toBytes()));
|
|
}
|
|
}
|
|
|
|
bool _readKeyPair(Map<String, Uint8List> map, BufferReader bufferReader) {
|
|
final keyLen = bufferReader.readVarInt();
|
|
if (keyLen == 0) return false;
|
|
|
|
final keyType = bufferReader.readUInt8();
|
|
final keyData = bufferReader.readSlice(keyLen - 1);
|
|
final value = bufferReader.readVarSlice();
|
|
|
|
map.set(keyType, keyData, value);
|
|
return true;
|
|
}
|
|
}
|