EVM ERC-721 Starter Contract for USDC
This is an example project to quickly get an NFT contract started. It is only a sample. You will very likely need to modify it to fit your needs. No warranty or guarantee of any sort is included with this SAMPLE software package.
Getting Started
Clone (or fork) this repository
git clone [email protected]:Crossmint/evm-721-starter-usdc.git
Install the dependencies
yarn install
Copy the .env file template
cp sample.env .env
Add required environment variables
GOERLI_RPC_URL=
ETHERSCAN_KEY=
PUBLIC_KEY=
PRIVATE_KEY=
-
You can get RPC urls from providers such as https://infura.io/, https://www.alchemy.com/, etc.
-
Get an Etherscan key (to verify your contract) https://info.etherscan.com/etherscan-developer-api-key/
-
Save your public key address to the .env file
-
Export private key from metamask or another wallet. You should not use the same wallet that you store mainnet assets in. Create a new development only metamask account to minimize the risk of storing your private key in plaintext files.
Initial adjustments
- You'll probably want to rename the contract. Change the filename in
/contracts/Evm721StarterUSDC.sol
to a name of your choosing. Then open that file and change the name there to. For example:
contract Evm721StarterUSDC is ERC721, AccessControl
changes to
contract MyNewName is ERC721, AccessControl
-
Then you'll also need to update the
/scripts/deploy.js
to reference this new file name. Select all instances ofEvm721StarterUSDC
and change toMyNewName
(or whatever you set the name to). -
You will probably want to change the deployed name to by updating the arguments in the constructor on line 26.
Deploy the contract to a testnet
npx hardhat run --network goerli scripts/deploy.js
Wait about a minute and then verify the Contract. (You'll need an etherscan API key) Note the last parameter is the goerli USDC token contract we are using for this example. You need to pass that as an argument when you verify. If you changed this value in the deploy.js script you'll need to change this command to match what you put there.
npx hardhat verify --network goerli "0x__CONTRACT_ADDR_FROM_PREVIOUS_STEP__" "0x98339D8C260052B7ad81c28c16C0b98420f2B46a"
Now you have a test contract deployed!
Next steps:
- add crossmint support! It's super easy! https://docs.crossmint.io/docs
- there is an example.html file in the /crossmint folder to get you started, just add your staging clientId
- you'll also need to deploy the actual metadata to IPFS