InkJet - Bluetooth Thermal Printer

v1.0.3

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.

4· 2.1k·0 current·0 all-time
byAaron Chartier@aaronchartier

Install

OpenClaw Prompt Flow

Install with OpenClaw

Best for remote or guided setup. Copy the exact prompt, then paste it into OpenClaw for aaronchartier/inkjet.

Previewing Install & Setup.
Prompt PreviewInstall & Setup
Install the skill "InkJet - Bluetooth Thermal Printer" (aaronchartier/inkjet) from ClawHub.
Skill page: https://clawhub.ai/aaronchartier/inkjet
Keep the work scoped to this skill only.
After install, inspect the skill metadata and help me finish setup.
Required binaries: inkjet
Use only the metadata you can verify from ClawHub; do not invent missing requirements.
Ask before making any broader environment changes.

Command Line

CLI Commands

Use the direct CLI path if you want to install manually and keep every step visible.

OpenClaw CLI

Canonical install target

openclaw skills install aaronchartier/inkjet

ClawHub CLI

Package manager switcher

npx clawhub@latest install inkjet
Security Scan
VirusTotalVirusTotal
Benign
View report →
OpenClawOpenClaw
Benign
medium confidence
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.
Assessment
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.

Like a lobster shell, security has layers — review code before you run it.

Runtime requirements

🖨️ Clawdis
Binsinkjet

Install

Install (Homebrew)
latestvk975jjj11v7d582h00q3mbcpms83sj4r
2.1kdownloads
4stars
8versions
Updated 4w ago
v1.0.3
MIT-0

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 \n escape sequences for multiline output. No emojis.

inkjet print text "Hello, World!"
inkjet print text "Line 1\nLine 2\nLine 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\n- 1x Coffee\n- 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 <UUID>      # Set default device
inkjet config set energy 12000        # Set darkness (local project)
inkjet config alias kitchen <UUID>    # 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 \n\n\n 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

Comments

Loading comments...