Skip to content

Commit b7d3b16

Browse files
author
Florian Schaal
committed
database-quota: add stats to website-tab
1 parent 1715c15 commit b7d3b16

File tree

5 files changed

+197
-0
lines changed

5 files changed

+197
-0
lines changed
Lines changed: 79 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,79 @@
1+
<?php
2+
require_once '../../lib/config.inc.php';
3+
require_once '../../lib/app.inc.php';
4+
5+
/******************************************
6+
* Begin Form configuration
7+
******************************************/
8+
9+
$list_def_file = "list/database_quota_stats.list.php";
10+
11+
/******************************************
12+
* End Form configuration
13+
******************************************/
14+
15+
//* Check permissions for module
16+
$app->auth->check_module_permissions('mail');
17+
18+
$app->load('listform_actions','functions');
19+
20+
$tmp_rec = $app->db->queryOneRecord("SELECT data from monitor_data WHERE type = 'database_size' ORDER BY created DESC");
21+
$monitor_data = array();
22+
$tmp_array = unserialize($tmp_rec['data']);
23+
24+
foreach($tmp_array as $database_name => $data) {
25+
$db_name = $data['database_name'];
26+
27+
$temp = $app->db->queryOneRecord("SELECT client.username, web_database.database_quota FROM web_database, sys_group, client WHERE web_database.sys_groupid = sys_group.groupid AND sys_group.client_id = client.client_id AND web_database.database_name = ?'", $db_name);
28+
29+
$monitor_data[$db_name]['database_name'] = $data['database_name'];
30+
$monitor_data[$db_name]['client']=$temp['username'];
31+
$monitor_data[$db_name]['used'] = $data['size'];
32+
$monitor_data[$db_name]['quota']=$temp['database_quota'];
33+
34+
unset($temp);
35+
}
36+
37+
class list_action extends listform_actions {
38+
39+
function prepareDataRow($rec) {
40+
global $app, $monitor_data;
41+
42+
$rec = $app->listform->decode($rec);
43+
44+
//* Alternating datarow colors
45+
$this->DataRowColor = ($this->DataRowColor == '#FFFFFF') ? '#EEEEEE' : '#FFFFFF';
46+
$rec['bgcolor'] = $this->DataRowColor;
47+
48+
$database_name = $rec['database_name'];
49+
50+
$rec['database'] = isset($monitor_data[$database_name]['database_name']) ? $monitor_data[$database_name]['database_name'] : array(1 => 0);
51+
$rec['client'] = isset($monitor_data[$database_name]['client']) ? $monitor_data[$database_name]['client'] : array(1 => 0);
52+
$rec['used'] = isset($monitor_data[$database_name]['used']) ? $monitor_data[$database_name]['used'] : array(1 => 0);
53+
$rec['quota'] = isset($monitor_data[$database_name]['quota']) ? $monitor_data[$database_name]['quota'] : array(1 => 0);
54+
55+
if (!is_numeric($rec['used'])) $rec['used']=$rec['used'][1];
56+
57+
if($rec['quota'] == 0){
58+
$rec['quota'] = $app->lng('unlimited');
59+
$rec['percentage'] = '';
60+
} else {
61+
$rec['percentage'] = round(100 * $rec['used'] / ( $rec['quota']*1024*1024) ).'%';
62+
$rec['quota'] .= ' MB';
63+
}
64+
65+
if ($rec['used'] > 0) $rec['used'] = $app->functions->formatBytes($rec['used']);
66+
67+
$rec['id'] = $rec[$this->idx_key];
68+
return $rec;
69+
70+
}
71+
72+
}
73+
74+
$list = new list_action;
75+
$list->SQLExtWhere = "";
76+
77+
$list->onLoad();
78+
79+
?>
Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
<?php
2+
$wb["database_txt"] = 'Database';
3+
$wb["client_txt"] = 'Client';
4+
$wb["used_txt"] = 'Used space';
5+
$wb["quota_txt"] = 'Quota';
6+
$wb["percentage_txt"] = 'Used in %';
7+
?>

interface/web/sites/lib/module.conf.php

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -184,6 +184,11 @@
184184
'link' => 'sites/user_quota_stats.php',
185185
'html_id' => 'user_quota_stats');
186186

