Onlyoffice-Documentserver: Difference between revisions

From NixOS Wiki
imported>Onny
mNo edit summary
imported>SuperSandro2000
Add warning when using caddy
Line 23: Line 23:


=== Caddy web server ===
=== Caddy web server ===
{{warning|Onlyoffice is very particular about it headers and if there are some missing or different than what upstream expects, a seemingly completely unrelated portion of the software like font rendering can break. The module maintainer can only fully support nginx as this is the only webserver upstream supplies config files for in their docker image}}


Instead of using the default [[Nginx]] web server, an configuration for [[Caddy]] might look like this
Instead of using the default [[Nginx]] web server, an configuration for [[Caddy]] might look like this

Revision as of 16:42, 23 January 2023

Onlyoffice Documentserver is a full-featured backend for editing different office documents like Open Document, Word, Excel, etc. online in your browser. The software is open source and can be easily deployed and integrated into existing server software. Available frontends are Nextcloud or the Onlyoffice CommunityServer. It can be also used in own software, see following examples for PHP, Nodejs, etc.

Installation

A minimal example to get a Onlyoffice Documentserver running on localhost should look like this

/etc/nixos/configuration.nix
services.onlyoffice = {
  enable = true;
  hostname = "localhost";
};

Configuration

Change default listening port

In case port 80 is already used by a different application or you're using a different web server than Nginx, which is used by the Onlyoffice module, you can change the listening port with the following option:

/etc/nixos/configuration.nix
services.nginx.virtualHosts."localhost".listen = [ { addr = "127.0.0.1"; port = 8080; } ];

Caddy web server

Warning: Onlyoffice is very particular about it headers and if there are some missing or different than what upstream expects, a seemingly completely unrelated portion of the software like font rendering can break. The module maintainer can only fully support nginx as this is the only webserver upstream supplies config files for in their docker image

Instead of using the default Nginx web server, an configuration for Caddy might look like this

/etc/nixos/configuration.nix
services.caddy = {
  virtualHosts = {
    "office.example.org".extraConfig = ''
      reverse_proxy http://127.0.0.1:8000 {
        # Required to circumvent bug of Onlyoffice loading mixed non-https content
        header_up X-Forwarded-Proto https
      }
    '';
  };
};

The reverse_proxy configuration directly forwards all requests to the Onlyoffice server, ignoring the default Nginx vhost.