solsystem


Namesolsystem JSON
Version 1.0.8 PyPI version JSON
download
home_pageNone
SummaryType-safe Solana RPC http/websocket API with a focus on Helius and built on Pydantic models.
upload_time2024-11-23 23:31:10
maintainerNone
docs_urlNone
authorNone
requires_python>=3.12
licenseMIT
keywords solana blockchain web3
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # SolSystem

Friendly Solana RPC API client supporting both Http and Websockets. 

Includes some endpoints specific only to Helius and the Metaplex DAAS API for
retrieving asset data.


## Why + Plans
After trying the official solana python + solders packages I was left feeling like they were an afterthought of development and weren't supported too well. The API wasn't to my liking, so I decided to develop something more pythonic and cleaner.

As I work on solana projects I plan to add further functionality to this API. One of the goals is to integrate a DEX API as well, likely from jupiter.


## Version Note

This API was built with Python 3.12 and the latest package versions available at the time. The purpose was to take advantage of the great typing additions that have come to python and pydantic up to version 3.12. The library can fairly easily be backported to earlier versions of python, but it was not in the current scope of the author's work. 


## Examples

Using the `SyncClient` to return account info for a particular public key. Common configuration parameters are provided via the Configuration Object. The response object here will be a fully typed solsystem Response object with populated fields.

```python
from SolSystem import (
    SyncClient,
    GetAccountInfo,
    Configuration,
    Encoding,
)
def main():
    with SyncClient(rpc_endpoint = "<RPC ENDPOINT URL>") as client:
        response = client.request(
            method = GetAccountInfo(
                account = "<BASE58 PUBLIC KEY>",
                configuration = Configuration(
                    encoding = Encoding.JSONPARSED,
                )
            )
        )
        # Note response is fully typed as a Response[Account] object
        print(response.model_dump_json(indent = 2))
```


Here we use the `AsyncClient` to get the current account balance and display the balance in both SOL and Lamports. We can use the Lamports response object to easily convert and perform arithmetic operations on the value.

```python
import asyncio
from SolSystem import (
    AsyncClient,
    GetAccountBalance,
    Configuration,
    Commitment,
)
async def main():
    async with AsyncClient(rpc_endpoint = "<RPC ENDPOINT URL>") as client:
        resopnse = await client.request(
            method = GetAccountBalance(
                account = "<BASE58 PUBLIC KEY>",
                configuration = Configuration(
                    commitment = Commitment.CONFIRMED,
                )
            )
        )
        # Note response is fully typed as a Response[Lamports] object
        print(response.model_dump_json(indent = 2))

        print(F"Lamport Value: {response.value}")
        print(F"Sol Value: {response.value.sol}")
```

The `Websocket` client works as a factory which creates subscribed clients. Each call to `subscribe` on the factory will create a separate object that manages the subscription for its specific method. We then use an async iterator or a loop to receive messages on each subscription.


```python
import asyncio
from SolSystem import (
    WebsocketClient,
    WsGetAccountInfo,
    Configuration,
    Commitment,
)
async def main():
    async with WebsocketClient(
            end_point = "<WS RPC ENDPOINT URL>",
            message_limit = 3,
    ) as client_factory:
        # We will only recieve 3 messages per subscription
        account_subscription = await client_factory.subscribe(
            method = WsGetAccountInfo(
                account = "<BASE58 PUBLIC KEY>",
                configuration = Configuration(
                    commitment = Commitment.FINALIZED,
                )
            )
        )

        async for message in account_subscription:
            print(F"Owner: {message.value.owner}")
            print(F"Balance: {message.value.lamports}")
            print(F"Data: {message.value.data}")
            
        await account_subscription.unsubscribe()
```


## Development

The project uses `pdm` as both the package manager and the build tool for simplicity. For development simply pull and run `pdm install` provided you have the correct python version and pdm installed already.

Simple tests are available in the `/tests/` folder for confirming that response and request models are working correctly.

