run.sh 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. #!/bin/bash -e
  2. PERMISSIONS_OK=0
  3. if [ ! -r "$GF_PATHS_CONFIG" ]; then
  4. echo "GF_PATHS_CONFIG='$GF_PATHS_CONFIG' is not readable."
  5. PERMISSIONS_OK=1
  6. fi
  7. if [ ! -w "$GF_PATHS_DATA" ]; then
  8. echo "GF_PATHS_DATA='$GF_PATHS_DATA' is not writable."
  9. PERMISSIONS_OK=1
  10. fi
  11. if [ ! -r "$GF_PATHS_HOME" ]; then
  12. echo "GF_PATHS_HOME='$GF_PATHS_HOME' is not readable."
  13. PERMISSIONS_OK=1
  14. fi
  15. if [ $PERMISSIONS_OK -eq 1 ]; then
  16. echo "You may have issues with file permissions, more information here: http://docs.grafana.org/installation/docker/#migration-from-a-previous-version-of-the-docker-container-to-5-1-or-later"
  17. fi
  18. if [ ! -d "$GF_PATHS_PLUGINS" ]; then
  19. mkdir "$GF_PATHS_PLUGINS"
  20. fi
  21. if [ ! -z ${GF_AWS_PROFILES+x} ]; then
  22. > "$GF_PATHS_HOME/.aws/credentials"
  23. for profile in ${GF_AWS_PROFILES}; do
  24. access_key_varname="GF_AWS_${profile}_ACCESS_KEY_ID"
  25. secret_key_varname="GF_AWS_${profile}_SECRET_ACCESS_KEY"
  26. region_varname="GF_AWS_${profile}_REGION"
  27. if [ ! -z "${!access_key_varname}" -a ! -z "${!secret_key_varname}" ]; then
  28. echo "[${profile}]" >> "$GF_PATHS_HOME/.aws/credentials"
  29. echo "aws_access_key_id = ${!access_key_varname}" >> "$GF_PATHS_HOME/.aws/credentials"
  30. echo "aws_secret_access_key = ${!secret_key_varname}" >> "$GF_PATHS_HOME/.aws/credentials"
  31. if [ ! -z "${!region_varname}" ]; then
  32. echo "region = ${!region_varname}" >> "$GF_PATHS_HOME/.aws/credentials"
  33. fi
  34. fi
  35. done
  36. chmod 600 "$GF_PATHS_HOME/.aws/credentials"
  37. fi
  38. # Convert all environment variables with names ending in __FILE into the content of
  39. # the file that they point at and use the name without the trailing __FILE.
  40. # This can be used to carry in Docker secrets.
  41. for VAR_NAME in $(env | grep '^GF_[^=]\+__FILE=.\+' | sed -r "s/([^=]*)__FILE=.*/\1/g"); do
  42. VAR_NAME_FILE="$VAR_NAME"__FILE
  43. if [ "${!VAR_NAME}" ]; then
  44. echo >&2 "ERROR: Both $VAR_NAME and $VAR_NAME_FILE are set (but are exclusive)"
  45. exit 1
  46. fi
  47. echo "Getting secret $VAR_NAME from ${!VAR_NAME_FILE}"
  48. export "$VAR_NAME"="$(< "${!VAR_NAME_FILE}")"
  49. unset "$VAR_NAME_FILE"
  50. done
  51. export HOME="$GF_PATHS_HOME"
  52. if [ ! -z "${GF_INSTALL_PLUGINS}" ]; then
  53. OLDIFS=$IFS
  54. IFS=','
  55. for plugin in ${GF_INSTALL_PLUGINS}; do
  56. IFS=$OLDIFS
  57. if [[ $plugin =~ .*\;.* ]]; then
  58. pluginUrl=$(echo "$plugin" | cut -d';' -f 1)
  59. pluginWithoutUrl=$(echo "$plugin" | cut -d';' -f 2)
  60. grafana-cli --pluginUrl "${pluginUrl}" --pluginsDir "${GF_PATHS_PLUGINS}" plugins install ${pluginWithoutUrl}
  61. else
  62. grafana-cli --pluginsDir "${GF_PATHS_PLUGINS}" plugins install ${plugin}
  63. fi
  64. done
  65. fi
  66. exec grafana-server \
  67. --homepath="$GF_PATHS_HOME" \
  68. --config="$GF_PATHS_CONFIG" \
  69. --packaging=docker \
  70. "$@" \
  71. cfg:default.log.mode="console" \
  72. cfg:default.paths.data="$GF_PATHS_DATA" \
  73. cfg:default.paths.logs="$GF_PATHS_LOGS" \
  74. cfg:default.paths.plugins="$GF_PATHS_PLUGINS" \
  75. cfg:default.paths.provisioning="$GF_PATHS_PROVISIONING"