Skip to content

Commit

Permalink
Merge remote-tracking branch 'origin'
Browse files Browse the repository at this point in the history
  • Loading branch information
PieWol committed Nov 22, 2024
2 parents 8d623f6 + f463964 commit 99e466d
Show file tree
Hide file tree
Showing 22 changed files with 1,642 additions and 40 deletions.
6 changes: 3 additions & 3 deletions .github/workflows/application_accepted.yml
Original file line number Diff line number Diff line change
Expand Up @@ -111,11 +111,11 @@ jobs:
Congratulations and welcome to the Web3 Foundation Grants Program! Please refer to our
[Milestone Delivery repository](/~https://github.com/w3f/Grant-Milestone-Delivery/) for
instructions on how to submit milestones and invoices, our
[FAQ](https://github.com/w3f/Grants-Program/blob/master/docs/faq.md) for frequently asked questions and the
[support section of our README](https://github.com/w3f/Grants-Program/blob/master/README.md#support)
[FAQ](https://grants.web3.foundation/docs/faq) for frequently asked questions and the
[support section on our website](https://grants.web3.foundation/docs/Introduction/support)
for more ways to find answers to your questions. <br/><br/>
Before you start, take a moment to read through our
[announcement guidelines](https://github.com/w3f/Grants-Program/blob/master/docs/Support%20Docs/announcement-guidelines.md)
[announcement guidelines](https://grants.web3.foundation/docs/Support%20Docs/announcement-guidelines)
for all communications related to the grant or make them known to the right person in your organisation.
In particular, please <b>don't announce the grant publicly before at least the first milestone of your
project has been approved.</b> At that point or shortly before, you can get in touch with us at
Expand Down
1 change: 0 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -278,7 +278,6 @@ flowchart LR

The treasury is a pot of on-chain funds collected through transaction fees, slashing, staking inefficiencies, etc. The funds held in the treasury can be spent on spending proposals. Both [Polkadot](https://polkadot.network/) and [Kusama](https://kusama.network/) offer everyone the opportunity to apply for funding via the treasury. See:

- [Treasury](https://polkadot.network/treasury/)
- [Treasury Bounties](https://polkadot.subsquare.io/treasury/bounties)
- [Polkadot Treasury Guide](https://docs.google.com/document/d/1IZykdp2cyQavcRyZd_dgNj5DcgxgZR6kAqGdcNARu1w)
- [Kusama Treasury Guide](https://docs.google.com/document/d/1p3UQUjph5t8TVaWnTkfrI5mE-BABnM9Xvtuhdlhl6JE)
Expand Down
273 changes: 273 additions & 0 deletions applications/NeuroZK.md

Large diffs are not rendered by default.

159 changes: 159 additions & 0 deletions applications/bison.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,159 @@
**Bison**
================================

- **Team Name:** Tuguldur Baigalmaa
- **Payment Address:** 14AZk92CKjovm4tDvzE9XsjGz3HNeeV2tmnbYitAqyweWoRp (UDSC - Asset Hub), 14AZk92CKjovm4tDvzE9XsjGz3HNeeV2tmnbYitAqyweWoRp (DOT - Polkadot)
- **[Level](/~https://github.com/w3f/Grants-Program/tree/master#level_slider-levels):** 2

Project Overview :page\_facing\_up:
-----------------------------------

### Overview

**Tagline:** A streamlined developer tool for Solidity smart contract deployment and testing on Polkadot.

**Brief Description:**
Bison is a developer tool designed to onboard Solidity developers into the Polkadot ecosystem by adapting the **Foundry** suite. The primary focus will be on:

* **Forge**: A testing framework customized to support Solidity smart contracts on Polkadot, compiling to **WASM** and **PolkaVM** via **Solang** and **Revive** compilers.
* **Mint**: A new tool using **subxt** to replace Cast, providing an interface for interacting with smart contracts, sending transactions, and querying chain data.

The tool will allow Solidity developers to continue using familiar workflows for building and testing smart contracts, while also handling deployment to Polkadot chains via **pallet-contracts**. Future iterations will expand towards deeper JAM protocol support, but this scope will focus on Polkadot integration.

**Relation to Substrate/Polkadot/Kusama**:
Bison leverages Polkadot’s Substrate framework for smart contract deployment via **pallet-contracts**. It integrates **subxt** for transaction handling and contract interaction, enabling developers to transition from Ethereum-based tooling to Polkadot seamlessly.

**Why We Are Interested**:
As one of the teams working on the development of the JAM protocol, our team saw a need for smart contract tooling for PolkaVM targets.
Although the existing tooling, foundry can be used as-is for EVM compatible parachains that support the RPC endpoints, this is not the case
for future smart contract development that target PolkaVM. Our team is passionate about building tools that ease the transition for Solidity developers to explore Polkadot’s multi-chain ecosystem. By leveraging Foundry and customizing it for Polkadot, we aim to make this process as smooth and familiar as possible for developers.

Project Details
---------------

### Technology Stack:

* **[Foundry](/~https://github.com/foundry-rs/foundry)**: Core testing framework for Solidity (customized for building and deploying on Polkadot).
* **[Solang](/~https://github.com/hyperledger-solang/solang)**: Solidity to WASM compiler.
* **[Revive](/~https://github.com/paritytech/revive/)**: Solidity to PolkaVM compiler.
* **[subxt](/~https://github.com/paritytech/subxt)**: Substrate interaction library for **Mint** (replacing Cast).
* **Rust**: For subxt and Polkadot-specific tooling development.

### Deliverables:

1. **Customized Foundry Toolchain**:
* Integrates Solang and Revive compilers for WASM and PolkaVM.
* Deploy contracts using subxt via Polkadot's **pallet-contracts**.
2. **Mint Tool**:
* Replaces Cast with a subxt-powered tool for interacting with smart contracts.
3. **Documentation Website**:
* A website offering detailed documentation, examples, and guides for Solidity developers on Polkadot.

### What the project is _not_:

* The project does not include JAM protocol integration at this stage.
* It will not include Anvil or Chisel customization in this phase.

### Ecosystem Fit:

**Target Audience**:
Solidity developers, dApp developers, smart contract auditors, and Polkadot parachain developers looking for a Solidity-native toolchain for Polkadot.

**Needs Addressed**:
Bison will address the need for Ethereum developers to interact with Polkadot using familiar tools, facilitating easy migration and development on Polkadot chains.

**Similar Projects**:
While other projects focus on native smart contract development for Polkadot (like ink!), Bison focuses on **Solidity** developers and provides familiar tooling to interact with the Polkadot ecosystem.

## Team
### Team members

- Name of team leader: Tuguldur Baigalmaa
- Names of team members: Tuguldur Baigalmaa

### Contact

- **Contact Name:** Tuguldur Baigalmaa
- **Contact Email:** tgldr0511@gmail.com
- **Website:** https://philoniare.com/about

### Legal Structure

- **Registered Address:** None
- **Registered Legal Entity:** None

### Team's experience

I have been a web2 developer for 7 years, web3 Rust developer for over 3 years and have developed unique expertise in
both Python and Rust. I have previously worked on a project to create a wrapper library for subxt and familiar with its
use cases and functionality.

### Team Code Repos

/~https://github.com/philoniare/pba-final-project

/~https://github.com/philoniare/subxtpy

### Team LinkedIn Profiles (if available)

- https://linkedin.com/in/tuguldurb

Development Roadmap :nut\_and\_bolt:
------------------------------------

### Overview

* **Total Estimated Duration:** 3 months
* **Full-Time Equivalent (FTE):** 2 FTE
* **Total Costs:** 30,000 USD
* **DOT %:** 50%

### Milestone 1 — Forge Customization for Polkadot

* **Estimated duration:** 1 month
* **FTE:** 1.5
* **Costs:** 10,000 USD


| Number | Deliverable | Specification |
|--------:|-------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| **0a.** | License | Apache 2.0 |
| **0b.** | Documentation | Provide inline documentation and a tutorial on how to compile Solidity contracts using Solang or Revive for Polkadot. |
| **0c.** | Testing and Testing Guide | Unit tests for Forge’s functionality on Polkadot’s pallet-contracts. |
| **0d.** | Docker | A Dockerfile for easy setup and testing of the tool. |
| 1. | Forge Customization | Customize Forge to compile Solidity contracts to WASM or PolkaVM via Solang or Revive, and deploy using subxt to call the pallet-contracts. |

### Milestone 2 — Mint Tool (Replacing Cast)

* **Estimated duration:** 1.5 months
* **FTE:** 1.5
* **Costs:** 16,000 USD


| Number | Deliverable | Specification |
|--------:|---------------------------| ------------- |
| **0a.** | License | Apache 2.0 |
| **0b.** | Documentation | User guide on using Mint (Cast replacement) to interact with Polkadot contracts. |
| **0c.** | Testing and Testing Guide | Tests for Mint’s ability to interact with Polkadot contracts using subxt.|
| 1. | Mint Tool | Develop the Mint tool using subxt to replace Cast, supporting contract interaction, transaction sending, and querying chain data. |

### Milestone 3 — Documentation Website

* **Estimated duration:** 0.5 month
* **FTE:** 1
* **Costs:** 4,000 USD

| Number | Deliverable | Specification |
|--------:|---------------------------| ------------- |
| **0a.** | License | Apache 2.0 |
| 1. | Documentation Website | Build a website containing complete guides, tutorials, and example projects for Solidity developers on Polkadot. |

Future Plans
------------

After this phase, the tool will be extended to fully support the JAM protocol, including its in-core execution model. Our goal is to establish Bison as a standard Solidity toolkit for Polkadot and JAM.

Additional Information :heavy\_plus\_sign:
------------------------------------------

We learned about the Web3 Foundation Grants Program through Polkadot developer community discussions and are eager to contribute by building tools that simplify Solidity development for Polkadot chains.
Loading

0 comments on commit 99e466d

Please sign in to comment.