From ebcb28e77d7841b32c5c1c002fb57fdbcfc19f2d Mon Sep 17 00:00:00 2001 From: CoprDistGit Date: Thu, 9 Mar 2023 15:56:04 +0000 Subject: automatic import of python-pysqueezebox --- python-pysqueezebox.spec | 256 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 256 insertions(+) create mode 100644 python-pysqueezebox.spec (limited to 'python-pysqueezebox.spec') diff --git a/python-pysqueezebox.spec b/python-pysqueezebox.spec new file mode 100644 index 0000000..8d3a54b --- /dev/null +++ b/python-pysqueezebox.spec @@ -0,0 +1,256 @@ +%global _empty_manifest_terminate_build 0 +Name: python-pysqueezebox +Version: 0.6.1 +Release: 1 +Summary: Asynchronous library to control Logitech Media Server +License: apache-2.0 +URL: https://github.com/rajlaud/pysqueezebox +Source0: https://mirrors.nju.edu.cn/pypi/web/packages/15/03/8194aa1e1480edde5b683779d57093badfc8f59e51184f2411d4f9ac003e/pysqueezebox-0.6.1.tar.gz +BuildArch: noarch + +Requires: python3-aiohttp + +%description +# pysqueezebox - Asynchronous control of squeezeboxes +This a library to control a Logitech Media Server asynchronously, intended for +integration with Home Assistant. + +Much of the code was adapted from the Home Assistant squeezebox integration. +The current convention is for all API-specific code to be part of a third +party library hosted on PyPi, so I created a separate library. + +The function names track the terms used by the LMS API, so they do not all +match the old Home Assistant squeezebox integration. + +Thank you to the original author of the squeezebox integration. If it is you, +please let me know so I can credit you here. + +# Usage +Install pysqueezebox from github, or using PyPi via pip. +```sh +$ pip3 install pysqueezebox +``` + +## Imports +Import the Server() and Player() classes from this module. You will also need +to create an aiohttp.ClientSession() that the module will use to communicate +with the Logitech Media Server. + +You can use Server.async_get_players() to retrieve a list of connected players, +or get a specific player using Server.async_get_player(name="PlayerName"). +Remember that any method starting with "async_" is a coroutine that must be +preceded by an await to run. + +For more information on using aiohttp.ClientSession(), see +https://aiohttp.readthedocs.io/en/stable/client_reference.html. +```Python +from pysqueezebox import Server, Player +import aiohttp +import asyncio +SERVER = '192.168.1.2' # ip address of Logitech Media Server + +async def main(): + async with aiohttp.ClientSession() as session: + lms = Server(session, SERVER) + player = await lms.async_get_player(name="Bedroom") + await player.async_update() + print(player.album) + await player.async_play() + +loop = asyncio.get_event_loop() +loop.run_until_complete(main()) +``` + +## Player.async_update() +The Player object stores information about the current status of the player. +This allows you to retrieve the player's properties without any I/O. Remember +to call Player.async_update() prior to retrieving properties if you want the +most up-to-date information. + +## Player() class +Most of the useful functions are in the Player class. More documentation to +follow, but in the meantime, the docstrings should be instructive. + + + + +%package -n python3-pysqueezebox +Summary: Asynchronous library to control Logitech Media Server +Provides: python-pysqueezebox +BuildRequires: python3-devel +BuildRequires: python3-setuptools +BuildRequires: python3-pip +%description -n python3-pysqueezebox +# pysqueezebox - Asynchronous control of squeezeboxes +This a library to control a Logitech Media Server asynchronously, intended for +integration with Home Assistant. + +Much of the code was adapted from the Home Assistant squeezebox integration. +The current convention is for all API-specific code to be part of a third +party library hosted on PyPi, so I created a separate library. + +The function names track the terms used by the LMS API, so they do not all +match the old Home Assistant squeezebox integration. + +Thank you to the original author of the squeezebox integration. If it is you, +please let me know so I can credit you here. + +# Usage +Install pysqueezebox from github, or using PyPi via pip. +```sh +$ pip3 install pysqueezebox +``` + +## Imports +Import the Server() and Player() classes from this module. You will also need +to create an aiohttp.ClientSession() that the module will use to communicate +with the Logitech Media Server. + +You can use Server.async_get_players() to retrieve a list of connected players, +or get a specific player using Server.async_get_player(name="PlayerName"). +Remember that any method starting with "async_" is a coroutine that must be +preceded by an await to run. + +For more information on using aiohttp.ClientSession(), see +https://aiohttp.readthedocs.io/en/stable/client_reference.html. +```Python +from pysqueezebox import Server, Player +import aiohttp +import asyncio +SERVER = '192.168.1.2' # ip address of Logitech Media Server + +async def main(): + async with aiohttp.ClientSession() as session: + lms = Server(session, SERVER) + player = await lms.async_get_player(name="Bedroom") + await player.async_update() + print(player.album) + await player.async_play() + +loop = asyncio.get_event_loop() +loop.run_until_complete(main()) +``` + +## Player.async_update() +The Player object stores information about the current status of the player. +This allows you to retrieve the player's properties without any I/O. Remember +to call Player.async_update() prior to retrieving properties if you want the +most up-to-date information. + +## Player() class +Most of the useful functions are in the Player class. More documentation to +follow, but in the meantime, the docstrings should be instructive. + + + + +%package help +Summary: Development documents and examples for pysqueezebox +Provides: python3-pysqueezebox-doc +%description help +# pysqueezebox - Asynchronous control of squeezeboxes +This a library to control a Logitech Media Server asynchronously, intended for +integration with Home Assistant. + +Much of the code was adapted from the Home Assistant squeezebox integration. +The current convention is for all API-specific code to be part of a third +party library hosted on PyPi, so I created a separate library. + +The function names track the terms used by the LMS API, so they do not all +match the old Home Assistant squeezebox integration. + +Thank you to the original author of the squeezebox integration. If it is you, +please let me know so I can credit you here. + +# Usage +Install pysqueezebox from github, or using PyPi via pip. +```sh +$ pip3 install pysqueezebox +``` + +## Imports +Import the Server() and Player() classes from this module. You will also need +to create an aiohttp.ClientSession() that the module will use to communicate +with the Logitech Media Server. + +You can use Server.async_get_players() to retrieve a list of connected players, +or get a specific player using Server.async_get_player(name="PlayerName"). +Remember that any method starting with "async_" is a coroutine that must be +preceded by an await to run. + +For more information on using aiohttp.ClientSession(), see +https://aiohttp.readthedocs.io/en/stable/client_reference.html. +```Python +from pysqueezebox import Server, Player +import aiohttp +import asyncio +SERVER = '192.168.1.2' # ip address of Logitech Media Server + +async def main(): + async with aiohttp.ClientSession() as session: + lms = Server(session, SERVER) + player = await lms.async_get_player(name="Bedroom") + await player.async_update() + print(player.album) + await player.async_play() + +loop = asyncio.get_event_loop() +loop.run_until_complete(main()) +``` + +## Player.async_update() +The Player object stores information about the current status of the player. +This allows you to retrieve the player's properties without any I/O. Remember +to call Player.async_update() prior to retrieving properties if you want the +most up-to-date information. + +## Player() class +Most of the useful functions are in the Player class. More documentation to +follow, but in the meantime, the docstrings should be instructive. + + + + +%prep +%autosetup -n pysqueezebox-0.6.1 + +%build +%py3_build + +%install +%py3_install +install -d -m755 %{buildroot}/%{_pkgdocdir} +if [ -d doc ]; then cp -arf doc %{buildroot}/%{_pkgdocdir}; fi +if [ -d docs ]; then cp -arf docs %{buildroot}/%{_pkgdocdir}; fi +if [ -d example ]; then cp -arf example %{buildroot}/%{_pkgdocdir}; fi +if [ -d examples ]; then cp -arf examples %{buildroot}/%{_pkgdocdir}; fi +pushd %{buildroot} +if [ -d usr/lib ]; then + find usr/lib -type f -printf "/%h/%f\n" >> filelist.lst +fi +if [ -d usr/lib64 ]; then + find usr/lib64 -type f -printf "/%h/%f\n" >> filelist.lst +fi +if [ -d usr/bin ]; then + find usr/bin -type f -printf "/%h/%f\n" >> filelist.lst +fi +if [ -d usr/sbin ]; then + find usr/sbin -type f -printf "/%h/%f\n" >> filelist.lst +fi +touch doclist.lst +if [ -d usr/share/man ]; then + find usr/share/man -type f -printf "/%h/%f.gz\n" >> doclist.lst +fi +popd +mv %{buildroot}/filelist.lst . +mv %{buildroot}/doclist.lst . + +%files -n python3-pysqueezebox -f filelist.lst +%dir %{python3_sitelib}/* + +%files help -f doclist.lst +%{_docdir}/* + +%changelog +* Thu Mar 09 2023 Python_Bot - 0.6.1-1 +- Package Spec generated -- cgit v1.2.3