2010-07-19 Miguel de Dios <miguel.dedios@artica.es>

* operation/users/user.php, godmode/users/user_list.php: added the default
	order to columns.
	
	* godmode/agentes/modificar_agente.php: added the source code to order by
	Name, OS or group column in the list agents.



git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@3027 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
This commit is contained in:
mdtrooper 2010-07-19 12:01:55 +00:00
parent ca3b88868d
commit c6d800168f
4 changed files with 104 additions and 12 deletions

View File

@ -1,9 +1,17 @@
2010-07-19 Miguel de Dios <miguel.dedios@artica.es>
* operation/users/user.php, godmode/users/user_list.php: added the default
order to columns.
* godmode/agentes/modificar_agente.php: added the source code to order by
Name, OS or group column in the list agents.
2010-07-19 Sergio Martin <sergio.martin@artica.es> 2010-07-19 Sergio Martin <sergio.martin@artica.es>
* include/functions_db.php: Fixed an index error of * include/functions_db.php: Fixed an index error of
groups array. groups array.
2010-07-18 Miguel de Dios <miguel.dedios@artica.es> 2010-07-19 Miguel de Dios <miguel.dedios@artica.es>
* include/auth/mysql.php: added function "get_users" the check to $order * include/auth/mysql.php: added function "get_users" the check to $order
parameter if it is array, extract the field and order. parameter if it is array, extract the field and order.

View File

