Skip to main content

Process clipboard content and show helpful overlays or notifications based on the content, e.g. parse UNIX timestamps, AWS account IDs, VINs, base64 strings and more.

Project description

clipboard-processor

CI Build

Process clipboard content and show helpful overlays or notifications based on the content, e.g. parse UNIX timestamps, AWS account IDs, VINs, base64 strings and more.

All parsing & decoding is done locally. The clipboard content is not sent to any external service.

demo gif

Installation

Quickstart

Install into userspace, create a userspace systemd service & enable it (via installer script):

curl -L -o install-clipboard-processor https://raw.githubusercontent.com/tom-mi/clipboard-processor/main/scripts/install
# review & adapt the installer as needed
chmod +x install-clipboard-processor
./install-clipboard-processor

Manual installation

Some features require additional libraries to be installed (see below).

Install with required dependencies only:

pip install clipboard-processor

Install with all optional dependencies (recommended):

pip install clipboard-processor[all]

Usage

clipboard-processor

Show help:

clipboard-processor --help

Run with xclip-primary input mode:

clipboard-processor --input xclip-primary

Check out the autogenerated demo text which contains example strings for most supported inputs.

Functionality

Input

There are different input modes available:

Mode Description
auto Use pyperclip for cross-platform clipboard access. This is the default.
xclip-primary Use the primary selection on linux via xclip. No explicit copy operation is needed – selecting the text is sufficient. Requires xclip command in the search path.

Plugins

All decoding functionality is provided via plugins. Per default, all available plugins are enabled.

Plugin Description External library
aws-account-id Show AWS account name for given AWS account ID by parsing ~/.aws/config -
base64 Decode base64 strings -
cron Print human readable description of cron expressions cron-descriptor
hex-utf8 Decode printable UTF-8 strings from hexadecimal representation -
jwt Decode JSON web tokens (JWTs) PyJWT
oui Show vendor name for given MAC address or OUI (see IEEE OUI database) netaddr
ulid Parse ULIDs and show the encoded timestamp python-ulid
unixtime Parse UNIX timestamps and show the human-readable (ISO 8601) time -
vin Decode Vehicle Identification Numbers (VINs) vininfo
well-known Show explanation for well known "magic" strings.

Output

There are different output modes available:

Mode Description
ui Use tkinter overlay near the current mouse position to show the output. This is the default.
notify Use desktop-notifier to show the output in a desktop notification.
stdout Print the result of the processing to the standard output. This is mostly intended for debugging and testing.

Development

This project uses Hatch for managing the development environment.

Prerequisites

Install xvfb for running the snapshot tests.

TODO: some more effort might be necessary to support Windows and macOS.

Run all tests

hatch test --all
hatch run test-minimal:run
hatch run test-snapshot:run

Create environment for IntelliJ

Create a development environment in .venv/ which can easily be used by IntelliJ or other IDEs:

hatch env create dev

Run development version

hatch shell
clipboard-processor

or

hatch run clipboard-processor

Troubleshooting

In case dependencies are not synced into an existing env, try removing all environments:

hatch env prune

Release a new version

Draft a new release on GitHub.

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

clipboard_processor-0.3.1.tar.gz (46.4 kB view details)

Uploaded Source

Built Distribution

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

clipboard_processor-0.3.1-py3-none-any.whl (18.5 kB view details)

Uploaded Python 3

File details

Details for the file clipboard_processor-0.3.1.tar.gz.

File metadata

  • Download URL: clipboard_processor-0.3.1.tar.gz
  • Upload date:
  • Size: 46.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for clipboard_processor-0.3.1.tar.gz
Algorithm Hash digest
SHA256 067963b78ef10646accc622de4e9376a58dfd5f8b28a1ee6540ae12f2f2252df
MD5 af1b695651b634053d103501f5e41add
BLAKE2b-256 9ac4986fc444ae2edbe3f4224ca2ab376169f73d51eeee9f6635f823de0cf810

See more details on using hashes here.

Provenance

The following attestation bundles were made for clipboard_processor-0.3.1.tar.gz:

Publisher: release.yml on tom-mi/clipboard-processor

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

File details

Details for the file clipboard_processor-0.3.1-py3-none-any.whl.

File metadata

File hashes

Hashes for clipboard_processor-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 223bd613dc0afc5422905c21ad448c038e71d3d2f5d41aba940e827f4b9fb4b9
MD5 b93d13b6069aa4594483457f08a894fd
BLAKE2b-256 aab78a21c77dbd40504448f33d2afde0dea4e88068f436b11960a2dd9b0790c0

See more details on using hashes here.

Provenance

The following attestation bundles were made for clipboard_processor-0.3.1-py3-none-any.whl:

Publisher: release.yml on tom-mi/clipboard-processor

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