This project is a modified version of aCallum's SafePi project and first and foremost, I want to give them a huge shoutout for the inspiration and work put forward to create this.
Crypto Tracker takes the SafePi project even further and creates support for other crypto currencies, currently supporting BTC, ETH, DOGE and of course, SAFEMOON!!
If you'd like to buy me a cup of coffee or if you want to unload some excess crypto burning a hole in your wallet 😂 -- you can thank me here coindrop.to/fauxvo
- Support for multiple wallets per coin
- A Javascript configuration panel which makes setting up of coins / wallets and configuration settings much easier
- Support for multiple types of displays including Adafruit's SSD1306 OLED, SH1106 OLED Displays and SSD1105 OLED Displays (currently untested)
- The ability to schedule when the application is being run either between a specific set of times (09:00 -> 17:00) or a schedule for a particular duration (20 minutes at the start of every hour)
- The ability to toggle through your tracked coins using Next / Prev buttons (currently only the Adafruit SSD1306 Display is supported)
- Support for rotating the screen
- Ability to toggle which screens are shown per coin (Balance, Current Price, Reflections)
- Ability to change the speed at which each screen is displayed for
- Support for showing total balance of all coins in all wallets
This project was built to support three main display drivers. I've done my best to automatically include the necessary drivers on install but you might have to do extra configuration if the display you'd like to use is not currently listed.
- Almost any RaspberryPi (with GPIO support):
- A SPI/I2C GPIO display:
- SD Card 8GB or higher -- image it with Raspberry Pi OS Lite
- Power Cable & Charger/Battery Bank
- Burn the OS in SD Card with Raspberry Pi Imager
- Connect the display to Pi GPIO Pins
- Plug in Power
- Install OS (Raspberry Pi OS Lite)
- Enable SPI & I2C in Raspi Config
- sudo raspi-config
- select Localization Options > Timezone (needed for scheduling functionality)
- select Interface Options > SPI > Yes (Only needed for SSH1105 Displays)
- select Interface Options > I2C > Yes
- Reboot the Pi
- sudo reboot now
The crypto tracker application does not perform any operations or manipulations on any of the coins or wallets that you share with the application. The only information made available is your wallet addresses which get queried to obtain the necessary balances. The 3rd party API keys also do no permit any operations of your coins and do not have any effect on manipulating your assets. The information provided is freely available, this application only returns the extremely small subsections of the blockchain which you are requesting. Like everything with cryptocurrency, you should not share your crypto balances with anyone and no information you provide ever leaves your raspberry pi device.
The crypto tracker app simply uses 3rd party apis to get total coin values for the wallet addresses you provide. These values are then compared against the Tether stablecoin (USDT) to determine the approximate value of the total number of coins within the wallets provided. If the user selects a currency other than USD, the Currency Converter API is used to convert that USD amount into the appropriate other currency.
The app then cycles through all of the coins provided and repeats the process. In addition to simply getting the latest values of the wallets from the blockchain APIs, the previous wallet balances are also stored in the system. The balance screen simply displays the change from the previous balances to the current balance.
In the case of coins with reflections like Safemoon, the application is not calculating reflections per say, just displaying the difference between two balances (the original balance upon application start and the current balance) which when using an exchange like Pancake Swap, will most likely show a new balance that is higher than the last time it was queried and you will see the growth your wallet has made.
In order to get the latest information used by the crypto tracker application, use of 3rd party APIs are required. Before running the installation & configuration sections, it would be handy to have these API keys and wallet addresses already available so that you can just copy and paste the information into the configuration application
-
- Used for converting coins to different currencies
-
- Necessary for obtaining token counts for SAFEMOON
-
- Necessary for obtaining token counts for ETH
-
If you do not plan on tracking ETH or SAFEMOON, you do not need to get API keys for these services.
-
Log in to your Raspberry PI
-
Execute the installation script in order to get the correct packages and repos
wget -O - https://raw.githubusercontent.com/fauxvo/crypto-tracker/master/installDependencies.sh | bash
-
Follow the necessary prompts and reboot the PI --- (if you selected to run the application on boot, you'll see an error in the terminal, this can be ignored until you setup the configuration file in the step below)
-
Setup the necessary configuration file by executing
cd ~/crypto-tracker && npm run start
-
Add the coins & wallets that you'd like the application to track
-
Add in the necessary crypto tracker settings required to configure the application
-
Save the configuration and restart the PI
You can always re-run the javascript configuration application if you'd like to make any changes to your application's settings. As well, you can also edit the raw output file from that application which is located at ~/crypto-tracker/cryptoTrackerConfig.json
Depending on if you wanted the application to run automatically or not on device startup, when executing the application, the necessary APIs are called and the application should be displaying information correctly on your display.
To run the application manually enter
cd ~/crypto-tracker/python && sudo python3 main.py
If you'd like to run the application manually in the background, enter
cd ~/crypto-tracker/python && sudo python3 main.py &
Since this is my first time extending a python application, it's inevitable that there are a few minor bugs which are currently outstanding
- I did my best to provide support for multiple screens and Raspberry Pi devices (Zero & Pi 4), other hardware hasn't been tested but should work.
- The application runs relatively smoothly but does crash on occasion (my guess is either hitting Raspi memory / temperature limits or API limits). Simply restarting the device or re-running the application should resolve this. If you have any ideas as to what is causing that, please provide a PR!
- Support for other crypto currencies (requests and/or PRs are welcomed!), especially coins being supported by the upcoming Safemoon wallet!
- Using other blockchain scanning APIs which do not require API keys
- Add button support for the SH1106 display
- Add thread support