Merge branch 'master' into og-newnetmap

This commit is contained in:
Oliver Gorwits
2017-12-12 23:38:00 +00:00
11 changed files with 109 additions and 107 deletions

View File

@@ -11,8 +11,6 @@ use HTML::Entities (); # to ensure dependency is met
use URI::QueryParam (); # part of URI, to add helper methods use URI::QueryParam (); # part of URI, to add helper methods
use Path::Class 'dir'; use Path::Class 'dir';
use Module::Load (); use Module::Load ();
use Storable 'dclone';
use Scope::Guard 'guard';
use App::Netdisco::Util::Web 'interval_to_daterange'; use App::Netdisco::Util::Web 'interval_to_daterange';
use App::Netdisco::Web::AuthN; use App::Netdisco::Web::AuthN;
@@ -73,24 +71,80 @@ Dancer::Session::Cookie::init(session);
# workaround for https://github.com/PerlDancer/Dancer/issues/935 # workaround for https://github.com/PerlDancer/Dancer/issues/935
hook after_error_render => sub { setting('layout' => 'main') }; hook after_error_render => sub { setting('layout' => 'main') };
# build list of port detail columns
{
my @port_columns =
sort { $a->{idx} <=> $b->{idx} }
map {{ name => $_, %{ setting('sidebar_defaults')->{'device_ports'}->{$_} } }}
grep { $_ =~ m/^c_/ } keys %{ setting('sidebar_defaults')->{'device_ports'} };
splice @port_columns, setting('device_port_col_idx_left'), 0,
grep {$_->{position} eq 'left'} @{ setting('_extra_device_port_cols') };
splice @port_columns, setting('device_port_col_idx_mid'), 0,
grep {$_->{position} eq 'mid'} @{ setting('_extra_device_port_cols') };
splice @port_columns, setting('device_port_col_idx_right'), 0,
grep {$_->{position} eq 'right'} @{ setting('_extra_device_port_cols') };
set('port_columns' => \@port_columns);
# update sidebar_defaults so hooks scanning params see new plugin cols
setting('sidebar_defaults')->{'device_ports'}->{ $_->{name} } = $_
for @port_columns;
}
hook 'before' => sub { hook 'before' => sub {
my $key = request->path; my $key = request->path;
if (param('tab') and ($key !~ m/ajax/)) { if (param('tab') and ($key !~ m/ajax/)) {
$key .= ('/' . param('tab')); $key .= ('/' . param('tab'));
} }
$key =~ s|.*/(\w+)/(\w+)$|${1}_${2}|; $key =~ s|.*/(\w+)/(\w+)$|${1}_${2}|;
vars->{'sidebar_key'} = $key; var(sidebar_key => $key);
# search or report from navbar can ignore params # copy sidebar defaults into vars so we can mess about with it
return if param('firstsearch'); foreach my $sidebar (keys %{setting('sidebar_defaults')}) {
vars->{'sidebar_defaults'}->{$sidebar} = { map {
($_ => setting('sidebar_defaults')->{$sidebar}->{$_}->{'default'})
} keys %{setting('sidebar_defaults')->{$sidebar}} };
}
};
my $defaults = dclone (setting('sidebar_defaults')->{$key} or return); hook 'before_template' => sub {
push @{ vars->{'guards'} }, # search or report from navbar, or reset of sidebar, can ignore params
guard { setting('sidebar_defaults')->{$key} = $defaults }; return if param('firstsearch')
or var('sidebar_key') !~ m/^\w+_\w+$/;
# otherwise update defaults to contain the passed url params # update defaults to contain the passed url params
setting('sidebar_defaults')->{$key}->{$_}->{'default'} = param($_) # (this follows initial copy from config.yml, then cookie restore)
for keys %{ $defaults }; var('sidebar_defaults')->{var('sidebar_key')}->{$_} = param($_)
for keys %{ var('sidebar_defaults')->{var('sidebar_key')} || {} };
};
hook 'before_template' => sub {
my $tokens = shift;
return unless var('sidebar_key') =~ m/^\w+_\w+$/;
# linked searches will use these default url path params
foreach my $sidebar_key (keys %{ var('sidebar_defaults') }) {
my ($mode, $report) = ($sidebar_key =~ m/(\w+)_(\w+)/);
if ($mode =~ m/^(?:search|device)$/) {
$tokens->{$sidebar_key} = uri_for("/$mode", {tab => $report});
}
elsif ($mode =~ m/^report$/) {
$tokens->{$sidebar_key} = uri_for("/$mode/$report");
}
foreach my $col (keys %{ var('sidebar_defaults')->{$sidebar_key} }) {
$tokens->{$sidebar_key}->query_param($col,
var('sidebar_defaults')->{$sidebar_key}->{$col});
}
# fix Plugin Template Variables to be only path+query
$tokens->{$sidebar_key} = $tokens->{$sidebar_key}->path_query;
}
# helper from NetAddr::MAC for the MAC formatting
$tokens->{mac_format_call} = 'as_'. lc(param('mac_format'))
if param('mac_format');
}; };
# this hook should be loaded _after_ all plugins # this hook should be loaded _after_ all plugins
@@ -114,35 +168,6 @@ hook 'before_template' => sub {
$tokens->{table_showrecordsmenu} = $tokens->{table_showrecordsmenu} =
to_json( setting('table_showrecordsmenu') ); to_json( setting('table_showrecordsmenu') );
# linked searches will use these defaults in their sidebars
foreach my $sidebar_key (keys %{ setting('sidebar_defaults') }) {
my ($mode, $report) = ($sidebar_key =~ m/(\w+)_(\w+)/);
if ($mode =~ m/^(?:search|device)$/) {
$tokens->{$sidebar_key} = uri_for("/$mode", {tab => $report});
}
elsif ($mode =~ m/^report$/) {
$tokens->{$sidebar_key} = uri_for("/$mode/$report");
}
if (defined setting('sidebar_defaults')->{$sidebar_key}) {
foreach my $col (keys %{ setting('sidebar_defaults')->{$sidebar_key} }) {
$tokens->{$sidebar_key}->query_param($col,
setting('sidebar_defaults')->{$sidebar_key}->{$col}->{'default'});
# used by the sidebar templates when first rendering
$tokens->{"${sidebar_key}_defaults"}->{$col}
= setting('sidebar_defaults')->{$sidebar_key}->{$col}->{'default'};
}
}
# fix Plugin Template Variables to be only path+query
$tokens->{$sidebar_key} = $tokens->{$sidebar_key}->path_query;
}
# helper from NetAddr::MAC for the MAC formatting
$tokens->{mac_format_call} = 'as_'. lc(param('mac_format'))
if param('mac_format');
# allow very long lists of ports # allow very long lists of ports
$Template::Directive::WHILE_MAX = 10_000; $Template::Directive::WHILE_MAX = 10_000;

View File

@@ -6,66 +6,41 @@ use Dancer::Plugin::DBIC;
use Dancer::Plugin::Auth::Extensible; use Dancer::Plugin::Auth::Extensible;
use URI (); use URI ();
use Storable 'dclone';
use Scope::Guard 'guard';
use URL::Encode 'url_params_mixed'; use URL::Encode 'url_params_mixed';
hook 'before' => sub { # build view settings for port connected nodes and devices
set('connected_properties' => [
sort { $a->{idx} <=> $b->{idx} }
map {{ name => $_, %{ setting('sidebar_defaults')->{'device_ports'}->{$_} } }}
grep { $_ =~ m/^n_/ } keys %{ setting('sidebar_defaults')->{'device_ports'} }
]);
# build list of port detail columns hook 'before_template' => sub {
my @port_columns = my $defaults = var('sidebar_defaults')->{'device_ports'}
sort { $a->{idx} <=> $b->{idx} } or return;
map {{ name => $_, %{ setting('sidebar_defaults')->{'device_ports'}->{$_} } }}
grep { $_ =~ m/^c_/ } keys %{ setting('sidebar_defaults')->{'device_ports'} };
# this could be done at app startup?
splice @port_columns, setting('device_port_col_idx_left'), 0,
grep {$_->{position} eq 'left'} @{ setting('_extra_device_port_cols') };
splice @port_columns, setting('device_port_col_idx_mid'), 0,
grep {$_->{position} eq 'mid'} @{ setting('_extra_device_port_cols') };
splice @port_columns, setting('device_port_col_idx_right'), 0,
grep {$_->{position} eq 'right'} @{ setting('_extra_device_port_cols') };
# update sidebar_defaults so code scanning params sees new plugin cols
setting('sidebar_defaults')->{'device_ports'}->{ $_->{name} } = $_
for @port_columns;
var('port_columns' => \@port_columns);
# build view settings for port connected nodes and devices
var('connected_properties' => [
sort { $a->{idx} <=> $b->{idx} }
map {{ name => $_, %{ setting('sidebar_defaults')->{'device_ports'}->{$_} } }}
grep { $_ =~ m/^n_/ } keys %{ setting('sidebar_defaults')->{'device_ports'} }
]);
# override ports form defaults with cookie settings # override ports form defaults with cookie settings
# always do this so that embedded links to device ports page have user prefs
if (param('reset')) { if (param('reset')) {
cookie('nd_ports-form' => '', expires => '-1 day'); cookie('nd_ports-form' => '', expires => '-1 day');
} }
elsif (my $cookie = cookie('nd_ports-form')) { elsif (my $cookie = cookie('nd_ports-form')) {
my $cdata = url_params_mixed($cookie); my $cdata = url_params_mixed($cookie);
my $defaults = eval { dclone setting('sidebar_defaults')->{'device_ports'} };
if ($cdata and (ref {} eq ref $cdata) and $defaults) {
push @{ vars->{'guards'} },
guard { setting('sidebar_defaults')->{'device_ports'} = $defaults };
if ($cdata and (ref {} eq ref $cdata)) {
foreach my $key (keys %{ $defaults }) { foreach my $key (keys %{ $defaults }) {
setting('sidebar_defaults')->{'device_ports'}->{$key}->{'default'} $defaults->{$key} = $cdata->{$key};
= $cdata->{$key};
} }
} }
} }
};
hook 'before_template' => sub {
return if param('reset') return if param('reset')
or not var('sidebar_key') or (var('sidebar_key') ne 'device_ports'); or not var('sidebar_key') or (var('sidebar_key') ne 'device_ports');
# update cookie from params we just recieved in form submit
my $uri = URI->new(); my $uri = URI->new();
foreach my $key (keys %{ setting('sidebar_defaults')->{'device_ports'} }) { foreach my $key (keys %{ $defaults }) {
$uri->query_param($key => param($key)) if exists params->{$key}; $uri->query_param($key => param($key));
} }
cookie('nd_ports-form' => $uri->query(), expires => '365 days'); cookie('nd_ports-form' => $uri->query(), expires => '365 days');
}; };

