source: trunk/www/ports.php @ 35223

Last change on this file since 35223 was 35223, checked in by eridius@…, 12 years ago

Add fairly simple implementation of paging to the by=all view

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
  • Property svn:mime-type set to text/x-php
File size: 12.0 KB
Line 
1<?php
2    /* -*- coding: utf-8; mode: php; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- vim:fenc=utf-8:filetype=php:et:sw=4:ts=4:sts=4 */
3    /* Web client to the PortIndex2MySQL script located in MacPorts base/portmgr/jobs svn directory. */
4    /* $Id: ports.php 35223 2008-03-21 06:04:51Z eridius@macports.org $ */
5    /* Copyright (c) 2004, OpenDarwin. */
6    /* Copyright (c) 2004-2007, The MacPorts Project. */
7   
8    $MPWEB = $_SERVER['DOCUMENT_ROOT'] . dirname($_SERVER['SCRIPT_NAME']);
9    include_once("$MPWEB/includes/common.inc");
10   
11    $portsdb_info = portsdb_connect($portsdb_host, $portsdb_user, $portsdb_passwd);
12    $sql = "SELECT UNIX_TIMESTAMP(activity_time) FROM $portsdb_name.log ORDER BY UNIX_TIMESTAMP(activity_time) DESC";
13    $result = mysql_query($sql);
14    if ($result && $row = mysql_fetch_row($result)) {
15        $date = date('Y-m-d', $row[0]);
16        $time = date('H:i:s e', $row[0]);
17    } else {
18        $date = '(unknown)';
19        $time = '(unknown)';
20    }
21    $by = isset($_GET['by']) ? $_GET['by'] : '';
22    $substr = isset($_GET['substr']) ? $_GET['substr'] : '';
23    $page = isset($_GET['page']) ? max($_GET['page'], 0) : '';
24    $pagesize = isset($_GET['pagesize']) ? max($_GET['pagesize'], 0) : 50; # arbitrary setting
25
26    print_header('The MacPorts Project -- Available Ports', 'utf-8');
27?>
28
29<div id="content">
30
31    <h2 class="hdr">MacPorts Portfiles</h2>
32
33    <p>The MacPorts Project currently distributes <b><?php print $portsdb_info['num_ports']; ?></b> ports, organized across
34    <?php print $portsdb_info['num_categories']; ?> different categories and available below for viewing. This form allows
35    you to search the MacPorts software index, last updated on <?php print '<b>' . $date . '</b> at <b>' . $time . '</b>'; ?>.
36    </p>
37   
38    <br />
39
40    <form action="<?php print $_SERVER['PHP_SELF']; ?>" method="get">
41        <p>
42            <label>Search by:</label>
43            <select name="by">
44                <option value="name"<?php if ($by == 'name') { print ' selected="selected"'; } ?>>Software Title</option>
45                <option value="category"<?php if ($by == 'category') { print ' selected="selected"'; } ?>>Category</option>
46                <option value="maintainer"<?php if ($by == 'maintainer') { print ' selected="selected"'; } ?>>Maintainer</option>
47<!--                <option value="library"<?php if ($by == 'dependency') { print ' selected="selected"'; } ?>>Dependency</option> -->
48                <option value="variant"<?php if ($by == 'variant') { print ' selected="selected"'; } ?>>Variant</option>
49                <option value="platform"<?php if ($by == 'platform') { print ' selected="selected"'; } ?>>Platform</option>
50            </select>
51            <input type="text" name="substr" size="40" />
52            <input type="submit" value="Search" />
53        </p>
54    </form>
55
56    <p>Or view the complete <a href="<?php print $_SERVER['PHP_SELF']; ?>?by=all">ports list (<?php print $portsdb_info['num_ports']; ?>
57    ports)</a>.</p>
58    <br />
59
60<?php
61    /* If no valid search criteria is specified (by set and not equal to all and a valid substring) we output port categories
62     as possible searches */
63    if (!$by || ($by != 'all' && !$substr)) {
64        $query = "SELECT DISTINCT category FROM $portsdb_name.categories ORDER BY category";
65        $result = mysql_query($query);
66        if ($result) {
67            $max_entries_per_column = floor($portsdb_info['num_categories']/4);
68            $columns = 0;
69            print '<h3>Port Categories</h3><div id="categories"><ul>';
70            while ($columns < 4) {
71                $entries_per_colum = 0;
72                print '<li><ul>';
73                while ($row = mysql_fetch_assoc($result)) {
74                    print "<li><a href=\"$_SERVER[PHP_SELF]?by=category&amp;substr=" . urlencode($row['category']) . '">'
75                    . htmlspecialchars($row['category']) . '</a></li>';
76                    if ($entries_per_colum == $max_entries_per_column) break;
77                    $entries_per_colum++;
78                }
79                print '</ul></li>';
80                $columns++;
81            }
82            print '</ul></div>';
83        }
84    }
85
86    /* If valid criteria is specified (by set and a valid substring, or by set to all) we poll the db and display the results */
87    if ($by && ($substr || $by == 'all')) {
88        $fields = 'name, path, version, description';
89        $tables = "$portsdb_name.portfiles AS p";
90        switch ($by) {
91        case 'name':
92            $criteria = "p.name LIKE '%" . mysql_real_escape_string($substr) . "%'";
93            break;
94        case 'category':
95            $tables .= ", $portsdb_name.categories AS c";
96            $criteria = "c.portfile = p.name AND c.category = '" . mysql_real_escape_string($substr) . "'";
97            break;
98        case 'maintainer':
99            $tables .= ", $portsdb_name.maintainers AS m";
100            $criteria = "m.portfile = p.name AND m.maintainer LIKE '%" . mysql_real_escape_string($substr) . "%'";
101            break;
102        case 'library':
103            $criteria = "p.name = '" . mysql_real_escape_string($substr) . "'";
104            break;
105        case 'variant':
106            $tables .= ", $portsdb_name.variants AS v";
107            $criteria = "v.portfile = p.name AND v.variant = '" . mysql_real_escape_string($substr) . "'";
108            break;
109        case 'platform':
110            $tables .= ", $portsdb_name.platforms AS pl";
111            $criteria = "pl.portfile = p.name AND pl.platform = '" . mysql_real_escape_string($substr) . "'";
112            break;
113        case 'all':
114            $criteria = '';
115            $paging = true;
116            break;
117        default:
118            $criteria = '0';
119            break;
120        }
121        $where = ($criteria == '' ? '' : "WHERE $criteria");
122        $query = "SELECT DISTINCT $fields FROM $tables $where ORDER BY name";
123        if ($paging) {
124            $offset = $pagesize * $page;
125            $query .= " LIMIT $pagesize OFFSET $offset";
126            # get the total count
127            $countquery = "SELECT COUNT(*) FROM $tables $where ORDER By name";
128            $result = mysql_query($countquery);
129            $row = mysql_fetch_array($result); # only 1 row
130            $totalcount = $row[0];
131            $pagecount = ceil($totalcount / $pagesize);
132            # generate a paging control and cache it so we can show it twice
133            $pagecontrol = "<p>Page ";
134            for ($i = 0; $i < $pagecount; $i++) {
135                if ($i != 0) {
136                    $pagecontrol .= " | ";
137                }
138                if ($i == $page) {
139                    $pagecontrol .= "<b>$i</b>";
140                } else {
141                    $pagecontrol .= "<a href=\"$_SERVER[PHP_SELF]?by=$by&amp;substr=$substr&amp;page=$i&amp;pagesize=$pagesize\">$i</a>";
142                }
143            }
144            $pagecontrol .= "</p>";
145        }
146        $result = mysql_query($query);
147       
148        /* Main query sent to the DB */
149        if ($result) {
150            print '<h3>Query Results</h3>';
151            $resultrows = mysql_num_rows($result);
152            if ($paging) {
153                print $pagecontrol;
154                $numrows = ($offset+1) . "-" . ($offset + $resultrows) . " of $totalcount Portfile" . ($totalcount == 1 ? '' : 's');
155            } else {
156                $numrows = "$resultrows Portfile" . ($resultrows == 1 ? '' : 's');
157            }
158            print "<p><i>$numrows Selected</i></p>";
159
160            print '<dl>';
161            /* Iterate over the entire set of returned ports */
162            while ($row = mysql_fetch_assoc($result)) {
163
164                /* Port name and Portfile URL */
165                print "<dt><b><a href=\"${trac_url}browser/trunk/dports/$row[path]/Portfile\">" . htmlspecialchars($row['name'])
166                . '</a></b> ' . htmlspecialchars($row['version']) . '</dt>';
167               
168                print '<dd>';
169                /* Port short description */
170                print htmlspecialchars($row['description']) . '<br />';
171               
172                /* Maintainers */
173                $nquery = "SELECT maintainer FROM $portsdb_name.maintainers WHERE portfile='" . mysql_real_escape_string($row['name']) .
174                "' ORDER BY is_primary DESC, maintainer";
175                $nresult = mysql_query($nquery);
176                if ($nresult) {
177                    $primary = 1;
178                    print '<i>Maintained by:</i>';
179                    while ($nrow = mysql_fetch_row($nresult)) {
180                        if ($primary) { print ' <b>'; }
181                        else { print ' '; }
182                        print obfuscate_email($nrow[0]);;
183                        if ($primary) { print '</b>'; }
184                        $primary = 0;
185                    }
186                }
187
188                /* Categories */
189                $nquery = "SELECT category FROM $portsdb_name.categories WHERE portfile='" . mysql_real_escape_string($row['name']) .
190                "' ORDER BY is_primary DESC, category";
191                $nresult = mysql_query($nquery);
192                if ($nresult) {
193                    $primary = 1;
194                    print '<br /><i>Categories:</i>';
195                    while ($nrow = mysql_fetch_row($nresult)) {
196                        if ($primary) { print ' <b>'; }
197                        else { print ' '; }
198                        print "<a href=\"$_SERVER[PHP_SELF]?by=category&amp;substr=" . urlencode($nrow[0]) . '">'
199                        . htmlspecialchars($nrow[0]) . '</a>';
200                        if ($primary) { print '</b>'; }
201                        $primary = 0;
202                    }
203                }
204
205                /* Platforms */
206                $nquery = "SELECT platform FROM $portsdb_name.platforms WHERE portfile='" . mysql_real_escape_string($row['name']) .
207                "' ORDER BY platform";
208                $nresult = mysql_query($nquery);
209                if ($nresult) {
210                    print '<br /><i>Platforms:</i> ';
211                    while ($nrow = mysql_fetch_row($nresult)) {
212                        print "<a href=\"$_SERVER[PHP_SELF]?by=platform&amp;substr=" . urlencode($nrow[0]) . '">'
213                        . htmlspecialchars($nrow[0]) . '</a> ';
214                    }
215                }
216
217                /* Dependencies */
218                $nquery = "SELECT library FROM $portsdb_name.dependencies WHERE portfile='" . mysql_real_escape_string($row['name']) .
219                "' ORDER BY library";
220                $nresult = mysql_query($nquery);
221                if ($nresult && mysql_num_rows($nresult) > 0) {
222                    print '<br /><i>Dependencies:</i> ';
223                    while ($nrow = mysql_fetch_row($nresult)) {
224                        $library = eregi_replace('^([^:]*:[^:]*:|[^:]*:)', '', $nrow[0]);
225                        print "<a href=\"$_SERVER[PHP_SELF]?by=library&amp;substr=" . urlencode($library) . '">'
226                        . htmlspecialchars($library) . '</a> ';
227                    }
228                }
229
230                /* Variants */
231                $nquery = "SELECT variant FROM $portsdb_name.variants WHERE portfile='" . mysql_real_escape_string($row['name']) .
232                "' ORDER BY variant";
233                $nresult = mysql_query($nquery);
234                if ($nresult && mysql_num_rows($nresult) > 0) {
235                    print '<br /><i>Variants:</i> ';
236                    while ($nrow = mysql_fetch_row($nresult)) {
237                        print "<a href=\"$_SERVER[PHP_SELF]?by=variant&amp;substr=" . urlencode($nrow[0]) . '">'
238                        . htmlspecialchars($nrow[0]) . '</a> ';
239                    }
240                }
241                print '<br /><br /></dd>';
242               
243            } /* while (listing of macthing ports) */
244            print '</dl>';
245
246            if ($paging) {
247                print $pagecontrol;
248            }
249
250        /* When we hit this else, the query failed for some reason */
251        } else {
252            print '<p>An Error Occurred: '. mysql_error($portsdb_info['connection_handler']) . '</p>';
253        }
254       
255    } /* if (main query sent to the DB) */
256?>
257
258</div>
259
260
261<?php
262    print_footer();
263    mysql_close($portsdb_info['connection_handler']);
264?>
Note: See TracBrowser for help on using the repository browser.