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

Configurable devevelopment port & documentation updates #6234

Merged
merged 7 commits into from
Feb 3, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 1 addition & 2 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -81,8 +81,7 @@ jobs:
- run: sudo apt-get update
- run: sudo apt-get -y install libgeos-dev # Required for shapely
- run: sudo apt-get -y install proj-bin libproj-dev
- run: pip install --upgrade pip pdm
- run: pdm config --global python.use_venv False
- run: pip install --upgrade pip pdm==2.7.4
- run: pdm export --dev --without-hashes > requirements.txt
- run: pip install -r requirements.txt
- run: mkdir --mode 766 -p /tmp/logs
Expand Down
10 changes: 6 additions & 4 deletions docker-compose.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,20 +15,21 @@ services:
# Main application
backend:
<<: *backend
container_name: backend
container_name: tm-backend
restart: always
labels:
- traefik.http.routers.backend.rule=(Host(`127.0.0.1`) || Host(`localhost`)) && PathPrefix(`/api/`)
- traefik.http.services.backend.loadbalancer.server.port=5000

migration:
<<: *backend
container_name: migration
container_name: tm-migration
restart: on-failure
command: flask db upgrade

frontend:
image: hotosm-tasking-manager:frontend
container_name: tm-frontend
restart: always
networks:
- tm-web
Expand All @@ -38,17 +39,18 @@ services:

postgresql:
image: postgis/postgis:14-3.3
container_name: postgresql
container_name: tm-postgresql
restart: always
env_file: ${ENV_FILE:-tasking-manager.env}
networks:
- tm-web

traefik:
image: traefik:v2.10
container_name: tm-traefik
restart: always
ports:
- "80:80"
- "${TM_DEV_PORT:-80}:80"
volumes:
- /var/run/docker.sock:/var/run/docker.sock:ro
command:
Expand Down
156 changes: 122 additions & 34 deletions docs/developers/development-setup.md
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@

## Development setup
# Development setup

### Architecture
## Architecture

The Tasking Manager is composed of two parts:

Expand All @@ -10,13 +10,104 @@ The Tasking Manager is composed of two parts:

The two parts can be developed independently of each other.

## OSM Auth

The Tasking Manager uses OAuth2 with OSM to authenticate users.

In order to use the frontend, you may need to create keys for OSM:

1. [Login to OSM][1]
(_If you do not have an account yet, click the signup
button at the top navigation bar to create one_).

Click the drop down arrow on the top right of the navigation bar
and select My Settings.

2. Register your Tasking Manager instance to OAuth 2 applications.

Put your login redirect url as `http://127.0.0.1:880/authorized/`

> Note: `127.0.0.1` is required for debugging instead of `localhost`
> due to OSM restrictions.

3. Permissions required:
- Read user preferences (read_prefs).
- Modify the map (write_api).

4. Now save your Client ID and Client Secret for the next step.

## Configure The Dot Env File

1. Copy the `example.env` to `tasking-manager.env`.

```bash
cp example.env tasking-manager.env
```

2. Uncomment or update the following variables

```dotenv
TM_DEV_PORT=880
TM_APP_BASE_URL=http://127.0.0.1:880
TM_APP_API_URL=http://127.0.0.1:880/api
# 'postgresql' if using docker, else 'localhost' or comment out
POSTGRES_ENDPOINT=postgresql
TM_REDIRECT_URI=http://127.0.0.1:880/authorized
TM_CLIENT_ID=from-previous-step
TM_CLIENT_SECRET=from-previous-step
```

- Note that the port 880 can be swapped to any available port on
your system.
- If you change this, don't forget to update the OAuth login redirect
URL from the step above.

