-
Notifications
You must be signed in to change notification settings - Fork 6
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Python package virtualenv as a dependency #16
Comments
Are you also going to resolve the sluggishness of the pyatv package with this approach ? FYI - My version of the same - https://github.com/NorthernMan54/homebridge-cmd-television I will be updating those packages next month, and can include. Will need assistance around testing though |
Hi @NorthernMan54, I did no experience any problems regarding pyatv besides incompatibility with Python 3.11 which I have fixed with this PR postlund/pyatv#2270. The plugin that I have written is very fast. We are talking <<1s response time. So it is most likely an implementation problem. I cannot look at you source code since there is no source code in your repo. However, from what I can tell from the README your installation, pairing and configuration looks largely manual in contrast to my plugin. As I said, my plugin is installing the venv, the requirements automatically and the pairing process is done without the need to go to the CLI (After autodiscovery of Apple TVs). The pairing process is happening in a web application that is hosted by the plugin when pairing. All the credentials as well as the appletv configs are stored in the userstorage path. |
@NorthernMan54 I just saw the index.js, so source code is checked in. However, the points from my comment before are still valid. |
What I found was that the atvremote commands were sluggish as they negotiated authentication every time ( this was about 18 months ago ) ie
|
PS I would gladly update mine to yours, if it was faster!!!! |
@NorthernMan54 not the right place to discuss that. Please only comment if you have comments on the topic that I have created this issue for. |
@NorthernMan54 I didn't want to deter you away from the discussion, I just wanted to make sure this issue was about what I opened it for. We can discuss if it makes sense to ship the mentioned python3-venv package with homebridge or not. The discussion about whether pyatv for a verified plugin should then be discussed in the issue about verification. The message before was a bit harsh, sorry for that ... |
I have added python3-venv to the test area for the next Homebridge-apt-pkg. Can you take a moment and test it to ensure that everything is okay for your plugin. https://github.com/NorthernMan54/homebridge-apt-pkg/releases/tag/1.20.1 You should be able to downland the appropriate DEB file, and install it with |
@NorthernMan54 That sounds awesome. I will test it on a fresh Raspberry PI OS Bookworm installation and let you know if it is working :) |
So I just tried it on a Raspberry Pi 3 with Pi OS Bookworm 64-bit installed on it. Regarding the virtual environment everything works fine. However, there are problems occuring when installing the python depdencies. Not all dependencies are built for every system architecture, e.g. arm64. Therefore pip tries to build them on itself which requires However, I would like to mention that adding |
FYI - I moved to the package we are working with Does installing The raspbian image and docker image both leverage this package, so the change only needs to be made in one place |
@NorthernMan54 yes, this does mean that there has to be code compiled. In the case of Raspberry Pi OS Lite 64-bit the build tools were already installed. Installing |
Build has been kicked off, it should take about an hour, and a release will be created in the test environment https://github.com/NorthernMan54/homebridge-apt-pkg/actions/runs/6981891690 Release target to be populated https://github.com/NorthernMan54/homebridge-apt-pkg/releases/tag/1.20.2 |
I have made another fresh Pi OS install and can confirm that everything is working with v1.20.2. 👍🏻 |
I just merged and published this as 1.1.4. can you check that production version out, then I will release the other packages. |
Everything is working fine on a fresh install with Homebridge 1.1.4 from the official repository. 🎉 |
Docker image was published a few minutes ago, and the homebridge-raspbian-image is in progress, it usually takes a few hours |
hi all! I am running Homebridge on Docker within unRAID. installed container - Oznu/Homebridge:latest Node.js Version : v20.11.0
when i run in terminal - it does download files which would suggest it was missing and when re-running that command i get:
I don't really know what to do next. Any suggestions? I just want to get the Enhanced Apple TV plugin running! |
Use the latest Homebridge image: https://hub.docker.com/r/homebridge/homebridge |
just wiped the whole thing and forced search through DockerHub and pulled homebridge/homebridge. Oznu/Homebridge:latest = not the latest as you rightfully point out in multiple replies across multiple raised issues referring to virtualenv. thank you for your patience! its now working. Thank you. |
Could you explain how to update the python in homebridge on a synology? Not really tech savvy with coding and such. |
Current Situation
Hi everyone,
first of all I want to say that I am very greatful for this amazing project. It really has changed the way I use my HomeKit home.
I am currently developing the plugin homebridge-appletv-enhanced which enables more possibilities than the vanilla integration of Apple TV into HomeKit. It is still in beta phase, but my aim is to provide a painless experience to the users from installation to initial setup to the usage. I am aiming to get this plugin verified.
The plugin is utilizing the pyatv python package because sadly there is no maintained npm packages which implements the protocol to control an Apple TV … and I know what you are thinking now … how could a plugin that is utilizing a python package provide a painless installation experience?
First, let’s talk about how easy it is for the user up until now.
a. The plugin checks if a supported Python version is installed
b. The plugin checks if the python package
virtualenv
is installedc. The plugin creates a virtual environment in the user storage path of homebridge (if not already created)
d. The plugin installs python packages according to a requirements.txt (if requirements not already satisfied)
e. The plugin discovers devices and so on … installation complete
Since Python 3 is in the docker image, the apt package and the raspian image by default, this requirement should not be a problem.
However, now we are finally coming to the problem I currently have, in order to comply with the requirements of getting a plugin verified, the plugin is not allowed to modify the users system, which is totally understandable and right to do in my mind. So my plugin creates a virtual environment (steps c-d) in the users storage path which is allowed according to the verified requirements. The issue with that is, that many users do not have installed the python package
virtualenv
. There was already an issue created in my repository regarding this problem.Proposed Change
Include the apt package python3-venv in the docker image, the raspian image and as a dependency in the apt package.
What would be the benefit?
virtualenv
being present. This would encourage to use virtual python environments which isolates the plugins that utilize python.Wouldn‘t it be better to "just" use plain type-/javascript? Of course, but in many cases there is not the time to create complex JavaScript libraries that provide functionality that can already be provided by a well maintained python package, like in my case. When not supporting
virtualenv
many developers may be deterred since in the end, there will be no way of installing a plugin painlessly and complying to the verified requirements at the same time withoutvirtualenv
(when utilizing python).Additional Context
No response
The text was updated successfully, but these errors were encountered: