2008-10-16 Evi Vanoost <vanooste@rcbi.rochester.edu>

* include/functions_html.php: Added print_error_message, a function
        that will print out <h3> error messages for you given a result

        * godmode/modules/manage_network_templates_form.php: Rewrite for new
        style and makes it easier for mass updates to templates (eg. if you
        have port 1-48 of a Cisco Switch (input, output and status) now you
        don't have to click 288 times.


git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1163 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
This commit is contained in:
guruevi 2008-10-16 19:47:06 +00:00
parent 16779bbc9f
commit 192147a06c
3 changed files with 235 additions and 165 deletions

View File

@ -1,3 +1,13 @@
2008-10-16 Evi Vanoost <vanooste@rcbi.rochester.edu>
* include/functions_html.php: Added print_error_message, a function
that will print out <h3> error messages for you given a result
* godmode/modules/manage_network_templates_form.php: Rewrite for new
style and makes it easier for mass updates to templates (eg. if you
have port 1-48 of a Cisco Switch (input, output and status) now you
don't have to click 288 times.
2008-10-16 Sancho Lerena <slerena@gmail.com> 2008-10-16 Sancho Lerena <slerena@gmail.com>
* operation/snmpconsole/snmp_alert.php: Fixed problem creating * operation/snmpconsole/snmp_alert.php: Fixed problem creating

View File

@ -17,10 +17,11 @@
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
// Load global vars // Load global vars
require("include/config.php"); require_once ("include/config.php");
check_login (); check_login ();
if (! give_acl ($config['id_user'], 0, "PM")) { if (! give_acl ($config['id_user'], 0, "PM")) {
audit_db ($config['id_user'], $REMOTE_ADDR, "ACL Violation", audit_db ($config['id_user'], $REMOTE_ADDR, "ACL Violation",
"Trying to access Network Profile Management"); "Trying to access Network Profile Management");
@ -28,180 +29,204 @@ if (! give_acl ($config['id_user'], 0, "PM")) {
exit; exit;
} }
$id_np = get_parameter ("id_np", -1); //Network Profile
$ncgroup = get_parameter ("ncgroup", -1); //Network component group
$id_nc = get_parameter ("components", array ());
if (isset($_GET["delete_module"])){ // Delete module from profile if (isset ($_GET["delete_module"])) {
$id_npc = $_GET["delete_module"]; // Delete module from profile
$sql1="DELETE FROM tnetwork_profile_component WHERE id_npc = $id_npc"; $errors = 0;
$result=mysql_query($sql1); foreach ($id_nc as $component) {
if (! $result) $sql = sprintf ("DELETE FROM tnetwork_profile_component WHERE id_np = %d AND id_nc = %d", $id_np, $component);
echo "<h3 class='error'>".__('Not deleted. Error deleting data')."</h3>"; $result = process_sql ($sql);
else { if ($result === false) {
echo "<h3 class='suc'>".__('Deleted successfully')."</h3>"; $errors++;
}
}
if (isset($_GET["add_module"])){ // Add module to profile
$id_nc = $_POST["component"];
$id_np = $_GET["id_np"];
$sql1="INSERT INTO tnetwork_profile_component (id_np,id_nc) VALUES ($id_np, $id_nc)";
$result=mysql_query($sql1);
if (! $result)
echo "<h3 class='error'>".__('Not created. Error inserting data')."</h3>";
else {
echo "<h3 class='suc'>".__('Created successfully')."</h3>";
}
}
$ncgroup = -1;
if (isset($_GET["refresh_module"])){ //Refresh module info from group combo
$ncgroup = $_POST["ncgroup"];
}
if (isset($_GET["id_np"])){ // Read module data
$id_np = $_GET["id_np"];
if ($id_np != -1){
$sql1="SELECT * FROM tnetwork_profile WHERE id_np = $id_np ORDER BY
name";
$result=mysql_query($sql1);
$row=mysql_fetch_array($result);
$description = $row["description"];
$name = $row["name"];
} else {
$comentarios = "";
$name = "";
}
}
if (isset($_GET["create"])){ // Create module
$name = entrada_limpia ($_POST["name"]);
$description = entrada_limpia ($_POST["description"]);
$sql_insert="INSERT INTO tnetwork_profile (name,description)
VALUES ('$name', '$description')";
$result=mysql_query($sql_insert);
if (! $result)
echo "<h3 class='error'>".__('Not created. Error inserting data')."</h3>";
else {
echo "<h3 class='suc'>".__('Created successfully')."</h3>";
$id_np = mysql_insert_id();
}
}
if (isset($_GET["update"])){ // Update profile
$id_np = $_GET["update"];
$name = entrada_limpia ($_POST["name"]);
$description = entrada_limpia ($_POST["description"]);
$sql_insert="UPDATE tnetwork_profile set name = '$name', description = '$description' WHERE id_np = $id_np";
$result=mysql_query($sql_insert);
if (! $result)
echo "<h3 class='error'>".__('Not updated. Error updating data')."</h3>";
else {
echo "<h3 class='suc'>".__('Updated successfully')."</h3>";
}
}
echo "<h2>".__('Module management')." &gt; ";
echo __('Module template management')."</h2>";
echo "<table width='550' cellpadding='4' cellspacing='4' class='databox_color'>";
if ($id_np == -1)
echo '<form name="new_user" method="post" action="index.php?sec=gmodules&sec2=godmode/modules/manage_network_templates_form&create=1">';
else
echo '<form name="user_mod" method="post" action="index.php?sec=gmodules&sec2=godmode/modules/manage_network_templates_form&update='.$id_np.'">';
echo "<tr><td class='datos'>".__('Name')."</td>";
echo "<td class='datos'>";
echo "<input type='text' size=25 name='name' value='$name'>";
echo "</td>";
echo "<tr><td class='datos2'>".__('Description')."</td>";
echo "<td class='datos2'>";
echo "<textarea cols=50 rows=2 name='description'>";
if (isset($description)) {
echo $description;
}
echo "</textarea>";
echo "</td></tr></table>";
if ($id_np != -1){
// Show associated modules, allow to delete, and to add
$sql1 = "SELECT * FROM tnetwork_profile_component where id_np = $id_np";
$result = mysql_query ($sql1);
if ($row=mysql_num_rows($result)) {
echo '<table width="550" cellpadding="4" cellspacing="4" class="databox">';
echo '<tr>';
echo "<th>".__('Module name')."</th>";
echo "<th>".__('Type')."</th>";
echo "<th>".__('Description')."</th>";
echo "<th>".__('NC.Group')."</th>";
echo "<th>X</th>";
$color =0;
while ( $row = mysql_fetch_array($result)) {
$id_nc = $row["id_nc"];
$id_npc = $row["id_npc"];
$sql2 = "SELECT * FROM tnetwork_component where id_nc = $id_nc ORDER BY name";
$result2 = mysql_query ($sql2);
if ($row2=mysql_fetch_array($result2)){
if ($color == 1){
$tdcolor="datos";
$color =0;
} else {
$tdcolor="datos2";
$color =1;
}
$id_tipo = $row2["type"];
$id_group = $row2["id_group"];
$nombre_modulo =$row2["name"];
$description = $row2["description"];
$module_group2 = $row2["id_module_group"];
echo "<tr><td class='".$tdcolor."_id'>";
echo $nombre_modulo;
echo "<td class='".$tdcolor."f9'>";
if ($id_tipo > 0) {
echo "<img src='images/".show_icon_type($id_tipo)."' border=0>";
}
echo "<td class='$tdcolor'>".substr($description,0,30)."</td>";
echo "<td class='$tdcolor'>".give_network_component_group_name($id_group)."</td>";
echo "<td class='$tdcolor'><a href='index.php?sec=gmodules&sec2=godmode/modules/manage_network_templates_form&id_np=$id_np&delete_module=$id_npc'><img src='images/cross.png'></a></td>";
} }
} }
} else {
echo "<div class='nf'>No modules</div>"; print_error_message (($errors < 1), __('Successfully deleted module from profile'), __('Error deleting module from profile'));
} elseif (isset ($_GET["add_module"])) {
// Add module to profile
$errors = 0;
foreach ($id_nc as $component) {
$sql = sprintf ("INSERT INTO tnetwork_profile_component (id_np,id_nc) VALUES (%d, %d)", $id_np, $component);
$result = process_sql ($sql);
if ($result === false) {
$errors++;
}
} }
echo "</table>";
print_error_message (($errors < 1), __('Successfully added module to profile'), __('Error adding module to profile'));
} }
echo "<table width='550'>"; if (isset ($_GET["create"]) || isset ($_GET["update"])) {
echo '<tr><td align="right">'; //Submitted form
if ($id_np == -1) $name = get_parameter_post ("name");
echo '<input name="crtbutton" type="submit" class="sub wand" value="'.__('Create').'">'; $description = get_parameter_post ("description");
else
echo '<input name="updbutton" type="submit" class="sub upd" value="'.__('Update').'">';
echo "</td></tr></table>";
echo "</form>";
if ($id_np > 0) {
if ($id_np != -1){ //Profile exists
echo "<h3>".__('Add')." ".__('Module')."</h3>"; $sql = sprintf ("UPDATE tnetwork_profile SET name = '%s', description = '%s' WHERE id_np = %d", $name, $description, $id_np);
echo "<table class='databox'>"; $result = process_sql ($sql);
echo '<tr><td>'; print_error_message ($result, __('Successfully updated network profile'), __('Error updating network profile'));
echo '<form name="add_module" method="post" action="index.php?sec=gmodules&sec2=godmode/modules/manage_network_templates_form&id_np='.$id_np.'&add_module=1">'; } else {
$sql1 = "SELECT * FROM tnetwork_component ORDER BY id_group, name"; //Profile doesn't exist
$result = mysql_query ($sql1); $sql = sprintf ("INSERT INTO tnetwork_profile (name, description) VALUES ('%s', '%s')", $name, $description);
echo "<select name='component'>"; $result = process_sql ($sql, "insert_id");
while ($row = mysql_fetch_array($result)) { print_error_message ($result, __('Successfully added network profile'), __('Error adding network profile'));
echo "<option value='" . $row["id_nc"] . "'>". $row["name"]." / ".give_network_component_group_name ($row["id_group"]); $id_np = (int) $result; //Will return either 0 (in case of error) or an int
} }
echo "</select>";
echo '<td valign="top">'; } elseif ($id_np > 0) {
echo '<input name="crtbutton" type="submit" class="sub wand" value="'.__('Add').'">'; //Profile exists
echo "</td></tr></table>"; $row = get_db_row ("tnetwork_profile", "id_np", $id_np);
echo "</form>";
$description = $row["description"];
$name = $row["name"];
} else {
//Profile has to be created
$description = "";
$name = "";
}
echo "<h2>".__('Module management')." &gt; ".__('Module template management')."</h2>";
if ($id_np < 1) {
echo '<form name="new_temp" method="post" action="index.php?sec=gmodules&sec2=godmode/modules/manage_network_templates_form&id_np='.$id_np.'&create=1">';
} else {
echo '<form name="mod_temp" method="post" action="index.php?sec=gmodules&sec2=godmode/modules/manage_network_templates_form&id_np='.$id_np.'&update='.$id_np.'">';
}
echo '<table width="550" cellpadding="4" cellspacing="4" class="databox_color">';
echo '<tr><td class="datos">'.__('Name').'</td><td class="datos">';
print_input_text ("name", $name, '', 63);
echo '</td></tr>';
echo '<tr><td class="datos2">'.__('Description').'</td>';
echo '<td class="datos2">';
print_textarea ("description", 2, 60, $description);
echo "</td></tr>";
echo '<tr><td></td><td style="text-align:right;">';
if ($id_np > 0) {
print_submit_button (__("Update"), "updbutton", false, 'class="sub upd"');
} else {
print_submit_button (__("Create"), "crtbutton", false, 'class="sub wand"');
}
echo "</td></tr></table></form>";
if ($id_np > 0) {
// Show associated modules, allow to delete, and to add
$sql = sprintf ("SELECT npc.id_nc AS component_id, nc.name, nc.type, nc.description, nc.id_module_group AS `group`
FROM tnetwork_profile_component AS npc, tnetwork_component AS nc
WHERE npc.id_nc = nc.id_nc AND npc.id_np = %d", $id_np);
$result = get_db_all_rows_sql ($sql);
if (empty ($result)) {
echo '<div style="width:550px;" class="error">'.__("No modules for this profile").'</div>';
$result = array ();
}
$table->head = array ();
$table->data = array ();
$table->align = array ();
$table->width = 550;
$table->cellpadding = 4;
$table->cellspacing = 4;
$table->class = "databox";
$table->head[0] = __('Module name');
$table->head[1] = __('Type');
$table->align[1] = "center";
$table->head[2] = __('Description');
$table->head[3] = __('Group');
$table->align[3] = "center";
$table->head[4] = print_checkbox_extended ('allbox', '', false, false, 'CheckAll();', '', true);
$table->align[4] = "center";
foreach ($result as $row) {
$data = array ();
$data[0] = $row["name"];
$data[1] = '<img src="images/'.show_icon_type($row["type"]).'" border="0" />';
$data[2] = substr($row["description"],0,30);
$data[3] = give_network_component_group_name ($row["group"]);
$data[4] = print_checkbox ("components[]", $row["component_id"], false, true);
array_push ($table->data, $data);
}
if (!empty ($table->data)) {
echo '<form name="component_delete" method="post" action="index.php?sec=gmodules&sec2=godmode/modules/manage_network_templates_form&id_np='.$id_np.'&delete_module=1">';
print_table ($table);
echo '<div style="width:540px; text-align:right">';
print_submit_button (__('Delete'), "delbutton", false, 'class="sub delete" onClick="if (!confirm(\'Are you sure?\')) return false;"');
echo '</div></form>';
}
unset ($table);
echo "<h3>".__('Add Modules')."</h3>";
//Here should be a form to filter group
//The form to submit when adding a list of components
echo '<form name="filter_group" method="post" action="index.php?sec=gmodules&sec2=godmode/modules/manage_network_templates_form&id_np='.$id_np.'#filter">';
echo '<div style="width:540px"><a name="filter"></a>';
$result = get_db_all_rows_in_table ("tnetwork_component_group","name");
//2 arrays. 1 with the groups, 1 with the groups by parent
$groups = array ();
$groups_compound = array ();
foreach ($result as $row) {
$groups[$row["id_sg"]] = $row["name"];
}
foreach ($result as $row) {
$groups_compound[$row["id_sg"]] = '';
if ($row["parent"] > 1) {
$groups_compound[$row["id_sg"]] = $groups[$row["parent"]]." / ";
}
$groups_compound[$row["id_sg"]] .= $row["name"];
}
print_select ($groups_compound, "ncgroup", $ncgroup, 'javascript:this.form.submit();', __('Group')." - ".__('All'), -1, false, false, true, '" style="width:350px');
echo '<noscript>';
print_submit_button (__('Filter'), 'ncgbutton', false, 'class="sub search"');
echo '</noscript></div></form>';
echo '<form name="add_module" method="post" action="index.php?sec=gmodules&sec2=godmode/modules/manage_network_templates_form&id_np='.$id_np.'&add_module=1">';
echo '<div style="width:540px">';
if ($ncgroup > 0) {
$sql = sprintf ("SELECT id_nc, name, id_group FROM tnetwork_component WHERE id_group = %d ORDER BY name", $ncgroup);
} else {
$sql = "SELECT id_nc, name, id_group FROM tnetwork_component ORDER BY name";
}
$result = get_db_all_rows_sql ($sql);
$components = array ();
if ($result === false)
$result = array ();
foreach ($result as $row) {
$components[$row["id_nc"]] = $row["name"];
}
print_select ($components, "components[]", $id_nc, '', '', -1, false, true, false, '" style="width:350px');
echo "&nbsp;&nbsp;";
print_submit_button (__('Add'), 'crtbutton', false, 'class="sub wand"');
echo "</div></form>";
} }
?> ?>
<script language="JavaScript" type="text/javascript">
<!--
function CheckAll() {
for (var i = 0; i < document.component_delete.elements.length; i++) {
var e = document.component_delete.elements[i];
if (e.type == 'checkbox' && e.name != 'allbox')
e.checked = !e.checked;
}
}
-->
</script>

View File

@ -567,4 +567,39 @@ function print_help_tip ($text, $return = false) {
echo $output; echo $output;
} }
/**
* Evaluates a result using empty () and then prints an error message or a
* success message
*
* @param any $result the results to evaluate. 0, NULL, false, '' or array()
* is bad, the rest is good
* @param string $good the string to be displayed if the result was good
* @param string $bad the string to be displayed if the result was bad
* @param string $attributes any other attributes to be set for the h3
* @param bool $return whether to output the string or return it
* @param string $tag what tag to use (you could specify something else than
* h3 like div or h2
*
* @return a string or an output
*/
function print_error_message ($result, $good = '', $bad = '', $attributes = '', $return = false, $tag = 'h3') {
if ($good == '' || $good === false)
$good = __('Request successfully processed');
if ($bad == '' || $bad === false)
$bad = __('Error processing request');
if (empty ($result)) {
$output = '<'.$tag.' class="error" '.$attributes.'>'.$bad.'</'.$tag.'>';
} else {
$output = '<'.$tag.' class="suc" '.$attributes.'>'.$good.'</'.$tag.'>';
}
if ($return !== false)
return $output;
echo $output;
}
?> ?>