You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
Craig Raw 3e47a49f49 core connection: default to cookie authentication when user/pass are not filled in 3 years ago
.github/workflows update github build to java 16 4 years ago
buildSrc make jackson jars open and non-synthetic modules 3 years ago
docs v1.5.0 final 3 years ago
drongo@e0302cef22 various whirlpool-related improvements 3 years ago
gradle/wrapper upgrade to gradle 7.1, java 16, javafx 16 4 years ago
src core connection: default to cookie authentication when user/pass are not filled in 3 years ago
.gitignore no ds store 5 years ago
.gitmodules fix recursive clone via https 3 years ago
LICENSE license 4 years ago
README.md update README for https cloning 3 years ago
build.gradle minor whirlpool related fixes 3 years ago
gradlew upgrade to gradle 7.1, java 16, javafx 16 4 years ago
gradlew.bat upgrade to gradle 7.1, java 16, javafx 16 4 years ago
settings.gradle Initial commit 5 years ago
sparrow Allow running `sparrow` script from other paths 3 years ago
sparrow.bat fix on windows 4 years ago

README.md

Sparrow Bitcoin Wallet

Sparrow is a modern desktop Bitcoin wallet application supporting most hardware wallets and built on common standards such as PSBT, with an emphasis on transparency and usability.

More information (and release binaries) can be found at https://sparrowwallet.com. Release binaries are also available directly from Github.

Sparrow Wallet

Building

To clone this project, use

git clone --recursive git@github.com:sparrowwallet/sparrow.git

or for those without SSH credentials:

git clone --recursive https://github.com/sparrowwallet/sparrow.git

In order to build, Sparrow requires Java 16 to be installed. The release binaries are built with AdoptOpenJdk 16.0.1+9 Hotspot.

These binaries can be built from source using

./gradlew jpackage

When updating to the latest HEAD

git pull --recurse-submodules

The release binaries are reproducible from v1.5.0 onwards (pre codesigning and installer packaging). More detailed instructions on reproducing the binaries are provided.

Running

If you prefer to run Sparrow directly from source, it can be launched with

./sparrow

Java 16 or higher must be installed.

Configuration

Sparrow has a number of command line options, for example to change its home folder or use testnet:

./sparrow -h

Usage: sparrow [options]
  Options:
    --dir, -d
      Path to Sparrow home folder
    --help, -h
      Show usage
    --level, -l
      Set log level
      Possible Values: [ERROR, WARN, INFO, DEBUG, TRACE]      
    --network, -n
      Network to use
      Possible Values: [mainnet, testnet, regtest, signet]

As a fallback, the network (mainnet, testnet, regtest or signet) can also be set using an environment variable SPARROW_NETWORK. For example:

export SPARROW_NETWORK=testnet

A final fallback which can be useful when running the Sparrow binary is to create a file called network-testnet in the Sparrow home folder (see below) to configure the testnet network.

Note that if you are connecting to an Electrum server when using testnet, that server will need to be running on testnet configuration as well.

When not explicitly configured using the command line argument above, Sparrow stores its mainnet config file, log file and wallets in a home folder location appropriate to the operating system:

Platform Location
OSX ~/.sparrow
Linux ~/.sparrow
Windows %APPDATA%/Sparrow

Testnet, regtest and signet configurations (along with their wallets) are stored in subfolders to allow easy switching between networks.

Reporting Issues

Please use the Issues tab above to report an issue. If possible, look in the sparrow.log file in the configuration directory for information helpful in debugging.

License

Sparrow is licensed under the Apache 2 software licence.

Credit

Yourkit

Sparrow Wallet uses the Yourkit Java Profiler to profile and improve performance. YourKit supports open source projects with useful tools for monitoring and profiling Java and .NET applications.