Skip to content
This repository has been archived by the owner on Jul 3, 2024. It is now read-only.
/ Nextcloud Public archive

Nextcloud-Container, including OnlyOffice, that mounts the user-directories

License

Notifications You must be signed in to change notification settings

philleconnect/Nextcloud

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

62 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Archived: Not actively maintained anymore!

NextCloud-Server with OnlyOffice-Integration

Nextcloud-Container including an online-office package (Collabora or Onlyoffice) that mounts the user-directories

To install:

  • Clone this repository: git clone https://github.com/philleconnect/Nextcloud. Make sure the cloned folder Nextcloud is in the same path like your ServerContainers-folder!
  • Configure your installation by adapting the values in the settings.env. It won't work if you don't have a working domain set up! But for testing you can also enter your host-IP followed by the port 86, i.e. 192.168.0.100:86.
  • Call the Domain from any browser and you are set up! The first call and login might take a little while, espeacially if you get a 502 Bad Gateway error, please hang on for a few minutes, Nextcloud takes its time to set up!

How it works

This will build the Nextcloud-container among other containers (database, OnlyOffice) in a separate virtual network. Since Nextcloud will most likely be made available from the Internet the isolated virtual network will provide extra security when there are security issues with Nextcloud. This is also why you need to suppy your LDAP-Server-IP.

The files are mounted to the Nextcloud-container as a docker-volume. This only works out-of-the-box when this is executed on the same host (Nextcloud-folder need to be in the same parent folder like ServerContainers).

Before first start please copy the settings.env.default to settings.env. That way all your changes will be independent from the git.

All Settings (Nextcloud, Apps, Ldap, OnlyOffice etc.) are being prepared on container start (using the occ-command of Nextcloud), so you just need to make very few adaptions to your environment like entering your IP in the settings.env.

Do you need it the special way?

You can also run it on a separate host, but you will need to mount the samba-folder to that machine in some way, there is no support for that solution though.

If you want even more security/isolation you can also mount the user-folders as ftp-shares. You will then need the ftpServer-Container on your PhilleConnect-host and change the Settings for external files. But this solution is slower and user can't share files, so this is not the default.

Access from the Web

To access your installation from the web you might want to set up a proxy-Server, that can at the same time take care for the https-encryption.

Be aware that there is no out-of-the-box - solution for that, since this will depend on your internet-connection (DSL, Firewall, dynamic IP, encryption, ...)

This is my config for nginx that does the job:

server {
    listen 443 ssl;
    listen [::]:443 ssl;
    ssl_certificate /etc/letsencrypt/live/nextcloud.mydomain.tld/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/nextcloud.mydomain.tld/privkey.pem;
    server_name nextcloud.mydomain.tld;
    location / {
        proxy_set_header        Host                $host;
        proxy_set_header        X-Forwarded-Proto   https;
        proxy_set_header        X-Real-IP           $remote_addr;
        proxy_set_header        X-Forwarded-For     $proxy_add_x_forwarded_for;
        proxy_pass http://172.16.0.102:86/;
    }
}

Guess where my Let's Encrypt-certificates are, that certbot is getting.

Remember to have as well an according config for OnlyOffice pointing to port 82!

Make sure your have your proxy-IP in your settings.env as TRUSTED_PROXIES!

Update

You can update the PhilleConnect-Part of this the normal way by executing

git pull
docker-compose up -d --build

from the Nextcloud-folder on the command line.

To get the latest subversion of Nextcloud please execute

docker pull nextcloud:15-fpm

before this.

Upgrades to the major-Versions will be tested by us first and will then be updated within PhilleConnect.

Customize

You can of course customize the settings like the welcome-logo, languages etc. and install your own apps or deinstall the preinstalled ones like OnlyOffice.

Just log in as admin with the credentials you have set up in the settings.env and go ahead!

Only for developers

You can access the Container with the command

docker exec -ti nextcloud_fpm /bin/bash

The entire configuration is done with the occ-command of Nextcloud. You can execute it with

sudo -u www-data php occ

To show the system-configuration (Settings especially in the config/config.php) the command `sudo -u www-data php occ config:list``` will do the job.

Please refer to the Nextcloud-documentation for occ for further instructions.

About

Nextcloud-Container, including OnlyOffice, that mounts the user-directories

Resources

License

Stars

Watchers

Forks

Packages

No packages published