@ -20,6 +20,8 @@ check_login ();
$offset = (int) get_parameter ("offset"); $offset = (int) get_parameter ("offset");
$group_id = (int) get_parameter ("group_id"); $group_id = (int) get_parameter ("group_id");
$ag_group = get_parameter ("ag_group_refresh", -1); $ag_group = get_parameter ("ag_group_refresh", -1);
$sortField = get_parameter('sort_field');
$sort = get_parameter('sort', 'none');
if ($ag_group == -1 ) if ($ag_group == -1 )
$ag_group = (int) get_parameter ("ag_group", -1); $ag_group = (int) get_parameter ("ag_group", -1);
@ -101,10 +103,64 @@ echo '<form method="post" action="index.php?sec=gagente&amp;sec2=godmode/agentes
echo "</td></tr></table>"; echo "</td></tr></table>";
$selected = 'border: 1px solid black;';
$selectNameUp = '';
$selectNameDown = '';
$selectOsUp = '';
$selectOsDown = '';
$selectGroupUp = '';
$selectGroupDown = '';
switch ($sortField) {
case 'name':
switch ($sort) {
case 'up':
$selectNameUp = $selected;
$order = array('field' => 'nombre', 'order' => 'ASC');
break;
case 'down':
$selectNameDown = $selected;
$order = array('field' => 'nombre', 'order' => 'DESC');
break;
}
break;
case 'os':
switch ($sort) {
case 'up':
$selectOsUp = $selected;
$order = array('field' => 'id_os', 'order' => 'ASC');
break;
case 'down':
$selectOsDown = $selected;
$order = array('field' => 'id_os', 'order' => 'DESC');
break;
}
break;
case 'group':
switch ($sort) {
case 'up':
$selectGroupUp = $selected;
$order = array('field' => 'id_grupo', 'order' => 'ASC');
break;
case 'down':
$selectGroupDown = $selected;
$order = array('field' => 'id_grupo', 'order' => 'DESC');
break;
}
break;
default:
$selectNameUp = $selected;
$selectNameDown = '';
$selectOsUp = '';
$selectOsDown = '';
$selectGroupUp = '';
$selectGroupDown = '';
$order = array('field' => 'nombre', 'order' => 'ASC');
break;
}
$search_sql = ''; $search_sql = '';
if ($search != ""){ if ($search != ""){
$search_sql = " AND ( nombre COLLATE utf8_general_ci LIKE '%$search%' OR direccion LIKE '%$search%') "; $search_sql = " AND ( nombre COLLATE utf8_general_ci LIKE '%$search%' OR direccion LIKE '%$search%') ";
} else {
} }
// Show only selected groups // Show only selected groups
@ -120,15 +176,15 @@ if ($ag_group > 0) {
FROM tagente FROM tagente
WHERE id_grupo = %d WHERE id_grupo = %d
%s %s
ORDER BY nombre LIMIT %d, %d', ORDER BY %s %s LIMIT %d, %d',
$ag_group, $search_sql, $offset, $config["block_size"]); $ag_group, $search_sql, $order['field'], $order['order'], $offset, $config["block_size"]);
} else { } else {
// Admin user get ANY group, even if they doesnt exist // Admin user get ANY group, even if they doesnt exist
if (check_acl ($config['id_user'], 0, "PM")){ if (check_acl ($config['id_user'], 0, "PM")){
$sql = sprintf ('SELECT COUNT(*) FROM tagente WHERE 1=1 %s', $search_sql); $sql = sprintf ('SELECT COUNT(*) FROM tagente WHERE 1=1 %s', $search_sql);
$total_agents = get_db_sql ($sql); $total_agents = get_db_sql ($sql);
$sql = sprintf ('SELECT * FROM tagente WHERE 1=1 %s ORDER BY nombre LIMIT %d, %d', $search_sql, $offset, $config["block_size"]); $sql = sprintf ('SELECT * FROM tagente WHERE 1=1 %s ORDER BY %s %s LIMIT %d, %d', $search_sql, $order['field'], $order['order'], $offset, $config["block_size"]);
} else { } else {
$sql = sprintf ('SELECT COUNT(*) $sql = sprintf ('SELECT COUNT(*)
@ -143,25 +199,34 @@ if ($ag_group > 0) {
FROM tagente FROM tagente
WHERE id_grupo IN (%s) WHERE id_grupo IN (%s)
%s %s
ORDER BY nombre LIMIT %d, %d', ORDER BY %s %s LIMIT %d, %d',
implode (',', array_keys (get_user_groups ())), implode (',', array_keys (get_user_groups ())),
$search_sql, $offset, $config["block_size"]); $search_sql, $order['field'], $order['order'], $offset, $config["block_size"]);
} }
} }
$agents = get_db_all_rows_sql ($sql); $agents = get_db_all_rows_sql ($sql);
// Prepare pagination // Prepare pagination
pagination ($total_agents, "index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id=$ag_group&search=$search", $offset); pagination ($total_agents, "index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id=$ag_group&search=$search&sort_field=$sortField&sort=$sort", $offset);
echo "<div style='height: 20px'> </div>"; echo "<div style='height: 20px'> </div>";
if ($agents !== false) { if ($agents !== false) {
echo "<table cellpadding='4' id='agent_list' cellspacing='4' width='95%' class='databox'>"; echo "<table cellpadding='4' id='agent_list' cellspacing='4' width='95%' class='databox'>";
echo "<th>".__('Agent name')."</th>"; echo "<th>".__('Agent name') . ' ' .
'<a href="index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id='.$ag_group.'&search='.$search .'&offset='.$offset.'&sort_field=name&sort=up"><img src="images/sort_up.png" style="' . $selectNameUp . '" /></a>' .
'<a href="index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id='.$ag_group.'&search='.$search .'&offset='.$offset.'&sort_field=name&sort=down"><img src="images/sort_down.png" style="' . $selectNameDown . '" /></a>';
echo "</th>";
echo "<th title='".__('Remote agent configuration')."'>".__('R')."</th>"; echo "<th title='".__('Remote agent configuration')."'>".__('R')."</th>";
echo "<th>".__('OS')."</th>"; echo "<th>".__('OS'). ' ' .
echo "<th>".__('Group')."</th>"; '<a href="index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id='.$ag_group.'&search='.$search .'&offset='.$offset.'&sort_field=os&sort=up"><img src="images/sort_up.png" style="' . $selectOsUp . '" /></a>' .
'<a href="index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id='.$ag_group.'&search='.$search .'&offset='.$offset.'&sort_field=os&sort=down"><img src="images/sort_down.png" style="' . $selectOsDown . '" /></a>';
echo "</th>";
echo "<th>".__('Group'). ' ' .
'<a href="index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id='.$ag_group.'&search='.$search .'&offset='.$offset.'&sort_field=group&sort=up"><img src="images/sort_up.png" style="' . $selectGroupUp . '" /></a>' .
'<a href="index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id='.$ag_group.'&search='.$search .'&offset='.$offset.'&sort_field=group&sort=down"><img src="images/sort_down.png" style="' . $selectGroupDown . '" /></a>';
echo "</th>";
echo "<th>".__('Description')."</th>"; echo "<th>".__('Description')."</th>";
echo "<th>".__('Delete')."</th>"; echo "<th>".__('Delete')."</th>";
$color=1; $color=1;
@ -248,11 +313,12 @@ if ($agents !== false) {
$offsetArg = $offset; $offsetArg = $offset;
echo "<td class='$tdcolor' align='center'><a href='index.php?sec=gagente&sec2=godmode/agentes/modificar_agente& echo "<td class='$tdcolor' align='center'><a href='index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&
borrar_agente=".$agent["id_agente"]."&search=$search&offset=$offsetArg'"; borrar_agente=".$agent["id_agente"]."&search=$search&offset=$offsetArg&sort_field=$sortField&sort=$sort'";
echo ' onClick="if (!confirm(\' '.__('Are you sure?').'\')) return false;">'; echo ' onClick="if (!confirm(\' '.__('Are you sure?').'\')) return false;">';
echo "<img border='0' src='images/cross.png'></a></td>"; echo "<img border='0' src='images/cross.png'></a></td>";
} }
echo "</table>"; echo "</table>";
pagination ($total_agents, "index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&group_id=$ag_group&search=$search&sort_field=$sortField&sort=$sort", $offset);
echo "<table width='95%'><tr><td align='right'>"; echo "<table width='95%'><tr><td align='right'>";
} else { } else {
echo "<div class='nf'>".__('There are no defined agents')."</div>"; echo "<div class='nf'>".__('There are no defined agents')."</div>";

View File

@ -74,6 +74,15 @@ switch ($sortField) {
break; break;
} }
break; break;
default:
$selectUserIDUp = '';
$selectUserIDDown = '';
$selectFullnameUp = $selected;
$selectFullnameDown = '';
$selectLastConnectUp = '';
$selectLastConnectDown = '';
$order = array('field' => 'fullname', 'order' => 'ASC');
break;
} }
// Header // Header

View File

@ -69,6 +69,15 @@ switch ($sortField) {
break; break;
} }
break; break;
default:
$selectUserIDUp = '';
$selectUserIDDown = '';
$selectFullnameUp = $selected;
$selectFullnameDown = '';
$selectLastConnectUp = '';
$selectLastConnectDown = '';
$order = array('field' => 'fullname', 'order' => 'ASC');
break;
} }
// Header // Header