diff options
Diffstat (limited to 'docker/entrypoint.sh')
-rwxr-xr-x | docker/entrypoint.sh | 90 |
1 files changed, 68 insertions, 22 deletions
diff --git a/docker/entrypoint.sh b/docker/entrypoint.sh index 4178d97..b2f4924 100755 --- a/docker/entrypoint.sh +++ b/docker/entrypoint.sh | |||
@@ -17,18 +17,23 @@ Brought to you by ferdium.org | |||
17 | EOL | 17 | EOL |
18 | 18 | ||
19 | # Update recipes from official git repository | 19 | # Update recipes from official git repository |
20 | |||
21 | # We need to set NODE_ENV to development to install devDependencies | ||
22 | SAVE_NODE_ENV=$NODE_ENV | ||
23 | NODE_ENV=development | ||
24 | |||
20 | if [ ! -d "/app/recipes/.git" ]; # When we mount an existing volume (ferdium-recipes-vol:/app/recipes) if this is only /app/recipes it is always true | 25 | if [ ! -d "/app/recipes/.git" ]; # When we mount an existing volume (ferdium-recipes-vol:/app/recipes) if this is only /app/recipes it is always true |
21 | then | 26 | then |
22 | echo '**** Generating recipes for first run ****' | 27 | echo '**** Generating recipes for first run ****' |
23 | git clone --branch main https://github.com/ferdium/ferdium-recipes recipes | 28 | git clone --branch main https://github.com/ferdium/ferdium-recipes recipes |
24 | else | 29 | else |
25 | echo '**** Updating recipes ****' | 30 | echo '**** Updating recipes ****' |
26 | chown -R root /app/recipes # Fixes ownership problem when doing git pull -r | 31 | chown -R root /app/recipes # Fixes ownership problem when doing git pull -r |
27 | cd recipes | 32 | cd recipes |
28 | git stash -u | 33 | git stash -u |
29 | git pull -r | 34 | git pull -r |
30 | git stash pop | 35 | git stash pop |
31 | cd .. | 36 | cd .. |
32 | fi | 37 | fi |
33 | 38 | ||
34 | cd recipes | 39 | cd recipes |
@@ -39,31 +44,72 @@ pnpm i | |||
39 | pnpm package | 44 | pnpm package |
40 | cd .. | 45 | cd .. |
41 | 46 | ||
47 | # Restore NODE_ENV | ||
48 | NODE_ENV=$SAVE_NODE_ENV | ||
49 | |||
42 | key_file="${DATA_DIR}/FERDIUM_APP_KEY.txt" | 50 | key_file="${DATA_DIR}/FERDIUM_APP_KEY.txt" |
43 | 51 | ||
44 | print_app_key_message() { | 52 | print_app_key_message() { |
45 | app_key=$1 | 53 | app_key=$1 |
46 | printf '**** App key is %s. ' ${app_key} | 54 | printf '**** App key is %s. ' ${app_key} |
47 | printf 'You can modify `%s` to update the app key ****\n' ${key_file} | 55 | printf 'You can modify `%s` to update the app key ****\n' ${key_file} |
48 | } | 56 | } |
49 | 57 | ||
50 | # Create APP key if needed | 58 | # Create APP key if needed |
51 | if [ -z ${APP_KEY} ] && [ ! -f ${key_file} ] | 59 | if [ -z ${APP_KEY} ] && [ ! -f ${key_file} ] |
52 | then | 60 | then |
53 | echo '**** Generating Ferdium-server app key for first run ****' | 61 | echo '**** Generating Ferdium-server app key for first run ****' |
54 | adonis key:generate | 62 | adonis key:generate |
55 | APP_KEY=$(grep APP_KEY .env | cut -d '=' -f2) | 63 | APP_KEY=$(grep APP_KEY .env | cut -d '=' -f2) |
56 | echo ${APP_KEY} > ${key_file} | 64 | echo ${APP_KEY} > ${key_file} |
57 | print_app_key_message ${APP_KEY} | 65 | print_app_key_message ${APP_KEY} |
58 | else | 66 | else |
59 | APP_KEY=$(cat ${key_file}) | 67 | APP_KEY=$(cat ${key_file}) |
60 | print_app_key_message ${APP_KEY} | 68 | print_app_key_message ${APP_KEY} |
61 | fi | 69 | fi |
62 | 70 | ||
71 | # ------------------------------------- | ||
72 | # Create JWT public/private keys if needed | ||
73 | |||
74 | # Check if JWT_USE_PEM is true | ||
75 | if [ "$JWT_USE_PEM" = "true" ]; then | ||
76 | # Define file paths for public and private keys | ||
77 | publicKeyFile="${DATA_DIR}/FERDIUM_JWT_PUBLIC_KEY.pem" | ||
78 | privateKeyFile="${DATA_DIR}/FERDIUM_JWT_PRIVATE_KEY.pem" | ||
79 | # Check if public and private key files exist | ||
80 | if [ ! -f "$publicKeyFile" ] || [ ! -f "$privateKeyFile" ]; then | ||
81 | echo "Generating public and private keys..." | ||
82 | |||
83 | # Use Node.js to generate the keys | ||
84 | node ace jwt:generate-keys $DATA_DIR | ||
85 | mv ${DATA_DIR}/public.pem ${publicKeyFile} | ||
86 | mv ${DATA_DIR}/private.pem ${privateKeyFile} | ||
87 | |||
88 | echo "Public and private keys generated successfully." | ||
89 | else | ||
90 | echo "Using existing public and private keys." | ||
91 | fi | ||
92 | JWT_PUBLIC_KEY=$(cat ${publicKeyFile}) | ||
93 | JWT_PRIVATE_KEY=$(cat ${privateKeyFile}) | ||
94 | export JWT_PUBLIC_KEY | ||
95 | export JWT_PRIVATE_KEY | ||
96 | else | ||
97 | echo "JWT_USE_PEM is not set to true. Skipping JWT certificate generation." | ||
98 | fi | ||
99 | # End of JWT public/private keys | ||
100 | # ------------------------------------- | ||
101 | |||
63 | export APP_KEY | 102 | export APP_KEY |
64 | 103 | ||
65 | node ace migration:run --force | 104 | # Enable the errexit option |
105 | set -e | ||
66 | 106 | ||
67 | chown -R "${PUID:-1000}":"${PGID:-1000}" "${DATA_DIR}" /app # This is the cause of the problem on line 29/32 | 107 | # Run the script to migrate from AdonisJS v4 to v5 |
108 | sh /app/scripts/adonisjs-4-to-5.sh | ||
109 | |||
110 | # Disable the errexit option | ||
111 | set +e | ||
112 | |||
113 | node ace migration:run --force | ||
68 | 114 | ||
69 | su-exec "${PUID:-1000}":"${PGID:-1000}" node server.js | 115 | node build/server.js |