Provides an API for requesting information from an Openhome device
Project description
openhomedevice
Library to provide an API to an existing openhome device. The device needs to have been discovered first by something like netdisco (https://github.com/home-assistant/netdisco).
The underlying UPnP client library used is https://github.com/StevenLooman/async_upnp_client
- Tested against Linn Products Ltd devices running Davaar 80 (thought expected to work on earlier variants)
- Tested against OpenHome Player devices
Installation
pip install openhomedevice
API
Constructor
device = Device(location)
await device.init()
Methods
Control
await set_standby(standbyRequested) #bool
await play() #starts playback
await play_media(track_details) #start playing `track_details`
await stop() #stops playback
await pause() #pauses playback
await skip(offset) #positive or negative integer
await set_volume(volume_level) #positive number
await increase_volume() #increase volume by 1
await decrease_volume() #decrease volume by 1
await set_mute(muteRequested) #bool
await set_source(index) #positive integer (use Sources() for indices)
await invoke_pin(index) #positive integer (use Pins() for indices)
Firmware
await check_latest_firmware() #check for the latest firmware
await update_firmware() #update the device firmware
await software_status() #returns a dictionary with information about the current software
Informational
uuid() #Unique identifier
manufacturer() #Manufacturer
model_name() #Model Name
friendly_name() #Friendly Name
await name() #Name of device
await room() #Name of room
await is_in_standby() #returns true if in standby
await transport_state() #returns one of Stopped, Playing, Paused or Buffering.
volume_enabled #property true if the volume service is available
await volume_level() #returns the volume setting or None if disabled
await is_muted() #returns true if muted or None if disabled
await source() #returns the currently connected source as a dictionary
await sources() #returns an array of source dictionaries with indices
await track_info() #returns a track dictionary
await pins() #returns an array of pin dictionaries with indices
pins_enabled #property true if the pins service is available
Source Response
{
'type': 'Playlist',
'name': 'Playlist'
}
Sources Response
[
{ 'index': 0, 'type': 'Playlist', 'name': 'Playlist' },
{ 'index': 1, 'type': 'Radio', 'name': 'Radio' },
{ 'index': 3, 'type': 'Receiver', 'name': 'Songcast' },
{ 'index': 6, 'type': 'Analog', 'name': 'Front Aux' }
]
Pins Response
[
{'index': 1, 'title': 'Playstation 4', 'artworkUri': 'external:///source?type=Hdmi&systemName=HDMI3'}
{'index': 4, 'title': 'Classic FM', 'artworkUri': 'http://cdn-profiles.tunein.com/s8439/images/logoq.png?t=1'}
{'index': 6, 'title': 'Chillout Playlist', 'artworkUri': 'http://media/artwork/chillout-playlist.png'}
]
TrackInfo Response
{
"mimeType": "http-get:*:audio/x-flac:DLNA.ORG_OP=01;DLNA.ORG_FLAGS=01700000000000000000000000000000",
"rating": None,
"performer": [
"Fahmi Alqhai, Performer - Johann Sebastian Bach, Composer"
],
"bitDepth": 16,
"channels": 2,
"disc": None,
"composer": [],
"year": 2017,
"duration": 460,
"author": [],
"albumArtist": [],
"type": "object.item.audioItem.musicTrack",
"narrator": [],
"description": None,
"conductor": [],
"albumArtwork": "http://static.qobuz.com/images/covers/58/20/8424562332058_600.jpg",
"track": 2,
"tracks": None,
"artwork": None,
"genre": [
"Klassiek"
],
"publisher": "Glossa",
"albumGenre": [
"Klassiek"
],
"artist": [
"Fahmi Alqhai"
],
"bitRate": None,
"albumTitle": "The Bach Album",
"uri": "http://192.168.0.110:58050/stream/audio/b362f0f7a1ff33b176bcf2adde75af96.flac",
"discs": None,
"published": None,
"title": "Violin Sonata No. 2 in A Minor, BWV 1003 (Arr. for Viola da gamba) : Violin Sonata No. 2 in A Minor, BWV 1003 (Arr. for Viola da gamba): II. Fuga",
"sampleRate": 44100
}
SoftwareStatus response
When an update is available:
{
"status":"update_available",
"current_software":{
"version":"4.99.491",
"topic":"main",
"channel":"release"
},
"update_info":{
"legal":{
"licenseurl":"http://products.linn.co.uk/VersionInfo/licenseV2.txt",
"privacyurl":"https://www.linn.co.uk/privacy",
"privacyuri":"https://products.linn.co.uk/VersionInfo/PrivacyV1.json",
"privacyversion":1
},
"releasenotesuri":"http://docs.linn.co.uk/wiki/index.php/ReleaseNotes",
"updates":[
{
"channel":"release",
"date":"07 Jun 2023 12:29:48",
"description":"Release build version 4.100.502 (07 Jun 2023 12:29:48)",
"exaktlink":"3",
"manifest":"https://cloud.linn.co.uk/update/components/836/4.100.502/manifest.json",
"topic":"main",
"variant":"836",
"version":"4.100.502"
}
],
"exaktUpdates":[]
}
}
When the system is on the latest firmware:
{
"status":"on_latest",
"current_software":{
"version":"4.100.502",
"topic":"main",
"channel":"release"
}
}
Upgrading Firmware
Use this to check if an update is required and then instruct the device to apply it
await openhomeDevice.check_latest_firmware()
await openhomeDevice.update_firmware()
Playing A Track
Use this to play a short audio track, a podcast Uri or radio station Uri. The audio will be played using the radio source of the device. The trackDetails
object should be the same as the one described in the TrackInfo
section above.
track_details = {}
track_details["uri"] = "http://opml.radiotime.com/Tune.ashx?id=s122119"
track_details["title"] = 'Linn Radio (Eclectic Music)'
track_details["albumArtwork"] = 'http://cdn-radiotime-logos.tunein.com/s122119q.png'
openhomeDevice.PlayMedia(track_details)
Example
python3 demo.py
Running Tests
PYTHONPATH=. pytest ./tests/*
Uploading Package
Following guide from https://packaging.python.org/tutorials/packaging-projects/
Update version in setup.py
python3 setup.py sdist
twine upload dist/*
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file openhomedevice-2.3.1.tar.gz
.
File metadata
- Download URL: openhomedevice-2.3.1.tar.gz
- Upload date:
- Size: 10.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 94784c9b790ab6329d09df07f6e57c007301e86894887c9e3eb083fb498049b8 |
|
MD5 | cdf32dd4e058ece1784a3395e9dd71d2 |
|
BLAKE2b-256 | 9325f621c4ccc79e20c8816225512f77b1c35ad91661469370d9d8fe2c12533d |