Skip to content
This repository has been archived by the owner on Apr 24, 2024. It is now read-only.

Update Dev-Setup Documentation & Add docker folder #1241

Open
wants to merge 10 commits into
base: master
Choose a base branch
from
3 changes: 1 addition & 2 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -89,9 +89,8 @@ doc-frontend: install-frontend ## Frontend src doc

# Install


.PHONY: install
install: install-pre-commit install-backend install-mdbook install-frontend install-e2e install-types ## Install ALL dependencies within the source repo
install: install-pre-commit install-backend install-mdbook install-frontend ## Install ALL dependencies within the source repo
hatchla marked this conversation as resolved.
Show resolved Hide resolved
@echo "Installation completed."

.PHONY: install-types
Expand Down
1 change: 1 addition & 0 deletions doc/changelog.md
Original file line number Diff line number Diff line change
Expand Up @@ -93,6 +93,7 @@ Syntax: `- short text describing the change _(Your Name)_`
- _()_
- Added planting notes to planting details _(Daniel Steinkogler)_
- _()_
- Update Dev-Setup Documentation & Add docker folder _(Jannis, Lukas)_
- Added keybinding configuration for macOS _(Daniel Steinkogler)_
- Up the rust version to 1.74 _(4ydan)_
- Display a rectangle for area of plantings _(Paul)_
Expand Down
25 changes: 25 additions & 0 deletions doc/development/01docker+local.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
# Docker + local

Run the database in Docker and the frontend and backend locally.

## Install Docker

