Skip to content

Demo :: Ethereum smart-contract ("crowdsourced citizen toll enforcement") with multi-currency payment (ledgers.js) and serverless backend (Azure)

License

Notifications You must be signed in to change notification settings

overhide/ledgers.js-demo-serverless-dapp

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

50 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

overhide.io

A free and open-sourced ecosystem of widgets, a front-end library, and back-end services — to make addition of "logins" and "in-app-purchases" (IAP) to your app as banal as possible.


Gamified Citizen Toll Enforcement

Please watch the introductory video.

Quick Links

Please do read through the rest of this write-up to understand what's behind these links.

Quick Start

  1. visit demo app

OR

  1. sync
  2. npm install --no-optional
  3. npm run build
  4. npm run serve
  5. open http://localhost:8080 with browser (or whatever port is indicated on command line)

This hack serves as a demo of ledgers.js library. Please see use of oh$ in ./src/lib/CarPanelTopUp.jsx.


Introduction

This demo app was created as a submission to the Ethereal Hackathon (2019):

The demo app aims to "...simulate a toll payment for an automobile [using Azure and Ethereum contracts]."

This is a demo of several things:

  1. leveraging Microsoft's Azure "serverless" backend with ledger-based authorizations
    • no need to write own backend code
    • multi-currency support: fiat and crypto
  2. leveraging Microsoft's Azure "serverless" for Ethereum smart-contract interaction
    • smart-contract deployment via Azure
    • Azure Logic Apps and Functions with trusted off-chain functionality supporting the smart-contract
    • smart-contract state-transitions funneled through Azure
    • smart-contract used by many anonymous entities
      • cars
      • citizen bounty hunters

Background & Motivation

The usual example of vehicle toll payments we see (at least in North America) is a fee levied for distance-based linear segments of major highways, bridges, tunnels. These are easy infrastructure components to monetize in a centralized fashion as vehicles are funneled in, out, and gated.

I set out to innovate on the idea of toll-collection using decentralization and to not limit the solution to infrastructure that can be easily gated.

Consider a city that wants to levy a toll fee on car access to certain zones in the city. It's not feasible to funnel cars within a city: this is not how our cities are built and connected.

Although toll booths can certainly be setup as checkpoints within the city where it makes sense, our solution applies regardless of them being in the picture.

Consider our grand city below. The city has three zones:

  • Zone A: downtown (destination: city hall)
  • Zone B: midtown (destinations: hospital, library, office)
  • Zone C: uptown (destinations: school, factory)
  • not zoned: suburbs

There are different toll fees for vehicles present in each zone, no toll fees in the suburbs.

The toll fees can be checked anywhere in the zone:

  1. authorized (by city Traffic Authority) traffic checkpoints for moving traffic (toll booths)
  2. anywhere for static traffic (parked for at least a couple minutes)

Checkpoints (1) can be done centrally by the city using Azure's backend. Although all the Azure functionality is present in this source code, this isn't the main concern addressed in the demo and the rest of this write-up.

Static traffic (2) within a zone can be toll-checked by anyone; decentralized, incentivized, and pseudonymous.

System Values (Goals)

The participants in this system are:

  1. the car -- or driver by-proxy
  2. the citizen bounty hunter -- individual toll checking throughout city (not at checkpoint)
  3. the Traffic Authority -- representatives of the city doing enforcement (roaming + checkpoints)

The components of the system are:

  1. the Azure backend -- central verification and validation of permit payments, configuration, administration
  2. the Ethereum blockchain -- contract auditing zone permits, transgression reports, ticket issuance

