Skip to main content

Something X device manager for Omarchy / Linux

Project description

Something X

A Linux-native companion app for Nothing and CMF Bluetooth devices.
Built for Omarchy · GTK4 · Pure black · JetBrains Mono · Nothing Red

PyPI AUR License: MIT Platform CI Coverage


Features

Feature Details
🎧 Earbud visual Cairo-rendered glowing battery rings for L / R / Case, live updates
🔇 ANC control Off · Noise Cancellation · Transparency over real RFCOMM protocol
🎵 EQ presets Balanced · More Bass · More Treble · Voice
🔊 Volume slider Direct PulseAudio / PipeWire A2DP sink control via pactl
💾 Per-device profiles ANC + EQ saved per device address, restored automatically on reconnect
🔋 Battery notifications Desktop alerts at 20 %, 15 %, 10 %, and 5 % per earbud and case
🔗 Auto-connect RFCOMM Connects to the device protocol as soon as BlueZ reports it paired
🏃 Background mode Closing the window keeps the app running; relaunch to reopen
💻 CLI Control your earbuds from the terminal without opening the GUI
📱 Device discovery BlueZ D-Bus scan with Nothing / CMF devices highlighted
ℹ️ Device info Firmware version and serial number read over RFCOMM

Device support

Device Battery ANC EQ Volume Firmware
Nothing Ear (1)
Nothing Ear (2)
Nothing Ear (a)
Nothing Ear (stick)
CMF Buds / Buds Pro
Nothing Phone (1/2)
Other Bluetooth devices ✅*

* via BlueZ Battery1 interface · RFCOMM features require an active connection


Installation

Arch / Omarchy (recommended)

Install system dependencies first:

sudo pacman -S python-gobject python-dbus python-cairo gtk4 libadwaita

Then install from AUR:

yay -S something-x
# or: paru -S something-x

Or via pip:

pip install something-x

Other distros

Ubuntu 24.04+
sudo apt install python3-gi python3-dbus python3-cairo gir1.2-gtk-4.0 gir1.2-adw-1
pip install something-x
Fedora 39+
sudo dnf install python3-gobject python3-dbus python3-cairo gtk4 libadwaita
pip install something-x
NixOS
nix run github:SoaOaoS/something-x

A flake.nix is included for reproducible builds.

Run from source

git clone https://github.com/SoaOaoS/something-x
cd something-x
pip install -e .
something-x

Usage

GUI

something-x
  1. Splash — animated intro, main window appears after ~2 s
  2. Home — lists all paired Bluetooth devices; Nothing / CMF devices get a NOTHING badge
  3. Scan — tap SCAN FOR DEVICES to run a 30 s BlueZ discovery
  4. Device page — tap a card to open controls:
    • Battery rings (L / R / Case) update in real time
    • ANC and EQ apply immediately over RFCOMM and are saved to your profile
    • Volume slider drives the A2DP sink via pactl
    • Firmware version and serial number appear after RFCOMM connects
  5. Close — hides to background; run something-x again to reopen

CLI

Control your earbuds without opening the GUI:

# Battery levels
something-x --battery

# ANC mode
something-x --anc off
something-x --anc on
something-x --anc transparency

# EQ preset
something-x --eq balanced
something-x --eq bass
something-x --eq treble
something-x --eq voice

# Combine
something-x --anc on --eq bass

# Target a specific device by address
something-x --device AA:BB:CC:DD:EE:FF --battery

Development releases

The develop branch publishes pre-release builds to PyPI automatically as something-x-dev:

pip install something-x-dev
something-x-dev

Dev builds use version numbers like 1.3.0.dev42. Not for production use.


Releases & versioning

Pushing to main triggers automatic versioning, a GitHub Release, a PyPI publish, and an AUR update — all from Conventional Commits:

Commit prefix Version bump
feat!: / BREAKING CHANGE: Major x.0.0
feat: Minor 1.x.0
fix: / perf: / refactor: Patch 1.0.x
docs: / chore: / style: / ci: / test: No release

Architecture

nothing_app/
├── application.py   Adw.Application — lifecycle, CSS, CLI arg handling, background mode
├── window.py        AdwNavigationView — home ↔ device routing, RFCOMM auto-connect manager
├── bluetooth.py     BlueZ D-Bus manager — device discovery, connect/disconnect signals
├── protocol.py      Nothing Ear 0x55 RFCOMM protocol (reverse-engineered from APK)
├── profiles.py      Per-device ANC/EQ persistence (~/.config/something-x/profiles.json)
├── splash.py        Animated splash screen (Cairo, typewriter, ripple rings)
├── data/
│   └── style.css    Glass-morphism CSS theme
└── pages/
    ├── home.py      Device list + scan button
    └── device.py    ANC / EQ / volume / settings + Cairo earbud visual

Protocol

Frame format: [SOF=0x55][ctrl:2 LE][cmd:2 LE][len:2 LE][FSN:1][payload][CRC16:2 LE]

All outgoing frames use ctrl=0x0160 with CRC16-ARC. The device silently drops SET commands if any frame in the session was sent without CRC.

Enable raw frame logging:

SOMETHING_X_DEBUG=1 something-x

Contributing

The RFCOMM protocol in nothing_app/protocol.py is reverse-engineered from the official Android APK. If your device uses different command IDs, channels, or ANC values, patches are very welcome — please include the raw RFCOMM dump (SOMETHING_X_DEBUG=1) in your issue or PR.


License

MIT

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

something_x_dev-1.7.0.dev15.tar.gz (38.9 kB view details)

Uploaded Source

Built Distribution

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

something_x_dev-1.7.0.dev15-py3-none-any.whl (36.0 kB view details)

Uploaded Python 3

File details

Details for the file something_x_dev-1.7.0.dev15.tar.gz.

File metadata

  • Download URL: something_x_dev-1.7.0.dev15.tar.gz
  • Upload date:
  • Size: 38.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for something_x_dev-1.7.0.dev15.tar.gz
Algorithm Hash digest
SHA256 e222de5b50b8aa6f9b8a8c3b33ffce253b7cb6b8f9b5f35e87cfc64c4ad14d29
MD5 622f4e5246f10c57adea6c881df8c7a3
BLAKE2b-256 d99402a00d376f082c20c0b8b0f7d73b4a5bcf4457a2c7280241a0abb0556157

See more details on using hashes here.

Provenance

The following attestation bundles were made for something_x_dev-1.7.0.dev15.tar.gz:

Publisher: release-dev.yml on SoaOaoS/something-x

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

File details

Details for the file something_x_dev-1.7.0.dev15-py3-none-any.whl.

File metadata

File hashes

Hashes for something_x_dev-1.7.0.dev15-py3-none-any.whl
Algorithm Hash digest
SHA256 67e1ed18a1b7a5d8d4688d320b79f9b07a0726b045042b4f25405f440b5e7b4a
MD5 a7a77cf837a0a4d528c430aba9f4af78
BLAKE2b-256 9794ae18e2e62cb621a39c0514b8be606d116c393840492d9986149ce9028617

See more details on using hashes here.

Provenance

The following attestation bundles were made for something_x_dev-1.7.0.dev15-py3-none-any.whl:

Publisher: release-dev.yml on SoaOaoS/something-x

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