Skip to main content

Python wrapper for the TYCMA ICON Interface HTTP TCPIP API for laser marking systems.

Project description

pyiconlaser

PyPI Python License

Python wrapper for the TYKMA ICON Interface HTTP/TCP API used by industrial laser marking systems.

This library provides a simple Python API for controlling compatible laser marking systems through the ICON Interface software.

This project is community-maintained and is not affiliated with or endorsed by any hardware manufacturer.

This library was developed and tested against TYKMA ICON Interface software based on available API documentation and observed real-world behavior.


Features

  • Load marking jobs
  • Read available IDs and modify their values
  • Start and stop marking sequences
  • Enable or clear jobs
  • Control limits (tracing beam)
  • Retrieve machine status
  • Get template preview images

Requirements

This library requires the vendor software TYKMA ICON Interface to be installed and running on the target machine.

The HTTP/TCP API must also be enabled manually in the Config.xml configuration file.

Before using this library:

  • Install TYKMA ICON Interface software
    • Vendor contact may be required to obtain the software and API documentation
  • Enable HTTP/TCP communication in Config.xml
    • default path: C:\tykma\custom\Tykma_Icon\config.xml
    • see the vendor documentation for the software
  • Verify the API is accessible (default port 5287)
  • Ensure the laser system is connected and recognized by ICON Interface

Installation

pip install pyiconlaser

Or install locally:

pip install .

Quick Start

from pyiconlaser import IconLaserClient

laser = IconLaserClient()

laser.prepare_job("test_job")

laser.set_id("SN", "123456")
laser.set_id("QR", "PRODUCT001")

laser.enable_job()
laser.start()

laser.clear_job()

Important Note

ICON Interface has undocumented behavior.

After loading a job:

laser.load_job("test_job")

the software automatically enables limits mode internally.

This causes:

all_ids -> empty response
set_id -> id_not_found

To fix this, limits must be disabled before modifying IDs:

laser.load_job("test_job")
laser.limits_off()

For convenience:

laser.prepare_job("test_job")

does both automatically.


python sdk laser industrial-automation automation hardware http-api wrapper

Basic Example

from pyiconlaser import IconLaserClient

laser = IconLaserClient()

print(laser.version())
print(laser.job_status())
print(laser.all_ids())

Supported API Methods

version()
job_status()
loaded_job()
state()

load_job()
prepare_job()
clear_job()
enable_job()

all_ids()
set_id()

start()
stop()

limits_on()
limits_off()

get_preview()

Tested Environment

  • Python 3.14.4
  • TYKMA ICON Interface 1.0.12.6 on Windows 11

Testing

Unit tests run without any hardware:

pytest

Integration tests communicate with a real laser running ICON Interface and are skipped by default. Enable them with the --run-integration flag:

pytest --run-integration

Configuration

The target hardware is configured through environment variables. You can set them in two ways:

Option 1: Using a .env file (recommended)

Copy .env.example to .env and update with your hardware details:

cp .env.example .env

Then edit .env and set your values:

ICON_LASER_HOST=192.168.0.10
ICON_LASER_PORT=5287
ICON_LASER_TIMEOUT=5
ICON_LASER_JOB=test_job
ICON_LASER_ID_NAME=SN
ICON_LASER_ID_VALUE=TEST123

The .env file is automatically loaded during testing and is not committed to git.

Option 2: Setting inline with the command

ICON_LASER_HOST=192.168.0.10 ICON_LASER_JOB=test_job pytest --run-integration

Environment Variables Reference

Variable Description Default
ICON_LASER_HOST ICON Interface host localhost
ICON_LASER_PORT ICON Interface port 5287
ICON_LASER_TIMEOUT Request timeout (seconds) 5
ICON_LASER_JOB Marking job to run (required)
ICON_LASER_ID_NAME ID field to set SN
ICON_LASER_ID_VALUE ID value to set TEST123

Integration tests will physically operate the laser. Only run them on a system that is safe to mark.


License

MIT License

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

pyiconlaser-0.2.2.tar.gz (7.9 kB view details)

Uploaded Source

Built Distribution

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

pyiconlaser-0.2.2-py3-none-any.whl (6.7 kB view details)

Uploaded Python 3

File details

Details for the file pyiconlaser-0.2.2.tar.gz.

File metadata

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

File hashes

Hashes for pyiconlaser-0.2.2.tar.gz
Algorithm Hash digest
SHA256 64ed79d72dfc36012550602773c185b72a42e4c0aca2ff3e7050d0ded848f57e
MD5 8bfd039ec2c139e46c0e2131f57d0a45
BLAKE2b-256 ae2eacc4dbc3a1e23d3b48211e9b238e985445ac17008150f59227d857eb3dcc

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyiconlaser-0.2.2.tar.gz:

Publisher: publish.yml on Jim-23/pyiconlaser

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

File details

Details for the file pyiconlaser-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: pyiconlaser-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 6.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pyiconlaser-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 185d49b32253d32e7a002d1059ccbc57fc2dab732969040ca38140bf80926538
MD5 0b3a79a960f54004c2dc407e437f1063
BLAKE2b-256 624706f50e0f5e7249790de90c06756696f5cba16e237fed1467401748a22f08

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyiconlaser-0.2.2-py3-none-any.whl:

Publisher: publish.yml on Jim-23/pyiconlaser

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