aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLukas Oertel2023-01-22 18:12:17 +0100
committerLukas Oertel2023-01-22 18:12:17 +0100
commite23a1db405b5181f66d2fad6636f89ec2c30948f (patch)
tree7953f44f081dbb133e01163f0c7a2278bdbb2df7
parentedf1ec190d2125ac5dbdd38635bc0b09f6c71033 (diff)
scripts/hedgedoc-ldap_to_oauth2: Init
-rw-r--r--scripts/hedgedoc-ldap_to_oauth2/README.md8
-rw-r--r--scripts/hedgedoc-ldap_to_oauth2/ldap_users.sh8
-rw-r--r--scripts/hedgedoc-ldap_to_oauth2/replacements.txt4
3 files changed, 20 insertions, 0 deletions
diff --git a/scripts/hedgedoc-ldap_to_oauth2/README.md b/scripts/hedgedoc-ldap_to_oauth2/README.md
new file mode 100644
index 0000000..d6c0d8b
--- /dev/null
+++ b/scripts/hedgedoc-ldap_to_oauth2/README.md
@@ -0,0 +1,8 @@
+Script to convert CodiMD, HackMD or Hedgedoc Postgres database users from LDAP authentication to OAuth2 (i.e. Keycloak in our case).
+
+
+`ldap_users.txt` should look like:
+```
+scott LDAP-1000
+peter LDAP-1001
+```
diff --git a/scripts/hedgedoc-ldap_to_oauth2/ldap_users.sh b/scripts/hedgedoc-ldap_to_oauth2/ldap_users.sh
new file mode 100644
index 0000000..8d05fa5
--- /dev/null
+++ b/scripts/hedgedoc-ldap_to_oauth2/ldap_users.sh
@@ -0,0 +1,8 @@
+#!/bin/bash
+
+while read p; do
+ USER=`echo $p | sed 's/\s.*$//'`
+ ID=`echo $p | sed 's/.* //'`
+ echo $USER $ID
+ sed 's/$UID/'$USER'/g' replacements.txt | sed 's/$LDAPID/'$ID'/g' - >> replacements.sql
+done <ldap_users.txt
diff --git a/scripts/hedgedoc-ldap_to_oauth2/replacements.txt b/scripts/hedgedoc-ldap_to_oauth2/replacements.txt
new file mode 100644
index 0000000..b093101
--- /dev/null
+++ b/scripts/hedgedoc-ldap_to_oauth2/replacements.txt
@@ -0,0 +1,4 @@
+UPDATE "Users" SET profileid = '$UID', profile = jsonb_set(profile::jsonb, '{id}', '"$UID"') where profileid = '$LDAPID';
+UPDATE "Users" SET profile = profile::jsonb || jsonb_build_object('displayName', profile::json->'username') where profileid = '$UID';
+UPDATE "Users" SET profile = jsonb_set(profile::jsonb, '{username}', '"$UID"') where profileid = '$UID';
+UPDATE "Users" SET profile = jsonb_set(profile::jsonb, '{provider}', '"oauth2"') where profileid = '$UID';