Skip to content

Build a community-owned ad inventory with DSponsor. As a media or a creator, set up your sponsorships tight to NFTs.

License

Notifications You must be signed in to change notification settings

siborg-ads/dsponsor-contracts

Repository files navigation

DSponsor contracts

DSponsor is a decentralized solution for sponsorship that provides funding in exchange for shares in visibility. It aligns the interests of both the sponsors and the sponsees.

This protocol allows anyone to create tokens for advertising spaces. These tokens can be purchased to acquire ad spaces on websites, apps, and more, for a specific time period, granting the exclusive right to place advertisements there.

logo DSponsor

Contracts Features

DSponsorAdmin.sol

This is the primary contract and serves as the gateway for frontends within the DSponsor ecosystem. It is compatible with any ERC721 contract, providing token owners with the exclusive right to advertise. It is also compatible with ERC4907 to allow token users the exclusive right to advertise.

The contract offers functions for creating and managing sponsorship tokens and advertising proposals. It includes a system for collecting minting fees for the protocol's treasury and a referral program to reward contributions to these fees.

  • A sponsee can define any number of sponsorship properties, which might include an audio URL, a website link, a logo, etc., based on their off-chain implementation.
  • Sponsors are allowed to submit data only for the sponsorship properties provided.
  • The sponsee may approve or reject the submitted data.
  • A sponsor can transfer a token to another address; the new owner will then be the only one able to set sponsorship data linked to the tokenId.
  • Includes a built-in Uniswap swap function to enable ERC20 payments from the native currency.

DSponsorNFT.sol

While any ERC721-compliant contract can be used with the DSponsor protocol, this specific NFT contract incorporates various standards and unique functionalities.

  • Allows pricing in ERC20 tokens and the native currency.
  • Includes rental capabilities (ERC4907).
  • Incorporates ERC2981 royalties.
  • Enables the contract owner to define a custom base URI for token metadata and a contract-level metadata URI.

DSponsorNFTPrivateSales.sol

Extends DSponsorNFT with mint restriction based on token holdings from a previous NFT collection.

DSponsorMarketplace.sol

This contract manages secondary sales and includes:

  • Direct Listing, English Auctions, and Offer mechanisms.
  • When a new bid is placed, the previous bidder is refunded and get also 5% of its bid amount.
  • Options for sale or rent.
  • Any ERC20 currency, swap built in if paid with the native coin.
  • Royalties, fee and protocol rewards mechanisms.

Deployment Addresses

Base Mainnet (Chain ID = 8453)

Mode Mainnet (Chain ID = 34443)

Sepolia Testnet (Chain ID = 11155111)

Abstract Testnet (Chain ID = 11124)

Development

Setting Up the Environment

  • Refer to the .env_example file for the necessary and optional environment variables.
  • Create your own .env file.
  • Install dependencies and compile the project:
# Set up environment variables for tests and deployment
cp .env_example .env

# Install project dependencies
npm install

# Compile contracts
npx hardhat compile

Running tests

Execute tests with gas reports as configured in hardhat.config.js:

npm run test 

To check test coverage:

npm run coverage

Security analysis

slither . --checklist  > slither-analysis.md

Deploy

# deploy in testnet
npm run deploy sepolia

# deploy in mainnet
npm run deploy base

About

Build a community-owned ad inventory with DSponsor. As a media or a creator, set up your sponsorships tight to NFTs.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published