From 8b3b2ccafc1afe5fa992b27cfd0cc14c5f5fc57c Mon Sep 17 00:00:00 2001 From: Jaka Purg Date: Tue, 29 Oct 2024 08:48:49 +0100 Subject: [PATCH] Infrastructure docs --- build/13-infrastructure-api.md | 311 ++++++++++++++++++++++++ web3-services/10-web3-infrastructure.md | 108 ++++++++ 2 files changed, 419 insertions(+) create mode 100644 build/13-infrastructure-api.md create mode 100644 web3-services/10-web3-infrastructure.md diff --git a/build/13-infrastructure-api.md b/build/13-infrastructure-api.md new file mode 100644 index 00000000..832cb5b5 --- /dev/null +++ b/build/13-infrastructure-api.md @@ -0,0 +1,311 @@ +# Infrastructure API + +The Infrastructure API provides an interface for managing essential infrastructure services required to build modern Web3 applications. + +
+ +## RPC Service + +### Create a RPC API Key + +> Create a new RPC API key for a project. + + POST /rpc/api-key + +
+
+ +#### Body Fields + +| Field | Type | Description | Required | +|--------------|----------|-----------------------------------------|----------| +| name | `string` | Name of the API key | Yes | +| description | `string` | Description of the API key | No | + +#### Possible Errors + +| Code | Description | +|----------|------------------------------------------| +| 40300000 | Forbidden | +| 40020001 | Max RPC API keys limit reached | +| 40405001 | Project owner not found | +| 50000001 | Internal server error | +| 422001101| RPC API key name is missing | + +
+
+
+ + + +```sh +curl --location --request POST "https://api.apillon.io/rpc/api-key" \ +--header "Authorization: Bearer :credentials" \ +--header "Content-Type: application/json" \ +--data-raw "{ + \"name\": \"RPC API Key\", + \"description\": \"Description of the API key\" +}" +``` + + + + + + +```json +{ + "status": 201, + "data": { + "id": 4, + "projectUuid": "d0c34b5e-1fd6-473e-81f8-e89ee479f7aa", + "name": "RPC API Key", + "description": "Description of the API key", + "uuid": "60020364-7edc-495a-a0a2-df695bb1cc3f" + } +} +``` + + + +
+
+ +### List RPC API Keys + +> Retrieve a list of RPC API keys associated with a project. + + GET /rpc/api-key + +
+
+ +#### Query Parameters + +All query parameters from [listing request](1-apillon-api.md#listing-requests) + +#### Response Fields + +| Field | Type | Description | +|----------------|------------|----------------------------------------------------------| +| id | `number` | Unique identifier of the RPC API key | +| projectUuid | `string` | UUID of the project the RPC API key belongs to | +| name | `string` | Name of the RPC API key | +| uuid | `string` | Unique identifier of the RPC API key returned by Dwellir | +| description | `string` | Description of the RPC API key | +| createTime | `DateTime` | Creation timestamp | +| updateTime | `DateTime` | Last updated timestamp | + +
+
+
+ + + +```sh +curl --location --request GET "https://api.apillon.io/rpc/api-key" \ +--header "Authorization: Bearer :credentials" +``` + + + + + + +```json +{ + "status": 200, + "data": { + "items": [ + { + "id": 4, + "createTime": "2024-09-09T11:15:26.000Z", + "updateTime": "2024-09-10T13:18:31.000Z", + "projectUuid": "cfd85992-8f79-4486-97cf-2406bd722d90", + "name": "RPC API Key", + "description": "Description of the API key", + "uuid": "60020364-7edc-495a-a0a2-df695bb1cc3f" + } + ], + "total": 1, + "page": 1, + "limit": 20 + } +} +``` + + + +
+
+ +### Get a RPC API Key + +> Retrieve the details of a specific RPC API key by its ID along with the list of RPC endpoints marked as favorite for this API key. + + GET /rpc/api-key/:id + +
+
+ +#### URL Parameters + +| Field | Type | Description | Required | +|-------|----------|------------------------------------------|----------| +| id | `number` | Unique identifier of the RPC API key | Yes | + +#### Response Fields + +| Field | Type | Description | +|----------------|------------|-------------------------------------------------------------| +| id | `number` | Unique identifier of the RPC API key | +| name | `string` | Name of the RPC API key | +| description | `string` | Description of the RPC API key | +| projectUuid | `string` | Unique identifier of the project | +| uuid | `string` | Unique identifier of the RPC API key | +| createTime | `DateTime` | Creation timestamp | +| updateTime | `DateTime` | Last updated timestamp | +| urls | `array` | Array of favorite URLs for the RPC API key | + +###### URL Fields +| Field | Type | Description | +|----------------|------------|--------------------------------------------------------------| +| id | `number` | Unique identifier of the RPC Endpoint | +| apiKeyId | `number` | Unique identifier of the RPC API key | +| chainName | `string` | Name of the chain the RPC Endpoint belongs to | +| network | `string` | Network of the RPC Endpoint (Usually mainnet, testnet, etc.) | +| httpsUrl | `string` | HTTPS URL of the RPC Endpoint | +| wssUrl | `string` | WSS URL of the RPC Endpoint | +| createTime | `DateTime` | Creation timestamp | +| updateTime | `DateTime` | Last updated timestamp | + +#### Possible Errors + +| Code | Description | +|----------|---------------------------| +| 40300000 | Forbidden | +| 40420001 | RPC API key not found | + +
+
+
+ + + +```sh +curl --location --request GET "https://api.apillon.io/rpc/api-key/:id" \ +--header "Authorization: Bearer :credentials" +``` + + + + + + +```json +{ + "id": "60020364-7edc-495a-a0a2-df695bb1cc3f", + "status": 200, + "data": { + "createTime": "2024-09-09T11:15:26.000Z", + "updateTime": "2024-09-10T13:18:31.000Z", + "name": "RPC API Key", + "description": null, + "project_uuid": "d0c34b5e-1fd6-473e-81f8-e89ee479f7aa", + "uuid": "60020364-7edc-495a-a0a2-df695bb1cc3f", + "urls": [ + { + "id": 77, + "chainName": "Ethereum", + "network": "mainnet", + "httpsUrl": "https://mainnet.apillon.io/60020364-7edc-495a-a0a2-df695bb1cc3f", + "wssUrl": "wss://mainnet.apillon.io/60020364-7edc-495a-a0a2-df695bb1cc3f", + "createTime": "2024-09-10T12:55:44.000Z", + "updateTime": "2024-09-12T13:57:26.000Z", + } + ] + } +} +``` + + + +
+
+ +### List RPC Endpoints + +> Retrieve a list of available RPC endpoints by Dwellir. + + GET /rpc/endpoints + +
+
+ +#### Response Fields + +| Field | Type | Description | +|----------------|------------|--------------------------------------------------------------| +| id | `number` | Unique identifier of the RPC Endpoint | +| image_url | `string` | URL of the RPC Endpoint chain image | +| name | `string` | Name of the RPC Endpoint chain | +| networkId | `number` | Network ID of the RPC Endpoint | +| networkName | `string` | Network of the RPC Endpoint (Usually Mainnet, Testnet, etc.) | +| nodes | `array` | Array of nodes for the RPC Endpoint | +| type | `string` | Type of the Entity (will be 'network') | +| version | `string ` | Version of the RPC Endpoint | + +##### Node Fields + +| Field | Type | Description | +|----------------|------------|--------------------------------------------------------------| +| id | `number` | Unique identifier of the RPC Endpoint Node | +| https | `string` | HTTPS URL of the RPC Endpoint Node | +| wss | `string` | WSS URL of the RPC Endpoint Node | +| type | `string` | Type of the Entity (will be 'node') | +| node_type | `string` | Type of the RPC Endpoint Node | +| version | `string ` | Version of the RPC Endpoint Node | + +
+
+
+ + + +```sh +curl --location --request GET "https://api.apillon.io/rpc/endpoints" \ +--header "Authorization: Bearer :credentials" +``` + + + + + + +```json +{ + "status": 200, + "data": [{ + "id": 1, + "image_url": "https://apillon.io/images/chains/ethereum.svg", + "name": "Ethereum", + "networkId": 31, + "networkName": "Mainnet", + "nodes": [{ + "id": 1, + "https": "https://mainnet.apillon.io/", + "wss": "wss://mainnet.apillon.io/", + "type": "node", + "node_type": "Archive", + "version": "1.0" + }], + "type": "network", + "version": "1.0" + }] +} +``` + + + +
+
\ No newline at end of file diff --git a/web3-services/10-web3-infrastructure.md b/web3-services/10-web3-infrastructure.md new file mode 100644 index 00000000..14b1112c --- /dev/null +++ b/web3-services/10-web3-infrastructure.md @@ -0,0 +1,108 @@ +# Web3 infrastructure + +## Introduction + +**Apillon's Infrastructure Service** provides developers with the essential infrastructure required to build modern Web3 applications. Our infrastructure services currently include: + +- **RPC Service**: Reliable and high-performance access to blockchain networks +- **Indexing Service**: Efficient data indexing and querying capabilities + +These services are designed to simplify Web3 development while ensuring scalability and reliability for your decentralized applications. + +## RPC Service + +The RPC (Remote Procedure Call) service in Apillon's infrastructure provides seamless connectivity to blockchain networks, allowing developers to interact with blockchain data and execute smart contracts. +By utilizing [Dwellir](https://www.dwellir.com/) as the RPC provider, Apillon ensures reliable and efficient access to blockchain nodes. The service is designed for flexibility, enabling developers to create, manage, and optimize their own RPC endpoints through a user-friendly interface. + +### Dwellir + +**Dwellir** is a highly reliable and scalable RPC (Remote Procedure Call) provider that powers the Apillon infrastructure, enabling developers to interact with various blockchain networks. +Dwellir ensures secure, low-latency connections and high availability, allowing developers to execute smart contract functions, query blockchain data, and perform transactions seamlessly. + +Core Services: +- **Multi-Blockchain Support**: Dwellir supports a wide range of blockchain networks, including popular ecosystems like EVM (Ethereum Virtual Machine), Substrate-based chains, and others, providing extensive coverage and flexibility. +- **High Availability and Redundancy**: Dwellir's infrastructure is designed with built-in redundancy and geo-distributed nodes, ensuring minimal downtime and reliable access to blockchain networks. +- **Secure Connections**: Supports both HTTPS and WSS (WebSocket Secure) protocols for encrypted communication, ensuring data privacy and integrity during transmission. +- **API Key Management**: Allows project owners to create, manage, and revoke API keys, offering fine-grained control over who can access RPC endpoints. + +### How it works + +1. **Activate RPC Service for a Project**: Project owner activates RPC service for their project in the Apillon dashboard. +2. **Create an RPC API Key**: Developers can generate an API key from the Apillon dashboard, which is used to authenticate requests to the RPC service. +3. **Set Favorite Endpoints**: Developers can mark the preferred RPC endpoints as "favorites" for selected API key to make them easily accessible through the Apillon dashboard. +4. **Manage API Keys**: Project owners can manage API keys in the Apillon dashboard, allowing for flexible management of access to RPC endpoints. +5. **Monitor Usage**: Developers can monitor the usage of their RPC keys in the Apillon dashboard, allowing for better control over their infrastructure costs. + +### Pricing + +The RPC service is available with two main plants: + +**Free Plan** (default): +- **RPC Calls**: Up to 5 million RPC calls per month +- **API Keys**: Allows a single API key per user +- **Cost**: Free of charge + +**Developer Plan**: +- **RPC Calls**: Increases the limit to 25 million RPC calls per month +- **API Keys**: Allows up to 5 API keys per user +- **Cost**: 49.99€ per month + + +## Indexing service + +The Indexing Service is a crucial component of Apillon's infrastructure, designed to efficiently index and query blockchain data. It plays a vital role in powering our Web3 services and enhancing the overall user experience. +In the background, Apillon uses the [Subsquid](https://subsquid.io/) indexing framework and Subsquid Cloud to run indexing nodes. +Developers can create their own indexers or use one of the available templates, and can query more than 150 blockchain networks. + +### SQD (Subsquid) Web3 Data Infrastructure + +**SQD** is a powerful Web3 data infrastructure platform that offers: + +- **High-Performance Data Indexing**: Processes blockchain data up to 100x faster than traditional providers +- **Comprehensive Network Coverage**: Supports 150+ blockchain networks including EVM, SVM, Substrate, and more +- **Cost-Efficient Infrastructure**: Eliminates egress fees, users only pay for compute resources +- **Core Services**: + - SQD Network: A decentralized data lake for Web3 + - Squid SDK: Advanced blockchain indexing toolkit + - SQD Cloud: Enterprise-grade hosted indexing service + +Used by major projects like PancakeSwap, Railgun, and Chainsafe, SQD processes hundreds of thousands of terabytes of blockchain data while significantly reducing infrastructure costs. + +### Workflow + +1. **Create an indexer**: Developers create an indexer in the Apillon Indexer Dashboard. +2. **Adjust indexer source code**: Use one of the available templates for squid indexer or write your own. +3. **Deploy indexer**: Deploy your indexer through the Apillon CLI. +4. **Use indexer**: Use the indexer in your application. + +### How it works + +The indexing process follows a standardized workflow while allowing for flexible implementation approaches. Developers can leverage existing templates as a starting point and customize them according to their specific requirements. Before deployment, indexers can be thoroughly tested in a local environment to ensure proper functionality. + +An indexer implementation consists of three core components: + +- **Indexer Processor**: Handles data fetching and processing from the blockchain +- **Indexer Database**: Stores the processed blockchain data +- **Indexer API**: Provides GraphQL endpoint for querying the indexed data + +To configure an indexer, developers need to specify: + +- **RPC Node Endpoint**: Connection point to the blockchain network +- **Starting Block**: Initial block number from which to begin indexing +- **Target Events and Fields**: Specific blockchain events and data fields to monitor and process + +The indexer processor continuously fetches new blocks from the specified starting point up to the latest block, processing the relevant data according to the configured rules and storing it in the indexer database. + +The processed data becomes accessible through a GraphQL API, providing a flexible and efficient way to query the indexed blockchain data. This API supports complex queries, filtering, and data relationships, enabling developers to retrieve exactly the information they need for their applications. + +### Pricing + +Indexers are billed based on the amount of processed and stored data and the number of queries made to the indexer API. +Project need to have sufficient credit balance to deploy an indexer. The deployment itself is free of charge, Apillon charges for the working indexer only. +Indexers are billed daily - each day Apillon calculates price for the indexer and uses project's credit balance to pay for it. + +If project's credit balance is insufficient, indexer will be hibernated and later deleted after few days if no action is taken. + +## Conclusion + +Apillon's Web3 Infrastructure services provide developers with powerful tools to build and scale decentralized applications. Through SQD integration, developers can efficiently index and query blockchain data across multiple networks, while maintaining cost-effectiveness and high performance. The platform's user-friendly approach, combined with its robust technical capabilities, makes it an ideal choice for projects of any size looking to leverage blockchain data effectively.