Skip to main content

Mopidy extension for controlling volume on a NAD amplifier

Project description

mopidy-nad

Latest PyPI version CI build status Test coverage

Mopidy extension for controlling volume on a NAD amplifier. Developed and tested with a NAD C355BEE.

Maintainer wanted

Mopidy-NAD is currently kept on life support by the Mopidy core developers. It is in need of a more dedicated maintainer.

If you want to be the maintainer of Mopidy-NAD, please:

  1. Make 2-3 good pull requests improving any part of the project.

  2. Read and get familiar with all of the project's open issues.

  3. Send a pull request removing this section and adding yourself as the "Current maintainer" in the "Credits" section below. In the pull request description, please refer to the previous pull requests and state that you've familiarized yourself with the open issues.

As a maintainer, you'll be given push access to the repo and the authority to make releases to PyPI when you see fit.

Installation

Install by running:

python3 -m pip install mopidy-nad

See https://mopidy.com/ext/nad/ for alternative installation methods.

Configuration

The Mopidy-NAD extension is enabled by default. To disable it, add the following to mopidy.conf:

[nad]
enabled = false

The NAD amplifier must be connected to the machine running Mopidy using a serial cable.

To use the NAD amplifier to control volume, set the audio/mixer config value in mopidy.conf to nad. You probably also needs to add some properties to the nad config section.

Supported properties includes:

  • port: The serial device to use, defaults to /dev/ttyUSB0. This must be set correctly for the mixer to work.

  • source: The source that should be selected on the amplifier, like aux, disc, tape, tuner, etc. Leave unset if you don't want the mixer to change it for you.

  • speakers-a: Set to on or off (or true or false) if you want the mixer to make sure that speaker set A is turned on or off. Leave unset if you don't want the mixer to change it for you.

  • speakers-b: See speakers-a.

Configuration example with minimum configuration, if the amplifier is available at /dev/ttyUSB0::

[audio]
mixer = nad

Configuration example with minimum configuration, if the amplifier is available elsewhere:

[audio]
mixer = nad

[nad]
port = /dev/ttyUSB3

Configuration example with full configuration::

[audio]
mixer = nad

[nad]
port = /dev/ttyUSB0
source = aux
speakers-a = true
speakers-b = false

Project resources

Development

Set up development environment

Clone the repo using, e.g. using gh:

gh repo clone mopidy/mopidy-nad

Enter the directory, and install dependencies using uv:

cd mopidy-nad/
uv sync

Running tests

To run all tests and linters in isolated environments, use tox:

tox

To only run tests, use pytest:

pytest

To format the code, use ruff:

ruff format .

To check for lints with ruff, run:

ruff check .

To check for type errors, use pyright:

pyright .

Making a release

To make a release to PyPI, go to the project's GitHub releases page and click the "Draft a new release" button.

In the "choose a tag" dropdown, select the tag you want to release or create a new tag, e.g. v0.1.0. Add a title, e.g. v0.1.0, and a description of the changes.

Decide if the release is a pre-release (alpha, beta, or release candidate) or should be marked as the latest release, and click "Publish release".

Once the release is created, the release.yml GitHub Action will automatically build and publish the release to PyPI.

Credits

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

mopidy_nad-4.0.0.tar.gz (12.3 kB view details)

Uploaded Source

Built Distribution

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

mopidy_nad-4.0.0-py3-none-any.whl (10.5 kB view details)

Uploaded Python 3

File details

Details for the file mopidy_nad-4.0.0.tar.gz.

File metadata

  • Download URL: mopidy_nad-4.0.0.tar.gz
  • Upload date:
  • Size: 12.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mopidy_nad-4.0.0.tar.gz
Algorithm Hash digest
SHA256 641dabb84c99f1345a6a771299ea91d8aefc7b5810425c686e7a402fec40f305
MD5 55b33d33eea668736012361a21dde3ce
BLAKE2b-256 4ffce4ec50920c40b199519541be6fb01e5eecc5746f5be4772081147ab66b3a

See more details on using hashes here.

Provenance

The following attestation bundles were made for mopidy_nad-4.0.0.tar.gz:

Publisher: release.yml on mopidy/mopidy-nad

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

File details

Details for the file mopidy_nad-4.0.0-py3-none-any.whl.

File metadata

  • Download URL: mopidy_nad-4.0.0-py3-none-any.whl
  • Upload date:
  • Size: 10.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mopidy_nad-4.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 39c393476388f1df194273a797ffad139cf2c10c46db913631aa149410a52cd8
MD5 ed3811ff2d7cc36ecb0c8b90a62536b3
BLAKE2b-256 cbbb9bd4ac8ae49aa01d964319a90b870b9890b050f0d49621261b73eebaa964

See more details on using hashes here.

Provenance

The following attestation bundles were made for mopidy_nad-4.0.0-py3-none-any.whl:

Publisher: release.yml on mopidy/mopidy-nad

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