187+
$items[] = array( 'title' => 'Database quota',
188+
'target' => 'content',
189+
'link' => 'sites/database_quota_stats.php',
190+
'html_id' => 'databse_quota_stats');
191+
187192
$module['nav'][] = array( 'title' => 'Statistics',
188193
'open' => 1,
189194
'items' => $items);
Lines changed: 52 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,52 @@
1+
<?php
2+
3+
// Name of the list
4+
$liste["name"] = "database_quota_stats";
5+
6+
// Database table
7+
$liste["table"] = "web_database";
8+
9+
// Index index field of the database table
10+
$liste["table_idx"] = "database_id";
11+
12+
// Search Field Prefix
13+
$liste["search_prefix"] = "search_";
14+
15+
// Records per page
16+
$liste["records_per_page"] = "15";
17+
18+
// Script File of the list
19+
$liste["file"] = "database_quota_stats.php";
20+
21+
// Script file of the edit form
22+
$liste["edit_file"] = "database_edit.php";
23+
24+
// Paging Template
25+
$liste["paging_tpl"] = "templates/paging.tpl.htm";
26+
27+
// Enable auth
28+
$liste["auth"] = "yes";
29+
30+
// mark columns for php sorting (no real mySQL columns)
31+
$liste["phpsort"] = array('used_sort', 'files');
32+
33+
34+
/*****************************************************
35+
* Suchfelder
36+
*****************************************************/
37+
38+
//$liste["item"][] = array( 'field' => "domain",
39+
$liste["item"][] = array( 'field' => "database_name",
40+
'datatype' => "VARCHAR",
41+
'filters' => array( 0 => array( 'event' => 'SHOW',
42+
'type' => 'IDNTOUTF8')
43+
),
44+
'formtype' => "TEXT",
45+
'op' => "like",
46+
'prefix' => "%",
47+
'suffix' => "%",
48+
'width' => "",
49+
'value' => ""
50+
);
51+
52+
?>
Lines changed: 54 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,54 @@
1+
<h2><tmpl_var name="list_head_txt"></h2>
2+
3+
<div class="panel panel_list_database_quota_stats">
4+
5+
<div class="pnl_listarea">
6+
<fieldset><legend><tmpl_var name="list_head_txt"></legend>
7+
<table class="list">
8+
<thead>
9+
<tr class="caption">
10+
<th class="tbl_col_database tbl_col_nosort" scope="col"><tmpl_var name="database_txt"></th>
11+
<th class="tbl_col_client tbl_col_nosort" scope="col"><tmpl_var name="client_txt"></th>
12+
<th class="tbl_col_used_sort" scope="col"><tmpl_var name="used_txt"></th>
13+
<th class="tbl_col_quota tbl_col_nosort" scope="col"><tmpl_var name="quota_txt"></th>
14+
<th class="tbl_col_percentage tbl_col_nosort" scope="col"><tmpl_var name="percentage_txt">
15+
<th class="tbl_col_limit" scope="col">{tmpl_var name='search_limit'}</th>
16+
</tr>
17+
<tr class="filter">
18+
<td class="tbl_col_database"><input type="text" name="search_database_name" value="{tmpl_var name='search_database_name'}" /></td>
19+
<td class="tbl_col_client">&nbsp;</td>
20+
<td class="tbl_col_used">&nbsp;</td>
21+
<td class="tbl_col_quota">&nbsp;</td>
22+
<td class="tbl_col_percentage">&nbsp;</td>
23+
<td class="tbl_col_buttons">
24+
<button type="button" class="button icons16 icoFilter" name="Filter" id="Filter" value="{tmpl_var name="filter_txt"}" onclick="submitForm('pageForm','sites/database_quota_stats.php');"><span>{tmpl_var name="filter_txt"}</span></button>
25+
</td>
26+
</tr>
27+
</thead>
28+
<tbody>
29+
<tmpl_loop name="records">
30+
<tr class="tbl_row_<tmpl_if name='__EVEN__'}even<tmpl_else>uneven</tmpl_if>">
31+
<td class="tbl_col_database"><a href="#" onclick="loadContent('sites/database_edit.php?id={tmpl_var name='id'}');">{tmpl_var name="database"}</a></td>
32+
<td class="tbl_col_client"><a href="#" onclick="loadContent('sites/database_edit.php?id={tmpl_var name='id'}');">{tmpl_var name="client"}</a></td>
33+
<td class="tbl_col_used"><a href="#" onclick="loadContent('sites/database_edit.php?id={tmpl_var name='id'}');">{tmpl_var name="used"}</a></td>
34+
<td class="tbl_col_quota"><a href="#" onclick="loadContent('sites/database_edit.php?id={tmpl_var name='id'}');">{tmpl_var name="quota"}</a></td>
35+
<td class="tbl_col_percentage"><a href="#" onclick="loadContent('sites/database_edit.php?id={tmpl_var name='id'}');">{tmpl_var name="percentage"}</a></td>
36+
<td class="tbl_col_buttons"></td>
37+
</tr>
38+
</tmpl_loop>
39+
<tmpl_unless name="records">
40+
<tr class="tbl_row_noresults tbl_row_<tmpl_if name='__EVEN__'}even<tmpl_else>uneven</tmpl_if>">
41+
<td colspan="7">{tmpl_var name='globalsearch_noresults_text_txt'}</td>
42+
</tr>
43+
</tmpl_unless>
44+
</tbody>
45+
<tfoot>
46+
<tr>
47+
<td class="tbl_footer tbl_paging" colspan="7"><tmpl_var name="paging"></td>
48+
</tr>
49+
</tfoot>
50+
</table>
51+
</fieldset>
52+
</div>
53+
54+
</div>

0 commit comments

Comments
 (0)