summaryrefslogtreecommitdiffstats
path: root/maintdb.php
blob: da8277e3b69cc91e3ed4bc8271fff42e3c76fd81 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
<?php
/**
 * Mageia maintdb quick filter.
 * Make use of http://pkgsubmit.mageia.org/data/maintdb.txt data.
 *
 * This only supports mapping 1 user to several packages
 * or 1 package to 1 user.
 *
 * @param string $uid (GET param) user id
 * @param string $pkg (GET param) package name
 * @param mixed  $txt (GET param) whether to return result in text or JSON (default)
 * @param string $iurt (GET param) return a iurt-specific response format: only the username
 *
 * @return string 
 *
 * Returned format is JSON format as a default:
 * <code>
 * {"user_name": {"packages" => ["package_name1", "package_name2"]}}
 * </code>
 *
 * either text format (use ?txt in query string)
 * <code>
 * package_name user_name
 * package_name2 user_name2
 * </code>
 *
 * either specific, iurt format (use ?pkg=...&iurt in query string)
 * <code>
 * user_name
 * </code>
 *
 * 
 * TODO check if preg_match_all() is more efficient than exec('grep ...')
 * TODO if so, check security concerns for $uid and $pkg
 *
 * @copyright Copyright (C) 2011 Mageia.Org
 * @author Romain d'Alverny
 * @license http://www.gnu.org/licenses/gpl-2.0.html GNU GPL v2
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License aspublished by the
 * Free Software Foundation; either version 2 of the License, or (at your
 * option) any later version.
*/

/** Path to maintdb.txt */
$maintdb = realpath(__DIR__) . '/data/maintdb.txt';

/** User name */
$uid = isset($_GET['uid']) ? trim(htmlentities(strip_tags($_GET['uid']))) : null;

/** Package name */
$pkg = isset($_GET['pkg']) ? trim(htmlentities(strip_tags($_GET['pkg']))) : null;

/** Return format */
$txt = isset($_GET['txt']) ? true : false;

$iurt = isset($_GET['iurt']) ? true : false;

/** Returned data */
$return  = array();

$s = file_get_contents($maintdb);

if (null !== $uid) {
    $pkg = null;
    if (preg_match_all(sprintf('/(.*) %s\n?/', $uid), $s, $res)) {
        $return = array($uid => array('packages' => $res[1]));
    }
} elseif (null !== $pkg) {
    $uid = null;
    if (preg_match_all(sprintf('/%s (.*)\n?/', $pkg), $s, $res)) {
        $return = array($pkg => array('uid' => $res[1][0]));
    } else {
        $return = array('_comment' => 'No maintainer found for this package.');
    }
}

if ($iurt && $pkg) {
    header('Content-Type: text/plain; charset: utf-8');
    if (isset($return[$pkg]))
        echo $return[$pkg]['uid'];
    else
        echo '';
}
elseif ($txt) {
    header('Content-Type: text/plain; charset: utf-8');
    if (is_array($return)) {
        if (null !== $uid) {
            foreach ($return as $u => $data) {
                foreach ($data['packages'] as $p) {
                    echo sprintf("%s %s\n", $p, $u);
                }
            }
        } else {
            echo sprintf('%s %s', $pkg, $return[$pkg]['uid']);
        }
    } else {
        echo $return;
    }
}
else {
    header('Content-Type: application/json; charset=utf-8');
    echo json_encode($return, JSON_FORCE_OBJECT);
}