Skip to main content

Synchronous Python client for the gomc-rest API

Project description

gomc-rest-client

日本語版 README

Python 3.10+ client library for the latest gomc-rest HTTP API.

This package wraps the synchronous REST endpoints exposed by gomc-rest for Mitsubishi PLC read, write, and remote-control operations using only the Python standard library, and converts API error responses into typed Python exceptions.

About gomc-rest-client

This package is a dedicated client library for gomc-rest. It is intended for users who already use gomc-rest, or who want to expose Mitsubishi PLC operations through the gomc-rest HTTP API.

This library does not communicate with PLCs directly. If you need the server, API surface, or gomc-rest itself, see the upstream project:

Install

uv add gomc-rest-client

With pip:

pip install gomc-rest-client

PyPI project page:

For offline environments, install from a prebuilt wheel distributed inside your network:

pip install dist/gomc_rest_client-*.whl

This package has no runtime dependencies outside the Python standard library, so wheel-based offline installation is straightforward.

Development tasks currently use dev dependencies such as PyYAML, pytest, ruff, and ty, but they are not required at runtime.

To set up the development environment:

uv sync --group dev

To build distributable artifacts before taking them into an offline environment:

uv build

Usage

from gomc_rest_client import (
    MINIMUM_SUPPORTED_GOMC_REST_VERSION,
    GomcRestBusyError,
    GomcRestPLCProtocolError,
    PLCClient,
)

with PLCClient("http://192.168.0.1:8080") as plc:
    health = plc.health()
    metrics = plc.metrics()
    version = plc.version()
    is_supported = plc.is_supported_version()
    is_compatible = plc.is_version_compatible(MINIMUM_SUPPORTED_GOMC_REST_VERSION)
    values = plc.read("D100", 3)
    bits = plc.read("M0", 4)
    dwords = plc.read("D100", 2, dword=True)
    signed = plc.read("D100", 3, sint=True)

    plc.write("D100", [10, 20, 30])
    plc.write("M0", [True, False])
    plc.write("D100", [-1, -32768, 32767], sint=True)

    try:
        plc.remote_run(clear=0, force=False)
    except GomcRestBusyError:
        pass
    except GomcRestPLCProtocolError as exc:
        print(exc.end_code, exc.message)

is_supported_version() and is_version_compatible() treat dev builds as compatible by default so local gomc-rest main builds can pass version checks during development.

Supported gomc-rest versions

This client supports gomc-rest v0.8.0 and later.

Servers older than v0.8.0 are not supported. In particular, servers without the /version endpoint are out of scope for this client.

This client expects the server to expose both /version and /metrics.

If you need to verify the support policy at runtime, call plc.is_supported_version() or compare against MINIMUM_SUPPORTED_GOMC_REST_VERSION.

API coverage

  • GET /version
  • GET /metrics
  • GET /health
  • GET /read
  • POST /write
  • POST /remote/run
  • POST /remote/stop
  • POST /remote/pause
  • POST /remote/latch-clear
  • POST /remote/reset

Remote-control endpoints require the gomc-rest server to start with -enable-remote.

Development

Run checks with uv:

uv run pytest
uv run ruff check .
uv run ty check
uv build

To publish to PyPI after configuring credentials:

uv publish

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

gomc_rest_client-0.4.0.tar.gz (16.5 kB view details)

Uploaded Source

Built Distribution

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

gomc_rest_client-0.4.0-py3-none-any.whl (7.9 kB view details)

Uploaded Python 3

File details

Details for the file gomc_rest_client-0.4.0.tar.gz.

File metadata

  • Download URL: gomc_rest_client-0.4.0.tar.gz
  • Upload date:
  • Size: 16.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for gomc_rest_client-0.4.0.tar.gz
Algorithm Hash digest
SHA256 730c573c7f8c295886e01c9fcd13653777fcabd0743de4467f970524d6a2cb6d
MD5 6bdfa25f4c133d139f19bfdbec8430df
BLAKE2b-256 9375885e8e2836159847053a21aad4aaecde8a6092d03a2f75ca814caf48033a

See more details on using hashes here.

Provenance

The following attestation bundles were made for gomc_rest_client-0.4.0.tar.gz:

Publisher: workflow.yml on Moge800/gomc_rest_client

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

File details

Details for the file gomc_rest_client-0.4.0-py3-none-any.whl.

File metadata

File hashes

Hashes for gomc_rest_client-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 882a82169fd2957053e1cf5db4195f3552b61df22a0cd7da50f8508684f3df25
MD5 4081ef3b9d69f5c4824d08e35e02f3e7
BLAKE2b-256 60c42aa393fcb1a3c97ab88dcff50e14c67589304331fe9acf31606ed9f6064e

See more details on using hashes here.

Provenance

The following attestation bundles were made for gomc_rest_client-0.4.0-py3-none-any.whl:

Publisher: workflow.yml on Moge800/gomc_rest_client

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