[Install Docker](https://docs.docker.com/engine/install/) for your host OS.

## Installing Node 20 + Npm

Make sure node 20 is installed, you may use to easly install multiple versions of node [nvm](https://github.com/nvm-sh/nvm),
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Try to not have several mentions of which versions to install, this is hard to maintain. (Add link to where the version is already mentioned).

Suggested change
Make sure node 20 is installed, you may use to easly install multiple versions of node [nvm](https://github.com/nvm-sh/nvm),
Make sure node, in the version as required for PermaplanT, is installed, you may use to easily install multiple versions of node [nvm](https://github.com/nvm-sh/nvm),

use apt or [download node directly](https://nodejs.org/en/download).
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
Make sure node 20 is installed, you may use to easly install multiple versions of node [nvm](https://github.com/nvm-sh/nvm),
use apt or [download node directly](https://nodejs.org/en/download).
Make sure node 20 is installed, you may use [nvm](https://github.com/nvm-sh/nvm) to easily install multiple versions of node, use apt or [download node directly](https://nodejs.org/en/download).


## Install Rust

Follow the sets to [install Rust using rustup](https://www.rust-lang.org/tools/install).
horenso marked this conversation as resolved.
Show resolved Hide resolved

## Run the database

This runs the Postgis database and PgAdmin.

```bash
cd docker
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
cd docker
cd .docker

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@horenso simply add/commit suggestion if it is okay.

docker compose up -d
```
30 changes: 30 additions & 0 deletions doc/development/02devcontainer.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
# Devcontainer

We are also supporting a containerized setup(docker/podman). For more information checkout the README inside [.devcontainer](https://github.com/ElektraInitiative/PermaplanT/blob/master/.devcontainer/README.md).
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
We are also supporting a containerized setup(docker/podman). For more information checkout the README inside [.devcontainer](https://github.com/ElektraInitiative/PermaplanT/blob/master/.devcontainer/README.md).
We are also supporting a containerized setup(docker/podman). For more information checkout the README inside [.devcontainer](https://blob.permaplant.net/master/.devcontainer/README.md).

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why can't we use relative links for files in the same repo with ..s?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Generally you can but it in many cases (e.g. links to outside of doc/) it won't work on doc.permaplant.net etc.


## Background

(Devcontainer)[https://code.visualstudio.com/docs/devcontainers/containers] allows you to
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Markdown is the other way round. Please try to write one sentence per line and keep sentences shorter.

develop using VSCode, without installing Node and Rust, you only need Docker and the
Dockercontainer extention.

## Install the extention

[Devcontainer](https://marketplace.visualstudio.com/items?itemName=ms-vscode-remote.remote-containers) extention and choose
`Dev Containers: Reopen in Container` in the VSCode command palette. The devcontainer includes a `PgAdmin` container on port `5050`,
see the `.devcontainer` directory.

Within the devcontainer install all dependencies with

```bash
make install
```

## Git user

Globally set git credentials are not available in the devcontainer, set them loaclly.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
Globally set git credentials are not available in the devcontainer, set them loaclly.
Globally set git credentials are not available in the devcontainer, set them locally.


```bash
git config user.name "Your name"
git config user.email "Your email"
```
20 changes: 20 additions & 0 deletions doc/development/03local.md
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This description is a bit useless? At least links to running frontend+backend should be provided?

Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
# Local

Run everything locally on your machine.

## Installing Node 20 + Npm

Make sure node 20 is installed, you may use to easly install multiple versions of node [nvm](https://github.com/nvm-sh/nvm),
use apt or [download node directly](https://nodejs.org/en/download).

## Install Rust

Follow the sets to [install Rust using rustup](https://www.rust-lang.org/tools/install).
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
Follow the sets to [install Rust using rustup](https://www.rust-lang.org/tools/install).
Follow the steps to [install Rust using rustup](https://www.rust-lang.org/tools/install).


## Install Postgis

Install postgres, for instance on Ubuntu:

```bash
apt-get install libpq-dev postgresql-client
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does this install the server?

```
95 changes: 31 additions & 64 deletions doc/development_setup.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,22 +3,36 @@
## Prerequisites

If you want to develop on the backend, make sure you have enough RAM.
When performing cargo build, we have experienced (on wsl) a usage of ~12GB.

- Python
- Rust
- Javascript
- nvm
- node
When performing cargo build, we have experienced a usage of ~12GB.

## Operating Systems

- Windows 11
- macOS 13.1 (Unix)
- Ubuntu or another Ubuntu/Debian-based Linux system
- Ubuntu in [WSL](https://learn.microsoft.com/de-de/windows/wsl/install) on Windows

## Ways to develop PermaplanT

Right now we have three different ways to develop Permaplant:
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
Right now we have three different ways to develop Permaplant:
Right now we have three different ways to develop PermaplanT:


### Docker services + local development

Run the database and other services in Docker containers but run backend and frontend locally.
[Read more](development/01docker+local.md)

### Dev container

Run everything within the VSCode devcontainer.
[Read more](development/02devcontainer.md)

### Local setup

Run everything locally, including the database setup.
[Read more](development/03local.md)

## IDE

- [Visual Studio Code](https://code.visualstudio.com/) for both Frontend and Backend
- [IntelliJ IDEA](https://www.jetbrains.com/idea/?var=1) for both Frontend and Backend

## Visual Studio Code Extensions

Expand All @@ -39,57 +53,6 @@ Rust formatting can be achieved by adding the following to settings.json in VSCo
}
```

## Package Managers

- Frontend [npm](https://www.npmjs.com/)
- Backend [cargo](https://crates.io/)

### Installing Node + Npm

If you are using unix, macOS, and windows WSL, consider using [nvm](https://github.com/nvm-sh/nvm)
to manage your node environment:

```bash
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.3/install.sh | bash
nvm install 20
nvm use 20
```

Or if you use the default macOS starting with Catalina shell `zsh`, try:

```zsh
sh -c "$(curl -fsSL https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.3/install.sh)"
```

### Installing Rust + Cargo

If you’re using Linux or macOS, open a terminal and enter the following command:

```bash
$ curl --proto '=https' --tlsv1.2 https://sh.rustup.rs -sSf | sh
```

This installs rust and cargo automatically on your machine.
If you get linker errors, proceed by installing a C Compiler, which will typically include a linker.

To install our specific version of Rust, just run the following command:

```bash
rustup install 1.74
```

On Windows, go to https://www.rust-lang.org/tools/install and follow the instructions for installing Rust.
At some point in the installation, you’ll receive a message explaining that you’ll also need the MSVC build tools for Visual Studio 2013 or later.

To acquire the build tools, you’ll need to install Visual Studio 2022. When asked which workloads to install, include:

- Desktop Development with C++
- The Windows 10 or 11 SDK
- The English language pack component, along with any other language pack of your choosing

In case you don't prefer any of the previously mentioned installations methods, click
[here](https://forge.rust-lang.org/infra/other-installation-methods.html) for alternatives.

## Browsers

- Chrome 108.0.5359
Expand All @@ -103,10 +66,14 @@ If you want to install all necessary dependencies for development run following
make install
```

## Containers

We are also supporting a containerized setup(docker/podman). For more information checkout the README inside [.devcontainer](https://github.com/ElektraInitiative/PermaplanT/blob/master/.devcontainer/README.md).

## Github Codespaces

PermaplanT supports Github codespaces. If you are interested in developing inside Github Codespaces you can learn more about [here](https://docs.github.com/de/codespaces).

## Backend Setup

[Setup for Backend](backend/01setup.md)

## Frontend Setup

[Readme in Frontend](https://blob.permaplant.net/master/frontend/README.md)
22 changes: 22 additions & 0 deletions docker/.env
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

rename folder to .docker

Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
NODE_VERSION="19.4"

BIND_ADDRESS_HOST=localhost
BIND_ADDRESS_PORT=8080

# Env variables must have the prefix VITE_ for Vite to include them.
# More information about env variables with Vite can be found here: https://vitejs.dev/guide/env-and-mode.html
VITE_BASE_API_URL=http://localhost:8080
VITE_NEXTCLOUD_URI=https://cloud.permaplant.net
# OAuth2 (other URLs will be fetched from this URL)
AUTH_DISCOVERY_URI=https://auth.permaplant.net/realms/PermaplanT/.well-known/openid-configuration
AUTH_CLIENT_ID=localhost

# DB
POSTGRES_USER=permaplant
POSTGRES_DB=permaplant
POSTGRES_PASSWORD=permaplant
PGPASSWORD=permaplant
DATABASE_URL=postgres://permaplant:permaplant@localhost/permaplant

[email protected]
PGADMIN_DEFAULT_PASSWORD=permaplant
8 changes: 8 additions & 0 deletions docker/.env.db
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
POSTGRES_USER=permaplant
POSTGRES_DB=permaplant
POSTGRES_PASSWORD=permaplant
PGPASSWORD=permaplant
DATABASE_URL=postgres://permaplant:permaplant@localhost/permaplant

[email protected]
PGADMIN_DEFAULT_PASSWORD=permaplant
5 changes: 5 additions & 0 deletions docker/Dockerfile.pg
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
# This Dockerfile is used inside the docker-compose.yml as development environment
FROM dpage/pgadmin4:7.3

COPY ./servers.json ./servers.json
COPY ./pgpass ../pgpass
30 changes: 30 additions & 0 deletions docker/docker-compose.yml
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is it really necessary to more or less duplicate everything from .devcontainers/?
I usually just start the database part of the devcontainer with
docker compose -f .devcontainer/docker-compose.yml up db pgadmin -d
(but have add port forwarding of the db service 5432)

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

we can also compose it from different compose files for .devcontainer and this setup, it's slightly different for instance it uses the host network

Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
version: "3.8"

services:
db:
image: postgis/postgis:13-3.1
restart: unless-stopped
volumes:
- postgis-data-dev:/var/lib/postgresql/data
env_file:
- .env
ports:
- "5432:5432"

pgadmin:
build:
context: .
dockerfile: Dockerfile.pg
restart: unless-stopped
volumes:
- pgadmin-data-dev:/var/lib/pgadmin
env_file:
- .env.db
ports:
- "5050:80"

volumes:
pgadmin-data-dev:
external: false
postgis-data-dev:
external: false
1 change: 1 addition & 0 deletions docker/pgpass
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
db:5432:permaplant:permaplant:permaplant
14 changes: 14 additions & 0 deletions docker/servers.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
{
"Servers": {
"1": {
"Name": "permaplant",
"Group": "Servers",
"Host": "db",
"Port": 5432,
"MaintenanceDB": "postgres",
"Username": "permaplant",
"PassFile": "/pgpass",
"SSLMode": "prefer"
}
}
}