> If you are a frontend developer and do not wish to configure the
> backend, you can use our staging server API.
>
> Update the variable:
>
>    `TM_APP_API_URL='https://tasking-manager-staging-api.hotosm.org'`
>
> before running the `yarn start` command.
>
> Be aware that the staging API can be offline while we are deploying
> newer versions to the staging server and that you'll not have access
> to some management views due to permissions. Check the
> [configuration](#configuration) section to learn more about how
> to configure Tasking Manager.

For more details see the [configuration section](#configuration).

## Docker

The easiest option to get started with all components may be using Docker.

### Requirements

[Docker Engine](https://docs.docker.com/engine/install/) must be
available locally.

### Running Tasking Manager

Once the steps above have been complete, simply run:

```bash
docker compose pull
docker compose build
docker compose --env-file tasking-manager.env up --detach
```

Tasking Manager should be available from:
[http://127.0.0.1:880](http://127.0.0.1:880)

## Running Components Standalone

### Frontend

The client is the front-end user interface of the Tasking Manager. It is based on the React framework and you can find all files in the `frontend` directory.

If you don't want to setup a backend server, you can work on frontend development using our staging server API. Execute `export TM_APP_API_URL='https://tasking-manager-staging-api.hotosm.org'` before running the `yarn start` command. Be aware that the staging API can be offline while we are deploying newer versions to the staging server and that you'll not have access to some management views due to permissions. Check the [configuration](#configuration) section to learn more about how to configure Tasking Manager.

**Dependencies**
#### Dependencies

The following dependencies must be available _globally_ on your system:
* Download and install [NodeJS LTS v12+](https://nodejs.org/en/) and [yarn](https://classic.yarnpkg.com/en/docs/install)
Expand Down Expand Up @@ -96,6 +187,7 @@ directory. To use that last option, follow the below instructions:
- `TM_CLIENT_SECRET`=oauth-client-secret-key-from-openstreetmap
- `TM_REDIRECT_URI`=oauth-client-redirect_uri
- `TM_SCOPE`=oauth-client-scopes
- `TM_LOG_DIR=logs`

In order to send email correctly, set these variables as well:
- `TM_SMTP_HOST`
Expand All @@ -105,20 +197,12 @@ In order to send email correctly, set these variables as well:
- `TM_SMTP_USE_TLS=0`
- `TM_SMTP_USE_SSL=1` (Either TLS or SSL can be set to 1 but not both)

#### Build
#### Install Dependencies

* Install project dependencies:
* Linux/Mac (Option 1: pep582):
* First ensure the Python version in `pyproject.toml:requires-python` is installed on your system.
* ```pip install --upgrade pdm```
* ```pdm config --global python.use_venv False```
* ```pdm --pep582 >> ~/.bash_profile```
* ```source ~/.bash_profile```
* ```pdm install```
* Linux/Mac (Option 2: pip (system/venv)):
* ```pip install --upgrade pdm```
* ```pdm export --without-hashes > requirements.txt```
* ```pip install requirements.txt```
* First ensure the Python version in `pyproject.toml:requires-python` is installed on your system.
* ```pip install --upgrade pdm```
* ```pdm install```

#### Tests

Expand Down Expand Up @@ -149,7 +233,7 @@ We use
create the database from the migrations directory. Check the
instructions on how to setup a PostGIS database with
[docker](#creating-a-local-postgis-database-with-docker) or on your
[local system](#non-docker). Then you can execute the following
[local system](#creating-a-local-postgis-database-without-docker). Then you can execute the following
command to apply the migrations:

```
Expand All @@ -169,12 +253,21 @@ on your terminal (with the OS user that is the owner of the database):

`psql -d <your_database> -c "UPDATE users set role = 1 where username = '<your_osm_username>'"`

### API
## API

If you plan to only work on the API you only have to build the backend
architecture. Install the backend dependencies, and run the server:

`flask run --debug --reload` or `pdm run start`
```bash
# Install dependencies
pdm install

# Run (Option 1)
pdm run start

# Run (Option 2)
pdm run flask run --debug --reload
```

You can access the API documentation on
[http://localhost:5000/api-docs](http://localhost:5000/api-docs), it
Expand All @@ -183,7 +276,7 @@ docs is also available on our
[production](https://tasks.hotosm.org/api-docs) and
[staging](https://tasks-stage.hotosm.org/api-docs/) instances.

#### API Authentication
### API Authentication

In order to authenticate on the API, you need to have an Authorization Token.

Expand Down Expand Up @@ -217,7 +310,7 @@ edit history of your user, selecting a changeset from the list, and
then at the bottom link `Changeset XML` and it will be in the `uid`
field of the XML returned.

#### API Authentication on remote instance
### API Authentication on remote instance

To get your token on the production or staging Tasking Manager
instances, sign in in the browser and then either:
Expand All @@ -227,20 +320,14 @@ instances, sign in in the browser and then either:
- inspect a network request and search for the `Authorization` field
in the request headers section.

# Docker
## Additional Info

## Creating a local PostGIS database with Docker
### Creating a local PostGIS database with Docker

If you're not able to connect to an existing tasking-manager DB, we
have a [Dockerfile]() that will allow you to run PostGIS locally as
follows.

### Dependencies

Following must be available locally:

* [Docker CE](https://www.docker.com/community-edition#/download)

### Build & Run the PostGIS dockerfile

1. From the root of the project:
Expand Down Expand Up @@ -279,21 +366,21 @@ export TM_DB=postgresql://hottm:hottm@localhost/tasking-manager
6. Refer to the rest of the instructions in the README to setup the
DB and run the app.

# Non-Docker
## Creating a local PostGIS database without Docker

## Creating the PostGIS database
### Creating the PostGIS database

It may be the case you would like to set up the database without using
Docker for one reason or another. This provides you with a set of
commands to create the database and export the database address to
allow you to dive into backend development.

### Dependencies
#### Dependencies

First, ensure that Postgresql and PostGIS are installed and running on
your computer.

### Create the database user and database
#### Create the database user and database

Assuming you have sudo access and the unix Postgresql owner is `postgres`:

Expand Down Expand Up @@ -325,3 +412,4 @@ get a working version of the API running.
* [Managing CI/CD with CircleCI](../sysadmins/ci-cd.md)
* [Deployment Guide](../sysadmins/deployment.md)

[1]: https://www.openstreetmap.org/login "Login to OSM"
3 changes: 3 additions & 0 deletions example.env
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,9 @@ TM_APP_API_URL=http://127.0.0.1:5000
# Defines the version of the API and will be used after /api/ on the url
TM_APP_API_VERSION=v2

# Override default port 80 during development
# TM_DEV_PORT=880

# Information about the hosting organization
TM_ORG_NAME="Humanitarian OpenStreetMap Team"
TM_ORG_CODE=HOT
Expand Down
2 changes: 0 additions & 2 deletions scripts/install/install_on_debian_10_buster.sh
Original file line number Diff line number Diff line change
Expand Up @@ -32,8 +32,6 @@ git clone https://github.com/hotosm/tasking-manager.git &&
cd tasking-manager/ &&
pip install --upgrade pip &&
pip install --upgrade pdm &&
pdm config --global python.use_venv False &&
eval "$(pdm --pep582)" &&
pdm install &&

# Set up configuration
Expand Down
2 changes: 0 additions & 2 deletions scripts/install/install_on_ubuntu_18_04.sh
Original file line number Diff line number Diff line change
Expand Up @@ -32,8 +32,6 @@ git clone https://github.com/hotosm/tasking-manager.git &&
cd tasking-manager/ &&
pip install --upgrade pip &&
pip install --upgrade pdm &&
pdm config --global python.use_venv False &&
eval "$(pdm --pep582)" &&
pdm install &&
echo fs.inotify.max_user_watches=524288 | sudo tee -a /etc/sysctl.conf && sudo sysctl -p &&

Expand Down
Loading