# AlphaWallet - Advanced, Open Source Ethereum Mobile Wallet & dApp Browser for iOS [![Build Status](https://travis-ci.com/AlphaWallet/alpha-wallet-ios.svg?branch=master)](https://github.com/AlphaWallet/alpha-wallet-ios/tree/master) [![Maintenance](https://img.shields.io/badge/Maintained%3F-yes-green.svg )](https://GitHub.com/AlphaWallet/alpha-wallet-ios/graphs/commit-activity) [![GitHub contributors](https://img.shields.io/github/contributors/AlphaWallet/alpha-wallet-ios.svg)](https://github.com/AlphaWallet/alpha-wallet-ios/graphs/contributors) [![MIT license](https://img.shields.io/badge/License-MIT-blue.svg)](https://github.com/AlphaWallet/alpha-wallet-ios/blob/master/LICENSE) [![codecov](https://codecov.io/gh/AlphaWallet/alpha-wallet-ios/branch/master/graph/badge.svg )](https://codecov.io/gh/AlphaWallet/alpha-wallet-ios) AlphaWallet is an open source programmable blockchain apps platform. It's compatible with tokenisation framework TokenScript, offering businesses and their users in-depth token interaction, a clean white label user experience and advanced security options. Supports all Ethereum based networks. AlphaWallet and TokenScript have been used by tokenisation projects like FIFA and UEFA’s [blockchain tickets](https://apps.apple.com/au/app/shankai/id1492559481), Bartercard’s [Qoin ecommerce ecosystem](https://apps.apple.com/au/app/qoin-wallet/id1483718254), several Automobiles’ [car ownership portal](https://github.com/AlphaWallet/TokenScript-Examples/tree/master/examples/Karma) and many more. ⭐ Star us on GitHub — it helps! [![alphawallet open source wallet ios preview](/resources/alphawallet-open-source-ethereum-wallet.jpg)](https://alphawallet.com/) ## About AlphaWallet - Features Easy to use and secure open source Ethereum wallet for iOS and Android, with native ERC20, ERC721 and ERC875 support. AlphaWallet supports all Ethereum based networks: Ethereum, xDai, Ethereum Classic, Artis, POA, Ropsten, Goerli, Kovan, Rinkeby and Sokol. - Beginner Friendly - Secure Enclave Security - Web3 dApp Browser - TokenScript Enabled - Interact with DeFi, DAO and Games with SmartTokens - No hidden fees or tech background needed ### AlphaWallet Is A Token Wallet AlphaWallet's focus is to provide an interface to interact with Ethereum Tokens in an intuitive, simple and full featured manner. This is what sets us aside from other open source ethereum wallets. ### Select Use Cases - [Bartercard Qoin](https://play.google.com/store/apps/details?id=com.qoin.wallet&hl=en) - [FIFA and UEFA’s blockchain tickets](https://apps.apple.com/au/app/shankai/id1492559481) - [Car Ownership portal](https://github.com/AlphaWallet/TokenScript-Examples/tree/master/examples/Karma) ### Full TokenScript Support With TokenScript, you can extend your Token’s capabilities to become "smart" and secure, enabling a mobile-native user experience :iphone: “SmartTokens” are traditional fungible and non fungible tokens that are extended with business logic, run natively inside the app and come with signed code to prevent tampering or phishing. It allows you to realise rich functions that Dapps previously struggled to implement. With SmartTokens you can get your token on iOS and Android in real time without the need to build your own ethereum wallet. AlphaWallet is the “browser” for users to access these SmartTokens. You can get the most out of your use case implementation... without leaving the wallet. Visit [TokenScript Documentation](https://github.com/AlphaWallet/TokenScript) or see [TokenScript Examples](https://github.com/AlphaWallet/TokenScript-Examples) to learn what you can do with it. ### Philosophy AlphaWallet is founded by blockchain geeks, business professionals who believe blockchain technology will have a massive impact on the future and change the landscape of technology in general. We are committed to connecting businesses and consumers with the new digital economic infrastructure through tokenisation. Tokenised rights can be traded on the market and integrated across systems, forming a Frictionless Market and allowing limitless integration with the web. We want to give businesses the whitelabel tools they need to develop their ethereum wallets, and join the tokenised economy. # Getting Started 1. [Download Xcode 13](https://developer.apple.com/download/more/) 2. Clone this repository 3. Run `make bootstrap` to install tools and dependencies. 4. Open the `AlphaWallet.xcworkspace` file (not `AlphaWallet.xcodeproj`) to begin. If you get a "Bundle does not exist. Please install bundle." error, please consult with your macOS guru because a vital part of your system is missing. This makefile has been tested to run on "Monterey"-12.0.1. It will not work on "Catalina" or "Big Sur". Read [INTRODUCTION-CODE.md](docs/INTRODUCTION-CODE.md). ### Updating GemFile or Podfile After the Gemfile is updated, run `make install_gems` to update the gems in the vendor/bundle directory. After the Podfile is updated, run `make install_pods` to update the pods in the Pods directory. ### Add your token to AlphaWallet If you’d like to include TokenScript and extend your token functionalities, please refer to [TokenScript](https://github.com/AlphaWallet/TokenScript). ### Add dApp to the “Discover dApps” section in the browser Submit a PR to the following file: https://github.com/AlphaWallet/alpha-wallet-ios/blob/master/AlphaWallet/Browser/ViewModel/Dapps.swift ### Replace API Keys API keys are stored in the file `AlphaWallet/Settings/Types/Constants+Credentials.swift`. You can replace the keys for your own build. Tell git to ignore changes to that file by running: ``` git update-index --assume-unchanged AlphaWallet/Settings/Types/Constants+Credentials.swift ``` Undo this with: ``` git update-index --no-assume-unchanged AlphaWallet/Settings/Types/Constants+Credentials.swift ``` ## How to Contribute You can submit feedback and report bugs as Github issues. Please be sure to include your operating system, device, version number, and steps to reproduce reported bugs. All contibutions welcome. ### Request or submit a feature :postbox: Would you like to request a feature? Please get in touch with us [Telegram](https://t.me/AlphaWalletGroup), [Twitter](https://twitter.com/AlphaWallet) or through our [community forums](https://community.tokenscript.org/). If you’d like to contribute code with a Pull Request, please make sure to follow code submission guidelines. ### Spread the word :hatched_chick: We want to connect businesses and consumers with the new digital economic infrastructure, where everyone can benefit from technology-enabled free markets. Help us spread the word: To learn more about us, please check our Blog or join the conversation: - [Blog](https://medium.com/alphawallet) - [Telegram](https://t.me/AlphaWalletGroup) - [Twitter](https://twitter.com/AlphaWallet) - [Facebook](https://www.facebook.com/AlphaWallet) - [LinkedIn](https://www.linkedin.com/company/alphawallet/) - [Community forum](https://community.tokenscript.org/) ## Contributors Thank you to all the contributors! You are awesome.