znc-push/doc/examples.md

103 lines
4.2 KiB
Markdown

Example Configurations
======================
Default Behavior
----------------
Most users that are new to ZNC Push expect to receive a push notification any
time they get mentioned in a channel or receive a private message. However,
by default, ZNC Push is configured to only send notifications when it's likely
that the user is either away from their computer, or not paying attention to
the conversation in question. This will ideally prevent you from getting
"spammed" with notifications every time you get mentioned or receive a PM,
especially when you are actively participating in discussion.
### Configuration
channel_conditions: all
query_conditions: all
away_only: no
client_count_less_than: 0
highlight:
idle: 0
last_active: 180
last_notification: 300
replied: yes
### Explanation
The use of `channel_conditions: all` and `query_conditions: all` means that
ZNC Push will evaluate all of the other conditions, and require that all of
them "pass" in order for a notification to be sent.
But the real key to understanding the default configuration is the use of
`last_active`, `last_notification`, and `replied` to try and determine if the
user is "active" in the conversation whenever they get highlighted or receive
a private message.
* `last_active` looks for whether the user has performed an action that would
generall require direct involvement, such as sending a message to a channel,
sending a private message, or sending an action (`/me ...`). This is
specific to the context in which the user receives a message. So by default,
if the user gets highlighted or receives a private message, a notification
will only get sent if the user hasn't sent a message to that context in the
last 180 seconds (three minutes).
* `last_notification` looks for the last time that a notification was sent to
the user. This is specific to the context in which a user receives a
message. So by default, if the user gets highlighted or receives a private
message, they will only get a notification if they haven't already received
a notification for that context within the last 300 seconds (five minutes).
* `replied` looks to see if the user has responded since the last time a
notification was sent. This is specific to the context in which the user
receives a message. By default, if the user gets highlighted or receives a
private message, a notification is only sent if the user has not yet received
a notification for that context, or if they have gotten a notification and
have since responded to that context.
Show Me Everything
------------------
Sometimes you just want to see everything. More is better. You want ZNC Push
to work more like Colloquy or Growl. You want a push notification every single
time you get mentioned, and every time you get a private message. And maybe
you don't care about nickserv.
That's easy!
### Configuration
channel_conditions: highlight and nick_blacklist
query_condition: nick_blacklist
nick_blacklist: nickserv
### Explanation
By overriding `channel_conditions` and `query_conditions`, you're telling
ZNC Push that you only care about a specific set of checks when sending
notifications, and that you want to ignore the rest.
Both of these options are [boolean expressions][booleans], which evaluate to
either true or false. If it evaluates to true, then a notification is sent.
By specifying `highlight and nick_blacklist`, you're telling ZNC Push that
only those two conditions must be true in order to send a notification.
In this case, `highlight` is true for any message that includes either your
nick, or a word that's listed in your configured value for the `highlight`
option. Similarly, `nick_blacklist` is true for any message that *isn't* sent
by a user that's listed in your configured value for the `nick_blacklist`
option. Since highlight is relatively meaningless for private messages,
it can safely be left out of `query_conditions`, leaving just `nick_blacklist`.
The result of this example is that you'll receive a push notification for each
and every private message -- that doesn't come from nickserv -- and every time
you get mentioned in a channel by someone who isn't nickserv.
[booleans]: https://en.wikipedia.org/wiki/Boolean_expression