With respect to the car (driver) the system:

  • expects an Ethereum address QR code visible on the driver side of the windshield (picked up with QR code scanner)
    • alternatively could be some near-field electronic tag on the driver side (picked up by proximity)
    • needs to be controlled from inside of car but available to the outside
    • car's Ethereum address not tied to the city or any authority: not registered
  • expects a SHA256 of the car's license plate or SHA256 of the car's VIN to be passed into the Ethereum contract
    • avoids people using the same address for multiple cars
  • expects that while the car is in a "toll" zone; the displayed Ethereum address has a valid permit in the city's Ethereum smart-contract
    • a valid paid-permit being a non-expired contract entry for the car's Ethereum address
    • each permit has a limited validity time-period
    • a permit is not a payment--just an expiry timestamp with metadata--no Ethereum based value transfer
  • expects that a valid permit is topped-up via dollars, ethers, or any other form of payment
    • top-up payments for permits are processed by the city's Azure backend cluster
  • provides enforcement accountability: a means to audit time, location, and existence of transgression reports and tickets
    • built into Ethereum contract
    • if no Ethereum event logged, no grounds for a ticket
    • Ethereum contract is a vessel for accountability, requires human judgement for resolution
  • provides convenience
    • no need to register with the city: perfect for out-of-town tourists
    • flexibility of toll fee payment currency
  • provides fees payment accountability

With respect to the citizen bounty hunter the system:

  • provides pseudonimity
    • they are Ethereum public addresses
    • stakes and bounties do involve value transfer on the Ethereum blockchain with this contract
  • provides decentralization
    • hunters interact with system outside of the city Traffic Authority's Azure backend
  • expects honesty
    • bounty hunters do risk a staked amount of ethers when reporting

With respect to the Traffic Authority the system:

  • provides easy onboarding and deployment
    • a new Ethereum contract can be provisioned for a new city via Microsoft Forms
    • same Azure workflows can apply to many different cities
    • Toll Enforcement as a Service (TEaaS)
  • provides inexpensive addition of currencies (Euros, BitCoin, DAI)
  • expects no collection of personally identifiable information by the city Traffic Authority
    • the city Traffic Authority knows entities paying for toll access (cars/drivers) only as ledger-based authorizations furnished pseudonymous public addresses
    • the city Traffic Authority doesn't know who the citizen bounty hunters are
      • Ethereum public addresses
      • stakes and bounties do involve value transfer on the Ethereum blockchain

Notes

1 the demo in this repo makes assumptions regarding the fees-schedule having configuration for dollars and ethers in three payment zones; for readability, this demo's fees-schedule parsing wasn't implemented in a generic way to require "no code adjustments"

2 as of this writing only dollars and ethers are abstracted via ledger-based authorizations, additional currencies can be easily added

Benefits

The city traffic authority works with their trusted secure workflows on Azure. They keep their costs down by not implementing and running their own backend infrastructure. The city can contract out for software development work focused on the functionality and not plumbing.

The Azure backend is a perfect place to validate toll top-up payments. Since the city accepts multiple currencies from toll-payers (via zone topup app), the top-up payments are not value-transfers within the system's Ethereum contract. The city keeps implementation, data-management, and liability costs down by leveraging ledger-based authorizations with Azure as the backend.

The city further saves on enforcement. The enforcement officers' job is highly automated through the Ethereum contract event log. The audit trail left by the Ethereum evnet log keeps toll violator litigation costs down to a minimum.

The drivers benefit by not having to register their cars--having to deal with any bureaucracy. Both locals and out-of-town tourists can just as quickly onboard with the zone topup app and drive in. No special hardware for the drivers to acquire--no transponders or costly and fickle GPS trackers--just a QR code in the right spot behind the windshield. Flexibility of payment (for tolls) furthers the city's mission to be accessible to all.

NOTE:

Cars not having a public Ethereum address (displaying a QR code) would be equivalent to not having a license plate: a costlier and riskier transgression.

Cars having a paid-for valid public Ethereum address in the contract; but the address having a mismatched SHA256 of the license plate or a mismatched SHA256 of VIN, would be equivalent to not having a license plate. This amounts to fraud (criminal offence).

Reporting of non-address bearing cars would be an extension of the workflows discussed here. For simplicity, such an extention is out of scope for this developer demo.

