Skip to content

Commit

Permalink
docs: reorg contributing section
Browse files Browse the repository at this point in the history
  • Loading branch information
akellbl4 authored and umputun committed Jul 25, 2022
1 parent f104a6e commit 922e779
Show file tree
Hide file tree
Showing 5 changed files with 38 additions and 60 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -50,3 +50,35 @@ find ./backend/web -regex '.*\.\(html\|js\|mjs\)$' -print -exec sed -i "s|{% REM
To run backend - `cd backend; go run app/main.go server --dbg --secret=12345 --url=http://127.0.0.1:8080 --admin-passwd=password --site=remark`. It stars backend service with embedded bolt store on port `8080` with basic auth, allowing to authenticate and run requests directly, like this:

`HTTP http://admin:password@127.0.0.1:8080/api/v1/find?site=remark&sort=-active&format=tree&url=http://127.0.0.1:8080`

## Technical Details

Data stored in [boltdb](https://github.com/etcd-io/bbolt) (embedded key/value database) files under `STORE_BOLT_PATH`. Each site is stored in a separate boltdb file.

To migrate/move Remark42 to another host, boltdb files and avatars directory `AVATAR_FS_PATH` should be transferred. Optionally, boltdb can be used to store avatars as well.

The automatic backup process runs every 24h and exports all content in JSON-like format to `backup-remark-YYYYMMDD.gz`.

Authentication implemented with [go-pkgz/auth](https://github.com/go-pkgz/auth) stored in a cookie. It uses HttpOnly, secure cookies.

All heavy REST calls cached internally in LRU cache limited by `CACHE_MAX_ITEMS` and `CACHE_MAX_SIZE` with [go-pkgz/rest](https://github.com/go-pkgz/rest).

User's activity throttled globally (up to 1000 simultaneous requests) and limited locally (per user, usually up to 10 req/sec).

Request timeout set to 60sec.

Admin authentication (`--admin-password` set) allows to hit Remark42 API without social login and admin privileges. Adds basic-auth for username: `admin`, password: `${ADMIN_PASSWD}`. Enable it only for the initial comment import or for manual backups. Do not leave server running with admin password set if you don't have intention to keep creating backups manually!

User can vote for the comment multiple times but only to change the vote. Double voting is not allowed.

User can edit comments in 5 mins (configurable) window after creation.

User ID hashed and prefixed by OAuth provider name to avoid collisions and potential abuse.

All avatars resized and cached locally to prevent rate limiters from OAuth providers, part of [go-pkgz/auth](https://github.com/go-pkgz/auth) functionality.

Images served over HTTP can be proxied to HTTPS (`IMAGE_PROXY_HTTP2HTTPS=true`) to prevent mixed HTTP/HTTPS.

All images can be proxied and saved locally (`IMAGE_PROXY_CACHE_EXTERNAL=true`) instead of serving from the original location. Beware, images that are posted with this parameter enabled will be served from proxy even after it is disabled.

Docker build uses [publicly available](https://github.com/umputun/baseimage) base images.
11 changes: 0 additions & 11 deletions site/src/docs/contributing/development/index.md

This file was deleted.

33 changes: 0 additions & 33 deletions site/src/docs/contributing/technical-details/index.md

This file was deleted.

22 changes: 6 additions & 16 deletions site/src/docs/nav.json
Original file line number Diff line number Diff line change
Expand Up @@ -95,18 +95,12 @@
"section": "Contributing",
"children": [
{
"title": "Development",
"href": "/contributing/development/",
"children": [
{
"title": "Backend",
"href": "/contributing/development/backend/"
},
{
"title": "Frontend",
"href": "/contributing/development/frontend/"
}
]
"title": "Backend",
"href": "/contributing/backend/"
},
{
"title": "Frontend",
"href": "/contributing/frontend/"
},
{
"title": "Translations",
Expand All @@ -115,10 +109,6 @@
{
"title": "API",
"href": "/contributing/api/"
},
{
"title": "Technical Details",
"href": "/contributing/technical-details/"
}
]
}
Expand Down

0 comments on commit 922e779

Please sign in to comment.