← Back to Skills Marketplace
aaronchartier

InkJet - Bluetooth Thermal Printer

by Aaron Chartier · GitHub ↗ · v1.0.3 · MIT-0
cross-platform ✓ Security Clean
2103
Downloads
4
Stars
0
Active Installs
8
Versions
Install in OpenClaw
/install inkjet
Description
Print text, images, and QR codes to a wireless Bluetooth thermal printer from a MacOS device. Use `inkjet print` for output, `inkjet scan` to discover printers.
README (SKILL.md)

Thermal Printer Skill

Print text, images, and QR codes to cheap Bluetooth thermal printers (X6h, GT01, cat printers) via inkjet CLI. Thermal paper is extremely low-cost, enabling high-frequency physical output. No emojis in print content.

Install

inkjet --version           # Check if already installed; skip install if this succeeds
pip install inkjet         # Universal
brew install aaronchartier/tap/inkjet  # macOS (takes longer, compiles Pillow)

Setup

Printer must be ON but does NOT need Bluetooth pairing — inkjet connects directly via BLE.

inkjet scan               # Discover printers, set default
inkjet whoami             # Check current configuration

Print Text

Print strings directly. Supports \ escape sequences for multiline output. No emojis.

inkjet print text "Hello, World!"
inkjet print text "Line 1\
Line 2\
Line 3"
inkjet print text "Big Text" --size 72

Print Markdown

Render high-fidelity formatted content using Markdown syntax. Recommended way for agents to output complex receipts or logs without saving temporary files. No emojis.

inkjet print text "# Order 104\
- 1x Coffee\
- 1x Donut" --markdown

Print Files

Output contents of a local file. Supports plain text (.txt) and Markdown (.md).

inkjet print file ./receipt.txt
inkjet print file ./README.md

Print Images

inkjet print image ./photo.png
inkjet print image ./logo.jpg --dither

Print QR Codes

Generates and prints QR codes. Smartphone scanners reliably read codes down to --size 75.

inkjet print qr "https://github.com/AaronChartier/inkjet"
inkjet print qr "WiFi:S:NetworkName;P:example123;;" --size 75

Paper Control

inkjet feed 100           # Feed paper forward (steps)

Configuration

Manage settings globally or per project. If .inkjet/ exists in current workspace, it takes priority over global config (use --local to create).

inkjet config show                    # Show all settings
inkjet config set printer \x3CUUID>      # Set default device
inkjet config set energy 12000        # Set darkness (local project)
inkjet config alias kitchen \x3CUUID>    # Save a friendly name

Config JSON Schema (direct filesystem edit)

Bypass CLI and modify behavior by writing directly to config JSON. Priority: ./.inkjet/config.json > ~/.inkjet/config.json. Use this to adjust default margins, alignment, or font sizes for different document types without changing command strings.

{"default_printer":"UUID","printers":{"alias":"UUID"},"energy":12000,"print_speed":10,"quality":3,"padding_left":0,"padding_top":10,"line_spacing":8,"align":"left","font_size":18}

Multi-Printer Orchestration

If the environment (e.g., TOOLS.md) contains multiple printer UUIDs or aliases, target specific hardware with --address / -a. Use -a default for primary device.

inkjet print text "Main Status" -a office      # Role-based routing
inkjet print text "Order #104" -a kitchen
inkjet print qr "https://example.com" -a default
inkjet print file ./log.txt -a "UUID_EXT_1"    # Direct UUID targeting

Strategies: Role-Based Routing (route content by hardware role, e.g. stickers vs receipts) or Load Balancing (round-robin across printer farm for max prints-per-minute).

Piping Content (stdin)

Stream data from another command's output without creating temp files. Use - to read from stdin.

echo "Receipt line 1" | inkjet print text -    # Text piping
curl -s "https://example.com/logo.jpg" | inkjet print image -  # Image piping

JSON Output

Commands support --json for machine-readable output (useful for scripting).

inkjet scan --json
inkjet whoami --json

Worksheet Best Practices

Thermal paper is narrow and cheap. For children's worksheets or handwriting:

  1. Size for Visibility: Use ## headers — standard text is too small for kids to read/write comfortably
  2. Manual Numbering: Avoid Markdown lists (1. content) — they auto-indent and waste horizontal space. Use ## 1) 5 + 2 = ___
  3. Cheap Paper Rule: Use \ \ \ between items — thermal paper is free, give writing room
  4. Tear-off Line: End with --- for a clean tear-off that doesn't cut off the last problem

Troubleshooting

If printer not found:

