Verified and machine readable blockchain metadata. If you are blockchain developer you can easily enrich metadata of system you are building.
Trying to solve the problem of cryptocurrencies and cryptoassets metadata, this repository accumulate dependencies, specs, logos, links and other sensitive metadata.
Rationale behind Chaingear you can find in a paper: cyber•Rating: Cryptoproperty Evaluation.
- API
- What benefits of adding to Chaingear?
- How to add a system?
- How to add a crowdsale?
- How to add my site?
- Specification of .toml file
Link to stable version is not published yet: chaingear.cyber.fund/v1.json
Unstable version could be found here: chaingear.cyber.fund/chaingear.json
- Make your system understandable for people. All meaningful information about system you develop should be gathered in one place in order to gain more adaption.
- Make your system accessible for other developers. It will make significantly easier to deal with your token for any wallet, exchange, bridge and any web app which want to work with your cryptocurrency or cryptoasset.
- Your system is listed in cyber•Fund's Radar or Rating for free. We are continuously working on attraction of investors to blockchain based projects.
We support 4 types of a systems:
cryptocurrency
cryptoasset
cryptoservice
cyptoproject
For every type data structure is quite similar, but requirements are differs.
Meta description is a simple text file in toml
format.
system = "Bitcoin"
icon = "bitcoin.png"
type = "cryptocurrency"
- Clone
chaingear
repository - Run
npm install
- Run
cg add {system type}
Now the process is not automated, so:
- Create a folder at `/chaingear/sourses`. Name of the folder should be same as a `system` name
- Copy desired type of a system from `/templates` into a folder you created
- Rename `example.toml` to a `system` name
- Fill out
.toml
file in accordance with specs. - Pull request
cyber•Fund's Team in short time will review and merge it.
Any system that follow basic digital property requirements could be added. This is closed list of such requirements:
- We allow listing of cryptocurrencies and cryptoassets that are cryptoproperty compliant.
- We allow listing of publicly traded cryptocurrencies and cryptoassets.
- We allow listing of cryptocurrencies and cryptoassets based on crowdinvesting valuation with fixed cap until cryptocurrency or cryptoasset goes to market.
We are going to publish a paper soon that explain a lot of stuff. But now the following requirements exist:
- Should be established and uniquely identifiable via Genesis ID.
- Should have underlying internal capital - a cryptocurrency responsible for resilience of network consensus.
- Core code responsible for network consensus should be open source, buildable and executable for at least one open source operating system.
- Should be registered using listed cryptocurrency and uniquely identifiable via Genesis ID.
- Registration protocol should be defined by a code (Counterparty, Omni, NXT AE, NXT Monetary System etc.) and/or natural language (protocol specification such as Open Assets protocol, AGS, etc.)
- Purpose of registration should be described by a code (e.g. smart contracts), and/or natural language (e.g. Ricardian contract or signed Shareholders agreement)
No problem. It could be registered using Chaingear library and will be listed in Radar. So when your brainchild will be ready to be publicly traded it will be included in Rating automagicaly. Follow cyber•Fund Radar listing section.
If you are not going to issue a token or create an independent system we could not add your
You can discuss or ask a question at cyber•Talk Thread
Crowdsale consist of 2 steps:
- Before the start. We recommend to add this information at least a month before ETA.
- After the finish. We recommend to add this information in an hour after finish.
We don't accept crowdfunding if certain condition didn't met:
- At least one genesis address exist. We don't accept crowdfunding if investors could not transparently track funds.
- Fund management is at least under 2 of 3 multisig. Fund managers could be anonymous, but some reputation inside community is highly recommended. Otherwise, well written paper or POC code eliminates any questions.
- Funding terms are defined and cryptographically signed by fund managers. To add crowdfunding put this data to toml file of your system.
[crowdsales]
start_date = "2015-03-31T00:00:00"
end_date = "2015-05-15T00:00:00"
genesis_address = ["35gLt5EgB367enjSjyEDahhWWcy6p1MGf6"] # Could be array. See multu currency crowdsale
funding_url = "https://koinify.com/#/project/FACTOM"
funding_tems = "http://blog.factom.org/post/115139137794/the-factoid-software-sale-is-live"
min_investment = 0.01
funding_operator = "Koinify" # Could be `nein`.
crowsale_feed = "http://example.com/feed" # For multi currency or non bitcoin crowdsale
Note that all fields are mandatory.
Then crowdsale is finished two liner report is needed.
tokens_sold = 4379973
tokens_issued = 8759946
btc_raised = 3500
After end of crowdsale your cap will be calculated automatically based on 4 fields: start_date
, end_date
, min_invesment
and genesis_address
. Thus your project will become visible in Rating with fixed cap until tokens (1) won't be distributed and (2) at least one public market will be established.
You can provide multiple addresses as array: ["address1", "address2"]
.
At this point of time we support only Bitcoin addresses for crowdsale calculations. For multi currency crowdsale or non bitcoin crowdsale you will need to provide pre calculated feed.
It is easy! Follow links section.
genesis_id = "hash_of_the_first_block"
system = "System Name"
icon = "system_name"
Should never be changed.
genesis_id
- Hash of the first block generated by system
system
- The unique name of a system. If there exist system with name in respect to communities please invent another name. In case of historical collisions (Bytecoin for instance) priority will have a system with older genesis date. Newer system will be excluded until renamed. Go to a /chaingear/sourses
to explore systems names or type in a Search at cyber.fund
dependencies
- Specify dependencies on other systems.
Names of the systems you can find in /chaingear/sourses
example
icon
- The name of image of a system logotype (for example icon
= "bitcoin"
)
Put image file in to a /chaingear/logos
folder.
Image requirements:
- file should be .png
- background should be transparent
- file name should be exact of system name ???
- image should be square
- image should have resolution between 256x256 and 1024x1024
This section contains information about technical specification of the system.
[specs]
genesis_id = "hash_of_the_first_block"
dependencies = ["independent"]
token_name = "token_name"
token_symbol = "token_ticker"
consensus_type = "Consensus Type" # `Proof-of-Work`, `Proof-of-Stake`, `Delegated Proof-of-Stake`, `Hybrid POS-POW`, `Federated Consensus`, `Blockchain Ledger`
consensus_name = "Consensus Name"
hashing = "Encryption Name"
system_type = "Independent System"
state = "Running"
headline = "A brief description of not more than 140 symbols or tagline"
hashtag = "#example"
tags = ["DAO"]
page_state = "draft" # can be "draft" or "ready"
block_time = 600
block_reward = 50
halfing_cycle = 210240
total_tokens = 21000000
premine_tokens = 0
difficulty_cycle = "2016"
txs_confirm = 6
rpc = "8332"
token_name
- The token name. Sometimes the system name and the name of the token is not the same, for example SAFE Network
token has name MaidSafeCoin
token_symbol
- Market ticker of the system (Bitcoin - BTC
)
system_type
- Choose a system type from a classification below:
- Independent System - Secured by decentralized consensus protocols. Examples: Bitcoin, Ripple, Ethereum, BitShares.
- Decentralized Application - Secured by independent systems. Tokens have internal value. No central emission point. Examples: Counterparty, GetGemz, Factom.
- Pegged Asset - Secured by independent system and pegged to a value of real world assets: fiat currencies, shares, indexes… Examples: BitUSD, Tether, NuBits, Ripple issued BitstampUSD, CoinoUSD or even Ethercoin. Though they could have very different nature: CFDs, IOUs or whatever else, we feel that it is more natural to group them into one class: Pegged Assets.
- Ownership Title - To this class belong systems where transaction (e.g. a transfer of money) by itself proves your ownership rights for what you expect to receive.. Examples: AGS, Neucoin or Ethereum before launch.
- Blockchain Share - These are blockchain securities, e.g. shares, that give you rights to receive dividends: Coinomat. That could be shares that promise you tokens in the future: SAFE Network or Synereo. Tokens don’t have internal value without counterparty. It is a reason why blockchain shares usually bear a counterparty risk.
For better understanding this classification read cyber•Fund blog post "Do Your Own Reserch"
If none of these types do not correspond with a nature of your System, choose our own and leave description at cyber•Talks Thread
state
- choose existing state of a system:
- Project - for systems that are in development or on idea stage. Systems with this state will be displayed at cyber•Fund Radar section
- Running - for systems that already works.
headline
- describe the system in a few words, not more than 140 symbols
hashtag
- fill hashtag for a system
tags
- you can specify any number of tags related to a system
page_state
-
- draft - for systems that require additional information and links
- ready - for systems that already have full information
block_time
- The number of seconds required for generating a block
txs_confirm
- The number of confirmations required to record transaction in the blockchain
block_reward
- The number of tokens received as a reward for the found block
total_tokens
- The number of tokens that will ever be generated by a system
premine_tokens
- The number of premined tokens
halfing_cycle
- The number of blocks required to increase
difficulty_cycle
- The number of blocks required to increase difficulty of calculation
rpc
- The number of the RPC port
You can add any property that not defined in this specification.
[[events]]
name = "Event Name"
start_date = "2015-03-31T00:00:00"
end_date = "2015-03-31T00:00:00"
url = "http://event_link.com"
[[links]]
type = "website"
name = "Name of the site"
url = "http://example.com"
rss = "http://example.com/rss_feed"
icon = "website.png"
tags = ["Main","Apps"]
type
-
For the standart types of links listed below, provides automatic detection of the icons
and tags
, so you do not need to fill out these properties.
Standard links types:
- website - tags: ["Main"], icon: fa-home
- paper - tags: ["Science"], icon: fa-graduation-cap
- wallet - tags: ["Apps","Wallet"], icon: fa-credit-card
- explorer - tags: ["Apps","Analytics"], icon: fa-search
- wiki - tags: ["Science"], icon: fa-wikipedia-w
- github - tags: ["Code"], icon: fa-github
- bitbucket - tags: ["Code"], icon: fa-bitbucket
- blog - tags: ["News"], icon: fa-pencil-square-o
- forum - tags: ["News"], icon: fa-comments-o
- twitter - tags: ["News"], icon: fa-twitter
- reddit - tags: ["News"], icon: fa-reddit
- facebook - tags: ["News"], icon: fa-facebook-official
- google+ - tags: ["News"], icon: fa-google-plus-square
- youtube - tags: ["News"], icon: fa-youtube-square
For other links types use:
- custom - all properties you should define manualy
name
- The name of the resource to which this link leads.
url
- URL for this link
rss
- URL of the RSS-feed for specified resource
icon
- If not defined - default icon for a type
. To customize icon for the link fill image name and put image file in to a /chaingear/logos
folder. Image requirements are the same as for the system logo
tags
- Tags define in which section of the cyber•Fund System's Profile Page will be plaeced:
- Main - section below Logotype, Name of the System and Raiting. Can contain only 4 links
- News - this tag places link Section: News
- Apps - by default this tag places link in the Section: Apps/Other
- Wallet - in combination with Apps tag places link in the Section: Apps/Wallets, use for wallets and clients
- Exchange - in combination with Apps tag places link in the Section: Apps/Exchanges, use for exchanges
- Analytics - in combination with Apps tag places link in the Section: Apps/Analytics, use for any analytics resources
- Code - Section: Developers Dimension
- Science - Section: Scientific Roots
- Also you can add any other tag
Serve as a way to resolve different name from different data sources or
coinmarketcap = "Bitcoin"
nickname = "Bitcoin"
Obsolete. Will be eventually moved to cyberfund/cybertaing
[ratings]
rating_cyber = 0
[flags]
suplly_from_here = true
rating_do_not_display = true