A GraphQL interface for Sia network components: walletd, renterd, hostd.
SiaQL provides a unified GraphQL API layer for interacting with various Sia network components. It simplifies the process of querying and managing Sia nodes by providing:
📚 See GraphQL documentation: siaql-docs.netlify.app
- Unified API: Access walletd, renterd, and hostd through a single GraphQL endpoint
- Type Safety: Fully typed schema with TypeScript/Python type definitions
- Flexible Queries: Built-in support for filtering, sorting, and pagination
- Interactive Documentation and Playground: GraphiQL interface with schema exploration
- CLI Tool: Easy setup and management through command-line interface
Install SiaQL using pip:
pip install siaql- Start the SiaQL server:
siaql- 
Access the GraphiQL interface at http://localhost:9090/graphqlby default.
- 
Start querying your Sia components! 
SiaQL can be configured through environment variables (.env file), command-line arguments:
| Variable | Default | Description | 
|---|---|---|
| HOST | 127.0.0.1 | Server host address | 
| PORT | 9090 | Server port | 
| ENABLE_RENTERD | true | Enable/disable renterd integration | 
| RENTERD_URL | http://localhost:9981 | Renterd API URL | 
| RENTERD_PASSWORD | None | Renterd API password | 
| ENABLE_WALLETD | true | Enable/disable walletd integration | 
| WALLETD_URL | http://localhost:9982 | Walletd API URL | 
| WALLETD_PASSWORD | None | Walletd API password | 
| ENABLE_HOSTD | true | Enable/disable hostd integration | 
| HOSTD_URL | http://localhost:9983 | Hostd API URL | 
| HOSTD_PASSWORD | None | Hostd API password | 
The same configuration options are available as command-line arguments:
siaql --host 127.0.0.1 --port 9090Note: SiaQL can be started without any configuration, in which case it will ask for the API URLs and passwords interactively.
SiaQL is compatible with following versions of Sia components:
| Component | Version | 
|---|---|
| Walletd | v0.8.0 | 
| Renterd | v1.1.1 | 
| Hostd | v2.0.2 | 
All queries are written as its respective Sia component. For example renterd_Contracts for  Renterd  contracts endpoint.
- Get Sorted Contracts
query GetSortedContracts {
  renterdContracts(
    sort: {
      field: "size"
      direction: DESC
    }
  ) {
    id
    size
    hostKey
    state
    totalCost
    spending {
      uploads
      downloads
      fundAccount
      deletions
      sectorRoots
    }
  }
}- Get Reliable Hosts
query GetReliableHosts {
  renterdGetHosts(
    filter: {
      field: "interactions.successfulInteractions"
      operator: GT
      value: "100"
    }
    sort: {
      field: "interactions.uptime"
      direction: DESC
    }
    pagination: {
      offset: 0
      limit: 20
    }
  ) {
    publicKey
    netAddress
    interactions {
      successfulInteractions
      uptime
      lastScan
    }
  }
}# Create a virtual environment if needed
# python3.9 -m venv venv
# Clone the repository
git clone https://github.com/justmert/siaql.git && cd siaql
# Tested with poetry 2.0.1
# pip install --upgrade poetry==2.0.1
# Install dependencies
poetry install
# Run tests
poetry run pytest
- Sia - The decentralized storage network
- Strawberry GraphQL - GraphQL library for Python
- Typer - CLI library for Python
This repository is a community effort and is not officially supported by the Sia Network.