unoserver
=========
Using LibreOffice as a server for converting documents.
Overview
--------
Using LibreOffice to convert documents is easy, you can use a command like this to
convert a file to PDF, for example::
$ libreoffice --headless --convert-to pdf ~/Documents/MyDocument.odf
However, that will load LibreOffice into memory, convert a file and then exit LibreOffice,
which means that the next time you convert a document LibreOffice needs to be loaded into
memory again.
To avoid that, LibreOffice has a listener mode, where it can listen for commands via a port,
and load and convert documents without exiting and reloading the software. This lowers the
CPU load when converting many documents with somewhere between 50% and 75%, meaning you can
convert somewhere between two and four times as many documents in the same time using a listener.
Unoserver contains three commands to help you do this, `unoserver` which starts a listener on the
specified IP interface and port, and `unoconverter` which will connect to a listener and ask it
to convert a document, as well as `unocompare` which will connect to a listener and ask it
to compare two documents and convert the result document.
Installation
------------
NB! Windows and Mac support is as of yet untested.
Unoserver needs to be installed by and run with the same Python installation that LibreOffice uses,
to properly run the `unoserver` command. For client/server installations, see below.
On Unix this usually means you can just install it with::
$ sudo -H pip install unoserver
If you have multiple versions of LibreOffice installed, you need to install it for each one.
Usually each LibreOffice install will have it's own `python` executable and you need to run
`pip` with that executable::
$ sudo -H /full/path/to/python -m pip install unoserver
To find all Python installations that have the relevant LibreOffice libraries installed,
you can run a script called `find_uno.py`::
wget -O find_uno.py https://gist.githubusercontent.com/regebro/036da022dc7d5241a0ee97efdf1458eb/raw/find_uno.py
python3 find_uno.py
This should give an output similar to this::
Trying python found at /usr/bin/python3... Success!
Trying python found at /opt/libreoffice7.1/program/python... Success!
Found 2 Pythons with Libreoffice libraries:
/usr/bin/python3
/opt/libreoffice7.1/program/python
The `/usr/bin/python3` binary will be the system Python used for versions of
Libreoffice installed by the system package manager. The Pythons installed
under `/opt/` will be Python versions that come with official LibreOffice
distributions.
To install on such distributions, do the following::
$ wget https://bootstrap.pypa.io/get-pip.py
$ sudo /path/to/python get-pip.py
$ sudo /path/to/python -m pip install unoserver
You can also install it in a virtualenv, if you are using the system Python
for that virtualenv, and specify the ``--system-site-packages`` parameter::
$ virtualenv --python=/usr/bin/python3 --system-site-packages virtenv
$ virtenv/bin/pip install unoserver
Windows and Mac installs aren't officially supported yet, but on Windows the
paths to the LibreOffice Python executable are usually in locations such as
`C:\\Program Files (x86)\\LibreOffice\\python.exe`. On Mac it can be for
example `/Applications/LibreOffice.app/Contents/python` or
`/Applications/LibreOffice.app/Contents/Resources/python`.
Usage
-----
Installing unoserver installs three scripts, `unoserver`, `unoconverter` and `unocompare`.
The server can also be run as a module with `python3 -m unoserver.server`, with the same
arguments as the main script, which can be useful as it must be run with the LibreOffice
provided Python.
Unoserver
~~~~~~~~~
.. code::
unoserver [-h] [-v] [--interface INTERFACE] [--uno-interface UNO_INTERFACE] [--port PORT] [--uno-port UNO_PORT]
[--daemon] [--executable EXECUTABLE] [--user-installation USER_INSTALLATION]
[--libreoffice-pid-file LIBREOFFICE_PID_FILE]
* `--interface`: The interface used by the XMLRPC server, defaults to "127.0.0.1"
* `--port`: The port used by the XMLRPC server, defaults to "2003"
* `--uno-interface`: The interface used by the LibreOffice server, defaults to "127.0.0.1"
* `--uno-port`: The port used by the LibreOffice server, defaults to "2002"
* `--daemon`: Deamonize the server
* `--executable`: The path to the LibreOffice executable
* `--user-installation`: The path to the LibreOffice user profile, defaults to a dynamically created temporary directory
* `--libreoffice-pid-file`: If set, unoserver will write the Libreoffice PID to this file.
If started in daemon mode, the file will not be deleted when unoserver exits.
* `--conversion-timeout`: Terminate Libreoffice and exit if a conversion does not complete in the given time (in seconds).
* `-v, --version`: Display version and exit.
Unoconvert
~~~~~~~~~~
.. code::
unoconvert [-h] [-v] [--convert-to CONVERT_TO] [--input-filter INPUT_FILTER] [--output-filter OUTPUT_FILTER]
[--filter-options FILTER_OPTIONS] [--update-index] [--dont-update-index] [--host HOST] [--port PORT]
[--host-location {auto,remote,local}] infile outfile
* `infile`: The path to the file to be converted (use - for stdin)
* `outfile`: The path to the converted file (use - for stdout)
* `--convert-to`: The file type/extension of the output file (ex pdf). Required when using stdout
* `--input-filter`: The LibreOffice input filter to use (ex 'writer8'), if autodetect fails
* `--output-filter`: The export filter to use when converting. It is selected automatically if not specified.
* `--filter`: Deprecated alias for `--output-filter`
* `--filter-option`: Pass an option for the export filter, in name=value format. Use true/false for boolean values. Can be repeated for multiple options.
* `--filter-options`: Deprecated alias for `--filter-option`.
* `--host`: The host used by the server, defaults to "127.0.0.1"
* `--port`: The port used by the server, defaults to "2003"
* `--host-location`: The host location determines the handling of files. If you run the client on the
same machine as the server, it can be set to local, and the files are sent as paths. If they are
different machines, it is remote and the files are sent as binary data. Default is auto, and it will
send the file as a path if the host is 127.0.0.1 or localhost, and binary data for other hosts.
* `-v, --version`: Display version and exit.
Example for setting PNG width/height::
unoconvert infile.odt outfile.png --filter-options PixelWidth=640 --filter-options PixelHeight=480
Unocompare
~~~~~~~~~~
.. code::
unocompare [-h] [-v] [--file-type FILE_TYPE] [--host HOST] [--port PORT] [--host-location {auto,remote,local}]
oldfile newfile outfile
* `oldfile`: The path to the older file to be compared with the original one (use - for stdin)
* `newfile`: The path to the newer file to be compared with the modified one (use - for stdin)
* `outfile`: The path to the result of the comparison and converted file (use - for stdout)
* `--file-type`: The file type/extension of the result output file (ex pdf). Required when using stdout
* `--host`: The host used by the server, defaults to "127.0.0.1"
* `--port`: The port used by the server, defaults to "2003"
* `--host-location`: The host location determines the handling of files. If you run the client on the
same machine as the server, it can be set to local, and the files are sent as paths. If they are
different machines, it is remote and the files are sent as binary data. Default is auto, and it will
send the file as a path if the host is 127.0.0.1 or localhost, and binary data for other hosts.
* `-v, --version`: Display version and exit.
Client/Server installations
---------------------------
If you are installing Unoserver on a dedicated machine (virtual or not) to do the conversions and
are running the commands from a different machine, or if you want to call the convert/compare commands
from Python directly, the clients do not need access to Libreoffice. You can therefore follow the
instructions above to make Unoserver have access to the LibreOffice library, but on the client
side you can simply install Unoserver as any other Python library, with `python -m pip install unoserver`
using the Python you want to use as the client executable.
Please note that there is no security on either ports used, and as a result Unoserver is vulnerable
to DDOS attacks, and possibly worse. The ports used **must not** be accessible to anything outside the
server stack being used.
Unoserver is designed to be started by some service management software, such as Supervisor or similar,
that will restart the service should it crash. Unoserver does not try to restart LibreOffice if it
crashes, but should instead also stop in that sitution. The ``--conversion-timeout`` argument will
teminate LibreOffice if it takes to long to convert a document, and that termination will also result
in Unoserver quitting. Because of this service monitoring software should be set up to restart
Unoserver when it exits.
Development and Testing
-----------------------
1. Clone the repo from `https://github.com/unoconv/unoserver`.
2. Setup a virtualenv::
$ virtualenv --system-site-packages ve
$ ve/bin/pip install -e .[devenv]
3. Run tests::
$ ve/bin/pytest tests
4. Run `flake8` linting:
$ ve/bin/flake8 src tests
Comparison with `unoconv`
-------------------------
Unoserver started as a rewrite, and hopefully a replacement to `unoconv`, a module with support
for using LibreOffice as a listener to convert documents.
Differences for the user
~~~~~~~~~~~~~~~~~~~~~~~~
* Easier install for system versions of LibreOffice. On Linux, the packaged versions of LibreOffice
typically uses the system Python, making it easy to install `unoserver` with a simple
`sudo pip install unoserver` command.
* Separate commands for server and client. The client no longer tries to start a listener and then
close it after conversion if it can't find a listener. Instead the new `unoconverter` client
requires the `unoserver` to be started. This makes it less practical for one-off converts,
but as mentioned that can easily be done with LibreOffice itself.
* The `unoserver` listener does not prevent you from using LibreOffice as a normal user, while the
`unoconv` listener would block you from starting LibreOffice to open a document normally.
* You should be able to on a multi-core machine run several `unoservers` with different ports.
There is however no support for any form of load balancing in `unoserver`, you would have to
implement that yourself in your usage of `unoconverter`. For performant multi-core scaling, it
is necessary to specify unique values for each `unoserver`'s `--port` and `--uno-port` options.
* Only LibreOffice is officially supported. Other variations are untested.
Differences for the maintainer
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
* It's a complete and clean rewrite, supporting only Python 3, with easier to understand and
therefore easier to maintain code, hopefully meaning more people can contribute.
* It doesn't rely on internal mappings of file types and export filters, but asks LibreOffice
for this information, which will increase compatibility with different LibreOffice versions,
and also lowers maintenance.
Contributors
------------
* Lennart Regebro, regebro@gmail.com
* Stephan Richter, srichter@shoobx.com
* Bruno Simão, https://github.com/ankology
* Åsmund Stavdahl, https://github.com/asmundstavdahl
* Balázs Varga, https://github.com/bvarga91
* Alessandro Filippini, https://github.com/AlePini
* Dmitry Shachnev, https://github.com/mitya57
* Socheat Sok, https://github.com/socheatsok78
* BohwaZ, https://github.com/bohwaz
* ReeceJones, https://github.com/ReeceJones
* Grunthos, https://github.com/Grunthos
3.0.1 (2024-10-26)
------------------
- Accidentally import uno library where it isn't needed.
3.0 (2024-10-22)
----------------
- No changes since beta.
3.0b2 (2024-10-15)
------------------
- Implementing a separate API version for more version flexibility, as I'm
releasing more often than I expected.
3.0b1 (2024-10-11)
------------------
- Added a --conversion-timeout argument to ``unoserver``, which causes unoserver
to fail if a conversion doesn't finish within a certain time.
- By default it will now use the `soffice`` executable instead of `libreoffice`,
as I had a problem with it using 100% load when started as `libreoffice`.
2.3b1 (2024-10-09)
------------------
- Much better handling of LibreOffice crashing or failing to start.
2.2.2 (2024-09-18)
------------------
- Fixed a memory leak in unoserver.
2.2.1 (2024-07-24)
------------------
- Restored Python 3.8 functionality.
2.2 (2024-07-23)
----------------
- ReeceJones added support to specify IPv6 adresses.
- Now tries to connect to the server, with retries if the server has
not been started yet.
- Verifies that the version installed on the server and client is the same.
- If you misspell a filter name, the output is nicer.
- The clients got very silent in the refactor, fixed that.
- --verbose and --quiet arguments to get even more output, or less.
2.1 (2024-03-26)
----------------
- Released with the wrong version number, that should have been 2.1.
2.0.2 (2024-03-21)
------------------
- Added --version flags to the commands to print the version number.
Also unoserver prints the version on startup.
- File paths are now always sent as absolute paths.
2.1b1 (2024-01-12)
------------------
- Add a --input-filter argument to specify a different file type than the
one LibreOffice will guess.
- For consistency renamed --filter to --output-filter, but the --filter
will remain for backwards compatibility.
- If you specify a non-existent filter, the list of filters is now alphabetical.
- You can now use both the LibreOffice name, but also internal shorter names
and sometimes even file suffices to specify the filter.
2.0.1 (2024-01-12)
------------------
- Specifying `--host-location=remote` didn't work for the outfile if you
used port forwarding from localhost.
- Always default the uno interface to 127.0.0.1, no matter what the XMLRPC
interface is.
2.0 (2023-10-19)
----------------
- Made the --daemon parameter work again
- Added a --filter-option alias for --filter-options
2.0b1 (2023-08-18)
------------------
- A large refactoring with an XML-RPC server and a new client using that XML-RPC
server for communicating. This means the client can now be lightweight, and
no longer needs the Uno library, or even LibreOffice installed. Instead the
new `unoserver.client.UnoClient()` can be used as a library from Python.
- A cleanup and refactor of the commands, with new, more gooder parameter names.
1.6 (2023-08-18)
----------------
- Added some deprecation warnings for command arguments as they will change in 2.0.
1.5 (2023-08-11)
----------------
- Added support for passing in filter options with the --filter-options parameter.
- Add `--user-installation` flag to `unoserver` for custom user installations.
- Add a `--libreoffice-pid-file` argument for `unoserver` to save the LibreOffice PID.
1.4 (2023-04-28)
----------------
- Added new feature: comparing documents and export the result to any format.
- You can run the new module as scripts, and also with ``python3 -m unoserver.comparer`` just
like the ``python3 -m unoserver.server`` and ``python3 -m unoserver.converter``.
- Porting feature from previous release: refresh of index in the Table of Contents
1.3 (2023-02-03)
----------------
- Now works on Windows (although it's not officially supported).
- Added --filter argument to unoconverter to allow explicit selection of which
export filter to use for conversion.
1.2 (2022-03-17)
----------------
- Move logging configuration from import time to the main() functions.
- Improved the handling of KeyboardInterrupt
- Added the deprecated but still necessary com.sun.star.text.WebDocument
for HTML docs.
1.1 (2021-10-14)
----------------
- Fixed a bug: If you specified an unknown file extension while piping the
result to stdout, you would get a type error instead of the correct error.
- Added an extra check that libreoffice is quite dead when exiting,
I experienced a few cases where soffice.bin was using 100% load in the
background after unoserver exited. I hope this takes care of that.
- Added ``if __name__ == "main":`` blocks so you can run the modules
as scripts, and also with ``python3 -m unoserver.server`` and
``python3 -m unoserver.converter``.
1.0.1 (2021-09-20)
------------------
- Fixed a bug that meant `unoserver` did not behave well with Supervisord's restart command.
1.0 (2021-08-10)
----------------
- A few small spelling and grammar changes.
1.0b3 (2021-07-01)
------------------
- Make sure `interface` and `port` options are honored.
- Added an --executable option to the server to pick a specific libreoffice installation.
- Changed the infile and outfile options to be positional.
- Added support for using stdin and stdout.
- Added a --convert-to argument to specify the resulting filetype.
1.0b2 (2021-06-24)
------------------
- A bug prevented converting to or from files in the local directory.
1.0b1 (2021-06-24)
------------------
- First beta release
0.0.1 (2021-06-16)
------------------
- First alpha release
Raw data
{
"_id": null,
"home_page": null,
"name": "unoserver",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.8",
"maintainer_email": null,
"keywords": "libreoffice, conversion, documents, uno, unoconv",
"author": null,
"author_email": "Lennart Regebro <regebro@gmail.com>",
"download_url": "https://files.pythonhosted.org/packages/6c/03/551b6002b07822d5e1892f77fe758a3c18317f659e8751ce343bb6d280af/unoserver-3.0.1.tar.gz",
"platform": null,
"description": "unoserver\n=========\n\nUsing LibreOffice as a server for converting documents.\n\nOverview\n--------\n\nUsing LibreOffice to convert documents is easy, you can use a command like this to\nconvert a file to PDF, for example::\n\n $ libreoffice --headless --convert-to pdf ~/Documents/MyDocument.odf\n\nHowever, that will load LibreOffice into memory, convert a file and then exit LibreOffice,\nwhich means that the next time you convert a document LibreOffice needs to be loaded into\nmemory again.\n\nTo avoid that, LibreOffice has a listener mode, where it can listen for commands via a port,\nand load and convert documents without exiting and reloading the software. This lowers the\nCPU load when converting many documents with somewhere between 50% and 75%, meaning you can\nconvert somewhere between two and four times as many documents in the same time using a listener.\n\nUnoserver contains three commands to help you do this, `unoserver` which starts a listener on the\nspecified IP interface and port, and `unoconverter` which will connect to a listener and ask it\nto convert a document, as well as `unocompare` which will connect to a listener and ask it\nto compare two documents and convert the result document.\n\n\nInstallation\n------------\n\nNB! Windows and Mac support is as of yet untested.\n\nUnoserver needs to be installed by and run with the same Python installation that LibreOffice uses,\nto properly run the `unoserver` command. For client/server installations, see below.\n\nOn Unix this usually means you can just install it with::\n\n $ sudo -H pip install unoserver\n\nIf you have multiple versions of LibreOffice installed, you need to install it for each one.\nUsually each LibreOffice install will have it's own `python` executable and you need to run\n`pip` with that executable::\n\n $ sudo -H /full/path/to/python -m pip install unoserver\n\nTo find all Python installations that have the relevant LibreOffice libraries installed,\nyou can run a script called `find_uno.py`::\n\n wget -O find_uno.py https://gist.githubusercontent.com/regebro/036da022dc7d5241a0ee97efdf1458eb/raw/find_uno.py\n python3 find_uno.py\n\nThis should give an output similar to this::\n\n Trying python found at /usr/bin/python3... Success!\n Trying python found at /opt/libreoffice7.1/program/python... Success!\n Found 2 Pythons with Libreoffice libraries:\n /usr/bin/python3\n /opt/libreoffice7.1/program/python\n\nThe `/usr/bin/python3` binary will be the system Python used for versions of\nLibreoffice installed by the system package manager. The Pythons installed\nunder `/opt/` will be Python versions that come with official LibreOffice\ndistributions.\n\nTo install on such distributions, do the following::\n\n $ wget https://bootstrap.pypa.io/get-pip.py\n $ sudo /path/to/python get-pip.py\n $ sudo /path/to/python -m pip install unoserver\n\nYou can also install it in a virtualenv, if you are using the system Python\nfor that virtualenv, and specify the ``--system-site-packages`` parameter::\n\n $ virtualenv --python=/usr/bin/python3 --system-site-packages virtenv\n $ virtenv/bin/pip install unoserver\n\nWindows and Mac installs aren't officially supported yet, but on Windows the\npaths to the LibreOffice Python executable are usually in locations such as\n`C:\\\\Program Files (x86)\\\\LibreOffice\\\\python.exe`. On Mac it can be for\nexample `/Applications/LibreOffice.app/Contents/python` or\n`/Applications/LibreOffice.app/Contents/Resources/python`.\n\n\nUsage\n-----\n\nInstalling unoserver installs three scripts, `unoserver`, `unoconverter` and `unocompare`.\nThe server can also be run as a module with `python3 -m unoserver.server`, with the same\narguments as the main script, which can be useful as it must be run with the LibreOffice\nprovided Python.\n\n\nUnoserver\n~~~~~~~~~\n\n.. code::\n\n unoserver [-h] [-v] [--interface INTERFACE] [--uno-interface UNO_INTERFACE] [--port PORT] [--uno-port UNO_PORT]\n [--daemon] [--executable EXECUTABLE] [--user-installation USER_INSTALLATION]\n [--libreoffice-pid-file LIBREOFFICE_PID_FILE]\n\n* `--interface`: The interface used by the XMLRPC server, defaults to \"127.0.0.1\"\n* `--port`: The port used by the XMLRPC server, defaults to \"2003\"\n* `--uno-interface`: The interface used by the LibreOffice server, defaults to \"127.0.0.1\"\n* `--uno-port`: The port used by the LibreOffice server, defaults to \"2002\"\n* `--daemon`: Deamonize the server\n* `--executable`: The path to the LibreOffice executable\n* `--user-installation`: The path to the LibreOffice user profile, defaults to a dynamically created temporary directory\n* `--libreoffice-pid-file`: If set, unoserver will write the Libreoffice PID to this file.\n If started in daemon mode, the file will not be deleted when unoserver exits.\n* `--conversion-timeout`: Terminate Libreoffice and exit if a conversion does not complete in the given time (in seconds).\n* `-v, --version`: Display version and exit.\n\nUnoconvert\n~~~~~~~~~~\n\n.. code::\n\n unoconvert [-h] [-v] [--convert-to CONVERT_TO] [--input-filter INPUT_FILTER] [--output-filter OUTPUT_FILTER]\n [--filter-options FILTER_OPTIONS] [--update-index] [--dont-update-index] [--host HOST] [--port PORT]\n [--host-location {auto,remote,local}] infile outfile\n\n* `infile`: The path to the file to be converted (use - for stdin)\n* `outfile`: The path to the converted file (use - for stdout)\n* `--convert-to`: The file type/extension of the output file (ex pdf). Required when using stdout\n* `--input-filter`: The LibreOffice input filter to use (ex 'writer8'), if autodetect fails\n* `--output-filter`: The export filter to use when converting. It is selected automatically if not specified.\n* `--filter`: Deprecated alias for `--output-filter`\n* `--filter-option`: Pass an option for the export filter, in name=value format. Use true/false for boolean values. Can be repeated for multiple options.\n* `--filter-options`: Deprecated alias for `--filter-option`.\n* `--host`: The host used by the server, defaults to \"127.0.0.1\"\n* `--port`: The port used by the server, defaults to \"2003\"\n* `--host-location`: The host location determines the handling of files. If you run the client on the\n same machine as the server, it can be set to local, and the files are sent as paths. If they are\n different machines, it is remote and the files are sent as binary data. Default is auto, and it will\n send the file as a path if the host is 127.0.0.1 or localhost, and binary data for other hosts.\n* `-v, --version`: Display version and exit.\n\nExample for setting PNG width/height::\n\n unoconvert infile.odt outfile.png --filter-options PixelWidth=640 --filter-options PixelHeight=480\n\n\nUnocompare\n~~~~~~~~~~\n\n.. code::\n\n unocompare [-h] [-v] [--file-type FILE_TYPE] [--host HOST] [--port PORT] [--host-location {auto,remote,local}]\n oldfile newfile outfile\n\n* `oldfile`: The path to the older file to be compared with the original one (use - for stdin)\n* `newfile`: The path to the newer file to be compared with the modified one (use - for stdin)\n* `outfile`: The path to the result of the comparison and converted file (use - for stdout)\n* `--file-type`: The file type/extension of the result output file (ex pdf). Required when using stdout\n* `--host`: The host used by the server, defaults to \"127.0.0.1\"\n* `--port`: The port used by the server, defaults to \"2003\"\n* `--host-location`: The host location determines the handling of files. If you run the client on the\n same machine as the server, it can be set to local, and the files are sent as paths. If they are\n different machines, it is remote and the files are sent as binary data. Default is auto, and it will\n send the file as a path if the host is 127.0.0.1 or localhost, and binary data for other hosts.\n* `-v, --version`: Display version and exit.\n\n\nClient/Server installations\n---------------------------\n\nIf you are installing Unoserver on a dedicated machine (virtual or not) to do the conversions and\nare running the commands from a different machine, or if you want to call the convert/compare commands\nfrom Python directly, the clients do not need access to Libreoffice. You can therefore follow the\ninstructions above to make Unoserver have access to the LibreOffice library, but on the client\nside you can simply install Unoserver as any other Python library, with `python -m pip install unoserver`\nusing the Python you want to use as the client executable.\n\nPlease note that there is no security on either ports used, and as a result Unoserver is vulnerable\nto DDOS attacks, and possibly worse. The ports used **must not** be accessible to anything outside the\nserver stack being used.\n\nUnoserver is designed to be started by some service management software, such as Supervisor or similar,\nthat will restart the service should it crash. Unoserver does not try to restart LibreOffice if it\ncrashes, but should instead also stop in that sitution. The ``--conversion-timeout`` argument will\nteminate LibreOffice if it takes to long to convert a document, and that termination will also result\nin Unoserver quitting. Because of this service monitoring software should be set up to restart\nUnoserver when it exits.\n\n\nDevelopment and Testing\n-----------------------\n\n1. Clone the repo from `https://github.com/unoconv/unoserver`.\n\n2. Setup a virtualenv::\n\n $ virtualenv --system-site-packages ve\n $ ve/bin/pip install -e .[devenv]\n\n3. Run tests::\n\n $ ve/bin/pytest tests\n\n4. Run `flake8` linting:\n\n $ ve/bin/flake8 src tests\n\n\nComparison with `unoconv`\n-------------------------\n\nUnoserver started as a rewrite, and hopefully a replacement to `unoconv`, a module with support\nfor using LibreOffice as a listener to convert documents.\n\nDifferences for the user\n~~~~~~~~~~~~~~~~~~~~~~~~\n\n* Easier install for system versions of LibreOffice. On Linux, the packaged versions of LibreOffice\n typically uses the system Python, making it easy to install `unoserver` with a simple\n `sudo pip install unoserver` command.\n\n* Separate commands for server and client. The client no longer tries to start a listener and then\n close it after conversion if it can't find a listener. Instead the new `unoconverter` client\n requires the `unoserver` to be started. This makes it less practical for one-off converts,\n but as mentioned that can easily be done with LibreOffice itself.\n\n* The `unoserver` listener does not prevent you from using LibreOffice as a normal user, while the\n `unoconv` listener would block you from starting LibreOffice to open a document normally.\n\n* You should be able to on a multi-core machine run several `unoservers` with different ports.\n There is however no support for any form of load balancing in `unoserver`, you would have to\n implement that yourself in your usage of `unoconverter`. For performant multi-core scaling, it\n is necessary to specify unique values for each `unoserver`'s `--port` and `--uno-port` options.\n\n* Only LibreOffice is officially supported. Other variations are untested.\n\n\nDifferences for the maintainer\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\n* It's a complete and clean rewrite, supporting only Python 3, with easier to understand and\n therefore easier to maintain code, hopefully meaning more people can contribute.\n\n* It doesn't rely on internal mappings of file types and export filters, but asks LibreOffice\n for this information, which will increase compatibility with different LibreOffice versions,\n and also lowers maintenance.\n\nContributors\n------------\n\n* Lennart Regebro, regebro@gmail.com\n* Stephan Richter, srichter@shoobx.com\n* Bruno Sim\u00e3o, https://github.com/ankology\n* \u00c5smund Stavdahl, https://github.com/asmundstavdahl\n* Bal\u00e1zs Varga, https://github.com/bvarga91\n* Alessandro Filippini, https://github.com/AlePini\n* Dmitry Shachnev, https://github.com/mitya57\n* Socheat Sok, https://github.com/socheatsok78\n* BohwaZ, https://github.com/bohwaz\n* ReeceJones, https://github.com/ReeceJones\n* Grunthos, https://github.com/Grunthos\n\n3.0.1 (2024-10-26)\n------------------\n\n- Accidentally import uno library where it isn't needed.\n\n\n3.0 (2024-10-22)\n----------------\n\n- No changes since beta.\n\n3.0b2 (2024-10-15)\n------------------\n\n- Implementing a separate API version for more version flexibility, as I'm\n releasing more often than I expected.\n\n\n3.0b1 (2024-10-11)\n------------------\n\n- Added a --conversion-timeout argument to ``unoserver``, which causes unoserver\n to fail if a conversion doesn't finish within a certain time.\n\n- By default it will now use the `soffice`` executable instead of `libreoffice`,\n as I had a problem with it using 100% load when started as `libreoffice`.\n\n2.3b1 (2024-10-09)\n------------------\n\n- Much better handling of LibreOffice crashing or failing to start.\n\n\n2.2.2 (2024-09-18)\n------------------\n\n- Fixed a memory leak in unoserver.\n\n\n2.2.1 (2024-07-24)\n------------------\n\n- Restored Python 3.8 functionality.\n\n\n2.2 (2024-07-23)\n----------------\n\n- ReeceJones added support to specify IPv6 adresses.\n\n- Now tries to connect to the server, with retries if the server has\n not been started yet.\n\n- Verifies that the version installed on the server and client is the same.\n\n- If you misspell a filter name, the output is nicer.\n\n- The clients got very silent in the refactor, fixed that.\n\n- --verbose and --quiet arguments to get even more output, or less.\n\n\n2.1 (2024-03-26)\n----------------\n\n- Released with the wrong version number, that should have been 2.1.\n\n\n2.0.2 (2024-03-21)\n------------------\n\n- Added --version flags to the commands to print the version number.\n Also unoserver prints the version on startup.\n\n- File paths are now always sent as absolute paths.\n\n\n2.1b1 (2024-01-12)\n------------------\n\n- Add a --input-filter argument to specify a different file type than the\n one LibreOffice will guess.\n\n- For consistency renamed --filter to --output-filter, but the --filter\n will remain for backwards compatibility.\n\n- If you specify a non-existent filter, the list of filters is now alphabetical.\n\n- You can now use both the LibreOffice name, but also internal shorter names\n and sometimes even file suffices to specify the filter.\n\n\n2.0.1 (2024-01-12)\n------------------\n\n- Specifying `--host-location=remote` didn't work for the outfile if you\n used port forwarding from localhost.\n\n- Always default the uno interface to 127.0.0.1, no matter what the XMLRPC\n interface is.\n\n\n2.0 (2023-10-19)\n----------------\n\n- Made the --daemon parameter work again\n\n- Added a --filter-option alias for --filter-options\n\n\n2.0b1 (2023-08-18)\n------------------\n\n- A large refactoring with an XML-RPC server and a new client using that XML-RPC\n server for communicating. This means the client can now be lightweight, and\n no longer needs the Uno library, or even LibreOffice installed. Instead the\n new `unoserver.client.UnoClient()` can be used as a library from Python.\n\n- A cleanup and refactor of the commands, with new, more gooder parameter names.\n\n\n1.6 (2023-08-18)\n----------------\n\n- Added some deprecation warnings for command arguments as they will change in 2.0.\n\n\n1.5 (2023-08-11)\n----------------\n\n- Added support for passing in filter options with the --filter-options parameter.\n\n- Add `--user-installation` flag to `unoserver` for custom user installations.\n\n- Add a `--libreoffice-pid-file` argument for `unoserver` to save the LibreOffice PID.\n\n\n1.4 (2023-04-28)\n----------------\n\n- Added new feature: comparing documents and export the result to any format.\n\n- You can run the new module as scripts, and also with ``python3 -m unoserver.comparer`` just\n like the ``python3 -m unoserver.server`` and ``python3 -m unoserver.converter``.\n\n- Porting feature from previous release: refresh of index in the Table of Contents\n\n\n1.3 (2023-02-03)\n----------------\n\n- Now works on Windows (although it's not officially supported).\n\n- Added --filter argument to unoconverter to allow explicit selection of which\n export filter to use for conversion.\n\n\n1.2 (2022-03-17)\n----------------\n\n- Move logging configuration from import time to the main() functions.\n\n- Improved the handling of KeyboardInterrupt\n\n- Added the deprecated but still necessary com.sun.star.text.WebDocument\n for HTML docs.\n\n\n1.1 (2021-10-14)\n----------------\n\n- Fixed a bug: If you specified an unknown file extension while piping the\n result to stdout, you would get a type error instead of the correct error.\n\n- Added an extra check that libreoffice is quite dead when exiting,\n I experienced a few cases where soffice.bin was using 100% load in the\n background after unoserver exited. I hope this takes care of that.\n\n- Added ``if __name__ == \"main\":`` blocks so you can run the modules\n as scripts, and also with ``python3 -m unoserver.server`` and\n ``python3 -m unoserver.converter``.\n\n\n1.0.1 (2021-09-20)\n------------------\n\n- Fixed a bug that meant `unoserver` did not behave well with Supervisord's restart command.\n\n\n1.0 (2021-08-10)\n----------------\n\n- A few small spelling and grammar changes.\n\n\n1.0b3 (2021-07-01)\n------------------\n\n- Make sure `interface` and `port` options are honored.\n\n- Added an --executable option to the server to pick a specific libreoffice installation.\n\n- Changed the infile and outfile options to be positional.\n\n- Added support for using stdin and stdout.\n\n- Added a --convert-to argument to specify the resulting filetype.\n\n\n1.0b2 (2021-06-24)\n------------------\n\n- A bug prevented converting to or from files in the local directory.\n\n\n1.0b1 (2021-06-24)\n------------------\n\n- First beta release\n\n\n0.0.1 (2021-06-16)\n------------------\n\n- First alpha release\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "A server for file conversions with Libre Office",
"version": "3.0.1",
"project_urls": {
"Homepage": "https://github.com/unoconv/unoserver"
},
"split_keywords": [
"libreoffice",
" conversion",
" documents",
" uno",
" unoconv"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "572c2ce2a52154fa8d541ed871dae658cbc32bf934c24a1ecac649bd0c345276",
"md5": "36f0d53c9ee2a618413cd0b291062d8c",
"sha256": "a833d766ca41db964216fc27fc703570a170932e986ae5240388ae8652c59bc2"
},
"downloads": -1,
"filename": "unoserver-3.0.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "36f0d53c9ee2a618413cd0b291062d8c",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.8",
"size": 22615,
"upload_time": "2024-10-26T06:38:12",
"upload_time_iso_8601": "2024-10-26T06:38:12.680150Z",
"url": "https://files.pythonhosted.org/packages/57/2c/2ce2a52154fa8d541ed871dae658cbc32bf934c24a1ecac649bd0c345276/unoserver-3.0.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "6c03551b6002b07822d5e1892f77fe758a3c18317f659e8751ce343bb6d280af",
"md5": "c8cb8d8f8e542e0b1e6fc8b03bf7915e",
"sha256": "a01101fc20b19745e23cc07cd13cc93231af357e7ffaff345ba06b894e8115ad"
},
"downloads": -1,
"filename": "unoserver-3.0.1.tar.gz",
"has_sig": false,
"md5_digest": "c8cb8d8f8e542e0b1e6fc8b03bf7915e",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.8",
"size": 76488,
"upload_time": "2024-10-26T06:38:14",
"upload_time_iso_8601": "2024-10-26T06:38:14.609105Z",
"url": "https://files.pythonhosted.org/packages/6c/03/551b6002b07822d5e1892f77fe758a3c18317f659e8751ce343bb6d280af/unoserver-3.0.1.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-10-26 06:38:14",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "unoconv",
"github_project": "unoserver",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "unoserver"
}