Giter Club home page Giter Club logo

starvingartistmint's Introduction

Starving Artist Mint

This is a non-production ready experimental implementation of 0xngmi proposal regarding Counterfactual Minting/Sponsored Minting found in this tweet

Motivations

The goal of Starving Artist Mint is to allow an artist to create a NFT collection by being sponsored through an initial buyer.

The goal is to give artists more autonomy and to not be reliant on Marketplace contracts like Opensea or Rarible.

Gas in this case is subsidized by the initial buyer who would deploy the NFT contract via a clone and mint the first NFT for themselves.

Flashbots relayers are used to help coordinate the sponsored transactions.

Todos and Findings

  1. Include a lazy minting functionality where an artist can sign something and allow someone else to mint for a fee. Right now subsequent mints are paid for by the artist.

  2. Include a signature verification on the StarvingArtistMintFactory to prevent theft by the first minter.

  3. Add additional payment logic on the Factory and Clone contract. There's no payment logic at the moment.

  4. Add ERC721Enumerable extension (optional as in eip721).

  5. Using Clones results in the contract creator being the Factory contract. Also you can't read and write Cloned contracts on etherscan atm.

  6. The Flashbot sponsor code requires the execution wallet (the wallet who isn't sponsoring the tx) to have sufficient eth to fund the transaction to be reimbursed later by the sponsor wallet. So it's not completely gas free. A Gas Station Network might be the alternative solution.

  7. It's possible to deploy Transparent Proxies

Goerli Deployments

StarvingArtistMint deployed to: 0x95e49076fdc6a1058F9d21910301A5f45e8642D9

StarvingArtistMintFactory deployed to: 0x0563EacF70D7030BFaB3a94437085838E65E1D47

Quickstart

  1. Run yarn to install dependencies

  2. Set up .env by copying .env.example. You will need to seed PRIVATE_KEY_1 with Goerli eth to test the contract on Goerli.

  3. Install hardhat

  4. Run npx hardhat compile to compile contracts.

  5. Run npx hardhat run scripts/deploy.js to deploy contracts. Include --network goerli to deploy on Goerli.

  6. Run npx hardhat run scripts/sponsor.js --network goerli to test with the flashbot provider on Goerli using the Factory Contract.

Advanced Sample Hardhat Project

This project demonstrates an advanced Hardhat use case, integrating other tools commonly used alongside Hardhat in the ecosystem.

The project comes with a sample contract, a test for that contract, a sample script that deploys that contract, and an example of a task implementation, which simply lists the available accounts. It also comes with a variety of other tools, preconfigured to work with the project code.

Try running some of the following tasks:

npx hardhat accounts
npx hardhat compile
npx hardhat clean
npx hardhat test
npx hardhat node
npx hardhat help
REPORT_GAS=true npx hardhat test
npx hardhat coverage
npx hardhat run scripts/deploy.js
node scripts/deploy.js
npx eslint '**/*.js'
npx eslint '**/*.js' --fix
npx prettier '**/*.{json,sol,md}' --check
npx prettier '**/*.{json,sol,md}' --write
npx solhint 'contracts/**/*.sol'
npx solhint 'contracts/**/*.sol' --fix

Etherscan verification

To try out Etherscan verification, you first need to deploy a contract to an Ethereum network that's supported by Etherscan, such as Ropsten.

In this project, copy the .env.example file to a file named .env, and then edit it to fill in the details. Enter your Etherscan API key, your Ropsten node URL (eg from Alchemy), and the private key of the account which will send the deployment transaction. With a valid .env file in place, first deploy your contract:

hardhat run --network ropsten scripts/deploy.js

Then, copy the deployment address and paste it in to replace DEPLOYED_CONTRACT_ADDRESS in this command:

npx hardhat verify --network ropsten DEPLOYED_CONTRACT_ADDRESS "Hello, Hardhat!"

starvingartistmint's People

Contributors

jseam2 avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.