Skip to content

Latest commit

 

History

History
223 lines (204 loc) · 7.08 KB

RaribleDropTokenDeployment.md

File metadata and controls

223 lines (204 loc) · 7.08 KB

Token Deployment

An example script to deploy a token contract is located at DeployAndConfigureExampleToken.s.sol. It can be run with forge script script/DeployAndConfigureExampleToken.s.sol --rpc-url ${RPC_URL} --broadcast -vvvv --private-key ${PK} --etherscan-api-key ${ETHERSCAN_API_KEY} --verify --retries 10

ERC721RaribleDrop

ERC721RaribleDrop contains only an Owner role (assigned to the deployer of the contract) that has authorization for all methods.

To split responsibilities with an Administrator role who can set fee parameters, use ERC721PartnerRaribleDrop.

  1. Deploy src/ERC721RaribleDrop.sol with constructor args string name, string symbol, address[] allowedRaribleDrop
    1. e.g. forge create --rpc-url ${RPC_URL} src/ERC721RaribleDrop.sol:ERC721RaribleDrop --constructor-args "TokenTest1" "TEST1" \[${RARIBLEDROP_ADDRESS}\] --private-key ${PK} --etherscan-api-key ${ETHERSCAN_API_KEY} --verify
  2. Set the token max supply with token.setMaxSupply()
  3. Set the creator payout address with token.updateCreatorPayoutAddress()
  4. Set the contract URI with token.setContractURI()
  5. Set the base URI with token.setBaseURI()
  6. Optionally:
    1. Set the provenance hash for random metadata reveals with token.setProvenanceHash()
      1. Must be set before first token is minted
    2. Set an allow list drop stage with token.updateAllowList()
    3. Set a token gated drop stage with token.updateTokenGatedDrop()
    4. Add server-side signers with token.updateSignedMintValidationParams()
  7. Set a public drop stage with token.updatePublicDrop()
  8. Set the drop URI with token.setDropURI()
    1. See Format of Drop URI

ERC721PartnerRaribleDrop

ERC721PartnerRaribleDrop is a token contract designed to split responsibilities between an Owner and Administrator.

  1. Deploy src/ERC721PartnerRaribleDrop.sol with constructor args string name, string symbol, address administrator, address[] allowedRaribleDrop
    1. e.g. forge create --rpc-url ${RPC_URL} src/ERC721PartnerRaribleDrop.sol:ERC721PartnerRaribleDrop --constructor-args "TokenTest1" "TEST1" ${ADMIN_ADDRESS} \[${RARIBLEDROP_ADDRESS}\] --private-key ${PK} --etherscan-api-key ${ETHERSCAN_API_KEY} --verify
  2. Required to be sent by token Owner:
    1. Set the token max supply with token.setMaxSupply()
    2. Set the creator payout address with token.updateCreatorPayoutAddress()
    3. Set the contract URI with token.setContractURI()
    4. Set the base URI with token.setBaseURI()
  3. Can be sent by token Owner or Administrator:
    1. Optionally:
      1. Set the provenance hash for random metadata reveals with token.setProvenanceHash()
        1. Must be set before first token is minted
        2. Instructions for generating the provenance hash here
      2. Set an allow list drop stage with token.updateAllowList()
        1. See Format of Allow List URI
      3. Set a token gated drop stage with token.updateTokenGatedDrop()
        1. Administrator must first initialize with feeBps
      4. Set a public drop stage with token.updatePublicDrop()
        1. Administrator must first initialize with feeBps with token.updatePublicDrop()
        2. If restrictFeeRecipients is set to true, Administrator must set allowed fee recipients with token.updateAllowedFeeRecipient()
    2. Set the drop URI with token.setDropURI()
      1. See Format of Drop URI

Specifications

Format of Drop URI

Follows the pattern of tokenURI — could be either on-chain data blob or external URI (IPFS) — that contains the metadata related to the drop and corresponding drop stages.

Example

{
  "name": "An Example Drop",
  "description": "This is the description for this example drop.",
  "stages": [
    {
      "name": "My Public Stage",
      "description": "My public stage description.",
      "uuid": "ecae5ad4-fa40-4e79-856b-ec304c3ea5d4",
      "isPublic": true,
      "mintPrice": 1000000000000000000,
      "maxTotalMintableByWallet": 50,
      "maxTokenSupplyForStage": 5000,
      "startTime": 1659045594,
      "endTime": 1659045594,
      "feeBps": 500
    },
    {
      "name": "My Private Allow List Stage",
      "description": "My private stage description",
      "uuid": "07e7a791-42ad-46e6-968a-564acf0c06dc",
      "isPublic": false,
      "mintPrice": 1000000000000000,
      "maxTotalMintableByWallet": 5,
      "maxTokenSupplyForStage": 1000,
      "startTime": 1659043594,
      "endTime": 1659044594,
      "feeBps": 500
    }
  ]
}

JSON Schema

{
  "$schema": "http://json-schema.org/draft-04/schema#",
  "type": "object",
  "properties": {
    "name": {
      "type": "string"
    },
    "description": {
      "type": "string"
    },
    "stages": {
      "type": "array",
      "items": {
        "type": "object",
        "properties": {
          "name": {
            "type": "string"
          },
          "description": {
            "type": "string"
          },
          "uuid": {
            "type": "string"
          },
          "isPublic": {
            "type": "boolean"
          },
          "allowListURI": {
            "type": "string"
          },
          "allowedTokenAddresses": {
            "type": "array",
            "items": {
              "type": "string"
            }
          },
          "mintPrice": {
            "type": "integer"
          },
          "maxTotalMintableByWallet": {
            "type": "integer"
          },
          "maxTokenSupplyForStage": {
            "type": "integer"
          },
          "startTime": {
            "type": "integer"
          },
          "endTime": {
            "type": "integer"
          },
          "feeBps": {
            "type": "integer"
          }
        }
      }
    }
  }
}

Example

[
  {
    "address": "0xf0E16c071E2cd421974dCb76d9af4DeDB578E059",
    "mintPrice": 1000000000000000000,
    "maxTotalMintableByWallet": 10,
    "startTime": 1659045594,
    "endTime": 1659045594,
    "dropStageIndex": 1,
    "maxTokenSupplyForStage": 1000,
    "feeBps": 1000,
    "restrictFeeRecipients": true
  },
  {
    "address": "0x829bd824b016326a401d083b33d092293333a830",
    "mintPrice": 1000000000000000000,
    "maxTotalMintableByWallet": 5,
    "startTime": 1659045594,
    "endTime": 1659045594,
    "dropStageIndex": 2,
    "maxTokenSupplyForStage": 500,
    "feeBps": 1250,
    "restrictFeeRecipients": false
  }
]

JSON Schema

{
  "$schema": "http://json-schema.org/draft-04/schema#",
  "type": "object",
  "properties": {
    "address": {
      "type": "string"
    },
    "mintPrice": {
      "type": "integer"
    },
    "maxTotalMintableByWallet": {
      "type": "integer"
    },
    "startTime": {
      "type": "integer"
    },
    "endTime": {
      "type": "integer"
    },
    "dropStageIndex": {
      "type": "integer"
    },
    "maxTokenSupplyForStage": {
      "type": "integer"
    },
    "feeBps": {
      "type": "integer"
    },
    "restrictFeeRecipients": {
      "type": "boolean"
    }
  }
}