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.8.0.dev21.tar.gz (67.7 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.8.0.dev21-py3-none-any.whl (36.3 kB view details)

Uploaded Python 3

File details

Details for the file something_x_dev-1.8.0.dev21.tar.gz.

File metadata

  • Download URL: something_x_dev-1.8.0.dev21.tar.gz
  • Upload date:
  • Size: 67.7 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.8.0.dev21.tar.gz
Algorithm Hash digest
SHA256 e0a04afe5a62e9c6386db84bbd81d911cc90f7c59dc2e004999b2b2a88a2096e
MD5 e2a7d3e638f0e602ad0ae612977cc085
BLAKE2b-256 b8ba655590c1639cc5de94db3ba16170a3ca726afc0aac095ee9298d194a2724

See more details on using hashes here.

Provenance

The following attestation bundles were made for something_x_dev-1.8.0.dev21.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.8.0.dev21-py3-none-any.whl.

File metadata

File hashes

Hashes for something_x_dev-1.8.0.dev21-py3-none-any.whl
Algorithm Hash digest
SHA256 39db327f15f81d48cce8b4974300adf6df4c65b0d03e341a98ee7ef3a4107a67
MD5 141b86ece79a303494cde8079ea5332e
BLAKE2b-256 d14415f1dddfb613be1d02776d639555474d34ad3aa607af108e56bbc28a8e1b

See more details on using hashes here.

Provenance

The following attestation bundles were made for something_x_dev-1.8.0.dev21-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