The project was developed in an environment running ruff and pylance so type checking was done through them.

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "solsystem",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.12",
    "maintainer_email": null,
    "keywords": "solana, blockchain, web3",
    "author": null,
    "author_email": "Aleksandr Grin <bytebrushsoftware@gmail.com>",
    "download_url": "https://files.pythonhosted.org/packages/b0/9e/386ec0ba6f57eb17c858c576ab8d58666ede4502e61d3e45efefa7853649/solsystem-1.0.8.tar.gz",
    "platform": null,
    "description": "# SolSystem\n\nFriendly Solana RPC API client supporting both Http and Websockets. \n\nIncludes some endpoints specific only to Helius and the Metaplex DAAS API for\nretrieving asset data.\n\n\n## Why + Plans\nAfter trying the official solana python + solders packages I was left feeling like they were an afterthought of development and weren't supported too well. The API wasn't to my liking, so I decided to develop something more pythonic and cleaner.\n\nAs I work on solana projects I plan to add further functionality to this API. One of the goals is to integrate a DEX API as well, likely from jupiter.\n\n\n## Version Note\n\nThis API was built with Python 3.12 and the latest package versions available at the time. The purpose was to take advantage of the great typing additions that have come to python and pydantic up to version 3.12. The library can fairly easily be backported to earlier versions of python, but it was not in the current scope of the author's work. \n\n\n## Examples\n\nUsing the `SyncClient` to return account info for a particular public key. Common configuration parameters are provided via the Configuration Object. The response object here will be a fully typed solsystem Response object with populated fields.\n\n```python\nfrom SolSystem import (\n    SyncClient,\n    GetAccountInfo,\n    Configuration,\n    Encoding,\n)\ndef main():\n    with SyncClient(rpc_endpoint = \"<RPC ENDPOINT URL>\") as client:\n        response = client.request(\n            method = GetAccountInfo(\n                account = \"<BASE58 PUBLIC KEY>\",\n                configuration = Configuration(\n                    encoding = Encoding.JSONPARSED,\n                )\n            )\n        )\n        # Note response is fully typed as a Response[Account] object\n        print(response.model_dump_json(indent = 2))\n```\n\n\nHere we use the `AsyncClient` to get the current account balance and display the balance in both SOL and Lamports. We can use the Lamports response object to easily convert and perform arithmetic operations on the value.\n\n```python\nimport asyncio\nfrom SolSystem import (\n    AsyncClient,\n    GetAccountBalance,\n    Configuration,\n    Commitment,\n)\nasync def main():\n    async with AsyncClient(rpc_endpoint = \"<RPC ENDPOINT URL>\") as client:\n        resopnse = await client.request(\n            method = GetAccountBalance(\n                account = \"<BASE58 PUBLIC KEY>\",\n                configuration = Configuration(\n                    commitment = Commitment.CONFIRMED,\n                )\n            )\n        )\n        # Note response is fully typed as a Response[Lamports] object\n        print(response.model_dump_json(indent = 2))\n\n        print(F\"Lamport Value: {response.value}\")\n        print(F\"Sol Value: {response.value.sol}\")\n```\n\nThe `Websocket` client works as a factory which creates subscribed clients. Each call to `subscribe` on the factory will create a separate object that manages the subscription for its specific method. We then use an async iterator or a loop to receive messages on each subscription.\n\n\n```python\nimport asyncio\nfrom SolSystem import (\n    WebsocketClient,\n    WsGetAccountInfo,\n    Configuration,\n    Commitment,\n)\nasync def main():\n    async with WebsocketClient(\n            end_point = \"<WS RPC ENDPOINT URL>\",\n            message_limit = 3,\n    ) as client_factory:\n        # We will only recieve 3 messages per subscription\n        account_subscription = await client_factory.subscribe(\n            method = WsGetAccountInfo(\n                account = \"<BASE58 PUBLIC KEY>\",\n                configuration = Configuration(\n                    commitment = Commitment.FINALIZED,\n                )\n            )\n        )\n\n        async for message in account_subscription:\n            print(F\"Owner: {message.value.owner}\")\n            print(F\"Balance: {message.value.lamports}\")\n            print(F\"Data: {message.value.data}\")\n            \n        await account_subscription.unsubscribe()\n```\n\n\n## Development\n\nThe project uses `pdm` as both the package manager and the build tool for simplicity. For development simply pull and run `pdm install` provided you have the correct python version and pdm installed already.\n\nSimple tests are available in the `/tests/` folder for confirming that response and request models are working correctly.\n\nThe project was developed in an environment running ruff and pylance so type checking was done through them.\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Type-safe Solana RPC http/websocket API with a focus on Helius and built on Pydantic models.",
    "version": "1.0.8",
    "project_urls": {
        "Source": "https://github.com/agrin96/solsystem"
    },
    "split_keywords": [
        "solana",
        " blockchain",
        " web3"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "089276506fcaaf5fb2ed03bb352f0f06e16af0a1902412b97fe4b84140bfb814",
                "md5": "ee6fa195f63c7ddc703c11fdbae974d2",
                "sha256": "782dbb52bc3096e6706a782fca474b38c63a7139952e08c9a79d9a0bd4a4a16c"
            },
            "downloads": -1,
            "filename": "solsystem-1.0.8-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "ee6fa195f63c7ddc703c11fdbae974d2",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.12",
            "size": 112021,
            "upload_time": "2024-11-23T23:31:08",
            "upload_time_iso_8601": "2024-11-23T23:31:08.707896Z",
            "url": "https://files.pythonhosted.org/packages/08/92/76506fcaaf5fb2ed03bb352f0f06e16af0a1902412b97fe4b84140bfb814/solsystem-1.0.8-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "b09e386ec0ba6f57eb17c858c576ab8d58666ede4502e61d3e45efefa7853649",
                "md5": "727bff6372e9d0180666985f1673cb1b",
                "sha256": "776fc624e48e062d77c9d6db3c6928975716fa44217bd97b1db5899ab0fcb653"
            },
            "downloads": -1,
            "filename": "solsystem-1.0.8.tar.gz",
            "has_sig": false,
            "md5_digest": "727bff6372e9d0180666985f1673cb1b",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.12",
            "size": 62080,
            "upload_time": "2024-11-23T23:31:10",
            "upload_time_iso_8601": "2024-11-23T23:31:10.425003Z",
            "url": "https://files.pythonhosted.org/packages/b0/9e/386ec0ba6f57eb17c858c576ab8d58666ede4502e61d3e45efefa7853649/solsystem-1.0.8.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-11-23 23:31:10",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "agrin96",
    "github_project": "solsystem",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "lcname": "solsystem"
}
        
Elapsed time: 0.34350s