The Social Network blockchain is a next-generation governance, economic, and social system for humanity built on Polkadot Substrate. To learn more read the whitepaper ๐๐.
The Social Blockchain is powered by a decentralized backend which allows anyone in the world to participate by running the node software in this repository. This removes the need for a central party or middleman to extract rent or censor the network for personal gain, control, or power.
The network is capable of securing and maintaining a single source of truth, globally, with 6 second finality using a byzantine fault tolerant, nominated Proof-of-Stake consensus algorithm. In addition, nodes can run dedicated real time applications off-chain, and use the network consensus for discovery and access control of their services from from end social network users.
Node operators are incentivized with NET tokens for keeping the software running, and earn greater rewards the more reliable their nodes are over time. Fees generated on the chain, are distributed to Node operators proportional to how much staked NET they have on their node. Node operators can specify which Social token they wish to support, such that when NET token holders stake their tokens to a node, they will receive a bonus amount of that Social token in their wallet. These social tokens can then be used for governance or voting on global social networking applications.
To get started, you can follow the steps depending on your operating system:
Open the Terminal application and execute the following commands:
# Install Homebrew if necessary https://brew.sh/
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"
# Make sure Homebrew is up-to-date, install openssl and cmake
brew update
brew install openssl cmake
Use a terminal shell to execute the following commands:
sudo apt update
# May prompt for location information
sudo apt install -y cmake pkg-config libssl-dev git build-essential clang libclang-dev curl libz-dev
Run these commands from a terminal:
pacman -Syu --needed --noconfirm cmake gcc openssl-1.0 pkgconf git clang
export OPENSSL_LIB_DIR="/usr/lib/openssl-1.0"
export OPENSSL_INCLUDE_DIR="/usr/include/openssl-1.0"
Please see this guide to get setup using Windows.
The Social Network software is built in rust, so Guardians must setup their tooling as follows:
Install rust with the following:
# Install
curl https://sh.rustup.rs -sSf | sh
# Configure
source ~/.cargo/env
# Configure Rust toolchain to the one needed for The Social Blockchain
rustup install nightly-2021-01-25
rustup default nightly-2021-01-25
# Install WebAssembly (WASM)
rustup target add wasm32-unknown-unknown --toolchain nightly-2021-01-25
To get a copy of The Social Blockchain software on your machine:
git clone https://github.com/social-network/blockchain.git
The runtime of the blockchain is compiled down to Web Assembly (WASM) so it can be ran in embedded devices, or even the browser. To compile it run:
cd blockchain
WASM_BUILD_TOOLCHAIN=nightly-2021-01-25 cargo build --release
Note if you are doing other blockchain development work, you will need to update your toolchain to match our version for the compilation to work. Feel free to join the #support circle in the Social Technologies Society if you need help getting setup.
As a decentralized project, we welcome all contributions that help us reach our mission faster, but ask that you follow our values. See our welcome blog for more details.
To jump right in, visit our jobs page to find a job or bounty that you think you can complete. Contributors will earn NET tokens to participate in the platform governance and help steward the decentralized technical development.
The security policy and procedures can be found in docs/SECURITY.md
.
- Substrate Primitives (
sp-*
), Frame (frame-*
) and the pallets (pallets-*
), binaries (/bin
) and all other utilities are licensed under Apache 2.0. - Substrate Client (
/client/*
/sc-*
) is licensed under GPL v3.0 with a classpath linking exception.
The reason for the split-licensing is to ensure that for the vast majority of teams using Substrate to create feature-chains, then all changes can be made entirely in Apache2-licensed code, allowing teams full freedom over what and how they release and giving licensing clarity to commercial teams.
In the interests of the community, we require any deeper improvements made to Substrate's core logic (e.g. Substrate's internal consensus, crypto or database code) to be contributed back so everyone can benefit.
In order to be compatible with polkadot.js the following type definitions will need to be added:
{
"AttributeTransaction": {
"signature": "Signature",
"name": "Vec<u8>",
"value": "Vec<u8>",
"validity": "u32",
"signer": "AccountId",
"identity": "AccountId"
},
"Attribute": {
"name": "Vec<u8>",
"value": "Vec<u8>",
"validity": "BlockNumber",
"creation": "Moment",
"nonce": "u64"
},
"SwapId": "u64",
"Swap": {
"token_id": "TokenId",
"swap_token": "TokenId",
"account": "AccountId"
},
"AssetId": "u32",
"SocialTokenBalance": "u128",
"RegistrarIndex": "u32",
"Judgement": {
"_enum": [
"Requested",
"Approved"
]
},
"JudgementItem": "(RegistrarIndex, Judgement)",
"Registration": {
"judgements": "Vec<JudgementItem>",
"account_id": "AccountId"
},
"Bloom": "H256",
"Log": {
"address": "H160",
"topics": "Vec<H256>",
"data": "Bytes"
},
"Receipt": {
"state_root": "H256",
"used_gas": "U256",
"logs_bloom": "Bloom",
"logs": "Vec<Log>"
},
"TransactionAction": {
"_enum": {
"Call": "H160",
"Create": "Null"
}
},
"TransactionRecoveryId": "u64",
"TransactionSignature": {
"v": "TransactionRecoveryId",
"r": "H256",
"s": "H256"
},
"Transaction": {
"nonce": "U256",
"gas_price": "U256",
"gas_limit": "U256",
"action": "TransactionAction",
"value": "U256",
"input": "Bytes",
"signature": "TransactionSignature"
},
"TransactionStatus": {
"transaction_hash": "H256",
"transaction_index": "u32",
"from": "H160",
"to": "Option<H160>",
"contract_address": "Option<H160>",
"logs": "Vec<Log>",
"logs_bloom": "Bloom"
},
"Id": "AuthorityId",
"ChainId": "u8",
"ResourceId": "Vec<u8>",
"ExchangeId": "u64",
"CurrencyOf": "Balance",
"NftId": "U256",
"Erc721Token": {
"id": "NftId",
"metadata": "Vec<u8>"
}
}