Projet

Général

Profil

Paste
Télécharger au format
Statistiques
| Branche: | Révision:

root / plugins / moodle / modules / moodle_mod_forum.php @ dd685310

Historique | Voir | Annoter | Télécharger (1,97 ko)

1
#!/usr/bin/php
2
<?php
3
/**
4
 * Moodle module forum
5
 * Munin plugin to count new posts on forums
6
 *
7
 * It's required to define a container entry for this plugin in your
8
 * /etc/munin/plugin-conf.d/munin-node (or a separate and dedicated file).
9
 *
10
 * @example Example entry for configuration:
11
 * [moodle*]
12
 * env.type mysql
13
 * env.db moodle
14
 * env.user mysql_user
15
 * env.pass mysql_pass
16
 * env.host localhost
17
 * env.port 3306
18
 * env.table_prefix mdl_
19
 *
20
 * @author Arnaud Trouvé <ak4t0sh@free.fr>
21
 * @version 1.0 2014
22
 *
23
 */
24
$dbh = null;
25
$db = getenv('db');
26
$type = getenv('type');
27
$host = getenv('host');
28
$user = getenv('user');
29
$pass = getenv('pass');
30
$table_prefix = getenv('table_prefix');
31
$port = getenv('port');
32
if (!$port)
33
    $port = 3306;
34
//$graph_period = getenv('graph_period');
35
$graph_period = time() - 5*60;
36

    
37

    
38
if (count($argv) === 2 && $argv[1] === 'config') {
39
    echo "graph_title Moodle Forum Posts\n";
40
    echo "graph_args --base 1000 --lower-limit 0\n";
41
    echo "graph_vlabel number\n";
42
    echo "graph_category Moodle\n";
43
    echo "graph_scale no\n";
44
    echo "graph_info Displays the sum of new forums posts / discussions in your Moodle site\n";
45
    echo "forum_posts.label posts\n";
46
    echo "forum_posts.min 0\n";
47
    echo "forum_posts.draw AREA\n";
48
    echo "forum_discussion.draw STACK\n";
49
    echo "forum_discussion.min 0\n";
50
    echo "forum_discussion.label discussions\n";
51
    exit(0);
52
}
53

    
54
try {
55
    $dsn = $type . ':host=' . $host . ';port=' . $port . ';dbname=' . $db;
56
    $dbh = new PDO($dsn, $user, $pass);
57
} catch (Exception $e) {
58
    echo "Connection failed\n";
59
    exit(1);
60
}
61

    
62
$nb = 0;
63
if (($stmt = $dbh->query("SELECT count(id) FROM {$table_prefix}forum_posts WHERE timemodified > $graph_period")) != false) {
64
    $nb = $stmt->fetchColumn();
65
}
66
echo "forum_posts.value $nb\n";
67

    
68
$nb = 0;
69
if (($stmt = $dbh->query("SELECT count(id) FROM {$table_prefix}forum_discussions WHERE timemodified > $graph_period")) != false) {
70
    $nb = $stmt->fetchColumn();
71
}
72
echo "forum_discussions.value $nb\n";