The car's location is not easily trackable with the toll-system. The driver's identity is not trackable with the toll-system. The toll-system is focused on tolls and cannot be accused otherwise and displease privacy advocates.

NOTE: if using dollars to pay via zone topup app the driver's (payer's) identity is known through Stripe but that's out-of-band to the toll system. The toll system only knows the driver as the topup Ethereum address from ledger-based authorizations.

Azure is in the critical path of top-ups, but not in the critical path of transgression checks and reports by citizen bounty hunters.

The bounty hunters are incentivized to participate for the rewards of finding toll-transgressors. The incentive is sufficient for the bounty hunters to onboard with Ethereum and use their own access to the blockchain.

Leveraging Ethereum means the bounty hunting booth app ecosystem is completely decoupled from the city's Azure APIs and can be ever richer with new features. Deployment and provisioning of toll-checking booths--booth apps--is a non-issue.

None of the participants know each other. Everyone is pseudonymous. But everything is auditable. The drivers are just a public address to the city. The citizen bounty hunters are just a public address to the drivers and the city.

Simulation / Demo

NOTE:

Your web3.js injecting wallet (e.g. MetaMask) must be connected to Rinkeby Ethereum testnet for the Toll Bounty App to work.

Car Top-Up App doesn't need the wallet: you can pay using dollars. However, if a wallet is connected to Rinkeby the payment for ethers option will be enabled.

To run the demo you can either:

The demo simulates three "apps" and the interaction between cars (drivers), citizen bounty hunters, and the city toll-enforcement officers:

The Car Top-Up App shows the Ethereum address of the car on the map. Refreshing the browser will recycle the address. This app has the Ethereum private-key for this address, since it simulates the car owning this address.

The car's Ethereum address is not the same as the Ethereum address used to pay for tolls. The car's Ethereum address identifies the car to the toll system while tolls are paid with the driver's (your) wallet Ethereum address. The car's Ethereum address is signed in the app (by the car) and validated in the Azure backend to track tolls paid.

The driver uses this app to pay toll fees for their desired destination zone for some some amount of time. For this simulation the toll fees expire after two minutes. The toll fee expiration timestamp is shown in the app.

Simply choose to pay with dollars or ethers and proceed to pay the toll.

Dollars Payment

Paying in dollars uses the test network from the overhide-ledger: which expects use of Stripe's test credit cards.

When asked for a test VISA simply use the following values:

  • Email: foo@bar.com
  • Verification Code (if shown): click the little back chevron (<) in the upper-left corner of modal to skip out
  • Card number: 4242 4242 4242 4242
  • MM/YY: 02/22 (any future date will do)
  • CVC: 222 (any number will do)

Once paid up (or not), click on a building in the city (the map) to "drive" to it.

Be aware that a concerned citizen bounty hunter is roaming the city. Click the little dude with a top-hat to make him run to wherever the car is (unless car is back in the suburbs).

Once the citizen bounty hunter is at the car, you can click the "click and report" button in the Toll Bounty App to interact with the Ethereum contract. Unlike the Car Top-Up App which uses Azure APIs to talk to Ethereum (see URLs in src/config.json), the Toll Bounty App goes directly to the Ethereum Rinkeby testnet as provided by your in-browser wallet.

If a bounty hunt was successful--i.e. the car had lapsed toll payment--the last application, the Enforcement App, will indicate a dispatching of the enforcement officer. This is done through Azure's Ethereum connector and Ethereum events.

NOTE:

For demo/simplicity, only the last NewReport event is tracked in a single dispatch file via an Azure Function (LastJson). Multiple people using this demo at the same time will possibly make your enforcement officer go to the wrong location and/or looking for the wrong car address. This is a funny, it's fine for this demo.

Beside a race condition in this simplistic dispatching mechanism, another way to avoid a ticket for violating toll-payment is to click another destination in the city and run away before the enforcement officer arrives.