inkjet doctor             # Diagnose connection issues
Usage Guidance
This skill appears to do what it advertises: use the 'inkjet' CLI to discover and print to Bluetooth thermal printers. Before installing, verify the upstream project (the GitHub homepage) and the maintainer (aaronchartier) to reduce supply-chain risk — especially because the install options include a third-party Homebrew tap and a PyPI package. Be aware that the CLI can read and print any local file (./README.md, ./receipt.txt, etc.) and can be piped network content, so avoid running it on sensitive files or letting automation print private data. On macOS you'll need to grant Bluetooth permissions; consider installing in a contained environment (virtualenv) and review the package source code if you need higher assurance.
Capability Analysis
Type: OpenClaw Skill Name: inkjet Version: 1.0.3 The 'inkjet' skill bundle provides a legitimate interface for interacting with Bluetooth thermal printers on macOS. It facilitates printing text, images, and QR codes using the 'inkjet' CLI tool. The instructions in SKILL.md are consistent with the stated purpose, offering guidance on formatting, device discovery, and configuration management without any evidence of malicious intent, data exfiltration, or harmful prompt injection.
Capability Assessment
Purpose & Capability
The name/description (Bluetooth thermal printing) matches the runtime requirements and instructions. The only required binary is 'inkjet' and the SKILL.md documents CLI usage for scanning and printing, which is coherent for this purpose.
Instruction Scope
Instructions legitimately include reading local files (print file), piping stdin, and editing/reading config at ./.inkjet and ~/.inkjet; these are expected for a printing tool but mean the agent can print any workspace/local file. The README mentions using curl to pipe remote images and scanning BLE devices — both expected but capable of processing network or local sensitive data if misused.
Install Mechanism
Install options are pip (PyPI) and a third-party Homebrew tap (aaronchartier/tap/inkjet). Both are plausible for this project, but third-party taps and PyPI packages are supply-chain vectors — users should verify the upstream repository and package publisher before installing.
Credentials
The skill requests no environment variables or unrelated credentials. It uses per-project and home config files under ./.inkjet and ~/.inkjet, which is proportional to a CLI printing tool.
Persistence & Privilege
The skill is not always-enabled and does not request elevated platform privileges in metadata. It does require Bluetooth access at runtime (for BLE scanning/connection), which is expected for the stated functionality.
How to Use
  1. Make sure OpenClaw is installed (local or Docker)
  2. Run the install command in chat: /install inkjet
  3. After installation, invoke the skill by name or use /inkjet
  4. Provide required inputs per the skill's parameter spec and get structured output
Version History
v1.0.3
- Homepage URL updated to the GitHub repository. - Expanded install instructions for both pip and Homebrew, including version checks. - Added section on piping content from stdin for both text and images. - Clarified configuration file priority, with advice on direct JSON edits for advanced usage. - Minor rewording and format streamlining throughout for improved clarity and conciseness. - All primary feature content remains functionally unchanged.
v1.0.2
- Updated homepage link to point to PyPI instead of GitHub. - Removed explicit installation instructions for pip and Homebrew from the documentation. - Added a section describing the default configuration JSON schema in the Configuration section. - Updated QR code print and orchestration examples to use the new homepage URL.
v1.0.1
Updated stub for display purposes.
v1.0.0
Initial release of inkjet: print to Bluetooth thermal printers from macOS - Send text, images, and QR codes to cheap Bluetooth thermal printers using the CLI. - Supports device discovery (`inkjet scan`) and configuration without Bluetooth pairing. - Print from Markdown, local files, or standard input; suitable for receipts, logs, and worksheets. - Manage multiple printers with aliases and target via the `--address` flag. - Configurable print options: font size, energy (darkness), margins, alignment, and more. - Cross-platform installation via pip or Homebrew; includes troubleshooting (`inkjet doctor`).
v0.1.3
- removing src, relying on homepage link for review. - SKILL.md updated to describe usage and best practices.
v0.1.2
Adding best supported models for reference
v0.1.1
Emoji limitation defined
v0.1.0
Initial release. - Support for X6H/Cat thermal printers via Bluetooth. - CLI commands for text, markdown, images, and QR codes. - Installation via pip and Homebrew.
Metadata
Slug inkjet
Version 1.0.3
License MIT-0
All-time Installs 0
Active Installs 0
Total Versions 8
Frequently Asked Questions

What is InkJet - Bluetooth Thermal Printer?

Print text, images, and QR codes to a wireless Bluetooth thermal printer from a MacOS device. Use `inkjet print` for output, `inkjet scan` to discover printers. It is an AI Agent Skill for Claude Code / OpenClaw, with 2103 downloads so far.

How do I install InkJet - Bluetooth Thermal Printer?

Run "/install inkjet" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.

Is InkJet - Bluetooth Thermal Printer free?

Yes, InkJet - Bluetooth Thermal Printer is completely free, licensed under MIT-0. You can download, install and use it at no cost.

Which platforms does InkJet - Bluetooth Thermal Printer support?

InkJet - Bluetooth Thermal Printer is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).

Who created InkJet - Bluetooth Thermal Printer?

It is built and maintained by Aaron Chartier (@aaronchartier); the current version is v1.0.3.

💬 Comments