Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/trustwallet/wallet-core
Cross-platform, cross-blockchain wallet library.
https://github.com/trustwallet/wallet-core
bitcoin blockchain cross-platform crypto cryptocurrency ethereum
Last synced: 5 days ago
JSON representation
Cross-platform, cross-blockchain wallet library.
- Host: GitHub
- URL: https://github.com/trustwallet/wallet-core
- Owner: trustwallet
- License: apache-2.0
- Created: 2019-02-14T18:25:54.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2025-01-02T09:43:13.000Z (9 days ago)
- Last Synced: 2025-01-03T05:43:03.733Z (8 days ago)
- Topics: bitcoin, blockchain, cross-platform, crypto, cryptocurrency, ethereum
- Language: C++
- Homepage: https://developer.trustwallet.com/wallet-core
- Size: 30.1 MB
- Stars: 2,942
- Watchers: 151
- Forks: 1,649
- Open Issues: 55
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Audit: audit/2023-09-15_TrustWallet_SecureCodeReviewReport_Public_v2.00.pdf
- Codeowners: .github/CODEOWNERS
- Security: SECURITY.MD
Awesome Lists containing this project
- best-of-crypto - GitHub - 2% open · ⏱️ 05.06.2024): (Exchange-based Tokens)
- awesome-aeternity - Trust Wallet - Wallet that supports many different cryptocurrencies. (Wallets / Mobile wallets)
- awesome-web3 - Trust Wallet Core - Cross-platform, mobile-focused library implementing low-level cryptographic wallet functionality for a high number of blockchains. (Software Development / C/C++)
README
Trust Wallet Core is an open-source, cross-platform, mobile-focused library
implementing low-level cryptographic wallet functionality for a high number of blockchains.
It is a core part of the popular [Trust Wallet](https://trustwallet.com), and some other projects.
Most of the code is C++ with a set of strict C interfaces, and idiomatic interfaces for supported languages:
Swift for iOS and Java (Kotlin) for Android.[![iOS CI](https://github.com/trustwallet/wallet-core/actions/workflows/ios-ci.yml/badge.svg)](https://github.com/trustwallet/wallet-core/actions/workflows/ios-ci.yml)
[![Android CI](https://github.com/trustwallet/wallet-core/actions/workflows/android-ci.yml/badge.svg)](https://github.com/trustwallet/wallet-core/actions/workflows/android-ci.yml)
[![Linux CI](https://github.com/trustwallet/wallet-core/actions/workflows/linux-ci.yml/badge.svg)](https://github.com/trustwallet/wallet-core/actions/workflows/linux-ci.yml)
[![Rust CI](https://github.com/trustwallet/wallet-core/actions/workflows/linux-ci-rust.yml/badge.svg)](https://github.com/trustwallet/wallet-core/actions/workflows/linux-ci-rust.yml)
[![Wasm CI](https://github.com/trustwallet/wallet-core/actions/workflows/wasm-ci.yml/badge.svg)](https://github.com/trustwallet/wallet-core/actions/workflows/wasm-ci.yml)
[![Kotlin CI](https://github.com/trustwallet/wallet-core/actions/workflows/kotlin-ci.yml/badge.svg)](https://github.com/trustwallet/wallet-core/actions/workflows/kotlin-ci.yml)
[![Docker CI](https://github.com/trustwallet/wallet-core/actions/workflows/docker.yml/badge.svg)](https://github.com/trustwallet/wallet-core/actions/workflows/docker.yml)
[![Quality Gate Status](https://sonarcloud.io/api/project_badges/measure?project=TrustWallet_wallet-core&metric=alert_status)](https://sonarcloud.io/summary/new_code?id=TrustWallet_wallet-core)[![Gitpod Ready-to-Code](https://img.shields.io/badge/Gitpod-ready--to--code-blue?logo=gitpod)](https://gitpod.io/#https://github.com/trustwallet/wallet-core)
![GitHub](https://img.shields.io/github/license/TrustWallet/wallet-core.svg)
![GitHub release (latest by date)](https://img.shields.io/github/v/release/trustwallet/wallet-core)
![SPM](https://img.shields.io/badge/SPM-ready-blue)
![Cocoapods](https://img.shields.io/cocoapods/v/TrustWalletCore.svg)# Documentation
For comprehensive documentation, see [developer.trustwallet.com](https://developer.trustwallet.com/wallet-core).
# Audit Reports
Security Audit reports can be found in the [audit](audit) directory.
# Supported Blockchains
Wallet Core supports more than **130** blockchains: Bitcoin, Ethereum, BNB, Cosmos, Solana, and most major blockchain platforms.
The full list is [here](docs/registry.md).# Building
For build instructions, see [developer.trustwallet.com/wallet-core/building](https://developer.trustwallet.com/wallet-core/building).
# Using from your project
If you want to use wallet core in your project follow these instructions.
## Android
Android releases are hosted on [GitHub packages](https://github.com/trustwallet/wallet-core/packages/700258), you need to add GitHub access token to install it. Please check out [this installation guide](https://developer.trustwallet.com/wallet-core/integration-guide/android-guide#adding-library-dependency) or `build.gradle` from our [android sample](https://github.com/trustwallet/wallet-core/blob/master/samples/android/build.gradle)
Don't forget replacing the version in the code with latest: ![GitHub release (latest by date)](https://img.shields.io/github/v/release/trustwallet/wallet-core)
## iOS
We currently support Swift Package Manager and CocoaPods (will discontinue in the future).
### SPM
Download latest `Package.swift` from [GitHub Releases](https://github.com/trustwallet/wallet-core/releases) and put it in a local `WalletCore` folder.
Add this line to the `dependencies` parameter in your `Package.swift`:
```swift
.package(name: "WalletCore", path: "../WalletCore"),
```Or add remote url + `master` branch, it points to recent (not always latest) binary release.
```swift
.package(name: "WalletCore", url: "https://github.com/trustwallet/wallet-core", .branchItem("master")),
```Then add libraries to target's `dependencies`:
```swift
.product(name: "WalletCore", package: "WalletCore"),
.product(name: "SwiftProtobuf", package: "WalletCore"),
```### CocoaPods
Add this line to your Podfile and run `pod install`:
```ruby
pod 'TrustWalletCore'
```## NPM (beta)
```js
npm install @trustwallet/wallet-core
```## Go (beta)
Please check out the [Go integration sample](https://github.com/trustwallet/wallet-core/tree/master/samples/go).
## Kotlin Multipleplatform (beta)
Please check out the [Kotlin Multiplatform sample](https://github.com/trustwallet/wallet-core/tree/master/samples/kmp)
# Projects
Projects using Trust Wallet Core. Add yours too!
[](https://trustwallet.com)
[Coinpaprika](https://coinpaprika.com/)
| [crypto.com](https://crypto.com)
| [Frontier](https://frontier.xyz/)
| [Tokenary](https://tokenary.io/)
| [MemesWallet](https://planetmemes.com/)
| [xPortal](https://xportal.com/)
| [Slingshot](https://slingshot.finance/)
| [ECOIN Wallet](https://play.google.com/store/apps/details?id=org.ecoinwallet&pcampaignid=web_share)# Community
There are a few community-maintained projects that extend Wallet Core to some additional platforms and languages. Note this is not an endorsement, please do your own research before using them:
- Flutter binding https://github.com/weishirongzhen/flutter_trust_wallet_core
- Python binding https://github.com/phuang/wallet-core-python
- Wallet Core on Windows https://github.com/kaetemi/wallet-core-windows# Contributing
The best way to submit feedback and report bugs related to WalletCore is to [open a GitHub issue](https://github.com/trustwallet/wallet-core/issues/new).
If the bug is not related to WalletCore but to the TrustWallet app, please [create a Customer Support ticket](https://support.trustwallet.com/en/support/tickets/new).
If you want to contribute code please see [Contributing](https://developer.trustwallet.com/wallet-core/contributing).
If you want to add support for a new blockchain also see [Adding Support for a New Blockchain](https://developer.trustwallet.com/wallet-core/newblockchain), make sure you have read the [requirements](https://developer.trustwallet.com/wallet-core/newblockchain#requirements) section.Thanks to all the people who contribute.
# Disclaimer
The Wallet Core project is led and managed by Trust Wallet with a large contributor community and actively used in several projects. Our goal at Wallet Core is to give other wallets an easy way to add chain support.
Trust Wallet products leverage wallet core, however, they may or may not leverage all the capabilities, features, and assets available in wallet core due to their own product requirements.
# License
Trust Wallet Core is available under the Apache 2.0 license. See the [LICENSE](LICENSE) file for more info.