An open API service indexing awesome lists of open source software.

https://github.com/onflow/flow-wallet-kit

Flow Blockchain SDK for mobile
https://github.com/onflow/flow-wallet-kit

android cryptocurrency cryptowallet flow flow-blockchain ios wallet

Last synced: about 2 months ago
JSON representation

Flow Blockchain SDK for mobile

Awesome Lists containing this project

README

        

![logo](./assets/logo.png)

[![DeepWiki](https://img.shields.io/badge/DeepWiki-onflow%2FFlow--Wallet--Kit-blue.svg?logo=)](https://deepwiki.com/onflow/Flow-Wallet-Kit)
# πŸš€ Flow Wallet Kit

A cross-platform SDK for integrating **Flow blockchain wallet** functionality into iOS and Android applications. This SDK provides a **secure interface** for managing Flow accounts and handling transactions across networks.

---

## πŸ—ΊοΈ Roadmap

Here's what's been built and what's coming next:

### βœ… Done
- [x] πŸ” Create and store private key
- [x] πŸ”‘ Support multiple private key types
- [x] 🌐 Handle Flow accounts across networks
- [x] 🧩 Manage COA (Cadence Owned Account)
- [x] πŸ‘Ά Manage child accounts

### πŸ”œ To Do
- [ ] πŸ’° Token balance querying
- [ ] ☁️ All-type backup support (e.g. cloud)
- [ ] 🌐 WalletConnect integration
- [ ] πŸ”„ FCL (Flow Client Library) support
- [ ] ⛓️ Multi-chain support for other blockchains
---

## πŸ“š Documentation

Visit our comprehensive documentation at [flow-wallet-kit.vercel.app/docs](https://flow-wallet-kit.vercel.app/docs)

Or visit Deepwiki at [deepwiki.com/onflow/Flow-Wallet-Kit](https://deepwiki.com/onflow/Flow-Wallet-Kit)

Platform-specific guides are also available here:
- πŸ“± [iOS Documentation](iOS/README.md)
- πŸ€– [Android Documentation](Android/README.md)

---

## πŸ” Hardware-Backed Key Security

We prioritize **secure private key handling** using platform-native secure hardware modules:

- 🧱 **Secure Enclave (iOS)**: Flow private keys can be securely generated and stored in the Secure Enclave using the `SecureElementProvider`.
- πŸ›‘οΈ **Android Keystore (Android)**: Private keys are protected with hardware-backed Android Keystore using the `HardwareBackedStorage` implementation.

These solutions help prevent private key extraction and elevate the security standard for mobile Flow wallets.

---

## πŸ—οΈ Architecture

Check out the full docs in here: [Architecture](./docs/architecture.md)

### 🧱 Core Components
- **Storage Protocol**: Secure data storage across platforms
- **Key Protocol**: Consistent key management
- **Crypto**: Secure encryption, derivation, hashing
- **Wallet**: Modular wallet handling
- **Account**: Multi-network and child account management
- **Security**: Hardware + software crypto implementations
- **Network**: Key Indexer API integration

---

## βœ… Features

### πŸ” Security & Storage
- **Secure Storage Protocol** (platform-agnostic)
- **iOS**:
- πŸ”‘ `KeychainStorage`: Secure key storage via Keychain
- πŸ“ `FileSystemStorage`: Encrypted file-based storage
- **Android**:
- πŸ›‘οΈ `HardwareBackedStorage`: Uses Android Keystore
- πŸ“ `FileSystemStorage`: Encrypted file-based storage
- 🧠 `InMemoryStorage`: Volatile, memory-only storage
- ✨ Common:
- Cacheable interfaces
- Encrypted storage
- Hardware-backed protection (when available)

- **Key Management Protocol**
- πŸ” `PrivateKeyProvider`: Supports ECDSA P-256 & secp256k1
- 🧱 `SecureElementProvider`: Secure Enclave / Keystore
- 🌱 `SeedPhraseProvider`: BIP-39 + HD Wallet

- **Backup**
- πŸ”’ Platform-specific basic secure backups

### πŸ”’ Cryptographic Operations
- **Encryption**
- AES-GCM & ChaCha20-Poly1305
- **Key Derivation**
- BIP-39 & HD Wallet support
- **Hashing**
- Secure data integrity functions

### πŸ‘› Core Wallet Types
- **Watch Wallet**: Address-only
- **Key Wallet**: Private key or seed phrase + πŸ” Key Indexer API integration

### πŸ‘₯ Account Management
- Multi-account, cross-network support
- Child account management
- πŸ” Flow-EVM account compatibility

---

## πŸ§ͺ Development Status

This SDK is **under active development**! πŸ› οΈ
We're focused on robust cross-platform key and account management. More features like balance queries and WalletConnect are on the way!

---

## πŸ“„ License

This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.

---

## πŸ’¬ Support

Found a bug? Need help?
Please open an issue in the repo or contact the maintainers.