Skip to main content

Cubsat Space Protocol (CSP) native Python implementation

Project description

PyPI - Version GitHub Actions Workflow Status

CSP.py

Native Python, async-friendly implementation of Cubesat Space Protocol.

Features

  • Python friendly async API
  • Sockets and connections
  • Interfaces
  • Socket options
  • CIDR Routing table
  • Hooks for inspecting and/or modifying packets going through node
  • System services
    • Ping

Missing features compared to libcsp

  • RDP
  • Packet flags
    • HMAC
  • Remaining system sevices: uptime, reboot/shutdown, process list, memory free query, CSP Management Protocol
  • Simple fragmentation protocol

When to use over libcsp?

  • Easy use (pure Python library, no native dependencies)
  • Testing
    • csp-py allows to start and tear down entire node within single test without leaking anything between tests
  • Async API
    • Use asyncio to run communication, with gracefully handled timeouts and cancellations

Usage

  1. Install package using pip
    user$ pip install cubesat-space-protocol-py
    
  2. Create node:
    import csp_py
    
    node = csp_py.CspNode()
    
  3. Add interface
    from csp_py.interfaces.serializing_interface import CspSerializingInterface
    
    async def capture_frame(frame: bytes) -> None:
        # TODO: frame contains entire serialized packet including header
        # send it over some communication channel
        pass
    
    async def handle_incoming_frames(iface: CspSerializingInterface) -> None:
        while True:
            # TODO: fetch frame from communication channel
            frame: bytes = await recv_frame()
            await iface.on_incoming_frame(frame)
    
    iface = CspSerializingInterface(capture_frame)
    # TODO: make sure addresses are correct
    node.router.add_interface(iface, address=1, netmask_bits=10)
    asyncio.create_task(handle_incoming_frames(iface))
    
  4. Start router task
    router_task = asyncio.create_task(node.router.arun())
    
  5. Use sockets
    connection = await node.connect(dst=0, port=20)
    await connection.send(b'Hello, world!')
    response = await connection.recv()
    print(f'Got response: {response.data}')
    
  6. Stop router
    router_task.cancel()
    await router_task
    

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cubesat_space_protocol_py-1.3.1.tar.gz (23.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cubesat_space_protocol_py-1.3.1-py3-none-any.whl (20.2 kB view details)

Uploaded Python 3

File details

Details for the file cubesat_space_protocol_py-1.3.1.tar.gz.

File metadata

File hashes

Hashes for cubesat_space_protocol_py-1.3.1.tar.gz
Algorithm Hash digest
SHA256 ccbabcb2911f7c14571d5f48005dfff6e8b80653780d9757db8291699571cc66
MD5 c9e395b52ce27f31871779dedd572fb5
BLAKE2b-256 f5c28015d2f9cbcfd65a01f8564828beeca885b611444a5268417f4ef5ae1086

See more details on using hashes here.

Provenance

The following attestation bundles were made for cubesat_space_protocol_py-1.3.1.tar.gz:

Publisher: publish.yml on kplabs-pl/csp-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cubesat_space_protocol_py-1.3.1-py3-none-any.whl.

File metadata

File hashes

Hashes for cubesat_space_protocol_py-1.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a7fab607d6a3365078ad451f09e0c34406a65c2b52190b29ca19fb977f20d5c1
MD5 33ea987955b93850544880328a4c087e
BLAKE2b-256 1123266aeb88fc901cd23da4c8eba7ebe3b70506c5d7f15f25e303bff85b20a5

See more details on using hashes here.

Provenance

The following attestation bundles were made for cubesat_space_protocol_py-1.3.1-py3-none-any.whl:

Publisher: publish.yml on kplabs-pl/csp-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page