Хранилища Subversion ant

Редакция

Редакция 209 | Содержимое файла | Сравнить с предыдущей | Последнее изменение | Открыть журнал | RSS

Редакция Автор № строки Строка
52 alex-w 1
<?php
2
 
3
/**
4
 * Project:     Ant: sources.list generator
5
 * File:        classic.php
6
 *
60 alex-w 7
 * This application is free software; you can redistribute it and/or
52 alex-w 8
 * modify it under the terms of the GNU Lesser General Public
9
 * License as published by the Free Software Foundation; either
10
 * version 2.1 of the License, or (at your option) any later version.
11
 *
60 alex-w 12
 * This application is distributed in the hope that it will be useful,
52 alex-w 13
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15
 * Lesser General Public License for more details.
16
 *
17
 * You should have received a copy of the GNU Lesser General Public
18
 * License along with this library; if not, write to the Free Software
19
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
20
 *
21
 */
22
 
23
 
101 alex-w 24
require_once dirname(__FILE__)."/lib/init.php";
52 alex-w 25
$ID = $_GET["id"];
26
 
27
list($dist,$vers) = split(",",$ID);
28
 
29
if ($ID!='') {
30
 
31
        $query =& $db->query("SELECT * FROM settings");
32
        $settings = array();
33
        while ($query->fetchInto($setting, DB_FETCHMODE_ASSOC)) {
209 alex-w 34
                $settings[$secure->stripStr($setting["opt"])] = $secure->stripStr($setting["optvalue"]);
52 alex-w 35
        };
36
 
37
        $query =& $db->query("SELECT * FROM version v JOIN distribution d ON d.dist_id=v.dist_id JOIN dtype p ON d.disttype=p.type_id WHERE v.dist_id='$dist' AND v.version_id='$vers'");
38
        $query->fetchInto($infodist, DB_FETCHMODE_ASSOC);
39
 
40
        $query =& $db->query("SELECT * FROM repository r JOIN ver2rep v ON r.rep_id=v.rep_id JOIN version v2 ON v.ver_id=v2.version_id JOIN scheme s ON s.scheme_id=r.scheme_id WHERE v.ver_id='$vers' ORDER BY r.rtype_id, r.scheme_id ASC");
41
 
42
        $result = "# Ant: sources.list generator :: http://track.altlug.ru/project/show/ant\n\n";
43
 
44
        while ($query->fetchInto($resinfo, DB_FETCHMODE_ASSOC)) {
209 alex-w 45
                $repscheme = $secure->stripStr($resinfo["scheme"]);
52 alex-w 46
 
47
                $querysect =& $db->query("SELECT * FROM section s JOIN sect2rep r ON s.sect_id=r.sect_id WHERE
48
r.rep_id='$resinfo[rep_id]'");
49
                $sections = "";
50
                while ($querysect->fetchInto($section,DB_FETCHMODE_ASSOC)) {
209 alex-w 51
                        $sections .= $secure->stripStr($section["sectname"])." ";
52 alex-w 52
                }
53
 
209 alex-w 54
                $repscheme = str_replace("{TYPE}",$secure->stripStr($infodist["type"]),$repscheme);
52 alex-w 55
                $repscheme = str_replace("{PROTO}",$settings["proto"],$repscheme);
221 alex-w 56
                $repscheme = str_replace("{ROOT}",$secure->stripStr($resinfo["root_folder"]),$repscheme);
52 alex-w 57
                $repscheme = str_replace("{URL}",$settings["url"],$repscheme);
209 alex-w 58
                $repscheme = str_replace("{REP}",$secure->stripStr($resinfo["repname"]),$repscheme);
59
                $repscheme = str_replace("{DIST}",$secure->stripStr($infodist["vcodename"]),$repscheme);
52 alex-w 60
                $repscheme = str_replace("{SECT}",$sections,$repscheme);
61
 
209 alex-w 62
                $result .= "# ".$secure->stripStr($resinfo["repdescribe"])."\n".$repscheme."\n\n";
52 alex-w 63
        }
64
 
65
        $HTTPHeader1 = "Content-type: text/plain";
66
        $HTTPHeader2 = "Content-length: ".strlen($result);
67
        $HTTPHeader3 = "Content-disposition: attachment; filename=sources.list\n\n";
68
 
69
        header($HTTPHeader1);
70
        header($HTTPHeader2);
71
        header($HTTPHeader3);
72
        print $result;
73
 
74
} else {
75
 
76
        header("Location: ./");
77
 
78
}
79
 
80
?>