forked from coop-cloud/outline
Compare commits
13 Commits
old-databa
...
0.8.0+0.69
Author | SHA1 | Date | |
---|---|---|---|
53e4d82aa3 | |||
361908fe84 | |||
ecb5314fe7 | |||
a016995516 | |||
2daf487bb8 | |||
0354892c74 | |||
86c215cbc9 | |||
8e7a7b9932 | |||
d1f7c765dd | |||
4f923ad0c1 | |||
672557c7fb | |||
00576231e5 | |||
beeffe65f6 |
43
.drone.yml
Normal file
43
.drone.yml
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
---
|
||||||
|
kind: pipeline
|
||||||
|
name: deploy to swarm-test.autonomic.zone
|
||||||
|
steps:
|
||||||
|
- name: deployment
|
||||||
|
image: git.coopcloud.tech/coop-cloud/stack-ssh-deploy:latest
|
||||||
|
settings:
|
||||||
|
host: swarm-test.autonomic.zone
|
||||||
|
stack: outline
|
||||||
|
generate_secrets: true
|
||||||
|
purge: true
|
||||||
|
deploy_key:
|
||||||
|
from_secret: drone_ssh_swarm_test
|
||||||
|
networks:
|
||||||
|
- proxy
|
||||||
|
environment:
|
||||||
|
DOMAIN: outline.swarm-test.autonomic.zone
|
||||||
|
STACK_NAME: outline
|
||||||
|
LETS_ENCRYPT_ENV: production
|
||||||
|
APP_ENTRYPOINT_VERSION: v1
|
||||||
|
SECRET_DB_PASSWORD_VERSION: v1
|
||||||
|
SECRET_SECRET_KEY_VERSION: v1 # length=64
|
||||||
|
SECRET_UTILS_SECRET_VERSION: v1 # length=64
|
||||||
|
SECRET_AWS_SECRET_KEY_VERSION: v1
|
||||||
|
trigger:
|
||||||
|
branch:
|
||||||
|
- main
|
||||||
|
---
|
||||||
|
kind: pipeline
|
||||||
|
name: generate recipe catalogue
|
||||||
|
steps:
|
||||||
|
- name: release a new version
|
||||||
|
image: plugins/downstream
|
||||||
|
settings:
|
||||||
|
server: https://build.coopcloud.tech
|
||||||
|
token:
|
||||||
|
from_secret: drone_abra-bot_token
|
||||||
|
fork: true
|
||||||
|
repositories:
|
||||||
|
- coop-cloud/auto-recipes-catalogue-json
|
||||||
|
|
||||||
|
trigger:
|
||||||
|
event: tag
|
@ -9,8 +9,6 @@ DOMAIN=outline.example.com
|
|||||||
LETS_ENCRYPT_ENV=production
|
LETS_ENCRYPT_ENV=production
|
||||||
|
|
||||||
COMPOSE_FILE="compose.yml"
|
COMPOSE_FILE="compose.yml"
|
||||||
#COMPOSE_YML="compose.yml:compose.oidc.yml"
|
|
||||||
#COMPOSE_YML="compose.yml:compose.google.yml"
|
|
||||||
|
|
||||||
# –––––––––––––––– REQUIRED ––––––––––––––––
|
# –––––––––––––––– REQUIRED ––––––––––––––––
|
||||||
|
|
||||||
@ -70,6 +68,7 @@ ALLOWED_DOMAINS=
|
|||||||
#SMTP_TLS_CIPHERS=
|
#SMTP_TLS_CIPHERS=
|
||||||
#SMTP_SECURE=true
|
#SMTP_SECURE=true
|
||||||
|
|
||||||
|
#COMPOSE_FILE="$COMPOSE_FILE:compose.oidc.yml"
|
||||||
#OIDC_ENABLED=1
|
#OIDC_ENABLED=1
|
||||||
#OIDC_CLIENT_ID=
|
#OIDC_CLIENT_ID=
|
||||||
#OIDC_AUTH_URI=
|
#OIDC_AUTH_URI=
|
||||||
@ -80,6 +79,7 @@ ALLOWED_DOMAINS=
|
|||||||
#OIDC_SCOPES="openid profile email"
|
#OIDC_SCOPES="openid profile email"
|
||||||
#SECRET_OIDC_CLIENT_SECRET_VERSION=v1
|
#SECRET_OIDC_CLIENT_SECRET_VERSION=v1
|
||||||
|
|
||||||
|
#COMPOSE_FILE="$COMPOSE_FILE:compose.google.yml"
|
||||||
#GOOGLE_ENABLED=1
|
#GOOGLE_ENABLED=1
|
||||||
#GOOGLE_CLIENT_ID=
|
#GOOGLE_CLIENT_ID=
|
||||||
#SECRET_GOOGLE_CLIENT_SECRET_VERSION=v1
|
#SECRET_GOOGLE_CLIENT_SECRET_VERSION=v1
|
||||||
|
10
README.md
10
README.md
@ -52,3 +52,13 @@ Where `<username-to-delete>` is the username of the user to be removed, and
|
|||||||
revisions to (instead of deleting them).
|
revisions to (instead of deleting them).
|
||||||
|
|
||||||
_As of 2022-03-30, this requires `abra` RC version, run `abra upgrade --rc`._
|
_As of 2022-03-30, this requires `abra` RC version, run `abra upgrade --rc`._
|
||||||
|
|
||||||
|
## Single Sign On with Keycloak
|
||||||
|
|
||||||
|
`abra app config YOURAPPNAME`, then uncomment everything in the `OIDC_` section.
|
||||||
|
|
||||||
|
Create a new client in Keycloak:
|
||||||
|
|
||||||
|
- **Valid Redirect URIs**: `https://YOURAPPDOMAIN/auth/oidc.callback`
|
||||||
|
|
||||||
|
`abra app deploy YOURAPPDOMAIN`
|
||||||
|
74
abra.sh
74
abra.sh
@ -6,9 +6,42 @@ migrate() {
|
|||||||
yarn db:migrate --env=production-ssl-disabled
|
yarn db:migrate --env=production-ssl-disabled
|
||||||
}
|
}
|
||||||
|
|
||||||
|
delete_user_by_id() {
|
||||||
|
if [ -z "$1" ] || [ -z "$2" ]; then
|
||||||
|
echo "Usage: ... delete_user_by_id <userid-to-delete> <userid-to-replace>"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
USERID_REPLACE="$2"
|
||||||
|
USERID_REMOVE="$1"
|
||||||
|
|
||||||
|
psql -U outline outline <<- SQL
|
||||||
|
UPDATE documents SET "userId" = '$USERID_REPLACE' WHERE "userId" = '$USERID_REMOVE';
|
||||||
|
UPDATE groups SET "createdById" = '$USERID_REPLACE' WHERE "createdById" = '$USERID_REMOVE';
|
||||||
|
UPDATE pins SET "createdById" = '$USERID_REPLACE' WHERE "createdById" = '$USERID_REMOVE';
|
||||||
|
UPDATE group_users SET "createdById" = '$USERID_REPLACE' WHERE "createdById" = '$USERID_REMOVE';
|
||||||
|
UPDATE collections SET "createdById" = '$USERID_REPLACE' WHERE "createdById" = '$USERID_REMOVE';
|
||||||
|
UPDATE collection_users SET "createdById" = '$USERID_REPLACE' WHERE "createdById" = '$USERID_REMOVE';
|
||||||
|
UPDATE collection_groups SET "createdById" = '$USERID_REPLACE' WHERE "createdById" = '$USERID_REMOVE';
|
||||||
|
UPDATE documents SET "lastModifiedById" = '$USERID_REPLACE' WHERE "lastModifiedById" = '$USERID_REMOVE';
|
||||||
|
UPDATE documents SET "createdById" = '$USERID_REPLACE' WHERE "createdById" = '$USERID_REMOVE';
|
||||||
|
UPDATE revisions SET "userId" = '$USERID_REPLACE' WHERE "userId" = '$USERID_REMOVE';
|
||||||
|
UPDATE attachments SET "userId" = '$USERID_REPLACE' WHERE "userId" = '$USERID_REMOVE';
|
||||||
|
UPDATE backlinks SET "userId" = '$USERID_REPLACE' WHERE "userId" = '$USERID_REMOVE';
|
||||||
|
UPDATE file_operations SET "userId" = '$USERID_REPLACE' WHERE "userId" = '$USERID_REMOVE';
|
||||||
|
UPDATE users SET "suspendedById" = '$USERID_REPLACE' WHERE "suspendedById" = '$USERID_REMOVE';
|
||||||
|
DELETE FROM search_queries WHERE "userId" = '$USERID_REMOVE';
|
||||||
|
DELETE FROM shares WHERE "userId" = '$USERID_REMOVE';
|
||||||
|
DELETE FROM notification_settings WHERE "userId" = '$USERID_REMOVE';
|
||||||
|
DELETE FROM events WHERE "actorId" = '$USERID_REMOVE';
|
||||||
|
DELETE FROM events WHERE "userId" = '$USERID_REMOVE';
|
||||||
|
DELETE FROM users WHERE "id" = '$USERID_REMOVE';
|
||||||
|
SQL
|
||||||
|
}
|
||||||
|
|
||||||
delete_user() {
|
delete_user() {
|
||||||
if [ -z "$1" ] || [ -z "$2" ]; then
|
if [ -z "$1" ] || [ -z "$2" ]; then
|
||||||
echo "Usage: ... delete_user <user-to-delete> <user-to-replace>"
|
echo "Usage: ... delete_user <userid-to-delete> <userid-to-replace>"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@ -25,22 +58,25 @@ delete_user() {
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
psql -U outline outline <<- SQL
|
delete_user_by_id "$USERID_REMOVE" "$USERID_REPLACE"
|
||||||
UPDATE documents SET "userId" = '$USERID_REPLACE' WHERE "userId" = '$USERID_REMOVE';
|
}
|
||||||
UPDATE groups SET "createdById" = '$USERID_REPLACE' WHERE "createdById" = '$USERID_REMOVE';
|
|
||||||
UPDATE pins SET "createdById" = '$USERID_REPLACE' WHERE "createdById" = '$USERID_REMOVE';
|
delete_duplicate_users() {
|
||||||
UPDATE group_users SET "createdById" = '$USERID_REPLACE' WHERE "createdById" = '$USERID_REMOVE';
|
if [ -z "$1" ]; then
|
||||||
UPDATE collections SET "createdById" = '$USERID_REPLACE' WHERE "createdById" = '$USERID_REMOVE';
|
echo "Usage: ... delete_duplicate_users <username>"
|
||||||
UPDATE collection_users SET "createdById" = '$USERID_REPLACE' WHERE "createdById" = '$USERID_REMOVE';
|
exit 1
|
||||||
UPDATE documents SET "lastModifiedById" = '$USERID_REPLACE' WHERE "lastModifiedById" = '$USERID_REMOVE';
|
fi
|
||||||
UPDATE documents SET "createdById" = '$USERID_REPLACE' WHERE "createdById" = '$USERID_REMOVE';
|
|
||||||
UPDATE revisions SET "userId" = '$USERID_REPLACE' WHERE "userId" = '$USERID_REMOVE';
|
USERIDS=$(echo "SELECT id FROM users WHERE username = '$1' ORDER BY users.\"createdAt\" DESC" | psql -t -A -U outline outline)
|
||||||
UPDATE attachments SET "userId" = '$USERID_REPLACE' WHERE "userId" = '$USERID_REMOVE';
|
|
||||||
DELETE FROM search_queries WHERE "userId" = '$USERID_REMOVE';
|
if [ ! "$(echo "$USERIDS" | wc -l)" -gt 1 ]; then
|
||||||
DELETE FROM shares WHERE "userId" = '$USERID_REMOVE';
|
echo "Only one user exists, bailing"
|
||||||
DELETE FROM notification_settings WHERE "userId" = '$USERID_REMOVE';
|
exit 1
|
||||||
DELETE FROM events WHERE "actorId" = '$USERID_REMOVE';
|
fi
|
||||||
DELETE FROM events WHERE "userId" = '$USERID_REMOVE';
|
|
||||||
DELETE FROM users WHERE username = '$1';
|
USERID_NEW=$(echo "$USERIDS" | head -n1)
|
||||||
SQL
|
|
||||||
|
for USERID_OLD in $(echo "$USERIDS" | tail -n+2); do
|
||||||
|
delete_user_by_id "$USERID_OLD" "$USERID_NEW"
|
||||||
|
done
|
||||||
}
|
}
|
||||||
|
12
compose.yml
12
compose.yml
@ -6,7 +6,7 @@ services:
|
|||||||
networks:
|
networks:
|
||||||
- backend
|
- backend
|
||||||
- proxy
|
- proxy
|
||||||
image: outlinewiki/outline:0.64.4
|
image: outlinewiki/outline:0.69.2
|
||||||
secrets:
|
secrets:
|
||||||
- aws_secret_key
|
- aws_secret_key
|
||||||
- db_password
|
- db_password
|
||||||
@ -43,14 +43,14 @@ services:
|
|||||||
- "traefik.http.routers.${STACK_NAME}.rule=Host(`${DOMAIN}`${EXTRA_DOMAINS})"
|
- "traefik.http.routers.${STACK_NAME}.rule=Host(`${DOMAIN}`${EXTRA_DOMAINS})"
|
||||||
- "traefik.http.routers.${STACK_NAME}.entrypoints=web-secure"
|
- "traefik.http.routers.${STACK_NAME}.entrypoints=web-secure"
|
||||||
- "traefik.http.routers.${STACK_NAME}.tls.certresolver=${LETS_ENCRYPT_ENV}"
|
- "traefik.http.routers.${STACK_NAME}.tls.certresolver=${LETS_ENCRYPT_ENV}"
|
||||||
- "coop-cloud.${STACK_NAME}.version=0.4.1+0.64.4"
|
- "coop-cloud.${STACK_NAME}.version=0.8.0+0.69.2"
|
||||||
## Redirect from EXTRA_DOMAINS to DOMAIN
|
## Redirect from EXTRA_DOMAINS to DOMAIN
|
||||||
#- "traefik.http.routers.${STACK_NAME}.middlewares=${STACK_NAME}-redirect"
|
#- "traefik.http.routers.${STACK_NAME}.middlewares=${STACK_NAME}-redirect"
|
||||||
#- "traefik.http.middlewares.${STACK_NAME}-redirect.headers.SSLForceHost=true"
|
#- "traefik.http.middlewares.${STACK_NAME}-redirect.headers.SSLForceHost=true"
|
||||||
#- "traefik.http.middlewares.${STACK_NAME}-redirect.headers.SSLHost=${DOMAIN}"
|
#- "traefik.http.middlewares.${STACK_NAME}-redirect.headers.SSLHost=${DOMAIN}"
|
||||||
|
|
||||||
cache:
|
cache:
|
||||||
image: redis:6.2.6
|
image: redis:7.0.11
|
||||||
networks:
|
networks:
|
||||||
- backend
|
- backend
|
||||||
|
|
||||||
@ -66,6 +66,12 @@ services:
|
|||||||
POSTGRES_USER: outline
|
POSTGRES_USER: outline
|
||||||
volumes:
|
volumes:
|
||||||
- "postgres_data:/var/lib/postgresql/data"
|
- "postgres_data:/var/lib/postgresql/data"
|
||||||
|
deploy:
|
||||||
|
labels:
|
||||||
|
backupbot.backup: "true"
|
||||||
|
backupbot.backup.path: "/tmp/dump.sql.gz"
|
||||||
|
backupbot.backup.post-hook: "rm -f /tmp/dump.sql.gz"
|
||||||
|
backupbot.backup.pre-hook: "sh -c 'PGPASSWORD=$$(cat $${POSTGRES_PASSWORD_FILE}) pg_dump -U outline outline | gzip > /tmp/dump.sql.gz'"
|
||||||
|
|
||||||
secrets:
|
secrets:
|
||||||
secret_key:
|
secret_key:
|
||||||
|
Reference in New Issue
Block a user