Skip to content

Latest commit

 

History

History
75 lines (46 loc) · 5.29 KB

README.md

File metadata and controls

75 lines (46 loc) · 5.29 KB

Mist Protocol 🌫️

Welcome to Mist! This project expands the concept of stealth addresses for private transactions on Ethereum, inspired by the Base SAP paper and incorporating support for ERC721 tokens alongside ETH and ERC20 tokens. Mist also integrates MetaMask Snaps for secure key storage and user notifications, promoting interoperability between different protocols supporting stealth addresses.

📜 Contracts are deployed and verified on the following networks:

What is Mist? 🌟

Mist is a privacy-focused protocol that enables stealth addresses for private transactions on Ethereum. It leverages the foundational ideas from the Base SAP paper and extends them to include ERC721 tokens. Mist enhances security and user experience by using MetaMask Snaps to store spending/viewing keys in encrypted data storage and to send notifications to users. It utilizes elliptic curve cryptography to achieve this level of security and privacy.

Key Features 🚀

  • Stealth Addresses: Enable private transactions by generating one-time addresses that can only be spent by the intended recipient.
  • Support for Multiple Tokens: Mist supports ETH, ERC20, and ERC721 tokens, making it versatile for various use cases.
  • MetaMask Snaps Integration: Store keys securely within MetaMask and receive notifications for transactions and key updates.
  • Interoperability: Designed to work seamlessly with different protocols supporting stealth addresses, inspired by the concept from the Base SAP paper.

Inspiration and Background 📚

Mist is inspired by the innovative concepts introduced in the Base SAP paper and builds upon them by implementing standards like ERC-5564 and ERC-6538 to enhance privacy and interoperability. While Umbra Protocol has implemented similar stealth address functionality, Mist extends this by supporting ERC721 tokens and integrating MetaMask Snaps for improved user experience.

How It Works ⚙️

  1. Generating Stealth Addresses: Mist generates a new, unique address for each transaction, ensuring privacy for both the sender and recipient.
  2. Token Support: Mist supports transactions with ETH, ERC20, and ERC721 tokens, making it suitable for a wide range of applications.
  3. Key Storage: Using MetaMask Snaps, Mist stores spending and viewing keys in an encrypted format within MetaMask, providing an additional layer of security.
  4. Notifications: Users receive notifications via MetaMask Snaps for transaction confirmations and key updates, ensuring they stay informed.

Getting Started 🚀

To start using Mist, follow these steps:

  1. Install MetaMask: Ensure you have MetaMask Flask installed in your browser.
  2. Enable Snaps: Follow the instructions to enable MetaMask Snaps for secure key storage and notifications.
  3. Interact with Mist: Use the Mist interface to generate stealth addresses, send and receive tokens, and manage your transactions securely.

Contributing 🤝

We welcome contributions from the community! If you're interested in contributing to Mist, please check out our project and open a pull request.

License 📄

Mist is released under the MIT License. Feel free to use, modify, and distribute it as per the terms of the license.


Thank you for using Mist! 🌫️