X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Fconfig%2Fconfig-view.cgi;h=0f6c99232f7796da0dc5b7ce62d86edb5e427a34;hb=56a2965996454a0649d43ecbc062beda61106e21;hp=91ba33769aa7f9314b98f089479ea072b6bc19b7;hpb=e75e410d0cdc5ca62af1888c3cb75163ca22d2ad;p=freeside.git diff --git a/httemplate/config/config-view.cgi b/httemplate/config/config-view.cgi index 91ba33769..0f6c99232 100644 --- a/httemplate/config/config-view.cgi +++ b/httemplate/config/config-view.cgi @@ -1,95 +1,332 @@ -<% include("/elements/header.html",'View Configuration', menubar( 'Main Menu' => $p, - 'Edit Configuration' => 'config.cgi' ) ) %> -% my $conf = new FS::Conf; my @config_items = $conf->config_items; -% foreach my $section ( qw(required billing username password UI session -% shell BIND -% ), -% '', 'deprecated') { - - - -% foreach my $nav_section ( qw(required billing username password UI session -% shell BIND -% ), -% '', 'deprecated') { -% if ( $section eq $nav_section ) { - - [<% ucfirst($nav_section || 'unclassified') %>] -% } else { - - [<% ucfirst($nav_section || 'unclassified') %>] -% } -% } +<% include("/elements/header.html", $title, menubar(@menubar)) %> + +Click on a configuration value to change it. +

+ +% unless ( $page_agent ) { +% +% if ( $cgi->param('showagent') ) { +% $cgi->param('showagent', 0); + ( hide agent overrides ) +% $cgi->param('showagent', 1); +% } else { +% $cgi->param('showagent', 1); + ( show agent overrides ) +% $cgi->param('showagent', 0); +% } +% +% } +

+ +<% include('/elements/init_overlib.html') %> + +% if ($FS::UID::use_confcompat) { + CONFIGURATION NOT STORED IN DATABASE -- USING COMPATIBILITY MODE

+%} + +% foreach my $section (@sections) { + + + + +% foreach my $nav_section (@sections) { +% +% if ( $section eq $nav_section ) { + [<% ucfirst($nav_section || 'unclassified') %>] +% } else { + [<% ucfirst($nav_section || 'unclassified') %>] +% } +% +% }
- <% table("#cccccc", 2) %> + -% foreach my $i (grep $_->section eq $section, @config_items) { +% foreach my $i (@{ $section_items{$section} }) { +% my @types = ref($i->type) ? @{$i->type} : ($i->type); +% my( $width, $height ) = ( 522, 336 ); +% if ( grep $_ eq 'textarea', @types ) { +% #800x600 +% $width = 763; +% $height = 408; +% #1024x768 +% #$width = +% #$height = +% } +% +% my @agents = (); +% my @add_agents = (); +% if ( $page_agent ) { +% @agents = ( $page_agent ); +% } else { +% @agents = ( '' ); +% if ( $i->per_agent ) { +% foreach my $agent (@all_agents) { +% if ( defined($conf->conf( $i->key, $agent->agentnum, 1 ) ) ) { +% push @agents, $agent; +% } else { +% push @add_agents, $agent; +% } +% } +% } +% } +% +% foreach my $agent ( @agents ) { +% my $agentnum = $agent ? $agent->agentnum : ''; +% +% next if $section eq 'deprecated' && ! $conf->exists($i->key, $agentnum); +% +% my $label = $i->key; +% $label = '['. $agent->agent. "] $label" +% if $agent && $cgi->param('showagent'); +% +% #indentation :/ - + -% } + +% } # foreach my $agentnum + +% if ( @add_agents ) { + + + + + +% } #if @add_agents + +% } # foreach my $i
<% ucfirst($section || 'unclassified') %> configuration options
- <% $i->key %> - <% $i->description %> - <% include('/elements/popup_link.html', + 'action' => 'config.cgi?key='. $i->key. + ';agentnum='. $agentnum, + 'width' => $width, + 'height' => $height, + 'actionlabel' => 'Enter configuration value', + 'label' => "$label", + 'aname' => $i->key, #agentnum + # if $cgi->param('showagent')? + ) + %>: <% $i->description %> +% if ( $agent && $cgi->param('showagent') ) { +% my $confnum = $conf->conf( $i->key, $agent->agentnum, 1 )->confnum; + (delete agent override) +% } elsif ( $i->base_key +% || ( $deleteable{$i->key} && $conf->exists($i->key) ) ) { +% my $confnum = +% $agent +% ? $conf->conf( $i->key, $agent->agentnum, 1 )->confnum +% : $conf->conf( $i->key )->confnum; +% my $showagent = $cgi->param('showagent') ? '_showagent' : ''; + (delete configuration item) +% } + + -% foreach my $type ( ref($i->type) ? @{$i->type} : $i->type ) { -% my $n = 0; -% if ( $type eq '' ) { + +% my $n = 0; +% foreach my $type (@types) { + +% if ( $type eq '' ) { -% } elsif ( $type eq 'textarea' -% || $type eq 'editlist' -% || $type eq 'selectmultiple' ) { +% } elsif ( $type eq 'image' ) { + + + + - -% } elsif ( $type eq 'checkbox' ) { + +% } elsif ( $type eq 'binary' ) { + + + + + +% } elsif ( $type eq 'textarea' +% || $type eq 'editlist' +% || $type eq 'selectmultiple' ) { - + -% } elsif ( $type eq 'text' || $type eq 'select' ) { + +% } elsif ( $type eq 'checkbox' ) { - -% } elsif ( $type eq 'select-sub' ) { + + + +% } elsif ( $type eq 'select' && $i->select_hash ) { +% +% my %hash; +% if ( ref($i->select_hash) eq 'ARRAY' ) { +% tie %hash, 'Tie::IxHash', '' => '', @{ $i->select_hash }; +% } else { +% tie %hash, 'Tie::IxHash', '' => '', %{ $i->select_hash }; +% } + + + + + +% } elsif ( $type eq 'text' || $type eq 'select' ) { - -% } else { + +% } elsif ( $type eq 'select-sub' ) { + + + + + +% } else { +% } +% $n++; % } -% $n++; }
no type
+ <% $conf->exists($i->key, $agentnum) + ? '' + : 'empty' + %> +
-
-<% encode_entities(join("\n", $conf->config($i->key) ) ) %>
-
+
+ <% $conf->exists($i->key, $agentnum) + ? qq!download! + : '' + %>
+ <% $conf->exists($i->key, $agentnum) + ? qq!download! + : 'empty' + %> +
YES' : 'ff0000">NO' %> +
<% encode_entities(join("\n",
+     map { length($_) > 88 ? substr($_,0,88).'...' : $_ }
+         $conf->config($i->key, $agentnum)
+   ) )
+%>
+
- <% $conf->exists($i->key) ? $conf->config($i->key) : '' %> -
YES' : 'ff0000">NO' %>
+ <% $conf->exists($i->key, $agentnum) ? $hash{ $conf->config($i->key, $agentnum) } : '' %> +
- <% $conf->config($i->key) %>: - <% &{ $i->option_sub }( $conf->config($i->key) ) %> + + <% $conf->exists($i->key, $agentnum) ? $conf->config($i->key, $agentnum) : '' %>
+ <% $conf->config($i->key, $agentnum) %>: + <% &{ $i->option_sub }( $conf->config($i->key, $agentnum) ) %> +
unknown type <% $type %>
+
+ Add <% $i->key %> override for + <% include('/elements/select-agent.html', + 'agents' => \@add_agents, + 'empty_label' => 'Select agent', + 'onchange' => "agent_changed", + 'id' => 'agent_'. $i->key, + ) + %> + agent + +% my $agent_el = "document.getElementById('agent_". $i->key. "')"; + $width, + 'height' => $height, + 'actionlabel' => 'Enter configuration value', + ) + %>" + > +
+


-% } +% } # foreach my $nav_section + + <%init> + die "access denied" unless $FS::CurrentUser::CurrentUser->access_right('Configuration'); + +my $page_agent = ''; +my $title; +my @menubar = (); +if ($cgi->param('agentnum') =~ /^(\d+)$/) { + my $page_agentnum = $1; + $page_agent = qsearchs('agent', { 'agentnum' => $page_agentnum } ); + die "Agent $page_agentnum not found!" unless $page_agent; + + push @menubar, 'View all agents' => $p.'browse/agent.cgi'; + $title = 'Agent Configuration for '. $page_agent->agent; +} else { + $title = 'Global Configuration'; +} + +my $conf = new FS::Conf; + +my @config_items = grep { $page_agent ? $_->per_agent : 1 } + grep { $page_agent ? 1 : !$_->agentonly } + $conf->config_items; + +my @deleteable = qw( invoice_latexreturnaddress invoice_htmlreturnaddress ); +my %deleteable = map { $_ => 1 } @deleteable; + +my @sections = qw(required billing username password UI session shell BIND ); +push @sections, '', 'deprecated'; + +my %section_items = (); +foreach my $section (@sections) { + $section_items{$section} = [ grep $_->section eq $section, @config_items ]; +} + +@sections = grep scalar( @{ $section_items{$_} } ), @sections; + +my @all_agents = (); +if ( $cgi->param('showagent') ) { + @all_agents = qsearch('agent', { 'disabled' => '' } ); +} +warn 'all agents: '. join('-', @all_agents); +