Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/limechain/stylus-toolkit
Building blocks for Arbitrum Stylus smart contract development
https://github.com/limechain/stylus-toolkit
arbitrum stylus toolkit web3
Last synced: about 1 month ago
JSON representation
Building blocks for Arbitrum Stylus smart contract development
- Host: GitHub
- URL: https://github.com/limechain/stylus-toolkit
- Owner: LimeChain
- License: mit
- Created: 2023-11-20T15:40:54.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-07-08T14:13:26.000Z (6 months ago)
- Last Synced: 2024-11-03T10:33:32.835Z (2 months ago)
- Topics: arbitrum, stylus, toolkit, web3
- Language: Rust
- Homepage:
- Size: 30.3 KB
- Stars: 0
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# stylus-toolkit
Building blocks for Stylus smart contract development## How to use
1. Create new project
```shell
cargo stylus new my-cool-project --minimal
```2. Import `stylus-toolkit` as dependency in the `Cargo.toml`
```toml
stylus-toolkit = { git = "https://github.com/LimeChain/stylus-toolkit.git", branch = "main" }
```3. Import the desired contracts into your source files
ERC20 Example
```rust
use stylus_toolkit::tokens::erc20::{Erc20, Erc20Params};struct MyParams;
impl Erc20Params for MyParams {
const NAME: &'static str = "Dummy ERC20 token";
const SYMBOL: &'static str = "DERC20";
const DECIMALS: u8 = 18;
}sol_storage! {
#[entrypoint]
struct DummyErc20 {
#[borrow] // Allows erc20 to access Dummy Erc20's storage and make calls
Erc20 erc20;
}
}
#[external]
#[inherit(Erc20)]
impl DummyrErc20 {}
```ED25519 Signature Verification
```rust
use stylus_toolkit::crypto::ed25519::ed25519_verify;sol_storage! {
#[entrypoint]
struct Ed25519Verify { }
}#[external]
impl Ed25519Verify {
pub fn verify(
&mut self,
msg: Bytes,
signature: Bytes,
public_key: FixedBytes<32>,
) -> Result<(bool), Vec> {
Ok(ed25519_verify(public_key, signature, msg))
}
}
```4. Build the project
```shell
cargo build --package my-cool-project --release
```5. Sanity check the source code for activation prior to deployment
```shell
cargo stylus check
```6. Deploy contracts
```shell
cargo stylus deploy -e $RPC --private-key $PK
```