entrypoint.sh 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. #!/bin/sh
  2. ln -snf "/usr/share/zoneinfo/$TZ" /etc/localtime
  3. echo "$TZ" >/etc/timezone
  4. find /etc/php*/ -type f -name php.ini -exec sed -i -E \
  5. -e "\\#^;?date.timezone#s#^.*#date.timezone = $TZ#" \
  6. -e "\\#^;?post_max_size#s#^.*#post_max_size = 32M#" \
  7. -e "\\#^;?upload_max_filesize#s#^.*#upload_max_filesize = 32M#" {} \;
  8. while read -r config_path _; do
  9. if [ -f "$config_path" ]; then
  10. APACHE_CONFIG="$config_path"
  11. break
  12. fi
  13. done <<EOF
  14. /etc/apache2/sites-available/FreshRSS.Apache.conf # Debian
  15. /etc/apache2/conf.d/FreshRSS.Apache.conf # Alpine
  16. /etc/httpd/conf/conf.d/FreshRSS.Apache.conf # Arch
  17. EOF
  18. if [ -z "$APACHE_CONFIG" ]; then
  19. echo '❌ Apache configuration file not found!'
  20. exit 11
  21. fi
  22. if [ -n "$LISTEN" ]; then
  23. sed -r -i "\\#^Listen#s#^.*#Listen $LISTEN#" "$APACHE_CONFIG"
  24. fi
  25. if [ -n "$TRUSTED_PROXY" ]; then
  26. if [ "$TRUSTED_PROXY" = "0" ]; then
  27. # Disable RemoteIPHeader and RemoteIPInternalProxy
  28. sed -r -i "/^\s*RemoteIP.*$/s/^/#/" "$APACHE_CONFIG"
  29. else
  30. # Custom list for RemoteIPInternalProxy
  31. sed -r -i "\\#^\s*RemoteIPInternalProxy#s#^.*#\tRemoteIPInternalProxy $TRUSTED_PROXY#" "$APACHE_CONFIG"
  32. fi
  33. fi
  34. if [ -n "$OIDC_ENABLED" ] && [ "$OIDC_ENABLED" -ne 0 ]; then
  35. # Default values
  36. export OIDC_SESSION_INACTIVITY_TIMEOUT="${OIDC_SESSION_INACTIVITY_TIMEOUT:-300}"
  37. export OIDC_SESSION_MAX_DURATION="${OIDC_SESSION_MAX_DURATION:-27200}"
  38. export OIDC_SESSION_TYPE="${OIDC_SESSION_TYPE:-server-cache}"
  39. # Debian
  40. (which a2enmod >/dev/null && a2enmod -q auth_openidc) ||
  41. # Alpine
  42. (mv /etc/apache2/conf.d/mod-auth-openidc.conf.bak /etc/apache2/conf.d/mod-auth-openidc.conf && echo 'Enabling module auth_openidc.') ||
  43. # Misc.
  44. (echo '❌ Failed to enable auth_openidc module!' && exit 12)
  45. if [ -n "$OIDC_SCOPES" ]; then
  46. # Compatibility with : as separator instead of space
  47. OIDC_SCOPES=$(echo "$OIDC_SCOPES" | tr ':' ' ')
  48. export OIDC_SCOPES
  49. fi
  50. fi
  51. if [ -n "$CRON_MIN" ]; then
  52. awk -v RS='\0' '!/^(FRESHRSS_INSTALL|FRESHRSS_USER|HOME|PATH|PWD|SHLVL|TERM|_)=/ {gsub("\047", "\047\\\047\047"); print "export \047" $0 "\047"}' /proc/self/environ >/var/www/FreshRSS/Docker/env.txt
  53. sed </etc/crontab.freshrss.default \
  54. -r "s#^[^ ]+ #$CRON_MIN #" | crontab -
  55. fi
  56. ./cli/access-permissions.sh --only-userdirs
  57. php -f ./cli/prepare.php >/dev/null
  58. if [ -n "$FRESHRSS_INSTALL" ]; then
  59. # shellcheck disable=SC2046
  60. php -f ./cli/do-install.php -- \
  61. $(eval "echo \"$FRESHRSS_INSTALL\"" | sed -r 's/[\r\n]+/\n/g' | paste -s -)
  62. EXITCODE=$?
  63. if [ $EXITCODE -eq 3 ]; then
  64. echo 'ℹ️ FreshRSS already installed; no change performed.'
  65. elif [ $EXITCODE -eq 0 ]; then
  66. echo '✅ FreshRSS successfully installed.'
  67. else
  68. echo '❌ FreshRSS error during installation!'
  69. exit $EXITCODE
  70. fi
  71. fi
  72. if [ -n "$FRESHRSS_USER" ]; then
  73. # shellcheck disable=SC2046
  74. php -f ./cli/create-user.php -- \
  75. $(eval "echo \"$FRESHRSS_USER\"" | sed -r 's/[\r\n]+/\n/g' | paste -s -)
  76. EXITCODE=$?
  77. if [ $EXITCODE -eq 3 ]; then
  78. echo 'ℹ️ FreshRSS user already exists; no change performed.'
  79. elif [ $EXITCODE -eq 0 ]; then
  80. echo '✅ FreshRSS user successfully created.'
  81. ./cli/list-users.php | xargs -n1 ./cli/actualize-user.php --user
  82. else
  83. echo '❌ FreshRSS error during the creation of a user!'
  84. exit $EXITCODE
  85. fi
  86. fi
  87. # Fix permissions of data added by prepare.php as well as a potential
  88. # installation/user setup
  89. ./cli/access-permissions.sh --only-userdirs
  90. exec "$@"