View File

@@ -6,6 +6,7 @@ use Dancer::Plugin;
use App::Netdisco::Util::Permission qw/check_acl_no check_acl_only/; use App::Netdisco::Util::Permission qw/check_acl_no check_acl_only/;
use aliased 'App::Netdisco::Worker::Status'; use aliased 'App::Netdisco::Worker::Status';
use Scope::Guard 'guard'; use Scope::Guard 'guard';
use Storable 'dclone';
register 'register_worker' => sub { register 'register_worker' => sub {
my ($self, $first, $second) = plugin_args(@_); my ($self, $first, $second) = plugin_args(@_);
@@ -47,7 +48,7 @@ register 'register_worker' => sub {
} }
my @newuserconf = (); my @newuserconf = ();
my @userconf = @{ setting('device_auth') || [] }; my @userconf = @{ dclone (setting('device_auth') || []) };
# worker might be vendor/platform specific # worker might be vendor/platform specific
if (ref $job->device) { if (ref $job->device) {
@@ -67,7 +68,7 @@ register 'register_worker' => sub {
next if exists $stanza->{action} next if exists $stanza->{action}
and not _find_matchaction($workerconf, lc($stanza->{action})); and not _find_matchaction($workerconf, lc($stanza->{action}));
push @newuserconf, $stanza; push @newuserconf, dclone $stanza;
} }
# per-device action but no device creds available # per-device action but no device creds available

View File

@@ -8,6 +8,7 @@ use aliased 'App::Netdisco::Worker::Status';
use Try::Tiny; use Try::Tiny;
use Module::Load (); use Module::Load ();
use Scope::Guard 'guard'; use Scope::Guard 'guard';
use Storable 'dclone';
use Moo::Role; use Moo::Role;
use namespace::clean; use namespace::clean;
@@ -31,7 +32,7 @@ sub run {
my $statusguard = guard { $job->finalise_status }; my $statusguard = guard { $job->finalise_status };
my @newuserconf = (); my @newuserconf = ();
my @userconf = @{ setting('device_auth') || [] }; my @userconf = @{ dclone (setting('device_auth') || []) };
# reduce device_auth by only/no # reduce device_auth by only/no
if (ref $job->device) { if (ref $job->device) {
@@ -42,7 +43,7 @@ sub run {
next if $no and check_acl_no($job->device, $no); next if $no and check_acl_no($job->device, $no);
next if $only and not check_acl_only($job->device, $only); next if $only and not check_acl_only($job->device, $only);
push @newuserconf, $stanza; push @newuserconf, dclone $stanza;
} }
# per-device action but no device creds available # per-device action but no device creds available

View File

@@ -3,7 +3,7 @@
<thead> <thead>
<tr> <tr>
<th></th> <th></th>
[% FOREACH item IN vars.port_columns %] [% FOREACH item IN settings.port_columns %]
[% NEXT IF item.name == 'c_admin' %] [% NEXT IF item.name == 'c_admin' %]
[% NEXT IF item.name == 'c_nodes' AND params.c_nodes AND params.c_neighbors %] [% NEXT IF item.name == 'c_nodes' AND params.c_nodes AND params.c_neighbors %]
[% NEXT UNLESS params.${item.name} %] [% NEXT UNLESS params.${item.name} %]

View File

@@ -2,7 +2,7 @@
[% SET headers = [] %] [% SET headers = [] %]
[% SET c_nodes_pos = -1 %] [% SET c_nodes_pos = -1 %]
[% FOREACH item IN vars.port_columns %] [% FOREACH item IN settings.port_columns %]
[% NEXT IF item.name == 'c_admin' %] [% NEXT IF item.name == 'c_admin' %]
[% NEXT UNLESS params.${item.name} %] [% NEXT UNLESS params.${item.name} %]

View File

@@ -57,12 +57,12 @@
</label></span> </label></span>
<div id="nd_columns" class="collapse in"> <div id="nd_columns" class="collapse in">
<ul class="nd_inputs-list unstyled"> <ul class="nd_inputs-list unstyled">
[% FOREACH item IN vars.port_columns %] [% FOREACH item IN settings.port_columns %]
[% NEXT IF item.name == 'c_admin' AND NOT user_has_role('port_control') %] [% NEXT IF item.name == 'c_admin' AND NOT user_has_role('port_control') %]
<li> <li>
<label class="checkbox"> <label class="checkbox">
<input type="checkbox" id="[% item.name | html_entity %]" <input type="checkbox" id="[% item.name | html_entity %]"
name="[% item.name | html_entity %]"[% ' checked="checked"' IF item.default %] /> name="[% item.name | html_entity %]"[% ' checked="checked"' IF vars.sidebar_defaults.device_ports.${item.name} %] />
[% IF item.name == 'c_admin' %] [% IF item.name == 'c_admin' %]
<span class="label label-info">[% item.label | html_entity %]</span> <span class="label label-info">[% item.label | html_entity %]</span>
[% ELSE %] [% ELSE %]
@@ -85,12 +85,12 @@
<em class="muted">Mark as Free if Down for:</em><br/> <em class="muted">Mark as Free if Down for:</em><br/>
<select id="nd_days-select" name="age_num"> <select id="nd_days-select" name="age_num">
[% FOREACH count IN [1..32] %] [% FOREACH count IN [1..32] %]
<option[% ' selected="selected"' IF device_ports_defaults.age_num == count %]>[% count %]</option> <option[% ' selected="selected"' IF vars.sidebar_defaults.device_ports.age_num == count %]>[% count %]</option>
[% END %] [% END %]
</select> </select>
<select id="nd_age-select" name="age_unit"> <select id="nd_age-select" name="age_unit">
[% FOREACH unit IN [ 'days', 'weeks', 'months', 'years' ] %] [% FOREACH unit IN [ 'days', 'weeks', 'months', 'years' ] %]
<option[% ' selected="selected"' IF device_ports_defaults.age_unit == unit %]>[% unit %]</option> <option[% ' selected="selected"' IF vars.sidebar_defaults.device_ports.age_unit == unit %]>[% unit %]</option>
[% END %] [% END %]
</select> </select>
</li> </li>
@@ -126,15 +126,15 @@
<em class="muted">MAC address format:</em><br/> <em class="muted">MAC address format:</em><br/>
<select id="nd_mac-format" name="mac_format"> <select id="nd_mac-format" name="mac_format">
[% FOREACH format IN [ 'IEEE', 'Cisco', 'Microsoft', 'Sun' ] %] [% FOREACH format IN [ 'IEEE', 'Cisco', 'Microsoft', 'Sun' ] %]
<option[% ' selected="selected"' IF device_ports_defaults.mac_format == format %]>[% format %]</option> <option[% ' selected="selected"' IF vars.sidebar_defaults.device_ports.mac_format == format %]>[% format %]</option>
[% END %] [% END %]
</select> </select>
</li> </li>
[% FOREACH item IN vars.connected_properties %] [% FOREACH item IN settings.connected_properties %]
<li> <li>
<label class="checkbox"> <label class="checkbox">
<input type="checkbox" id="[% item.name | html_entity %]" <input type="checkbox" id="[% item.name | html_entity %]"
name="[% item.name | html_entity %]"[% ' checked="checked"' IF item.default %] /> name="[% item.name | html_entity %]"[% ' checked="checked"' IF vars.sidebar_defaults.device_ports.${item.name} %] />
[% item.label | html_entity %] [% item.label | html_entity %]
</label> </label>
</li> </li>

View File

@@ -58,7 +58,7 @@
<div class="clearfix input-prepend"> <div class="clearfix input-prepend">
<label class="add-on"> <label class="add-on">
<input type="checkbox" id="fruonly" <input type="checkbox" id="fruonly"
name="fruonly"[% ' checked="checked"' IF report_moduleinventory_defaults.fruonly %]/> name="fruonly"[% ' checked="checked"' IF vars.sidebar_defaults.report_moduleinventory.fruonly %]/>
</label> </label>
<label class="nd_checkboxlabel" for="fruonly"> <label class="nd_checkboxlabel" for="fruonly">
<span class="nd_searchcheckbox uneditable-input">FRU Only</span> <span class="nd_searchcheckbox uneditable-input">FRU Only</span>
@@ -67,7 +67,7 @@
<div class="clearfix input-prepend"> <div class="clearfix input-prepend">
<label class="add-on"> <label class="add-on">
<input type="checkbox" id="matchall" <input type="checkbox" id="matchall"
name="matchall"[% ' checked="checked"' IF report_moduleinventory_defaults.matchall %]/> name="matchall"[% ' checked="checked"' IF vars.sidebar_defaults.report_moduleinventory.matchall %]/>
</label> </label>
<label class="nd_checkboxlabel" for="matchall"> <label class="nd_checkboxlabel" for="matchall">
<span class="nd_searchcheckbox uneditable-input">Match All Options</span> <span class="nd_searchcheckbox uneditable-input">Match All Options</span>

View File

@@ -89,7 +89,7 @@
<div class="clearfix input-prepend"> <div class="clearfix input-prepend">
<label class="add-on"> <label class="add-on">
<input type="checkbox" id="matchall" <input type="checkbox" id="matchall"
name="matchall"[% ' checked="checked"' IF search_device_defaults.matchall %]/> name="matchall"[% ' checked="checked"' IF vars.sidebar_defaults.search_device.matchall %]/>
</label> </label>
<label class="nd_checkboxlabel" for="matchall"> <label class="nd_checkboxlabel" for="matchall">
<span class="nd_searchcheckbox uneditable-input">Match All Options</span> <span class="nd_searchcheckbox uneditable-input">Match All Options</span>

View File

@@ -4,7 +4,7 @@
<div class="clearfix input-prepend"> <div class="clearfix input-prepend">
<label class="add-on"> <label class="add-on">
<input type="checkbox" id="stamps" <input type="checkbox" id="stamps"
name="stamps"[% ' checked="checked"' IF search_node_defaults.stamps %]/> name="stamps"[% ' checked="checked"' IF vars.sidebar_defaults.search_node.stamps %]/>
</label> </label>
<label class="nd_checkboxlabel" for="stamps"> <label class="nd_checkboxlabel" for="stamps">
<span class="nd_searchcheckbox uneditable-input">Time Stamps</span> <span class="nd_searchcheckbox uneditable-input">Time Stamps</span>
@@ -13,7 +13,7 @@
<div class="clearfix input-prepend"> <div class="clearfix input-prepend">
<label class="add-on"> <label class="add-on">
<input type="checkbox" id="deviceports" <input type="checkbox" id="deviceports"
name="deviceports"[% ' checked="checked"' IF search_node_defaults.deviceports %]/> name="deviceports"[% ' checked="checked"' IF vars.sidebar_defaults.search_node.deviceports %]/>
</label> </label>
<label class="nd_checkboxlabel" for="deviceports"> <label class="nd_checkboxlabel" for="deviceports">
<span class="nd_searchcheckbox uneditable-input">Device Ports</span> <span class="nd_searchcheckbox uneditable-input">Device Ports</span>
@@ -22,7 +22,7 @@
<div class="clearfix input-prepend"> <div class="clearfix input-prepend">
<label class="add-on"> <label class="add-on">
<input type="checkbox" id="show_vendor" <input type="checkbox" id="show_vendor"
name="show_vendor"[% ' checked="checked"' IF search_node_defaults.show_vendor %]/> name="show_vendor"[% ' checked="checked"' IF vars.sidebar_defaults.search_node.show_vendor %]/>
</label> </label>
<label class="nd_checkboxlabel" for="show_vendor"> <label class="nd_checkboxlabel" for="show_vendor">
<span class="nd_searchcheckbox uneditable-input">Vendor</span> <span class="nd_searchcheckbox uneditable-input">Vendor</span>
@@ -31,7 +31,7 @@
<div class="clearfix input-prepend"> <div class="clearfix input-prepend">
<label class="add-on"> <label class="add-on">
<input type="checkbox" id="archived" <input type="checkbox" id="archived"
name="archived"[% ' checked="checked"' IF search_node_defaults.archived %]/> name="archived"[% ' checked="checked"' IF vars.sidebar_defaults.search_node.archived %]/>
</label> </label>
<label class="nd_checkboxlabel" for="archived"> <label class="nd_checkboxlabel" for="archived">
<span class="nd_searchcheckbox uneditable-input"> <span class="nd_searchcheckbox uneditable-input">
@@ -41,7 +41,7 @@
<div class="clearfix input-prepend"> <div class="clearfix input-prepend">
<label class="add-on nd_sidebar-legend"> <label class="add-on nd_sidebar-legend">
<input type="checkbox" id="node_partial" <input type="checkbox" id="node_partial"
name="partial"[% ' checked="checked"' IF search_node_defaults.partial %]/> name="partial"[% ' checked="checked"' IF vars.sidebar_defaults.search_node.partial %]/>
</label> </label>
<label class="nd_checkboxlabel" for="node_partial"> <label class="nd_checkboxlabel" for="node_partial">
<span class="nd_searchcheckbox uneditable-input">Partial Match</span> <span class="nd_searchcheckbox uneditable-input">Partial Match</span>
@@ -52,20 +52,20 @@
<div class="clearfix input-prepend"> <div class="clearfix input-prepend">
<label class="add-on"> <label class="add-on">
<input type="checkbox" id="age_invert" <input type="checkbox" id="age_invert"
name="age_invert"[% ' checked="checked"' IF search_node_defaults.age_invert %]/> name="age_invert"[% ' checked="checked"' IF vars.sidebar_defaults.search_node.age_invert %]/>
</label> </label>
<label class="nd_checkboxlabel" for="age_invert"> <label class="nd_checkboxlabel" for="age_invert">
<span class="nd_searchcheckbox uneditable-input">Not within...</span> <span class="nd_searchcheckbox uneditable-input">Not within...</span>
</label> </label>
</div> </div>
<input class="nd_side-input" id="daterange" <input class="nd_side-input" id="daterange"
type="text" name="daterange" value="[% search_node_defaults.daterange | html_entity %]"/> type="text" name="daterange" value="[% vars.sidebar_defaults.search_node.daterange | html_entity %]"/>
</div> </div>
<div class="clearfix"> <div class="clearfix">
<em class="muted">MAC address format:</em><br/> <em class="muted">MAC address format:</em><br/>
<select id="nd_node-mac-format" name="mac_format"> <select id="nd_node-mac-format" name="mac_format">
[% FOREACH format IN [ 'IEEE', 'Cisco', 'Microsoft', 'Sun' ] %] [% FOREACH format IN [ 'IEEE', 'Cisco', 'Microsoft', 'Sun' ] %]
<option[% ' selected="selected"' IF search_node_defaults.mac_format == format %]>[% format %]</option> <option[% ' selected="selected"' IF vars.sidebar_defaults.search_node.mac_format == format %]>[% format %]</option>
[% END %] [% END %]
</select> </select>
</div> </div>

View File

@@ -4,7 +4,7 @@
<div class="clearfix input-prepend"> <div class="clearfix input-prepend">
<label class="add-on"> <label class="add-on">
<input type="checkbox" id="port_partial" <input type="checkbox" id="port_partial"
name="partial"[% ' checked="checked"' IF search_port_defaults.partial %]/> name="partial"[% ' checked="checked"' IF vars.sidebar_defaults.search_port.partial %]/>
</label> </label>
<label class="nd_checkboxlabel" for="port_partial"> <label class="nd_checkboxlabel" for="port_partial">
<span class="nd_searchcheckbox uneditable-input">Partial Match</span> <span class="nd_searchcheckbox uneditable-input">Partial Match</span>
@@ -13,7 +13,7 @@
<div class="clearfix input-prepend"> <div class="clearfix input-prepend">
<label class="add-on"> <label class="add-on">
<input type="checkbox" id="port_uplink" <input type="checkbox" id="port_uplink"
name="uplink"[% ' checked="checked"' IF search_port_defaults.uplink %]/> name="uplink"[% ' checked="checked"' IF vars.sidebar_defaults.search_port.uplink %]/>
</label> </label>
<label class="nd_checkboxlabel" for="port_uplink"> <label class="nd_checkboxlabel" for="port_uplink">
<span class="nd_searchcheckbox uneditable-input">Uplinks</span> <span class="nd_searchcheckbox uneditable-input">Uplinks</span>
@@ -22,7 +22,7 @@
<div class="clearfix input-prepend"> <div class="clearfix input-prepend">
<label class="add-on"> <label class="add-on">
<input type="checkbox" id="port_ethernet" <input type="checkbox" id="port_ethernet"
name="ethernet"[% ' checked="checked"' IF search_port_defaults.ethernet %]/> name="ethernet"[% ' checked="checked"' IF vars.sidebar_defaults.search_port.ethernet %]/>
</label> </label>
<label class="nd_checkboxlabel" for="port_ethernet"> <label class="nd_checkboxlabel" for="port_ethernet">
<span class="nd_searchcheckbox uneditable-input">Ethernet Only</span> <span class="nd_searchcheckbox uneditable-input">Ethernet Only</span>