diff options
Diffstat (limited to 'doc')
-rw-r--r-- | doc/02-Installation.md | 86 | ||||
-rw-r--r-- | doc/70-Troubleshooting.md | 16 |
2 files changed, 102 insertions, 0 deletions
diff --git a/doc/02-Installation.md b/doc/02-Installation.md new file mode 100644 index 0000000..82a63a9 --- /dev/null +++ b/doc/02-Installation.md @@ -0,0 +1,86 @@ +# Installation <a id="installation"></a> + +## Requirements <a id="installation-requirements"></a> + +* PHP (>= 7.2) +* Icinga Web 2 (>= 2.9) +* Icinga Web 2 libraries: + * [Icinga PHP Library (ipl)](https://github.com/Icinga/icinga-php-library) (>= 0.8) + * [Icinga PHP Thirdparty](https://github.com/Icinga/icinga-php-thirdparty) (>= 0.10) + +## Google Chrome/Chromium Setup <a id="installation-chrome-setup"></a> + +The module needs Google Chrome or Chromium supporting headless mode. + +### RHEL/CentOS <a id="installation-chrome-setup-rhel"></a> + +Add the Chrome repository from Google to yum, next to EPEL. + +``` +yum -y install epel-release + +cat >/etc/yum.repos.d/google-chrome-stable.repo <<EOF +[google-chrome-stable] +name=google-chrome-stable +baseurl=http://dl.google.com/linux/chrome/rpm/stable/\$basearch +enabled=1 +gpgcheck=1 +gpgkey=https://dl-ssl.google.com/linux/linux_signing_key.pub +EOF + +yum makecache +``` + +Install Chrome and additional dependencies (optional). + +``` +yum install google-chrome-stable +yum install mesa-libOSMesa mesa-libOSMesa-devel gnu-free-sans-fonts ipa-gothic-fonts ipa-pgothic-fonts +``` + +### Debian/Ubuntu <a id="installation-chrome-setup-rhel"></a> + +Add the Chrome repository from Google to apt. + +``` +apt-get -y install apt-transport-https gnupg wget + +wget -O - https://dl-ssl.google.com/linux/linux_signing_key.pub | apt-key add - + +echo "deb http://dl.google.com/linux/chrome/deb/ stable main" >> /etc/apt/sources.list.d/google.list + +apt-get update +``` + +Install Chrome. + +``` +apt-get install google-chrome-stable +``` + +## Module Installation <a id="installation-module"></a> + +1. Install it [like any other module](https://icinga.com/docs/icinga-web-2/latest/doc/08-Modules/#installation). +Use `pdfexport` as name. + +2. You might need to set the absolute path to the Google Chrome / Chromium +binary, depending on your system. This can be done in +`Configuration -> Modules -> pdfexport -> Chrome` + +This concludes the installation. PDF exports now use Google Chrome/Chromium for rendering. + +### Using a Remote Chrome/Chromium + +As an alternative to a local installation of Chrome/Chromium it is also possible +to launch and utilize a remote instance. + +Just install it as described above on a different machine and configure its connection +details in `Configuration -> Modules -> pdfexport -> Chrome`. + +To start a remote instance of Chrome/Chromium use the following commandline options: + +> google-chrome --remote-debugging-address=0.0.0.0 --remote-debugging-port=9222 --headless --keep-alive-for-test --disable-gpu --disable-dev-shm-usage --no-sandbox --bwsi --no-first-run --user-data-dir=/tmp --homedir=/tmp + +Note that the browser does accept any and all connection attempts without any authentication. +Keep that in mind and let it listen on a public IP (or even on 0.0.0.0) only during tests or +with a proper firewall in place. diff --git a/doc/70-Troubleshooting.md b/doc/70-Troubleshooting.md new file mode 100644 index 0000000..0cb7fa3 --- /dev/null +++ b/doc/70-Troubleshooting.md @@ -0,0 +1,16 @@ +# Troubleshooting <a id="troubleshooting"></a> + +## PDF Export <a id="troubleshooting-pdf-export"></a> + +If the PDF export fails, ensure that Chrome headless works fine. +You can test that on the CLI like this: + +``` +google-chrome --version +``` + +If you have a local installation, you could also try to force temporary local +storage. (Available in the module's configuration) This will store the content +to print on disk, instead of transferring it directly to the browser. Note that +for this to work, the browser needs to be able to access the temporary files of +the webserver's process user. |