-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
ae5d3a5
commit 203fbc3
Showing
12 changed files
with
40 additions
and
29 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,46 +1,57 @@ | ||
# Getting Started with Create React App | ||
# Cryptopasser | ||
data:image/s3,"s3://crabby-images/95161/951611455c50daef744b367703fe07ffc51e0935" alt="alt text" | ||
data:image/s3,"s3://crabby-images/b25c7/b25c7601135a835db759497b584ad151337cabc2" alt="alt text" | ||
data:image/s3,"s3://crabby-images/0d063/0d06347713dee52eb0672a828fa5853e5a3bff5c" alt="alt text" | ||
data:image/s3,"s3://crabby-images/e6394/e6394d212e1405656fdfd4d4ee9760a0597b0d38" alt="alt text" | ||
|
||
This project was bootstrapped with [Create React App](https://github.com/facebook/create-react-app). | ||
Cryptopasser is a mobile friendly web app to **issue, sign, store and verify** [EIP-4361 Sign-In with Ethereum](https://eips.ethereum.org/EIPS/eip-4361) authentication token. | ||
|
||
## Available Scripts | ||
Cryptopasser works similar to JWT web token. However, for signing and verifying, it uses Ethereum's [EIP-191](https://eips.ethereum.org/EIPS/eip-191), and for data communication, it uses an offline QR code. | ||
|
||
In the project directory, you can run: | ||
Two devices (signer and accesor) in an [air-gapped](https://en.wikipedia.org/wiki/Air_gap_%28networking%29) environment can share the access of a wallet from one account by creating a signed [EIP-4361](https://eips.ethereum.org/EIPS/eip-4361) standard authentication certificate. | ||
|
||
### `npm start` | ||
## Usage | ||
This can be useful for the following usage. | ||
|
||
Runs the app in the development mode.\ | ||
Open [http://localhost:3000](http://localhost:3000) to view it in the browser. | ||
Imagine you need to prove an ownership of a NFT to gain access to a certain event. You have a hardware wallet that has a valuable NFT. However, you don't want to import your hardware wallet into your mobile device for security issues. | ||
|
||
The page will reload if you make edits.\ | ||
You will also see any lint errors in the console. | ||
With Cryptopasser, you just simply sign the token, save the signed token as a QR code image onto your phone. The event organizer scan the QR code, and verify that 1) you've signed the auth token and 2) you hold ownership of a NFT. | ||
|
||
### `npm test` | ||
## Demo | ||
|
||
Launches the test runner in the interactive watch mode.\ | ||
See the section about [running tests](https://facebook.github.io/create-react-app/docs/running-tests) for more information. | ||
Fully working demo on [https://cryptopasser.netlify.app](https://cryptopasser.netlify.app) | ||
|
||
### `npm run build` | ||
## Security features | ||
|
||
Builds the app for production to the `build` folder.\ | ||
It correctly bundles React in production mode and optimizes the build for the best performance. | ||
- Tokens expire after expiration date | ||
- User can specify the specific chain id to make sure the token is only valid for a certain network. | ||
- [CSRF protection](https://en.wikipedia.org/wiki/Cross-site_request_forgery). The auth token is only valid on the same domain as the issuing domain. | ||
- It run offline. Internet is used only for fetching the NFT ownership | ||
|
||
The build is minified and the filenames include the hashes.\ | ||
Your app is ready to be deployed! | ||
## Features to implement | ||
|
||
See the section about [deployment](https://facebook.github.io/create-react-app/docs/deployment) for more information. | ||
- [ ] Add ERC20 token verfication mode | ||
- [ ] Grant access to a certain NFT or token only not all NFT/token owned by the user | ||
- [ ] Invalidate the token to prevent replay attacks (requires database to keep track of nonce) | ||
- [ ] Implement own indexer API to check the NFT ownership instead of calling Opensea API | ||
|
||
### `npm run eject` | ||
## Run locally | ||
`npm start` | ||
|
||
**Note: this is a one-way operation. Once you `eject`, you can’t go back!** | ||
## Pages | ||
### `/issue` (Issue and Sign) | ||
data:image/s3,"s3://crabby-images/b25c7/b25c7601135a835db759497b584ad151337cabc2" alt="alt text" | ||
data:image/s3,"s3://crabby-images/b0458/b0458bd9433208ad63950a002d1cc2bfb5e7e71c" alt="alt text" | ||
data:image/s3,"s3://crabby-images/f4f37/f4f372bcf651b631914bf97905272801eaf9b22a" alt="alt text" | ||
|
||
If you aren’t satisfied with the build tool and configuration choices, you can `eject` at any time. This command will remove the single build dependency from your project. | ||
## `/view` (View and Save) | ||
data:image/s3,"s3://crabby-images/26b0c/26b0cca5a198dfe41e359b08d6793c604262afa0" alt="alt text" | ||
data:image/s3,"s3://crabby-images/fdb4c/fdb4c59dddb9ba2b68d404aa6a5148fde0d856e9" alt="alt text" | ||
data:image/s3,"s3://crabby-images/0d063/0d06347713dee52eb0672a828fa5853e5a3bff5c" alt="alt text" | ||
|
||
Instead, it will copy all the configuration files and the transitive dependencies (webpack, Babel, ESLint, etc) right into your project so you have full control over them. All of the commands except `eject` will still work, but they will point to the copied scripts so you can tweak them. At this point you’re on your own. | ||
## `/verify` (Verify) | ||
data:image/s3,"s3://crabby-images/3dbaa/3dbaaef38d19ca43fb8fc43090ec67cd70ee68c9" alt="alt text" | ||
data:image/s3,"s3://crabby-images/a9e00/a9e0031477246745a2acfd0b8021c3dde3f192cc" alt="alt text" | ||
data:image/s3,"s3://crabby-images/95161/951611455c50daef744b367703fe07ffc51e0935" alt="alt text" | ||
data:image/s3,"s3://crabby-images/b3dd7/b3dd79dfb7e7cd765a0cf3470cf6832f68c243c8" alt="alt text" | ||
|
||
You don’t have to ever use `eject`. The curated feature set is suitable for small and middle deployments, and you shouldn’t feel obligated to use this feature. However we understand that this tool wouldn’t be useful if you couldn’t customize it when you are ready for it. | ||
|
||
## Learn More | ||
|
||
You can learn more in the [Create React App documentation](https://facebook.github.io/create-react-app/docs/getting-started). | ||
|
||
To learn React, check out the [React documentation](https://reactjs.org/). |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.