Note that if the car runs away from a location before the enforcement officer arrives, not only does the citizen bounty hunter miss out on the reward from the ticket, the bounty hunter gives up their staked ethers for their mis-reporting: bounty hunters stake some ether when reporting a car. As such, the citizen bounty hunter must be somewhat confident the car will stay where it is for some time. The time is not unbounded; it's 30 seconds in the simulation. In the real world this would be location dependent, but enforcement officers on bike or foot should be able to get to reports on the order of minutes and ticket cars in a matter of seconds.

Implementation

The Car Top-Up App is simulated by the src/lib/CarPanel.jsx React component. It interacts with ledgers.js and Azure all within the component.

The Toll Bounty App is simulated by the src/lib/TollPanel.jsx React component. It interacts with the injected web3.js library.

The Enforcement App is simulated by the src/lib/OfficerPanel.jsx React component. It interacts with Azure.

All Azure Logic Apps are deployed as per the URLs in src/config.json. The Logic Apps can all be found in azure/logic-apps. The Logic Apps depend on Azure functions as deployed from azure/functions.

The Ethereum contract bringing everything together is in contract/.

The contract is instantiated by the azure/logic-apps/toll-enforce-new-admin-form-email.json Logic App. There is a Microsoft Form which--when ran, re-deploys the contract and configures all new fees schedules for the city. The details of the new fees schedule and the new Ethereum contract instance address are emailed to the email address specified in the Microsoft Form.

The configuration points emailed (as per above) need to be transcribed into src/config.json to take effect:

  • admin__FormId
  • ethereumContractAddress

As such, many different "demo" cities can use the same setup to run the toll collecting operation.

NOTE:

Running through the form yourself will not interfere with the deployed demo: it's already running as per current deployment.

The following figure models the workflows involved in the system:

Ledger-Based Authorizations

This demo uses the ledger-based authorizations concept for currency agnostic toll fee payments: dollars and ethers.

Ledger-based authorization is a very simple concept where fiat and crypto payments are available on a pseudonymous public ledger with each participant being able to prove ownership of their entry on this ledger (crypto PKI). More literature on the subject:

Using the overhide remuneration API in a backend and the ledgers.js library in a login-page a developer can provide authorization into different tiers of access with multiple currencies--hedging against new currencies with these abstractions. Future-proof code need only be written once. The relationship between the API and ledgers.js is summarized in the quick summary write-up

Azure Serverless Backend

In this demo we used the Azure serverless backend (Azure Logic Apps) to allow toll payment in multiple currencies. The backend implementation to verify the payment--regardless of currency--are two simple HTTP calls in the toll-enforce-topup Logic App.

The currency specific components in the above flow deal with the unit conversion from the human-readable fees-schedule (dollars and ethers) to the denomination that the API deals with (cents and wei).

First, before the two overhide API calls for authentication and authorization, we retrieve a token (using GET /token) based on an API key we registered earlier.

The two API calls are identical, they just go against different remuneration provider URLs; as configured with the fees-schedule.

The two API calls on Ethereum's Rinkeby testnet: https://rinkeby.ethereum.overhide.io/swagger.html.

The two API calls on overhide-ledger's test instance: https://test.ledger.overhide.io/swagger.html.

Login Page

The Car Top-Up App is the login page. The actual topup component fully resides in the src/lib/CarPanelTopUp.jsx React component.

This component's use of the oh$ import from ledgers.js are all the integration points for presenting ledger-based authorizations to the user.

A quick overview of the login-page ledgers.js is available in this video.

Read More

Please visit overhide.io and overhide-ledger for more.

Appendix :: Logic Apps (screenshots)

With an Azure Logic App we could poll periodically for new Ethereum events; but that costs money. Instead we activate polling for Ethereum events with an HTTP POST trigger. The HTTP POST is sent right before the contract's doReport call is invoked in src/lib/TollPanel.jsx. The Ethereum event polling expires after some time.

About

Demo :: Ethereum smart-contract ("crowdsourced citizen toll enforcement") with multi-currency payment (ledgers.js) and serverless backend (Azure)

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 81.3%
  • Solidity 18.3%
  • HTML 0.4%