Skip to content

monterman/rarity-analyzer

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OpenRarity.xyz - NFT Rarities Analyzer

https://openrarity.xyz

Features

  • Website
  • Discord Bot
  • Serverless (Netlify)

Website

https://openrarity.xyz

  • Create React App
  • Netlify Continuous Deployment from Github
  • Project Themes
  • Lazy Loading for Great Performance

  • Small Screen Support

  • Large Screen Support

Nft Metadata

  • Analyzed with node scripts using GitHub Actions (or locally)
  • Easy 1,2,3 to add a project
    • Fork GitHub Repo
    • Add 2 metadata files:
      • ./data/[project].json
      • ./data/[project].project.json
    • Submit a PR
      • Github actions will automatically build the rarity files
      • Netlify Continous Deployment will automatically generate a preview

Rarity Analysis

NFT Rarity Card

  • Easily see Rank and Score
  • OpenSea Last Sell, List Price, and Link
  • NFT Preview
  • Attribute Values with Integrated Bar Graph
  • Quickly visualize and compare NFTs

Trait Filters

  • Visualize Trait Rarity with integrated bar graphs
  • Preview the number of NFTs remaining after selecting each trait
  • Drill down to specific traits

  • Filter applies to all views
    • NFT Cards
    • Trait Waterfall
    • Rarest Trait Combinations

Trait Waterfall

  • See everything in one beautiful view
  • Rarest NFTs are the top rows
  • Common NFTs are the bottom rows
  • Traits are columns

  • Sort Traits by Rarity
    • Left is rare traits
    • Right is common traits

Rarest Trait Combinations (Sankey Diagram)

  • Explore the Rarest combinations of traits

Discord Bot

  • /openrarity projects

  • /openrarity project project-key:one-day-punks

  • /openrarity nft project-key:one-day-punks token-id:42
    • Even has a ascii bar graph!

Discord Application Commands Api

  • Discord Outgoing Webhooks

    • No running server costs
    • Using Netlify Functions
    • Continous Deployment from GitHub Repo
  • tl;dr - free (unless you get a ton of traffic somehow)

Clonable

  • Cloning is easy
  • Setup your own website with just your projects
  • But also submit those to be included in OpenRarity.xyz
  • GitHub PR allows you to easily submit metadata that you've added to your own fork

Introduction

This project is a submission for the PunkScape Hackathon #1.
The main purpose of this project is to provide an open source alternative to other paid closed source NFT rarity sites. Developers should be able to submit a project by either:

  1. PR request to the main branch to include their project or
  2. Fork this project and configure for their own deployment.

Technologies

Project is created with:

  • Language - "typescript": "^4.4.3"
  • Client - "react": "^17.0.2"
  • Server - "ts-node": "^10.2.1" and "express": "^4.17.1"

Installation

DEVELOPMENT

  1. Requires npm version 7+ (for npm workspaces). Npm upgrade info for Windows https://stackoverflow.com/questions/18412129/how-can-i-update-npm-on-windows

  2. Run npm install at the root of rarity-analyzer to install server dependencies including scope packages and workspaces.

    • NOTE: you can run npm install at root to build scoped packages.
    • e.g (While running packages/server/, you can make changes to packages/common/ and run npm install at root to rebuild the @crypto-dev-common package)
  3. Run npm start to start the development server.

FORKING AND DEPLOYMENT

Instructions for Forking and deploy to site provider (Netlify)
  1. Go to https://github.com/cryptoDevAmigos/rarity-analyzer and fork the project to your github account
  2. Go to https://app.netlify.com/start/deploy?repository=https://github.com/{INSERT_FORKED_PROJECT_URL_HERE}
  3. On Netlify, please follow instructions to Connect forked GitHub repo.

NEW NFT PROJECTS

Instructions for submitting new nft project for rarities

You may submit new NFT Projects to https://github.com/cryptoDevAmigos/rarity-analyzer or your forked repository

  1. Copy and rename the following file to create a new project /data/example.project.json to /data/project-name.project.json
    • Modify project file with the project specific information
  2. Copy new metadata json file to /data/ like /data/project-name.json
  3. Submit a pull request
    • Rarities will be calculated
    • Website will be updated with results

Architecture

Frontend

  • load /tokenId.json files from api
  • routing /projectKey/tokenId
    • /project Pages - show list of tokens
    • /token - show rarity details

Static Pregenerated Rarity Data (using GitHub actions to pre-calculate rarity)

  • Host website on Netlify (with continuous deploy from repo folder '/web/')
  • GitHub actions
  • root of repo: /data/nft-projects-metadata/
  • To submit a new project, github PR to add a new .json to that folder
    • projectName-nfts.json
    • projectName-details.json
  • Github action would process all the files in that folder and generate the rarities into a static folder structure
    • i.e.
    • /web/data/results/projectId/list.json
    • /web/data/results/projectId/0.json
    • /web/data/results/projectId/1.json
  • Website would access the .json files as static content of the same domain:
    • site.com/projectName/0 would load site.com/data/projectName/0.json
  • Anybody can setup their own website
    • create a netlify
    • point netlify to repo/web

Discord Integration

  • Use discord outgoing webhooks (serverless)
  • Requests handled by Netlify functions (or other serverless provider like AWS lambda)

PRogress

Hackathon Requirements

  • https://github.com/punkscape/01-rarity-analyser-hackathon

    • Only OneDayPunk owners may participate in the hackathon
      • You have to hold a OneDayPunk to take part in the hackathon.
    • The app has to calculate a rarity score for each item in the given collection
    • The app has to be deployed on a live server (Heroku free tier or similar is fine)
    • The app has to be usable: Minimum requirement is that the rarity of each item in the collection can be queried / viewed
    • There must be easy to follow documentation for other developers on how to configure their own collection metadata and deploy it to a server.
  • Generate /web/projectName/collection-rarities.json

  • Json data is accessible

  • Discord integration

  • Instructions

    • Add Project
    • Deploy clone
  • Submission before 27.09.2021 00:00 UTC

Tasks

  • Github action to build:rarities

  • Copy files from react/build to web in build script

  • Fix build path for common web/build

  • Finish Web UI

    • List all projects
      • Add web/data/projects.json output
      • Create ProjectsComponent
    • List nfts for a project
      • Add web/data/one-day-punks/project.json output
      • Create ProjectNftsComponent
    • Fix React favicons, title, etc.
    • Add Project Details
      • Links (Discord, Twitter, Site, etc.)
      • Theme (see css vars)
      • Logo
    • OpenRarity Site
      • Logo (Home Button)
      • Creators List (Punks)
        • Name, Bio, Links
      • Feature List (of site)
  • OpenRarity Discord Server + OutgoingWebhookBot

  • ? Easy Button: Add contract address and hit submit on website

    • [!STORAGE]
      • This probably can't be done purely by github actions
      • Where will the data go?
    • ? Use web3 to get contract data
    • ? Use open sea api to get data
  • Add Instructions for adding project

    1. Create /data/project-name.project.json file with ContractUri json data
    2. Create /data/project-name.json file with nft metadata (TokenUri json array) data
    3. Submit a pull request
      • Rarities will be calculated
      • Website will be updated with results
  • Instructions for Forking and deploy to site provider (Netlify)

  • Improve Git Performance

    • Remove web folder from all branches except deploy branch
    • Run build github action only on deploy branch

Ideas

Other Rarity Tools

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 92.3%
  • CSS 4.8%
  • HTML 2.9%