Skip to content

Smart Contract to provide a probabilistic model for determining Proof of Location

Notifications You must be signed in to change notification settings

maryannxy/geo-probabilistic-proof-of-location

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Geo Probabilistic Proof of Location

logo

A. Proof Generation

  1. User visits verifying node $V_0$
  2. User signs message $sig_{user} = ECSign(latestBlockNum, latestBlockHash, UUID, K^{private}_{user})$
  3. $V_0$ randomly selects $k-1$ verifying nodes $[V_1..V_{k-1}]$
  4. $[V_0..V_{k-1}]$ signs ring signature $sig_{ring} = RingSign(sig_{user}, K^{private}{V_0}, K^{public}{[V_0..V_{k-1}]})$
  5. Proof $Pr = (sig_{user}, sig_{ring})$ is given to the user.
  6. User logs the proof via an Ethereum transaction at time $T_{log}​$.
  7. $Pr$ proves that there's a $\frac{1}{k}$ probability that the user visited $V_0$ at sometime between $latestBlockHash$ and $T_{log}$

B. Proof Verification

  1. Check that $ECRecover(keccak256(latestBlockNum, latestBlockHash, UUID), sig_{user}) == user.address$
  2. Check that $RingVerify(sig_{ring}, sig_{user}, K^{public}{[V_0..V{k-1}]})$

About

Smart Contract to provide a probabilistic model for determining Proof of Location

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • CoffeeScript 62.8%
  • HTML 18.7%
  • JavaScript 18.0%
  • CSS 0.5%