To create new wiki account, please join us on #znc at Libera.Chat and ask admins to create a wiki account for you. You can say thanks to spambots for this inconvenience.

Log: Difference between revisions

From ZNC
Jump to navigation Jump to search
KindOne (talk | contribs)
Fix log paths in 1.6+
 
(5 intermediate revisions by 3 users not shown)
Line 7: Line 7:
  In the znc-0.206 release this module is NOT a core module, see [[ZNC-Extra]] for more information on how to use it
  In the znc-0.206 release this module is NOT a core module, see [[ZNC-Extra]] for more information on how to use it


In a future ZNC release, this module will mimic directory permissions set on its data directory (<tt>moddata/log</tt>, in whatever location appropriate to the mode it is running in; see above) when creating new subdirectories. However, as of 2013-08-20, umasks may interfere with it and result in less access being granted than expected. For example, the module may be unable to grant write access to Group or World (umask 0022).
Since ZNC 1.2, this module mimics directory permissions set on its data directory (<tt>moddata/log</tt>, in whatever location appropriate to the mode it is running in; see above) when creating new subdirectories. However, as of 2013-08-20, umasks may interfere with it and result in less access being granted than expected. For example, the module may be unable to grant write access to Group or World (umask 0022).


To get the directory permission inheritance under ZNC 1.0, use [https://raw.github.com/dgw/znc/log-permissions-1.0-backport/modules/log.cpp this file] and <tt>znc-buildmod log.cpp</tt>, then move the module to the ZNC modules directory.
To get the directory permission inheritance under ZNC 1.0, use [https://raw.github.com/dgw/znc/log-permissions-1.0-backport/modules/log.cpp this file] and <code>znc-buildmod log.cpp</code>, then move the module to the ZNC modules directory.


== Usage ==
== Usage ==


{{Module arguments
{{Module arguments
|count=one or two
|count=one through three
|extra=<br>First argument: <code>-sanitize</code> If presented, removes color codes and [https://en.wikipedia.org/wiki/C0_and_C1_control_codes C0 control codes] from the lines before logged.
|extra=<br>This user module takes one through three arguments.
<br>Second argument: Relative path where to store logs. It can contain <code>$USER</code>, <code>$NETWORK</code> and <code>$WINDOW</code> tokens as well as [[Timestamps|time format tokens]].
|extra=<br>First argument: <code>-sanitize</code> If presented, removes color codes and [https://en.wikipedia.org/wiki/C0_and_C1_control_codes C0 control codes] from the lines before logged.  
<br>Second argument: <code>-timestamp</code> If presented, permits manually specifying a timestamp that will be passed through <code>strftime</code>.
<br>Third argument: Relative path where to store logs. It can contain <code>$USER</code>, <code>$NETWORK</code> and <code>$WINDOW</code> tokens as well as [[Timestamps|time format tokens]].
<br>Depending on the scope in which the log module is loaded, the path argument is relative to the following paths: (Note: <code>~/.znc/</code> might be different if you use a non-standard data directory):
<br>Depending on the scope in which the log module is loaded, the path argument is relative to the following paths: (Note: <code>~/.znc/</code> might be different if you use a non-standard data directory):
   global:  ~/.znc/moddata/log/
   global:  ~/.znc/moddata/log/
Line 29: Line 31:
   user:    $NETWORK_$WINDOW_%Y%m%d.log
   user:    $NETWORK_$WINDOW_%Y%m%d.log
   network: $WINDOW_%Y%m%d.log
   network: $WINDOW_%Y%m%d.log
To convert your old logs to the 1.6 format, you can use [https://github.com/ZacharyDuBois/Random-Scripts/blob/master/convert-znc-1.4-logs-to-1.6.sh this user created script].
If you want to log to some other place, make a symlink.
If you want to log to some other place, make a symlink.
}}
}}
Line 35: Line 38:


=== Commands ===
=== Commands ===
This module does not support any commands.
 
; <code>ClearRules</code>
: Clear all logging rules
 
; <code>Help <search term></code>
: Generate this output. Optionally search for a given word/phrase.
 
; <code>ListRules</code>
: List all logging rules
 
; <code>Set boolean</code> ''(added in 1.7)''
: Set one of the following booleans: joins, quits, nickchanges.
: For example, <code>/msg *log Set quits false</code> to exclude quit messages from the log.
 
; <code>SetRules <rules></code>
: Filter chat rooms which should be logged (all by default). Use <code>!#chan</code> or <code>!query</code> to negate and <code>*</code> for wildcards. For example, <code>SetRules #znc !*</code> would log only #znc and no other channel.
 
; <code>ShowSettings</code> ''(added in 1.7)''
: Show current settings set by Set command


== pisg ==
== pisg ==

Latest revision as of 08:34, 26 May 2021


This module logs your conversations to some special place on your disk.

Notes

In the znc-0.206 release this module is NOT a core module, see ZNC-Extra for more information on how to use it

Since ZNC 1.2, this module mimics directory permissions set on its data directory (moddata/log, in whatever location appropriate to the mode it is running in; see above) when creating new subdirectories. However, as of 2013-08-20, umasks may interfere with it and result in less access being granted than expected. For example, the module may be unable to grant write access to Group or World (umask 0022).

To get the directory permission inheritance under ZNC 1.0, use this file and znc-buildmod log.cpp, then move the module to the ZNC modules directory.

Usage

Arguments

This user module takes one through three arguments.
First argument: -sanitize If presented, removes color codes and C0 control codes from the lines before logged.
Second argument: -timestamp If presented, permits manually specifying a timestamp that will be passed through strftime.
Third argument: Relative path where to store logs. It can contain $USER, $NETWORK and $WINDOW tokens as well as time format tokens.
Depending on the scope in which the log module is loaded, the path argument is relative to the following paths: (Note: ~/.znc/ might be different if you use a non-standard data directory):

 global:  ~/.znc/moddata/log/
 user:    ~/.znc/users/$USER/moddata/log/
 network: ~/.znc/users/$USER/networks/$NETWORK/moddata/log/

Default paths since 1.6:

 global:  $USER/$NETWORK/$WINDOW/%Y-%m-%d.log
 user:    $NETWORK/$WINDOW/%Y-%m-%d.log
 network: $WINDOW/%Y-%m-%d.log

Default paths prior 1.6:

 global:  $USER_$NETWORK_$WINDOW_%Y%m%d.log
 user:    $NETWORK_$WINDOW_%Y%m%d.log
 network: $WINDOW_%Y%m%d.log

To convert your old logs to the 1.6 format, you can use this user created script. If you want to log to some other place, make a symlink.

Read loading modules to learn more about loading modules.

Load the module to start logging, unload it to stop logging. Kinda easy, eh?

Commands

ClearRules
Clear all logging rules
Help <search term>
Generate this output. Optionally search for a given word/phrase.
ListRules
List all logging rules
Set boolean (added in 1.7)
Set one of the following booleans: joins, quits, nickchanges.
For example, /msg *log Set quits false to exclude quit messages from the log.
SetRules <rules>
Filter chat rooms which should be logged (all by default). Use !#chan or !query to negate and * for wildcards. For example, SetRules #znc !* would log only #znc and no other channel.
ShowSettings (added in 1.7)
Show current settings set by Set command

pisg

The log module uses the "energymech" format so it can be used with pisg if so desired.

Example Config

   <channel="#znc">
       # Before ZNC 1.6.0
       Logfile = "/home/znc/.znc/users/efnet/moddata/log/#znc_*.log"
       # Since ZNC 1.6.0
       LogDir="/home/znc/.znc/moddata/log/user/efnet/#znc"
       Format = "energymech"
       Network = "EFnet"
       OutputFile = "znc.html"
   </channel>