From b6ddcc0413c4d2c03c80b2333173c868da9de7dd Mon Sep 17 00:00:00 2001 From: Daniel Hiller Date: Tue, 24 Oct 2023 12:53:10 +0200 Subject: [PATCH] add: latest commit based manual installation --- .../development_version/_category_.json | 8 + .../development_version/debian_ubuntu.md | 253 ++++++++++++++++++ .../development_version/windows.md | 142 ++++++++++ 3 files changed, 403 insertions(+) create mode 100644 docs/installation/manual_installation/development_version/_category_.json create mode 100644 docs/installation/manual_installation/development_version/debian_ubuntu.md create mode 100644 docs/installation/manual_installation/development_version/windows.md diff --git a/docs/installation/manual_installation/development_version/_category_.json b/docs/installation/manual_installation/development_version/_category_.json new file mode 100644 index 0000000..f0f8391 --- /dev/null +++ b/docs/installation/manual_installation/development_version/_category_.json @@ -0,0 +1,8 @@ +{ + "label": "Development Version", + "position": "99", + "link": { + "type": "generated-index", + "description": "Non production ready version of Planka" + } +} diff --git a/docs/installation/manual_installation/development_version/debian_ubuntu.md b/docs/installation/manual_installation/development_version/debian_ubuntu.md new file mode 100644 index 0000000..ac568f5 --- /dev/null +++ b/docs/installation/manual_installation/development_version/debian_ubuntu.md @@ -0,0 +1,253 @@ +--- +sidebar_position: 1 +--- + +# Debian & Ubuntu + +:::danger +This version is not production ready and may result in data loss + +Use at your own risk + +**No Backup – No Mercy!** +::: + + +### System requirements + + Debian 11 or Ubuntu 22.04 + + PostgreSQL + + Nodejs + + + +### PostgreSQL +###### Installing PostgreSQL + +To install PostgreSQL, first refresh your server’s local package index: +```bash +sudo apt update +``` + +Then, install the Postgres package along with a -contrib package that adds some additional utilities and functionality: + + +```bash +sudo apt install postgresql postgresql-contrib -y +``` + +If you are prompted to restart any services, press **ENTER** to accept the defaults and continue. + +##### Creating User and Database +You need to create a User and a Database for Planka + +**Create the user** +```bash +sudo -u postgres createuser --interactive +``` + + +The script will prompt you with some choices and, based on your responses, execute the correct Postgres commands to create a user to your specifications. + +```bash +Output +Enter name of role to add: planka +Shall the new role be a superuser? (y/n) y +``` + + + +**Create the Database** + +Change directory to prevent a sudo permission error +```bash +cd /tmp +``` + +Now create the database, you are not getting any response from this command. +```bash +sudo -u postgres createdb planka +``` + + + +##### Create a Unix User and test Database acceess and change the password +We need this user later to run planka as non-root user too + +```bash +sudo adduser planka +``` + + +Login to the Database as user Planka +```bash +sudo -u planka psql +``` + +Change the database password +```bash +ALTER USER planka PASSWORD 'YOUR_DATABASE_PASSWORD'; +``` + +Cloese the database with + +```bash +\q +``` + + +### Nodejs +Installing Node.js with Apt Using a [NodeSource](https://github.com/nodesource/distributions#nodejs) PPA + +```bash +# Download and import the Nodesource GPG key +sudo apt-get update +sudo apt-get install -y ca-certificates curl gnupg +sudo mkdir -p /etc/apt/keyrings +curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | sudo gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg + +# Create deb repository +NODE_MAJOR=18 +echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_$NODE_MAJOR.x nodistro main" | sudo tee /etc/apt/sources.list.d/nodesource.list +``` + +Then run update and install +```bash +sudo apt-get update +sudo apt-get install nodejs -y +``` + +Verify that you’ve installed the new version by running node with the -v version flag: +```bash +node -v +``` +```bash +Output +v18.X.X +``` + +### Install Planka +First we have to prepare some stuff +our installation directory is `/vaw/www/planka` +```bash +sudo mkdir -p /var/www/planka +sudo chown -R planka:planka /var/www/planka +``` + +Now we can work as user **Planka** + +```bash +sudo -i -u planka +``` + +**Clone the repository into the directory.** +```bash +git clone https://github.com/plankanban/planka.git /var/www/planka +``` + + + +**Install dependencies for client and build it.** + +```bash +cd /var/www/planka +npm install + +cd client +npm run build +``` + +**Symlink Fun** +Normaly we have to copy everything from client/build to server/public and client/build/index.html to server/views/index.ejs, we don't want to go this way. +instead we are using symlinks, this makes updating way easier and faster. + + +```bash +ln -s /var/www/planka/client/build/asset-manifest.json /var/www/planka/server/public/asset-manifest.json +ln -s /var/www/planka/client/build/favicon.ico /var/www/planka/server/public/favicon.ico +ln -s /var/www/planka/client/build/logo192.png /var/www/planka/server/public/logo192.png +ln -s /var/www/planka/client/build/logo512.png /var/www/planka/server/public/logo512.png +ln -s /var/www/planka/client/build/manifest.json /var/www/planka/server/public/manifest.json +ln -s /var/www/planka/client/build/robots.txt /var/www/planka/server/public/robots.txt +ln -s /var/www/planka/client/build/static /var/www/planka/server/public/static +ln -s /var/www/planka/client/build/index.html /var/www/planka/server/views/index.ejs +``` + + + + + +```bash + +``` + +#### Configure environment variables. +Go into the ``server`` directory and edit the ``.env`` file + +First we have to copy the ``.env.sample`` file +```bash +cd /var/www/planka/server +cp .env.sample .env +``` + +Before we open the .env file, we need a screct_key +you can generate one using the openssl command + +```bash +openssl rand -hex 64 +``` +**Note the output down** + + +Edit ``.env`` file +```bash +nano .env +``` + +Your ``.env`` file should look like this + +```bash +## Required +BASE_URL=http://YOUR_DOMAIN_NAME:YOUR_PORT +DATABASE_URL=postgresql://planka:YOUR_DATABASE_PASSWORD@localhost/planka +SECRET_KEY=YOUR_GENERATED_KEY + +## Optional + +# TRUST_PROXY=0 +# TOKEN_EXPIRES_IN=365 # In days + +# related: https://github.com/knex/knex/issues/2354 +# As knex does not pass query parameters from the connection string we +# have to use environment variables in order to pass the desired values, e.g. +# PGSSLMODE= + +# Configure knex to accept SSL certificates +# KNEX_REJECT_UNAUTHORIZED_SSL_CERTIFICATE=false + +DEFAULT_ADMIN_EMAIL=YOUR_ADMIN_EMAIL # Do not remove if you want to prevent this user from being edited/deleted +DEFAULT_ADMIN_PASSWORD=YOUR_ADMIN_PASSWORD +DEFAULT_ADMIN_NAME=YOUR_ADMIN_NAME +DEFAULT_ADMIN_USERNAME=YOUR_ADMIN_USERNAME + +# OIDC_ISSUER= +# OIDC_CLIENT_ID= +# OIDC_CLIENT_SECRET= +# OIDC_SCOPES=openid email profile +# OIDC_ADMIN_ROLES=admin +# OIDC_ROLES_ATTRIBUTE=groups + +## Do not edit this + +TZ=UTC +``` + + + +#### Start Planka the first Time +in the ``/var/www/planka/server`` directory just type + +```bash +npm run db:init && npm start --prod +``` + +Now you can browse to **http://YOUR_DOMAIN_NAME:YOUR_PORT** and login as **YOUR_ADMIN_EMAIL** with password **YOUR_ADMIN_PASSWORD** diff --git a/docs/installation/manual_installation/development_version/windows.md b/docs/installation/manual_installation/development_version/windows.md new file mode 100644 index 0000000..f72b7c3 --- /dev/null +++ b/docs/installation/manual_installation/development_version/windows.md @@ -0,0 +1,142 @@ +--- +sidebar_position: 2 +--- +# Windows + +:::danger +This version is not production ready and may result in data loss + +Use at your own risk + +**No Backup – No Mercy!** +::: + +### System requirements +* PostgreSQL (testet with v15.2) https://www.postgresql.org/download/windows/ +* Nodejs (testet with 18.14.2) https://nodejs.org/en/download/ +* Windows Powershell as **Administrator** +### Install Planka +First we have to prepare some stuff +our installation directory is `C:\planka` +```batch +mkdir C:\planka +cd C:\planka +``` + +**Clone the repository into the directory.** +```batch +git clone https://github.com/plankanban/planka.git . +``` + + + +**Install dependencies for client and build it.** + +```batch +npm install + +cd client +npm run build +``` + +**Symlink Fun** +Normaly we have to copy everything from ``client\build`` to ``server\public`` and ``build\index.html`` to ``server\views\index.ejs``, we don't want to go this way. +instead we are using symlinks, this makes updating way easier and faster. + + +```batch +New-Item -ItemType SymbolicLink -Path "C:\planka\server\public\asset-manifest.json" -Target "C:\planka\client\build\asset-manifest.json" +New-Item -ItemType SymbolicLink -Path "C:\planka\server\public\favicon.ico" -Target "C:\planka\client\build\favicon.ico" +New-Item -ItemType SymbolicLink -Path "C:\planka\server\public\logo192.png" -Target "C:\planka\client\build\logo192.png" +New-Item -ItemType SymbolicLink -Path "C:\planka\server\public\logo512.png" -Target "C:\planka\client\build\logo512.png" +New-Item -ItemType SymbolicLink -Path "C:\planka\server\public\manifest.json" -Target "C:\planka\client\build\manifest.json" +New-Item -ItemType SymbolicLink -Path "C:\planka\server\public\robots.txt" -Target "C:\planka\client\build\robots.txt" +New-Item -ItemType SymbolicLink -Path "C:\planka\server\public\static" -Target "C:\planka\client\build\static" +New-Item -ItemType SymbolicLink -Path "C:\planka\server\views\index.ejs" -Target "C:\planka\client\build\index.html" +``` + + +#### Configure environment variables. +Go into the ``server`` directory and edit the ``.env`` file + +First we have to copy the ``.env.sample`` file +```batch +cd C:\planka\server +cp .env.sample .env +``` + +Before we open the .env file, we need a screct_key +you can generate one using this Powershell command + +```batch +-join ((33..126) | Get-Random -Count 32 | % {[char]$_}) +``` +**Note the output down** + + +Edit ``.env`` file +```batch +notepad.exe .env +``` + +Your ``.env`` file should look like this + +```batch +## Required +BASE_URL=http://YOUR_DOMAIN_NAME:YOUR_PORT +DATABASE_URL=postgresql://planka:YOUR_DATABASE_PASSWORD@localhost/planka +SECRET_KEY=YOUR_GENERATED_KEY + +## Optional + +# TRUST_PROXY=0 +# TOKEN_EXPIRES_IN=365 # In days + +# related: https://github.com/knex/knex/issues/2354 +# As knex does not pass query parameters from the connection string we +# have to use environment variables in order to pass the desired values, e.g. +# PGSSLMODE= + +# Configure knex to accept SSL certificates +# KNEX_REJECT_UNAUTHORIZED_SSL_CERTIFICATE=false + +DEFAULT_ADMIN_EMAIL=YOUR_ADMIN_EMAIL # Do not remove if you want to prevent this user from being edited/deleted +DEFAULT_ADMIN_PASSWORD=YOUR_ADMIN_PASSWORD +DEFAULT_ADMIN_NAME=YOUR_ADMIN_NAME +DEFAULT_ADMIN_USERNAME=YOUR_ADMIN_USERNAME + +# OIDC_ISSUER= +# OIDC_CLIENT_ID= +# OIDC_CLIENT_SECRET= +# OIDC_SCOPES=openid email profile +# OIDC_ADMIN_ROLES=admin +# OIDC_ROLES_ATTRIBUTE=groups + +## Do not edit this + +TZ=UTC +``` + + + +#### Start Planka the first Time +in the ``C:\planka\server`` directory just type + +```batch +npm run db:init +npm start --prod +``` + +Now you can browse to **http://YOUR_DOMAIN_NAME:YOUR_PORT** and login as **YOUR_ADMIN_EMAIL** with password **YOUR_ADMIN_PASSWORD** + + +### Problems + +It's possible that you are running into an issue while building Planka in Windows + +Use this command, should fix it. +```batch +git config --global core.autocrlf false +``` + +After that, you need restart the whole installation