Skip to content

Latest commit

 

History

History
209 lines (149 loc) · 9.36 KB

README.md

File metadata and controls

209 lines (149 loc) · 9.36 KB

Readme

Summary

The DCLBillboard system is a decentralised marketing system that allows users to rent advertising space on billboards within the Decentraland Game. Users pay with Ethereum to rent billboards on a daily basis.

Features

  • Delivery system is fully decentralise utilising the Ethereum block chain and IPFS.
  • Tightly integrated with Metamask.
  • Users can upload banners and store information on the blockchain .
  • Land owners can deploy billboards and make available for lease.
  • Land owners can specify daily lease rate for billboards.
  • Customers can self schedule advertising flights choosing available billboards given a data range.
  • Customers pay for the lease directly in Eth when confirming the scheduled banner advertisement, billboard and number of days.
  • Administrator has approval over transactions.
  • Administrator can transfer funds collected into a personal wallet.

Concepts

  • Banner - Any image that can be displayed on a billboard. The same image can be used many times.
  • IPFS - InterPlanetary File System - This is where banner images are stored. Currently accessed via the Infura API.
  • Billboard - Represents a Smart Item which can be targeted for a banner. Each one should have a unique TargetId for banner delivery. Descriptions, Parcel, and Location are optional attributes to manage billboards for later use. The Billboard's rate is in Finney per day which equates to 1/1000 of an Eth. Given the current cost of Eth this unit seems to be the most appropriate.
  • Flight - A flight is a match between a banner and a billboard. It is the creation of the advertisement run for a given rate over a set period of time. Flights are approved by the administrator before they can run. Scheduling a flight costs Eth to prepay for the total run.
  • Admin - Special user with full privileges, based on their Eth address. By default, this is the address used to deploy the DCLBillboard Smart Contract,

Architecture

DCLBillboard contract

The DCLBillboard contract holds the information for the system. This includes:

  • Permissions - The addressed used to deploy the contract is automatically the administrator of the system. Other administrator addresses may be added and removed. See the OpenZeppelin documentation for more information on Ownership and Role-Based Access Control.
  • Banners, Billboards, and Flight objects
  • Payments from users who have schedule Flights.

DCLBillboard Management System

The management system is written in Node.js and React. It is not distributed; however all state is managed by the DCLBillboard contract. Therefore, the system can be hosted anywhere, have multiple instances or be moved without any impact on operations.

Metamask Integration

The system in integrated with Metamask. Whatever account is selected in Metamask, that account is used by the system. To verify both the account address and Jazzicon in Metamask is also displayed in the DCLBillboard Manager.

screenshot_99.png

Permissions / Security

Permissions and Security are completely based upon the Ethereum address selected in MetaMask. If the address has the Admin role in the DCLBillboard contract, then administrative functions will be displayed. Behind the scenes, any component marked "IsAdmin" in React, will only be rendered when the address has the "IsAdmin" role in the contract.

With Admin Address:

screenshot_100.png

With Non-Admin Address:

screenshot_101.png

Banner Manager

The Banner Manager is open to the public. Any user can upload a banner to the system. Each banner must be a valid image file and have a description. User will pay a small Eth fee to upload the banner to the contract. Once successful, the banner is copied to the IPFS.

screenshot_102.png

screenshot_103.png

Billboard Manager (Administrator Only)

Administrators can create any number of billboards. Each billboard should have a unique TargetId that will match with the DCL Smart Item. Description, Parcel and Realm are fields used purely for front end administration and have no other impact on the system. The rate field is used to calculate the total cost when this billboard is selected for a flight.

screenshot_104.png

screenshot_105.png

Flight Manager

Flight Manager joins an existing banner with an existing billboard over a period of time in whole days. Anyone can register a flight. This is the money maker! When scheduled, users must pay for the entire run of the flight in Eth. This is calculated by the billboard rate * the number of days of the flight. Dates that are already booked for the billboard are blocked out and not available for selection.

screenshot_106.png

screenshot_107.png

Admin

Currently, the Admin screen has two purposes. To withdraw funds from the DCLBillboard contract into the administrators wallet and to approve flights. Only approved flights will show up on the billboard asset in DCL. Flights can also be unapproved, however refunds are not automatic. See Un-approving Flights.

screenshot_108.png

DCL Delivery System

The DCL Delivery System is built around the DCL API and has no dependencies on the DCLBillboard Management System, other than having the DCLBillboard smart contract deployed. Any smart item using the Delivery System will listen to the contract for an Approved Flight event that matches the item's targetID. If an event happens for that billboard for the given dates, then the billboard will display the corresponding banner.

Config.ts

Within the source files for the DCL Delivery System is the config.ts file which contains the configuration information required by DCL to run billboards. These parameters are:

  • INFURA_URL : should be "https://ipfs.infura.io/ipfs/"
  • PROVIDER : Url for node provider, example: "http://127.0.0.1:8545"
  • CONTRACT_ADDRESS : Must contain the correct address for the DCLBillboard Contract after it is deployed, example: " 0xabfe99d4cf78e5e2823bccf02a6687face5d99cb"
  • STARTBLOCK = the begging block to look for ApprovedFlight events. The earlier the block, the longer it will take for the delivery system to start. Recommend it is the block after the DCLBillboard deployment. Example: " 0xb91deb892a285d833b21af137c70228fd6f2d91116a39159d5e124701fee7f71"

BillboardListener.ts

The BillboardListener.ts module contains the methods required to get banners from the DCLBillboard Contract. The only call required is getBanners(targetId: string). Where the targetId is the unique identifier for the billboard. BillboardListener.ts uses Config.ts to establish the connection with the Ethereum blockchain and uses the DCL libraries for all calls.

Smart Item code

The following snippet shows how to integrate the banner code into a DCL Smart Item:

// get current banner
let bannerImage = "";
const TARGET_ID = "dclbanner1";
const flightSummary = getBanners(TARGET_ID);
flightSummary.then((fs) => {
// @ts-ignore
  const nowDate = Date.now();
  fs.forEach(row => {
    if (row.startDate <= nowDate && row.endDate >= nowDate) {
      bannerImage = row.hash;
    }
  });
  // @ts-ignore
  script1.init(options);
  script1.spawn(
    imageBillboardBlack,
    {
      image:
        config.INFURA_URL + bannerImage
    },
    createChannel(channelId, imageBillboardBlack, channelBus)
  );
}

Results:

screenshot_109.png

Future Enhancements

Click-thru

The system has hooks already built for users to interact with banners using a click-thru url. However no functionality is implemented.

Banner Size Restriction

Currently, any banner can be uploaded into the system. This includes very large images and images that have aspect ratios not suitable to the billboard. Implementing a precheck before saving a banner for the suitability of a banner is a easy feature to implement.

Un-approving Flights

The approval system has two possible enhancements:

  • If a flight is not approved, or it is unapproved, then create a refund to the user. Currently, this must be handled manually.
  • Unapproved flights still block out the calendar for other banners. Instead, flights could have three states, waiting approval (which blocks the calendar), approved (which blocks the calendar and keeps the funds) and unapproved (which unblocks the calendar and issues a refund).

Expanding Smart Items

In the future, instead of having to put the getBanner code into the Smart Item and declaring the targetId in code, the targetID could be an attribute which is exposed in the Decentraland Builder. Then users will not need any code to deploy billboards only unique ids.

Listening to New Flights

When billboards are deployed, the getBanner method searches for all previously approved flights. In order to schedule more flights, the item must be redeployed. An enhancement would create an event listener which would response to newly approved flights and keep them in memory to rotate when the correct date arrives.