Skip to content

Commit

Permalink
docs: build instructions, about, installation and configuration steps
Browse files Browse the repository at this point in the history
  • Loading branch information
ncosta-ic committed Jun 25, 2024
1 parent 4726c6a commit d1fe0e9
Show file tree
Hide file tree
Showing 4 changed files with 128 additions and 0 deletions.
27 changes: 27 additions & 0 deletions doc/01-About.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
# Icinga Notifications Web

!!! warning
This is an early beta version for you to try, but do not use this in production. There may still be severe bugs.
At the moment, we don't provide any support for this module.

Icinga Notifications is a set of components that processes received events from miscellaneous sources, manages
incidents and forwards notifications to predefined contacts, consisting of:

* An [Icinga Notifications Daemon](https://github.com/Icinga/icinga-notifications), which receives events and sends
notifications.
* The Icinga Notifications Web module (this repository), which provides graphical configuration and further
processing of the data collected by the daemon.

Icinga 2 and any other sources propagate state updates and acknowledgement events to the [Icinga Notifications
Daemon](https://github.com/Icinga/icinga-notifications).

![Icinga Notifications Web Preview](doc/res/notifications-preview.webp)

## Installation

To install Icinga Notifications Web see [Installation](02-Installation.md).

## License

Icinga Notifications and the Icinga Notifications documentation are licensed under the terms of the
GNU General Public License Version 2.
16 changes: 16 additions & 0 deletions doc/02-Installation.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
<!-- {% if index %} -->

# Installing Icinga Notifications Web

The recommended way to install Icinga Notifications Web is to use prebuilt packages for
all supported platforms from our official release repository.
Please follow the steps listed for your target operating system,
which guide you through setting up the repository and installing Icinga Notifications Web.

Before installing Icinga Notifications Web, make sure you have installed the
[Icinga Notifications Daemon](https://icinga.com/docs/icinga-notifications/latest/doc/02-Installation).

<!-- {% else %} -->

This concludes the installation. Now proceed with the [configuration](03-Configuration.md).
<!-- {% endif %} --><!-- {# end else if index #} -->
22 changes: 22 additions & 0 deletions doc/02-Installation.md.d/From-Source.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
# Installing Icinga Notifications Web from Source

Please see the Icinga Web documentation on
[how to install modules](https://icinga.com/docs/icinga-web-2/latest/doc/08-Modules/#installation) from source.
Make sure you use `notifications` as the module name. The following requirements must also be met.

### Requirements

- PHP (≥7.2)
- PHP needs the following extensions to be installed and activated:
- `cURL`
- `dom`
- `json`
- `libxml`
- [MySQL](https://www.php.net/manual/en/ref.pdo-mysql.php)
or [PostgreSQL](https://www.php.net/manual/en/ref.pdo-pgsql.php) PDO PHP libraries
- [Icinga Notifications Daemon](https://github.com/Icinga/icinga-notifications)
- [Icinga Web 2](https://github.com/Icinga/icingaweb2) (≥2.9)
- [Icinga PHP Library (ipl)](https://github.com/Icinga/icinga-php-library) (≥0.12.0)
- [Icinga PHP Thirdparty](https://github.com/Icinga/icinga-php-thirdparty) (≥0.11.0)

<!-- {% include "02-Installation.md" %} -->
63 changes: 63 additions & 0 deletions doc/03-Configuration.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
# Configuration

If Icinga Web has been installed but not yet set up, please visit Icinga Web and follow the web-based setup wizard.
For Icinga Web setups already running, log in to Icinga Web with a privileged user and follow the steps below to
configure Icinga Notifications Web:

## Module Activation

If you just installed the module, do not forget to activate it on your Icinga 2 Web instance(s) by using your
preferred way:

- Access the Icinga 2 command-line interface on your master(s) and execute `icingacli module enable notifications`.
- Navigate to the Icinga 2 website(s), log in as a privileged user and activate the module under `Configuration →
Modules → Notifications` by switching the state from `disabled` to `enabled`.

## Database Configuration

Connection configuration for the database `notifications`, which both,
the [Icinga Notifications Daemon](https://github.com/Icinga/icinga-notifications) and the [Icinga Notifications Web
Module](https://github.com/Icinga/icinga-notifications-web), use.

!!! tip
If not already done, initialize your `notifications` database by following
the [instructions](https://icinga.com/docs/icinga-notifications/latest/doc/02-Installation#setting-up-the-database).

1. Create a new resource for the Icinga Notifications database via the `Configuration → Application → Resources` menu.
2. Configure the resource you just created as the database connection for the Icinga Notifications Web module using the
`Configuration → Modules → notifications → Database` menu.

## Channels Configuration

As this module notifies contacts in case of events and incidents, you need to configure appropriate communication
channels.
Currently, the following technologies are supported:

- E-Mail (SMTP)
- Rocket.Chat
- Webhook

You need to configure at least one valid communication channel to be able to provide your contacts notifications.

## Sources Configuration

!!! question
This paragraph is currently missing more specific information about adding external sources.

The notifications module operates on data fed by miscellaneous sources and is therefore not restricted to Icinga 2 only.
Though, any other external system needs to respect a specific data structure when providing its own data.

You need to provide at least one valid source for this module to function properly.

### Adding an Icinga 2 source

If you want the notifications module to process Icinga 2 events, you will need to add it as a source:

1. Navigate to `Configuration → Module → notifications → Sources` and add a new source.
2. Choose type `Icinga` and provide Icinga 2 API credentials with the following
[permissions](https://icinga.com/docs/icinga-2/latest/doc/12-icinga2-api/#overview):
- events/*
- objects/query/*
3. Enable `Verify API Certificate` if you want the
[Icinga Notifications Daemon](https://github.com/Icinga/icinga-notifications) to check for the certificate
validity of the given REST API endpoint.

0 comments on commit d1fe0e9

Please sign in to comment.