X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=planetlab%2Fslices%2Fslice.php;h=e0868b7361e61aa48bf5519205121ee208b31ea5;hb=e417acbe5b45f14f5f7b0f297a327d2aa18c7038;hp=64aef694dd32b75ae0929c67cdb36034154b5b86;hpb=074abc2c9036064e9c2f8b4904fc9333500da505;p=plewww.git
diff --git a/planetlab/slices/slice.php b/planetlab/slices/slice.php
index 64aef69..e0868b7 100644
--- a/planetlab/slices/slice.php
+++ b/planetlab/slices/slice.php
@@ -1,7 +1,5 @@
');
-// -------------------- admins potentially need to get full list of users
-ini_set('memory_limit','32M');
+$profiling = false;
+if (get_array($_GET, 'profiling')) {
+ $profiling = true;
+}
+
+if ($profiling) {
+ plc_debug_prof_start();
+}
-// --------------------
+// --------------------
// recognized URL arguments
-$slice_id=intval($_GET['id']);
-if ( ! $slice_id ) { plc_error('Malformed URL - id not set'); return; }
+$slice_id = intval(get_array($_GET, 'id'));
+if (!$slice_id) {
+ plc_error('Malformed URL - id not set');
+ return;
+}
////////////////////
-// Get all columns as we focus on only one entry
-$slices= $api->GetSlices( array($slice_id));
+// have to name columns b/c we need the non-native 'omf_control' column
+$slice_columns = array('slice_id', 'name', 'peer_id', 'site_id', 'person_ids', 'node_ids', 'expires',
+ 'url', 'description', 'instantiation', 'omf_control');
+$slices = $api->GetSlices(array($slice_id), $slice_columns);
if (empty($slices)) {
- drupal_set_message ("Slice " . $slice_id . " not found");
- return;
- }
+ drupal_set_message("Slice " . $slice_id . " not found");
+ return;
+}
+
+$slice = $slices[0];
-$slice=$slices[0];
+if ($profiling) {
+ plc_debug_prof('01: slice', count($slices));
+}
// pull all node info to vars
-$name= $slice['name'];
-$expires = date( "d/m/Y", $slice['expires'] );
-$site_id= $slice['site_id'];
+$name = $slice['name'];
+$expires = date("d/m/Y", $slice['expires']);
+$site_id = $slice['site_id'];
-//$node_ids=$slice['node_ids'];
-$person_ids=$slice['person_ids'];
-//$slice_tag_ids= $slice['slice_tag_ids'];
+$person_ids = $slice['person_ids'];
// get peers
-$peer_id= $slice['peer_id'];
-$peers=new Peers ($api);
-$local_peer = ! $peer_id;
+$peer_id = $slice['peer_id'];
+$peers = new Peers($api);
+$local_peer = !$peer_id;
+
+if ($profiling) {
+ plc_debug_prof('02: peers', count($peers));
+}
// gets site info
-$sites= $api->GetSites( array( $site_id ) );
-$site=$sites[0];
-$site_name= $site['name'];
+$sites = $api->GetSites(array($site_id));
+$site = $sites[0];
+$site_name = $site['name'];
$max_slices = $site['max_slices'];
-// xxx PIs
-//$pis=$api->GetPersons(...)
-
-// get all persons info
-if (!empty($person_ids))
- $persons=$api->GetPersons($person_ids,array('email','enabled'));
+if ($profiling) {
+ plc_debug_prof('03: sites', count($sites));
+}
//////////////////////////////////////// building blocks for the renew area
// Constants
-global $DAY; $DAY = 24*60*60;
-global $WEEK; $WEEK = 7 * $DAY;
-global $MAX_WEEKS; $MAX_WEEKS= 8; // weeks from today
-global $GRACE_DAYS; $GRACE_DAYS=10; // days for renewal promoted on top
-global $NOW; $NOW=mktime();
-
-
+global $DAY;
+$DAY = 24 * 60 * 60;
+global $WEEK;
+$WEEK = 7 * $DAY;
+global $MAX_WEEKS;
+$MAX_WEEKS = 8; // weeks from today
+global $GRACE_DAYS;
+$GRACE_DAYS = 10; // days for renewal promoted on top
+global $NOW;
+$NOW = time();
+
+//////////////////////////////////////////////////////////// utility for the renew tab
// make the renew area on top and open if the expiration time is less than 10 days from now
-function renew_needed ($slice) {
- global $DAY, $NOW, $GRACE_DAYS;
- $current_exp=$slice['expires'];
-
- $time_left = $current_exp - $NOW;
- $visible = $time_left/$DAY <= $GRACE_DAYS;
- return $visible;
-}
-
-function renew_area ($slice,$site,$visible) {
- global $DAY, $WEEK, $MAX_WEEKS, $GRACE_DAYS, $NOW;
-
- $current_exp=$slice['expires'];
- $max_exp= $NOW + ($MAX_WEEKS * $WEEK); // seconds since epoch
-
- // xxx some extra code needed to enable this area only if the slice description is OK:
- // description and url must be non void
- $toggle=
- new PlekitToggle('renew',"Renew this slice",
- array("bubble"=>
- "Enter this zone if you wish to renew your slice",
- 'visible'=>$visible));
- $toggle->start();
-
- // xxx message could take roles into account
- if ($site['max_slices']<=0) {
- $message= <<< EOF
+function renew_needed($slice)
+{
+ global $DAY, $NOW, $GRACE_DAYS;
+ $current_exp = $slice['expires'];
+
+ $time_left = $current_exp - $NOW;
+ $visible = $time_left / $DAY <= $GRACE_DAYS;
+ return $visible;
+}
+
+function renew_area($slice, $site, $visible)
+{
+ global $DAY, $WEEK, $MAX_WEEKS, $GRACE_DAYS, $NOW;
+
+ $current_exp = $slice['expires'];
+ $current_text = gmstrftime("%A %b-%d-%y %T %Z", $current_exp);
+ $max_exp = $NOW + ($MAX_WEEKS * $WEEK); // seconds since epoch
+ $max_text = gmstrftime("%A %b-%d-%y %T %Z", $max_exp);
+
+ // xxx some extra code needed to enable this area only if the slice description is OK:
+ // description and url must be non void
+ $toggle =
+ new PlekitToggle('renew', "Expires $current_text - Renew this slice",
+ array("bubble" =>
+ "Enter this zone if you wish to renew your slice",
+ 'visible' => $visible));
+ $toggle->start();
+
+ // xxx message could take roles into account
+ if ($site['max_slices'] <= 0) {
+ $message = <<< EOF
Slice creation and renewal have been temporarily disabled for your
site details page to find
out more about your site's nodes, and how to contact your site's PI(s)
and Technical Contact(s).
EOF;
- echo $message;
-
- } else {
- // xxx this is a rough cut and paste from the former UI
- // showing a datepicker view could be considered as well with some extra work
- // calculate possible extension lengths
- $selectors = array();
- foreach ( array ( 1 => "One more week",
- 2 => "Two more weeks",
- 3 => "Three more weeks",
- 4 => "One more month" ) as $weeks => $text ) {
- $candidate_exp = $current_exp + $weeks*$WEEK;
- if ( $candidate_exp < $max_exp) {
- $selectors []= array('display'=>"$text (" . gmstrftime("%A %b-%d-%y %T %Z", $candidate_exp) . ")",
- 'value'=>$candidate_exp);
- $max_renewal_weeks=$weeks;
- $max_renewal_date= gmstrftime("%A %b-%d-%y %T %Z", $candidate_exp);
- }
- }
+ echo $message;
+
+ } else {
+ // xxx this is a rough cut and paste from the former UI
+ // showing a datepicker view could be considered as well with some extra work
+ // calculate possible extension lengths
+ $selectors = array();
+ foreach (array(1 => "One more week",
+ 2 => "Two more weeks",
+ 3 => "Three more weeks",
+ 4 => "One more month") as $weeks => $text) {
+ $candidate_exp = $current_exp + $weeks * $WEEK;
+ if ($candidate_exp < $max_exp) {
+ $selectors[] = array('display' => "$text (" . gmstrftime("%A %b-%d-%y %T %Z", $candidate_exp) . ")",
+ 'value' => $candidate_exp);
+ $max_renewal_weeks = $weeks;
+ $max_renewal_date = gmstrftime("%A %b-%d-%y %T %Z", $candidate_exp);
+ }
+ }
- if ( empty( $selectors ) ) {
- print <<< EOF
-
-Slice cannot be renewed any further into the future, try again closer to expiration date.
+ if (empty($selectors)) {
+ print <<< EOF
+
+Slices cannot be renewed more than $MAX_WEEKS weeks from now, i.e. not beyond $max_text.
+For this reason, the current slice cannot be renewed any further into the future, try again closer to expiration date.
You must provide a short description as well as a link to a project website before renewing it.
-Do not provide bogus information; if a complaint is lodged against your slice
-and PlanetLab Operations is unable to determine what the normal behavior of your slice is,
-your slice may be deleted to resolve the complaint.
-
NOTE:
-Slices cannot be renewed beyond another $max_renewal_weeks week(s) ($max_renewal_date).
+Important: Please take this opportunity to review and update your slice information in the Details tab.
+
+PlanetLab's security model requires that anyone who is concerned about a slice's activity be able to immediately learn about that slice. The details that you provide are your public explanation about why the slice behaves as it does. Be sure to describe the kind of traffic that your slice generates, and how it handles material that is under copyright, if relevant.
+
+The PlanetLab Operations Centres regularly respond to concerns raised by third parties about site behaviour. Most incidents are resolved rapidly based upon the publicly posted slice details. However, when these details are not sufficiently clear or accurate, and we cannot immediately reach the slice owner, we must delete the slice.
";
+
+ // leases_data is the name used by leases.js to locate this place
+ // first population will be triggered by init_scheduler from leases.js
+ echo "
";
+
+ // the general layout for the scheduler
+ echo <<< EOF
+
+
+
+
+
+
+EOF;
+
+ $toggle_nodes->end();
+}
+
+if ($profiling) {
+ plc_debug_prof('06: leases', 0);
+}
+
+//////////////////// node configuration panel
+if ($first_time_configuration) {
+ $column_conf_visible = '1';
+} else {
+ $column_conf_visible = '0';
+}
+
+$layout_info = '
+This tab allows you to customize the columns in the node tables,
+below. Information on the nodes comes from a variety of monitoring
+sources. If you, as either a user or a provider of monitoring data,
+would like to see additional columns made available, please send us
+your request in mail to support@myslice.info. You can
+find more information about the MySlice project at http://trac.myslice.info.
+';
+$toggle_nodes = new PlekitToggle('my-slice-nodes-configuration',
+ "Node table layout",
+ array('info-text' => $layout_info,
+ 'info-visible' => $show_layout_info));
+$toggle_nodes->start();
+
+//usort ($table_headers, function($col1, $col2) {return strcmp($col1["header"],$col2["header"]);}));
+//print("
TABLE HEADERS
");
+//print_r($table_headers);
+
+print("
");
+print("");
+print("");
+print("");
+print("");
+print("");
+print("");
+print(" ");
+print("");
+print("");
+
+if ($profiling) {
+ plc_debug_prof('07: before configuration_panel', 0);
+}
+
+$ConfigureColumns->configuration_panel_html(true);
+
+if ($profiling) {
+ plc_debug_prof('08: before javascript_init', 0);
+}
+
+$ConfigureColumns->javascript_init();
+
+$toggle_nodes->end();
+
+if ($profiling) {
+ plc_debug_prof('09: layout', 0);
+}
+
+$all_sites = $api->GetSites(null, array('site_id', 'login_base'));
+$site_hash = array();
+foreach ($all_sites as $tmp_site) {
+ $site_hash[$tmp_site['site_id']] = $tmp_site['login_base'];
+}
+
+$interface_columns = array('ip', 'node_id', 'interface_id');
+$interface_filter = array('is_primary' => true);
+$interfaces = $api->GetInterfaces($interface_filter, $interface_columns);
+
+$interface_hash = array();
+if ($interfaces) {
+ foreach ($interfaces as $interface) {
+ $interface_hash[$interface['node_id']] = $interface;
+ }
+
+}
+
+if ($profiling) {
+ plc_debug_prof('10: interfaces', count($interfaces));
+}
+
+//////////////////// nodes currently in
+$toggle_nodes = new PlekitToggle('my-slice-nodes-current',
+ count_english($slice_nodes, "node") . " currently in $name",
+ array('visible' => get_arg('show_nodes_current')));
$toggle_nodes->start();
-$headers=array();
+$headers = array();
+$notes = array();
+//$notes=array_merge($notes,$visibletags->notes());
+$notes[] = "For information about the different columns please see the node table layout tab above or mouse over the column headers";
+
+/*
$headers['peer']='string';
$headers['hostname']='string';
-$headers['arch']='string';
+$short="-S-"; $long=Node::status_footnote(); $type='string';
+$headers[$short]=array('type'=>$type,'title'=>$long); $notes []= "$short = $long";
+$short=reservable_mark(); $long=reservable_legend(); $type='string';
+$headers[$short]=array('type'=>$type,'title'=>$long); $notes []= "$short = $long";
+// the extra tags, configured for the UI
+$headers=array_merge($headers,$visibletags->headers());
+
if ($privileges) $headers[plc_delete_icon()]="none";
+ */
+
+$edit_header = array();
+if ($privileges) {
+ $edit_header[plc_delete_icon()] = "none";
+}
+
+$headers = array_merge($ConfigureColumns->get_headers(), $edit_header);
-$table_options = array('notes_area'=>false,
- 'search_width'=>15,
- 'pagesize'=>20);
-$table=new PlekitTable('nodes',$headers,'0',$table_options);
+//print("
Shared initscripts are global to the
+MyPLC, and managed by the Operations Team. For that reason, regular
+users cannot change these scripts, but can reference one of the
+available names in the drop down below.
+
+
You also have the option to provide your own
+code , with the following conventions:
+
+
Like regular initscripts, your script must expect to receive as a
+first argument start ,
+stop or restart . It is important
+to honor this argument, as your slice may be stopped and restarted at
+any time; also this is used whenever the installed code gets changed.
+
+
+
As a second argument, you will receive the slicename; in most
+cases this can be safely ignored.
+
+
+
+
+The slice-specific setting has precedence on a shared initscript.
+";
+
+$shared_initscripts = $api->GetInitScripts(array('-SORT' => 'name'), array('name'));
+//$shared_initscripts=$api->GetInitScripts();
+if ($profiling) {
+ plc_debug_prof('13: initscripts', count($initscripts));
+}
+
+// xxx expose this even on foreign slices for now
+if ($local_peer) {
+ $initscript = '';
+ $initscript_code = '';
+ if ($tags) {
+ foreach ($tags as $tag) {
+ if ($tag['tagname'] == 'initscript') {
+ if ($initscript != '') {
+ drupal_set_error("multiple occurrences of 'initscript' tag");
+ }
+
+ $initscript = $tag['value'];
+ }
+ if ($tag['tagname'] == 'initscript_code') {
+ if ($initscript_code != '') {
+ drupal_set_error("multiple occurrences of 'initscript_code' tag");
+ }
+
+ $initscript_code = $tag['value'];
+ // plc_debug_txt('retrieved body',$initscript_code);
+ }
+ }
+ }
+
+ $label = "No initscript";
+ $trimmed = trim($initscript_code);
+ if (!empty($trimmed)) {
+ $label = "Initscript : slice-specific (" . substr($initscript_code, 0, 20) . " ...)";
+ } else if (!empty($initscript)) {
+ $label = "Initscript: shared " . $initscript;
+ }
+
+ $toggle = new PlekitToggle('slice-initscripts', $label,
+ array('bubble' => 'Manage initscript on that slice',
+ 'visible' => get_arg('show_initscripts'),
+ 'info-text' => $initscript_info,
+ // not messing with persontags to guess whether this should be displayed or not
+ // hopefully some day toggle will know how to handle that using web storage
+ ));
+ $toggle->start();
+
+ $details = new PlekitDetails(true);
+ // we expose the previous values so that actions.php can know if changes are really needed
+ // the code needs to be encoded as it may contain any character
+ // as far as the code, this does not work too well b/c what actions.php receives
+ // seems to have spurrious \r chars, and the comparison between old and new values
+ // is not reliable, which results in changes being made although the code hasn't changed
+ // hve spent too much time on this, good enough for now...
+ $details->form_start(l_actions(), array('action' => 'update-initscripts',
+ 'slice_id' => $slice_id,
+ 'name' => $name,
+ 'previous-initscript' => $initscript,
+ 'previous-initscript-code' => htmlentities($initscript_code)));
+ $details->start();
+ // comppute a pulldown with available names
+ $selectors = array();
+ $is_found = false;
+ if ($shared_initscripts) {
+ foreach ($shared_initscripts as $is) {
+ $is_selector = array('display' => $is['name'], 'value' => $is['name']);
+ if ($is['name'] == $initscript) {
+ $is_selector['selected'] = true;
+ $is_found = true;
+ }
+ $selectors[] = $is_selector;
+ }
+ }
+
+ // display a warning when initscript references an unknown script
+ $details->tr_submit('unused', 'Update initscripts');
+ ////////// by name
+ $details->th_td("shared initscript name",
+ $details->form()->select_html('initscript', $selectors, array('label' => 'none')),
+ 'initscript',
+ array('input_type' => 'select'));
+ if ($initscript && !$is_found)
+ // xxx better rendering ?
+ {
+ $details->th_td('WARNING', plc_warning_html("Current name '" . $initscript . "' is not a known shared initscript name"));
+ }
+
+ ////////// by contents
+ $script_height = 8;
+ $script_width = 60;
+ if ($initscript_code) {
+ $text = explode("\n", $initscript_code);
+ $script_height = count($text);
+ $script_width = 10;
+ foreach ($text as $line) {
+ $script_width = max($script_width, strlen($line));
+ }
+
+ }
+ $details->th_td('slice initscript', $initscript_code, 'initscript-code',
+ array('input_type' => 'textarea', 'width' => $script_width, 'height' => $script_height));
+ $details->tr_submit('unused', 'Update initscripts');
+ $details->form_end();
+ $details->end();
+ $toggle->end();
+}
+
+//////////////////////////////////////////////////////////// tab:tags
+// very wide values get abbreviated
+$tag_value_threshold = 24;
+// xxx fixme
+// * this area could use a help message about some special tags:
+// * initscript-related should be taken out
+// * sliverauth-related (ssh_key & hmac) should have a toggle to hide or show
+// xxx fixme
+
+// xxx expose this even on foreign slices for now
//if ( $local_peer ) {
- $tags=$api->GetSliceTags (array('slice_id'=>$slice_id));
- function get_tagname ($tag) { return $tag['tagname'];}
- $tagnames = array_map ("get_tagname",$tags);
-
- $toggle = new PlekitToggle ('slice-tags',count_english_warning($tags,'tag'),
- array('bubble'=>'Inspect and set tags on tat slice',
- 'visible'=>get_arg('show_tags',false)));
- $toggle->start();
-
- $headers=array(
- "Name"=>"string",
- "Value"=>"string",
- "Node"=>"string",
- "NodeGroup"=>"string");
- if ($tags_privileges) $headers[plc_delete_icon()]="none";
-
- $table_options=array("notes_area"=>false,"pagesize_area"=>false,"search_width"=>10);
- $table=new PlekitTable("slice_tags",$headers,'0',$table_options);
- $form=new PlekitForm(l_actions(),
- array('slice_id'=>$slice['slice_id']));
- $form->start();
- $table->start();
- if ($tags) {
+if ($profiling) {
+ plc_debug_prof('14: slice tags', count($tags));
+}
+
+function get_tagname($tag)
+{return $tag['tagname'];}
+$tagnames = array_map("get_tagname", $tags);
+
+$toggle = new PlekitToggle('slice-tags', count_english_warning($tags, 'tag'),
+ array('bubble' => 'Inspect and set tags on that slice',
+ 'visible' => get_arg('show_tags')));
+$toggle->start();
+
+$headers = array(
+ "Name" => "string",
+ "Value" => "string",
+ "Node" => "string",
+ "NodeGroup" => "string");
+if ($tags_privileges) {
+ $headers[plc_delete_icon()] = "none";
+}
+
+$table_options = array("notes_area" => false, "pagesize_area" => false, "search_width" => 10);
+$table = new PlekitTable("slice_tags", $headers, '0', $table_options);
+$form = new PlekitForm(l_actions(),
+ array('slice_id' => $slice['slice_id']));
+$form->start();
+$table->start();
+if ($tags) {
+ // Get hostnames for nodes in a single pass
+ $_node_ids = array();
foreach ($tags as $tag) {
- $node_name = "ALL";
- if ($tag['node_id']) {
- $nodes = $api->GetNodes(array('node_id'=>$tag['node_id']));
- if($nodes) {
- $node = $nodes[0];
- $node_name = $node['hostname'];
+ if ($tag['node_id']) {
+ array_push($_node_ids, $tag['node_id']);
}
- }
- $nodegroup_name="n/a";
- if ($tag['nodegroup_id']) {
- $nodegroup=$api->GetNodeGroups(array('nodegroup_id'=>$tag['nodegroup_id']));
- if ($nodegroup) {
- $nodegroup = $nodegroup[0];
- $nodegroup_name = $nodegroup['groupname'];
+ }
+ $_nodes = $api->GetNodes(array('node_id' => $_node_ids), array('node_id', 'hostname'));
+ $_hostnames = array();
+ if ($_nodes) {
+ foreach ($_nodes as $_node) {
+ $_hostnames[$_node['node_id']] = $_node['hostname'];
+ }
+ }
+
+ // Loop through tags again to display
+ foreach ($tags as $tag) {
+ $node_name = "ALL";
+ if ($tag['node_id']) {
+ $node_name = $_hostnames[$tag['node_id']];
+ }
+ $nodegroup_name = "n/a";
+ if ($tag['nodegroup_id']) {
+ $nodegroups = $api->GetNodeGroups(array('nodegroup_id' => $tag['nodegroup_id']));
+ if ($profiling) {
+ plc_debug_prof('15: nodegroup for slice tag', $nodegroup);
+ }
+
+ if ($nodegroup) {
+ $nodegroup = $nodegroups[0];
+ $nodegroup_name = $nodegroup['groupname'];
+ }
+ }
+ $table->row_start();
+ $table->cell(l_tag_obj($tag));
+ // very wide values get abbreviated
+ $table->cell(truncate_and_popup($tag['value'], $tag_value_threshold));
+ $table->cell($node_name);
+ $table->cell($nodegroup_name);
+ if ($tags_privileges) {
+ $table->cell($form->checkbox_html('slice_tag_ids[]', $tag['slice_tag_id']));
}
- }
- $table->row_start();
- $table->cell(l_tag_obj($tag));
- $table->cell($tag['value']);
- $table->cell($node_name);
- $table->cell($nodegroup_name);
- if ($tags_privileges) $table->cell ($form->checkbox_html('slice_tag_ids[]',$tag['slice_tag_id']));
- $table->row_end();
+
+ $table->row_end();
}
- }
- if ($tags_privileges) {
+}
+if ($tags_privileges) {
$table->tfoot_start();
$table->row_start();
- $table->cell($form->submit_html ("delete-slice-tags","Remove selected"),
- array('hfill'=>true,'align'=>'right'));
+ $table->cell($form->submit_html("delete-slice-tags", "Remove selected"),
+ array('hfill' => true, 'align' => 'right'));
$table->row_end();
-
+
$table->row_start();
- function tag_selector ($tag) {
- return array("display"=>$tag['tagname'],"value"=>$tag['tag_type_id']);
+ function tag_selector($tag)
+ {
+ return array("display" => $tag['tagname'], "value" => $tag['tag_type_id']);
}
- $all_tags= $api->GetTagTypes( array ("category"=>"slice*","-SORT"=>"+tagname"), array("tagname","tag_type_id"));
- $selector_tag=array_map("tag_selector",$all_tags);
-
- function node_selector($node) {
- return array("display"=>$node["hostname"],"value"=>$node['node_id']);
+ $all_tags = $api->GetTagTypes(array("category" => "*slice*", "-SORT" => "+tagname"), array("tagname", "tag_type_id"));
+ if ($profiling) {
+ plc_debug_prof('16: tagtypes', count($all_tags));
}
- $all_nodes = $api->GetNodes( array ("node_id" => $slice['node_ids']), array("hostname","node_id"));
- $selector_node=array_map("node_selector",$all_nodes);
-
- function nodegroup_selector($ng) {
- return array("display"=>$ng["groupname"],"value"=>$ng['nodegroup_id']);
+
+ $selector_tag = array_map("tag_selector", $all_tags);
+
+ function node_selector($node)
+ {
+ return array("display" => $node["hostname"], "value" => $node['node_id']);
+ }
+ $selector_node = array_map("node_selector", $slice_nodes);
+
+ function nodegroup_selector($ng)
+ {
+ return array("display" => $ng["groupname"], "value" => $ng['nodegroup_id']);
}
- $all_nodegroups = $api->GetNodeGroups( array("groupname"=>"*"), array("groupname","nodegroup_id"));
- $selector_nodegroup=array_map("nodegroup_selector",$all_nodegroups);
-
- $table->cell($form->select_html("tag_type_id",$selector_tag,array('label'=>"Choose Tag")));
- $table->cell($form->text_html("value","",array('width'=>8)));
- $table->cell($form->select_html("node_id",$selector_node,array('label'=>"All Nodes")));
- $table->cell($form->select_html("nodegroup_id",$selector_nodegroup,array('label'=>"No Nodegroup")));
- $table->cell($form->submit_html("add-slice-tag","Set Tag"),array('columns'=>2,'align'=>'left'));
+ $all_nodegroups = $api->GetNodeGroups(array("groupname" => "*"), array("groupname", "nodegroup_id"));
+ if ($profiling) {
+ plc_debug_prof('17: nodegroups', count($all_nodegroups));
+ }
+
+ $selector_nodegroup = array_map("nodegroup_selector", $all_nodegroups);
+
+ $table->cell($form->select_html("tag_type_id", $selector_tag, array('label' => "Choose Tag")));
+ $table->cell($form->text_html("value", "", array('width' => 8)));
+ $table->cell($form->select_html("node_id", $selector_node, array('label' => "All Nodes")));
+ $table->cell($form->select_html("nodegroup_id", $selector_nodegroup, array('label' => "No Nodegroup")));
+ $table->cell($form->submit_html("add-slice-tag", "Set Tag"), array('columns' => 2, 'align' => 'left'));
$table->row_end();
- }
-
- $form->end();
- $table->end();
- $toggle->end();
+}
+
+$table->end();
+$form->end();
+$toggle->end();
//}
+//////////////////////////////////////////////////////////// tab:renew
+if ($local_peer) {
+ if (!$renew_visible) {
+ renew_area($slice, $site, null);
+ }
-//////////////////////// renew slice
-if ($local_peer ) {
- if ( ! $renew_visible) renew_area ($slice,$site,false);
- }
+}
$peers->block_end($peer_id);
+if ($profiling) {
+ plc_debug_prof_end();
+}
+
// Print footer
include 'plc_footer.php';
-
-?>