-
Notifications
You must be signed in to change notification settings - Fork 83
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
separate unoconvert so it can be run from user virtualenv without uno or system-site-packages #29
Comments
There should be no need for libreoffice packages etc. at all on a unoconvert-client-only host. It's horrible to install (and update) the whole of libreoffice as a dependency for what's probably a very simple TCP thingy. |
That's not possible, sorry. The communication is handled by the uno library that is a part of Libreoffice. |
Hi there, it is possible and there are a few ways to do it. One way (I did something similar recently) is to use python's xmlrpc to add an rpc server to converter.py. The server would need to wrap Converter.convert so that it can be called from another process via rpc. An xmlrpc client would also be needed, but you only have one function that needs to be wrapped so would be quick to do The xmlrpc client would be installable in virtualenvs. Users would need to take care of starting the server/converter before using it via the xmlrpc client. See e.g. https://docs.python.org/3/library/xmlrpc.server.html#module-xmlrpc.server |
I've added in #32 rough changes that would be needed to add the rpc server. The client will also be quite simple |
Yes, sure we could build a completely different rpcserver and do this, but that's not what this module does, and you could do that on your side as well. The convert server in your case would still have the exact same problem, it needs to have access to the uno library. Yes, you would now get a "client client" that does not, but that doesn't really solve the issue itself. You still need to install unoserver so it has access to LibreOffice. |
Thanks & yes agreed that this library would still need to be installed into system python env along with libreoffice+uno, there is no way around that. The problem I was trying to solve is that other projects need to use this library, but at the moment they can only do so by either: i) running converter.py as a separate process (taking care to use system python not virtualenv python), or ii) installing the project into system python env. Both have their downsides especially the latter option you risk breaking your system python or being unable to satisfy the project's dependencies. Also as an improvement to suggested structure, it would make more sense to run the rpc server in the same process that starts soffice (rpc server would still run from system python env). All the conversion code could be moved back into a "unoserver+rpc" module and the converter client could be very lightweight, using only RPC for conversion via both command line and API. This would also allow the converter to be installed in virtualenvs. Thanks! |
It would make it possible to make a Python library to make conversions, so that's a benefit. |
Having unoserver start a server, f ex with xml-rpc, and letting unoconvert use that instead is something we are fine with maintaining. It doesn't look like I will have time to implement it at the moment, but we are happy to accept contributions. I would like to see the protocol used to somehow be versioned, so that we give an explicit error message if we end up using the wrong versions, and possibly even support different versions. |
2.0a is out now with an XML-RPC server |
A great improvement! Will start testing ASAP and move into production rather quickly, I assume... |
Headsup! I noticed the --daemon argument doesn't work in 2.0b1. If you need that I'll release a 2.0b2. |
Daemons are kind of redundant these days, with systemd it's much better to run service processes in the foreground. I managed to get the server bit running on a dedicated conversion server for a test (moodle) environment, ie. installed 2.0b1 over what was there previously and it still just magically works. But then, I hit sort of a brick wall. Sorry for the stupid question, but how might one actually run the light client? We now have a situation where transferring the data to convert and the resulting file via the XML-RPC mechanism (instead of NFS access currently used elsewhere) would be pure gold too... |
The unoconvert client script acts as that wrapper, so you would still use it the same way, by starting unoserver, and then using unconvert to convert files. |
Ah. Thanks for that golden tip. Running setup install with the system python and a custom prefix actually works, I did get the whole thing running and a remote conversion working. |
Great stuff! Thanks for that, I'll release a 2.0 final shortly. |
Happy to report that after some stress- and other testing we went into production (with 2.0b1) on our main Moodle instance, so now there are quite a lot of (end user) beta testers involved. :D In case you'd like to add some docs/tips/examples, I've written a wrapper script which emulates unoconv 0.7, which Moodle directly supports - hopefully, can get rid of it via native support some day, but it works. Other than that, the most interesting bits are probably the converter service multi-instance systemd unit (ie. 'systemctl enable unoserver@2001 unoserver@2002') and maybe some haproxy config tips. (Perhaps the non-interactive installation scripts for everything too, but they're a bit too specific for our environment to share...)
/opt/bin/unoserver-wrapper:
haproxy config bits (from a keepalived+haproxy balancer pair, shared with other related use):
(In production, we actually use 2 converter servers with 6 libreoffice 7.6.2's running on each.) last but not least, the unoconv-remote translator script for Moodle (uses a static document formats list generated with unoconv 0.7):
|
Glad to hear it! It would be good to have some place to store configuration tips. |
This would completely isolate unoconvert and make use of it in virtualenvs safer
unoconvert is already a remote process that doesn't in theory need access to uno directly (via import, etc), and using system-site-packages is a bit fragile - if your virtualenv is not setup correctly you might accidentally import a system package instead of one you thought you had in your virtualenv.
Thanks for great package!
The text was updated successfully, but these errors were encountered: