Building Blockchain Foundations

🔸About🔸

Pyramidic specializes in blockchain node validation and security, focusing on delivering reliable services that support the foundation of decentralized networks.

🔸Connect🔸

🔸Twitter🔸Medium🔸Linktr🔸[email protected]🔸

🔸Core Projects🔸

Kwil

## **Step 1: Install Kwil Node**

### **Prerequisites**
- Docker installed on your machine
- Minimum system requirements:
  - 4 CPU cores
  - 8 GB RAM
  - 100 GB of available storage

### **Step 2: Pull the Kwil Node Docker Image**

Run the following command to pull the latest Kwil node image:

```bash
docker pull kwilteam/node:latest

Step 3: Configure and Start the Kwil Node

Create a Configuration File

Create a config.yaml file to set up your Kwil node. Here's an example configuration:

network: mainnet
data_dir: /data/kwil
rpc:
  enabled: true
  address: 0.0.0.0:8545
p2p:
  port: 30303
  bootnodes:
    - enode://bootnode1@ip:port
    - enode://bootnode2@ip:port

Run the Kwil Node

Run the node using Docker and bind your local configuration:

docker run -d \\
  --name kwil-node \\
  -v $(pwd)/config.yaml:/config.yaml \\
  -v $(pwd)/data:/data \\
  -p 8545:8545 \\
  -p 30303:30303 \\
  kwilteam/node:latest --config /config.yaml

This command:


Step 4: Interact with the Kwil Node

You can now interact with your Kwil node via its RPC API.

Example: Check Node Status

Use curl or an HTTP client to check the node's status:

curl -X POST <http://localhost:8545> \\
-H "Content-Type: application/json" \\
-d '{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "kwil_nodeStatus",
  "params": []
}'

Expected response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": {
    "status": "running",
    "network": "mainnet",
    "nodeId": "your-node-id"
  }
}

Step 5: Create a Kwil Database

Deploy a Database

Deploy a new database using the RPC API:

curl -X POST <http://localhost:8545> \\
-H "Content-Type: application/json" \\
-d '{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "kwil_createDatabase",
  "params": {
    "name": "example_db",
    "schema": "CREATE TABLE users (id INT PRIMARY KEY, name TEXT);"
  }
}'

Expected response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": {
    "dbId": "example_db_id"
  }
}

Query the Database

Send a SQL query to the database:

curl -X POST <http://localhost:8545> \\
-H "Content-Type: application/json" \\
-d '{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "kwil_query",
  "params": {
    "dbId": "example_db_id",
    "query": "SELECT * FROM users;"
  }
}'

Expected response:

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": {
    "rows": []
  }
}

Step 6: Stop and Remove the Node

To stop the Kwil node:

docker stop kwil-node

To remove the container:

docker rm kwil-node

## [**0G Labs**](<https://x.com/0G_labs>)

We are participates in the 0G project, where we focus on providing secure and stable node deployment and maintenance. Our role involves ensuring that nodes are correctly set up and continuously monitored to maintain optimal performance. By implementing rigorous security measures, we help safeguard the network against potential threats and vulnerabilities, contributing to the project's overall stability and resilience

```bash
timedatectl set-timezone UTC

# Verify timezone
timedatectl

# Install 0gchaind
sudo apt update && sudo apt upgrade -y
sudo apt install -y git build-essential
git clone -b v0.2.3 <https://github.com/0glabs/0g-chain.git>
cd 0g-chain/networks/testnet
./install.sh
source ~/.profile

# Set Chain ID
0gchaind config chain-id zgtendermint_16600-2

# Initialize Node
0gchaind init PyramidicValidator --chain-id zgtendermint_16600-2

# Copy Genesis File
sudo apt install -y unzip wget
rm ~/.0gchain/config/genesis.json
wget -P ~/.0gchain/config <https://github.com/0glabs/0g-chain/releases/download/v0.2.3/genesis.json>
0gchaind validate-genesis

# Add Seed Nodes
cat <<EOF >> $HOME/.0gchain/config/config.toml
seeds = "[email protected]:26656,[email protected]:26656,[email protected]:26656,[email protected]:26656"
EOF

# Start Node
0gchaind start

# Optimize Garbage Collection
export GOGC=900
export GOMEMLIMIT=40GB
0gchaind start

# Create Validator
0gchaind keys add PyramidicKey --eth
0gchaind keys unsafe-export-eth-key PyramidicKey

# Acquire testnet tokens for your validator

0gchaind tx staking create-validator \\
  --amount=1000000ua0gi \\
  --pubkey=$(0gchaind tendermint show-validator) \\
  --moniker="PyramidicValidator" \\
  --chain-id=zgtendermint_16600-2 \\
  --commission-rate="0.10" \\
  --commission-max-rate="0.20" \\
  --commission-max-change-rate="0.01" \\
  --min-self-delegation="1" \\
  --from=PyramidicKey \\
  --gas=auto \\
  --gas-adjustment=1.4

# Check if the validator is in the set
0gchaind q staking validators -o json --limit=1000 | jq '.validators[] | select(.status=="BOND_STATUS_BONDED")' | jq -r '.tokens + " - " + .description.moniker' | sort -gr | nl

#  Unjail Validator (if necessary)
0gchaind tx slashing unjail --from PyramidicKey --gas=500000 --gas-prices=99999neuron -y

# Upgrade Node (if needed)
# Reset data if upgrading to a breaking version
rm $HOME/.0gchain/config/addrbook.json $HOME/.0gchain/config/genesis.json
0gchaind tendermint unsafe-reset-all --home $HOME/.0gchain

# Restart the node
0gchaind start

# Migrate Node (if necessary)
# Recover wallet account on the new server
0gchaind keys add PyramidicAccount --eth --recover

# Transfer the following files to the new server:
# $HOME/xx.address
# $HOME/xx.info
# $HOME/keyhash
# $HOME/config/priv_validator_key.json

# Ensure the node is synced to the latest block height before migration

Bool Network

In the Bool project, we are handles node validation and security audits. We conduct comprehensive assessments to identify and mitigate potential risks, ensuring the network's integrity. Our team also works on optimizing node performance, enabling Bool to operate efficiently and securely. Through our proactive approach to security and maintenance, we aim to support Bool's goals of creating a reliable and scalable decentralized network.


sudo curl -fsSL <https://get.docker.com> | bash -s docker
sudo systemctl enable docker
sudo systemctl start docker

sudo systemctl status docker
sudo chmod 666 /var/run/docker.sock
docker version

sudo curl -L "<https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$>(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose
docker-compose --version

mkdir -p pyramidic-node/node-data

cd pyramidic-node

chmod 777 node-data

cat > docker-compose.yaml <<EOF
version: "3"
services:
  bnk-node1:
    image: boolnetwork/bnk-node:alpha-testnet
    restart: always
    environment:
      RUST_LOG: info
    volumes:
      - "./node-data:/data"
    command: |
      --validator
      --enable-offchain-indexing true
      --rpc-methods Unsafe
      --unsafe-rpc-external
      --rpc-cors all
      --rpc-max-connections 100000
      --pool-limit 100000
      --pool-kbytes 2048000
      --tx-ban-seconds 600
      --blocks-pruning=archive
      --state-pruning=archive
      --ethapi=debug,trace,txpool
      --chain alpha_testnet
    ports:
      - 9944:9944
      - 30333:30333
EOF

docker-compose up -d

git clone <https://github.com/boolnetwork/mining-scripts.git>

apt update
apt install build-essential automake autoconf libtool wget python libssl-dev dkms
wget <https://download.01.org/intel-sgx/latest/linux-latest/distro/ubuntu18.04-server/sgx_linux_x64_driver_1.41.bin>
bash sgx_linux_x64_driver_1.41.bin

cd mining-scripts && ./sgx-detect

vim configs/keyring.toml

node_ws_url = "ws://127.0.0.1:9944"
node_call_port = 8720
identity = "0xPrivatePyramidicKey" 
db_path = "/host/data"
console_port = 5555

[db _ option]
create_if_missing = true
atomic_flush = true

[network _ config]
port = 38700
boot_nodes = ["/ip4/172.210.130.200/tcp/38700/p2p/12D3KooWJVjkr19spLuvmWb68zdxki2qucnubPzbHRjxRi8jhwzF"]
share_peer_interval = 30
only_global_ips = true

[key _ server _ config]
version = 1
attestation_style = 2
seal_policy = "MRSIGNER"
exe_policy = { Multiply = { executors = 8 } }

vim configs/sgx_default_qcnl.conf

{
  "pccs_url": "<https://sgx-dcap-server.cn-hongkong.aliyuncs.com/sgx/certification/v3/>"
}

🔸Services🔸

Our services include node setup, performance monitoring, and security audits, tailored to meet the specific needs of each project. Check page

Services

Powered by Fruition