Skip to content
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

Installation on Synology-NAS #1870

Open
Ball-Pic opened this issue May 31, 2024 · 2 comments
Open

Installation on Synology-NAS #1870

Ball-Pic opened this issue May 31, 2024 · 2 comments

Comments

@Ball-Pic
Copy link

Does anyone have experience installing on a Synlogy NAS?
I just can't do it.
Can someone provide me with instructions?
Maybe even via portainer.

Thx Gerhard

@geimist
Copy link
Contributor

geimist commented Jul 9, 2024

These instructions only serve as a start. The following pages serve as a basis and should be observed:

This tutorial is based on DSM 7.2

Preparation:

  • create a key that will later be used as SECRET_KEY (= "a long and random secret key that must not be shared"
    You can easily generate one with openssl at command line with: openssl rand -base64 32)
  • Under which web address should uMap be called? It must be assigned to the environment variable SITE_URL and specified in the reverse proxy. In this description https://map.example.com is used

1. Paths:

Create the following folders in the FileStation (there may also be different paths, but these must also be adjusted in the configuration below):
/volume1/docker/umap/POSTGRESQL_DATA
/volume1/docker/umap/STATIC_ROOT
/volume1/docker/umap/MEDIA_ROOT
/volume1/docker/umap/conf


2. Config:

Create the configuration file and save it here (I recommend the DSM text editor from the package centre):

  • /volume1/docker/umap/conf/umap.conf
example config (click) - you still need to customise them:
# ➜ https://docs.umap-project.org/en/master/config/settings
#[general]
# Site name
title = "My uMap"
# Site URL
site_url = "https://map.example.com/"
# Site description
description = "My uMap description"
# Site logo (optional)
logo = "/static/umap.png"
# Site favicon (optional)
# favicon = "/static/favicon.ico"

# Default language
language = "de"
# Default map center
default_latitude = "49.90305"
default_longitude = "15.77054"
default_zoom = "16"
# Map background
background_layer = "osm"
# Map tile server
tile_layer = "https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png"
# Map attribution
attribution = "© OpenStreetMap contributors"
SECRET_KEY = "1234"
#
# Do you want users to be able to create an account directly on your uMap instance (instead of only using OAuth).
# You need to create first a superuser, on the command line (open Terminal in Container Manager):
# > umap createsuperuser
#   umapadmin
#   umap@map.example.com
#   YOURPASSWORD
#
ENABLE_ACCOUNT_LOGIN=1
#
# To log in as the first user, you must set the UMAP_REGISTRATION_OPEN option to True. 
# This allows you to create a new account that is automatically considered a superuser. 
# After you have registered, you can set the option to False again to prevent further registrations. 
# Alternatively, you can also create a superuser account via the Django admin interface.
UMAP_REGISTRATION_OPEN = True

3. Reverse Proxy = (Direct your uMap domain to your uMap Docker container):

  • 'Control Panel' ➜ 'Login Portal' ➜ Tab 'Advanced' ➜ 'Reverse Proxy' and adjust like this:
    reverse_proxy

  • Open the Firewall for Port 443

  • forward Port 443 in your Router to your DiskStation


4. Container Manager (formerly package 'Docker'):

open 'Container Manager' ➜ go to 'Project' ➜ 'create'

  • define a project name
  • select yout project path (/volume1/docker/umap/)
  • select 'Create docker-compose.yaml' and paste this code into (adjust environment variables SITE_URL, SECRET_KEY and volume mounts [for db & app]):
version: '3'
services:
  db:
    image: postgis/postgis:14-3.4-alpine
    environment:
      - POSTGRES_HOST_AUTH_METHOD=trust
    volumes:
      - /volume1/docker/umap/POSTGRESQL_DATA:/var/lib/postgresql/data

  app:
    image: umap/umap:2.3.1
    ports:
      - "8000:8000"
    environment:
      - DATABASE_URL=postgis://postgres@db/postgres
      - SITE_URL=https://map.example.com/
      - STATIC_ROOT=/srv/umap/static
      - MEDIA_ROOT=/srv/umap/uploads
      - SECRET_KEY=1234
    volumes:
#     # FIX the path on the left, below, to your location 
      - /volume1/docker/umap/conf/umap.conf:/etc/umap/umap.conf
      - /volume1/docker/umap/STATIC_ROOT:/srv/umap/static
      - /volume1/docker/umap/MEDIA_ROOT:/srv/umap/uploads
    restart: always
    depends_on:
      - db
  • now 'create' your project

5. create superuser:

Do you want users to be able to create an account directly on your uMap instance (instead of only using OAuth).
You need to create first a superuser, on the command line (open Terminal in Container Manager):

umap createsuperuser
#   umapadmin
#   umap@map.example.com
#   YOURPASSWORD

@davidbgk
Copy link
Contributor

davidbgk commented Jul 9, 2024

@geimist nice!

Would you care to submit a PR with that content in a dedicated synology.md file within that folder?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants