Skip to content

Implementation of a tokenized restaurant rewards system using Solidity Smart Contracts

Notifications You must be signed in to change notification settings

al-gladkow/Snack-Coin-Rewards

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

81 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Snack Coin Rewards

Project Overview

Welcome to Snack Coin Rewards! This Streamlit-based application reinvents the way customers earn and store rewards using smart contracts.

Package Requirements and Versions

pip install x ; where 'x' is the package listed below:

  • python == 3.10.6
  • web3 == 5.31.1
  • streamlit == 1.13.0

References

  • OpenZeppelin: Importing implementations of standard smart contracts in order to create the deployer, menu, and SNAK token
  • smtp4dev: A dummy SMTP server to test email confirmation of orders

Files Navigation

  • Images: Directory containing images of menu itmes and sub directory of application examples
  • Solidity: Directory containing the the token contract file, the menu and deployer contracts file, and the associated JSON files of the required abi for both contracts
    • Solidity/SnackCoin.sol
    • Solidity/SnackMenu.sol
    • Solidity/abi-menu.json
    • Solidity/abi-token.json
  • SQL: Directory containing the SQL files creating the database framework and the associated schema and queries
    • SQL/create_db.sql
    • SQL/insert_data.sql
  • snack.db: Database containing the completed order information, including the Customers, Food, MenuItems, Menus, OrderItems, Orders, and Rewards
  • app.py: Python script containing the code that’s associated with the web interface of the application
  • notify.py: Python script containing the code that's associated with the local smtp email confirmation

Installation

  1. Clone Snack_Coin_Rewards repository to a local drive.
  2. Upload the smart contract files (SnackCoin.sol and SnackMenu.sol) to Remix IDE. Compile both contracts.
  3. Before deploying the contracts, make sure that “Ganache Provider” is selected as the environment and that the RPC Server from Ganache matches the one in Remix IDE.
  4. Add your mnemonic seed phrase (which Ganache provides as the RPC Server) to the SAMPLE.env file as WEB_PROVIDER_URI. Then rename the file to .env.
  5. Select an account from Ganache in Remix IDE to deploy the contracts.
  6. First, choose the SnackCoinMenuDeployer contract from the Contract pulldown and press DEPLOY.
  7. Open the Deployed Contracts, specifically the SNACKCOINMENUDEPLOYER, and call the snackcoin_menu_address button and the snackcoin_token_address button.
  8. Next, choose the SnackCoinMenu contract and paste the snackcoin_menu_address in the AT ADDRESS box under the DEPLOY.
    Menu Contract
  9. Scroll down and under the Deployed Contracts you will see the SNACKCOINMENU.
  10. Next, choose the SnackCoin contract and follow the same instructions in step 9, except paste the snackcoin_token_address in the AT ADDRESS box under the DEPLOY.
  11. Scroll down and under the Deployed Contracts and you will see the SNACKCOIN.
  12. Due to limitations, paste both the snackcoin_menu_address and the snackcoin_token_address in app.py.
  13. Save the updated app.py and run the file via Streamlit by running the following code in your bash or terminal:
    streamlit run app.py
    
  14. Optional: run smtp4dev in order to activate the confirmation email system
  15. Make sure to fill out the sidebar menu before cotinuing to the Snack Menu.

Usage

Once installed, you can use the contracts and the python script to run the Snack Coin Rewards interface through Streamlit. The user will be able to add menu items to their order, use eth to pay for the order, and earn SNAK tokens based on the total cost of their order. The owner of the deployed contracts are even able to withdraw eth that customers used to pay for their order. And because we used SQLite, we are also able to see the data behind each order through the snack.db.

Examples of Application

After the application is launched, the user/customer can fill out their information in the sidebar, and then click the "Add Customer" button before moving on to the Snack Menu.
Add Customer

The customer can then browse the menu items, and scroll down and must click the "Start an Order" button before continuing.
Start an Order

Once menu items are added to the cart, the total amount due in eth will display. The customer can then complete their order by clicking on the "Place Order" button and get a receipt and find out how many SNAK tokens they earned.
Place Order

Finally, the customer can check their SNAK token balance by going back to the sidebar and clicking on the "Check SNAK Balance" button.
SNAK Balance

As for the owner of the deployed contract, or the restaurant, on the sidebar under the "Admin Only" section, they are able to check the balance of the contract and withdraw any eth they were paid by the customers. However, only the owner of the contract can withdraw funds. If anyone else tries, an error will occur. If this was an actual app, we would not include the "Admin Only" section, but would include it on an owners-only protected page.
Owner Contract Blanace

Challenges, Limitations, and Future Developments

Unfortunately Streamlit's limitations did not allow us to create all of the features that we would have liked to make. And because the app was written in Python, we were not able to shift the app to a different framework, such as Django, in order to add more features.

Another challenge we faced was not being able to import environment variables such as the contract addresses, so those had to be hard-coded in the Python script after deploying the contracts in Remix IDE. We were also unable to index customers based on their wallets, and instead had to use customer_id as an index. Despite many attempts, we believe this is another Streamlit limitation. If we had more time, one option to adjust this would be to shift the app to a different framework with more options.

Additionally, another challenge with the app is that there is no way (using Streamlit) for multiple people to interact or order using the app at the same time. If multiple people try to use the app at the same time, the most recent order will combine with the next order that's attempting to complete. This also coincides with the issue that customers are not able to start a new order as a new customer unless the "Start New Order" button is selected. For example, if the page is refreshed, the order will continue with the last customer's order instead of starting new. Again, this seems to be a Streamlit limitation and if more time allowed, we would adjust and shift the app to a different framework that has more functionality.

If more time allowed, in addition to shifting the app to a different framework, our team would likely move the frontend and the backend to a server, and deploy the contract on the testnet.

Team Members

  1. Lara Barger
  2. Bryan Follenweider
  3. Alec Gladkowski
  4. Alejandro Palacios

About

Implementation of a tokenized restaurant rewards system using Solidity Smart Contracts

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 67.6%
  • Solidity 20.7%
  • PLpgSQL 11.6%
  • Shell 0.1%