summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorivan <ivan>2002-03-18 09:10:12 +0000
committerivan <ivan>2002-03-18 09:10:12 +0000
commitdaac302e231e2e09b84e771c0413b0f2119c52e8 (patch)
treebbe52639e866c9016ebe2d342308ee92de2532ab
parent697dfd9ac2dfa36aa244e6d2d9f2e8f8a364a120 (diff)
new config value `defaultrecords', documentation, javascript config file editor
-rw-r--r--FS/FS/Conf.pm22
-rw-r--r--FS/FS/svc_domain.pm85
-rw-r--r--README.1.4.0pre122
-rw-r--r--httemplate/config/config-process.cgi6
-rw-r--r--httemplate/config/config-view.cgi4
-rw-r--r--httemplate/config/config.cgi51
-rw-r--r--httemplate/docs/upgrade8.html3
7 files changed, 81 insertions, 92 deletions
diff --git a/FS/FS/Conf.pm b/FS/FS/Conf.pm
index 5dba387fe..18725ced2 100644
--- a/FS/FS/Conf.pm
+++ b/FS/FS/Conf.pm
@@ -437,28 +437,40 @@ httemplate/docs/config.html
{
'key' => 'mxmachines',
- 'section' => 'BIND',
+ 'section' => 'deprecated',
'description' => 'MX entries for new domains, weight and machine, one per line, with trailing `.\'',
'type' => 'textarea',
},
{
'key' => 'nsmachines',
- 'section' => 'BIND',
+ 'section' => 'deprecated',
'description' => 'NS nameservers for new domains, one per line, with trailing `.\'',
'type' => 'textarea',
},
{
- 'key' => 'arecords',
+ 'key' => 'defaultrecords',
'section' => 'BIND',
- 'description' => 'A list of tab seperated A records to add automatically when creating a domain',
+ 'description' => 'DNS entries add automatically when creating a domain',
+ 'type' => 'editlist',
+ 'editlist_parts' => [ { type=>'text' },
+ { type=>'immutable', value=>'IN' },
+ { type=>'select',
+ select_enum=>{ map { $_=>$_ } qw(A CNAME MX NS)} },
+ { type=> 'text' }, ],
+ },
+
+ {
+ 'key' => 'arecords',
+ 'section' => 'deprecated',
+ 'description' => 'A list of tab seperated CNAME records to add automatically when creating a domain',
'type' => 'textarea',
},
{
'key' => 'cnamerecords',
- 'section' => 'BIND',
+ 'section' => 'deprecated',
'description' => 'A list of tab seperated CNAME records to add automatically when creating a domain',
'type' => 'textarea',
},
diff --git a/FS/FS/svc_domain.pm b/FS/FS/svc_domain.pm
index 1e16ba87f..d01a403d1 100644
--- a/FS/FS/svc_domain.pm
+++ b/FS/FS/svc_domain.pm
@@ -2,8 +2,8 @@ package FS::svc_domain;
use strict;
use vars qw( @ISA $whois_hack $conf $smtpmachine
- @mxmachines @nsmachines $soadefaultttl $soaemail $soaexpire $soamachine
- $soarefresh $soaretry $qshellmachine $nossh_hack %arecords %cnamerecords
+ @defaultrecords $soadefaultttl $soaemail $soaexpire $soamachine
+ $soarefresh $soaretry $qshellmachine $nossh_hack
);
use Carp;
use Mail::Internet;
@@ -29,10 +29,7 @@ $FS::UID::callback{'FS::domain'} = sub {
$smtpmachine = $conf->config('smtpmachine');
- %arecords = map { split /\t/ } $conf->config('arecords');
- %cnamerecords = map { split /\t/ } $conf->config('cnamerecords');
- @mxmachines = $conf->config('mxmachines');
- @nsmachines = $conf->config('nsmachines');
+ @defaultrecords = $conf->config('defaultrecords');
$soadefaultttl = $conf->config('soadefaultttl');
$soaemail = $conf->config('soaemail');
$soaexpire = $conf->config('soaexpire');
@@ -119,15 +116,9 @@ in the same package, it is automatically used. Otherwise an error is returned.
If any I<soamachine> configuration file exists, an SOA record is added to
the domain_record table (see <FS::domain_record>).
-If any machines are defined in the I<nsmachines> configuration file, NS
-records are added to the domain_record table (see L<FS::domain_record>).
-
-If any machines are defined in the I<mxmachines> configuration file, MX
-records are added to the domain_record table (see L<FS::domain_record>).
-
-If the I<arecords> configuration file exits, A records are added to the
-domain_record table. The I<cnamerecords> file does the same thing for
-CNAME records.
+If any records are defined in the I<defaultrecords> configuration file,
+appropriate records are added to the domain_record table (see
+L<FS::domain_record>).
If a machine is defined in the I<shellmachine> configuration value, the
I<qmailmachines> configuration file exists, and the I<catchall> field points
@@ -200,63 +191,19 @@ sub insert {
return "couldn't insert SOA record for new domain: $error";
}
- foreach my $nsmachine ( @nsmachines ) {
- my $ns = new FS::domain_record {
- 'svcnum' => $self->svcnum,
- 'reczone' => '@',
- 'recaf' => 'IN',
- 'rectype' => 'NS',
- 'recdata' => $nsmachine,
- };
- my $error = $ns->insert;
- if ( $error ) {
- $dbh->rollback if $oldAutoCommit;
- return "couldn't insert NS record for new domain: $error";
- }
- }
-
- foreach my $mxmachine ( @mxmachines ) {
- my $mx = new FS::domain_record {
- 'svcnum' => $self->svcnum,
- 'reczone' => '@',
- 'recaf' => 'IN',
- 'rectype' => 'MX',
- 'recdata' => $mxmachine,
- };
- my $error = $mx->insert;
- if ( $error ) {
- $dbh->rollback if $oldAutoCommit;
- return "couldn't insert MX record for new domain: $error";
- }
- }
-
- foreach my $arecord ( keys %arecords ) {
- my $arec = new FS::domain_record {
- 'svcnum' => $self->svcnum,
- 'reczone' => $arecord,
- 'recaf' => 'IN',
- 'rectype' => 'A',
- 'recdata' => $arecords{$arecord},
- };
- my $error = $arec->insert;
- if ( $error ) {
- $dbh->rollback if $oldAutoCommit;
- return "WARNING: couldn't insert A record for new domain: $error";
- }
- }
-
- foreach my $cnamerecord ( keys %cnamerecords ) {
- my $cnamerec = new FS::domain_record {
+ foreach my $record ( @defaultrecords ) {
+ my($zone,$af,$type,$data) = split(/\s+/,$record,4);
+ my $record = new FS::domain_record {
'svcnum' => $self->svcnum,
- 'reczone' => $cnamerecord,
- 'recaf' => 'IN',
- 'rectype' => 'CNAME',
- 'recdata' => $cnamerecords{$cnamerecord},
+ 'reczone' => $zone,
+ 'recaf' => $af,
+ 'rectype' => $type,
+ 'recdata' => $data,
};
- my $error = $cnamerec->insert;
+ my $error = $record->insert;
if ( $error ) {
$dbh->rollback if $oldAutoCommit;
- return "WARNING: couldn't insert CNAME record for new domain: $error";
+ return "couldn't insert record for new domain: $error";
}
}
@@ -460,7 +407,7 @@ sub submit_internic {
=head1 VERSION
-$Id: svc_domain.pm,v 1.25 2002-03-09 10:19:38 khoff Exp $
+$Id: svc_domain.pm,v 1.26 2002-03-18 09:10:12 ivan Exp $
=head1 BUGS
diff --git a/README.1.4.0pre12 b/README.1.4.0pre12
index 824b7fd86..c801a2604 100644
--- a/README.1.4.0pre12
+++ b/README.1.4.0pre12
@@ -25,3 +25,5 @@ Arrange for freeside-expiration-alerter to be run daily, if desired.
Restart Apache and freeside-queued
+the mxmachines, nsmachines, arecords and cnamerecords configuration values have been deprecated. Use the defaultrecords configuration value instead.
+
diff --git a/httemplate/config/config-process.cgi b/httemplate/config/config-process.cgi
index a296abfe4..38d9af0db 100644
--- a/httemplate/config/config-process.cgi
+++ b/httemplate/config/config-process.cgi
@@ -32,6 +32,12 @@
} else {
$conf->delete($i->key);
}
+ } elsif ( $type eq 'editlist' || $type eq 'selectmultiple' ) {
+ if ( scalar(@{[ $cgi->param($i->key. $n) ]}) ) {
+ $conf->set($i->key, join("\n", $cgi->param($i->key. $n) ));
+ } else {
+ $conf->delete($i->key);
+ }
} else {
}
$n++;
diff --git a/httemplate/config/config-view.cgi b/httemplate/config/config-view.cgi
index 917cc7316..d40c4dc10 100644
--- a/httemplate/config/config-view.cgi
+++ b/httemplate/config/config-view.cgi
@@ -8,6 +8,7 @@
shell mail radius apache BIND
),
'', 'deprecated') { %>
+ <A NAME="<%= $section || 'unclassified' %>"></A>
<FONT SIZE="-2">
<% foreach my $nav_section ( qw(required billing username password UI session
shell mail radius apache BIND
@@ -16,11 +17,10 @@
<% if ( $section eq $nav_section ) { %>
[<A NAME="not<%= $nav_section || 'unclassified' %>" style="background-color: #cccccc"><%= ucfirst($nav_section || 'unclassified') %></A>]
<% } else { %>
- [<A HREF="#<%= $nav_section %>"><%= ucfirst($nav_section || 'unclassified') %></A>]
+ [<A HREF="#<%= $nav_section || 'unclassified' %>"><%= ucfirst($nav_section || 'unclassified') %></A>]
<% } %>
<% } %>
</FONT><BR>
- <A NAME="<%= $section || 'unclassified' %>"></A>
<%= table("#cccccc", 2) %>
<tr>
<th colspan="2" bgcolor="#dcdcdc">
diff --git a/httemplate/config/config.cgi b/httemplate/config/config.cgi
index 155dcfdbc..5013de0dc 100644
--- a/httemplate/config/config.cgi
+++ b/httemplate/config/config.cgi
@@ -2,25 +2,33 @@
<%= header('Edit Configuration', menubar( 'Main Menu' => $p ) ) %>
<SCRIPT>
var gSafeOnload = new Array();
+var gSafeOnsubmit = new Array();
window.onload = SafeOnload;
function SafeAddOnLoad(f) {
gSafeOnload[gSafeOnload.length] = f;
}
-function SafeOnload()
-{
+function SafeOnload() {
for (var i=0;i<gSafeOnload.length;i++)
gSafeOnload[i]();
}
+function SafeAddOnSubmit(f) {
+ gSafeOnsubmit[gSafeOnsubmit.length] = f;
+}
+function SafeOnsubmit() {
+ for (var i=0;i<gSafeOnsubmit.length;i++)
+ gSafeOnsubmit[i]();
+}
</SCRIPT>
<% my $conf = new FS::Conf; my @config_items = $conf->config_items; %>
-<form name="OneTrueForm" action="config-process.cgi" METHOD="POST">
+<form name="OneTrueForm" action="config-process.cgi" METHOD="POST" onSubmit="SafeOnsubmit()">
<% foreach my $section ( qw(required billing username password UI session
shell mail radius apache BIND
),
'', 'deprecated') { %>
+ <A NAME="<%= $section || 'unclassified' %>"></A>
<FONT SIZE="-2">
<% foreach my $nav_section ( qw(required billing username password UI session
shell mail radius apache BIND
@@ -29,11 +37,10 @@ function SafeOnload()
<% if ( $section eq $nav_section ) { %>
[<A NAME="not<%= $nav_section || 'unclassified' %>" style="background-color: #cccccc"><%= ucfirst($nav_section || 'unclassified') %></A>]
<% } else { %>
- [<A HREF="#<%= $nav_section %>"><%= ucfirst($nav_section || 'unclassified') %></A>]
+ [<A HREF="#<%= $nav_section || 'unclassified' %>"><%= ucfirst($nav_section || 'unclassified') %></A>]
<% } %>
<% } %>
</FONT><BR>
- <A NAME="<%= $section || 'unclassified' %>"></A>
<%= table("#cccccc", 2) %>
<tr>
<th colspan="2" bgcolor="#dcdcdc">
@@ -65,6 +72,7 @@ function SafeOnload()
<% if ( $conf->exists($i->key) && $conf->config($i->key) && ! grep { $conf->config($i->key) eq $_ } @{$i->select_enum}) { %>
<option value=<%= $conf->config($i->key) %> SELECTED><%= conf->config($i->key) %>
<% } %>
+ </select>
<% } elsif ( $type eq 'editlist' ) { %>
<script>
function doremove<%= $i->key. $n %>() {
@@ -77,6 +85,12 @@ function SafeOnload()
function deleteOption<%= $i->key. $n %>(object,index) {
object.options[index] = null;
}
+ function selectall<%= $i->key. $n %>() {
+ fromObject = document.OneTrueForm.<%= $i->key. $n %>;
+ for (var i=fromObject.options.length-1;i>-1;i--) {
+ fromObject.options[i].selected = true;
+ }
+ }
function doadd<%= $i->key. $n %>(object) {
var myvalue = "";
<% if ( defined($i->editlist_parts) ) { %>
@@ -105,16 +119,19 @@ function SafeOnload()
}
</script>
<select multiple size=5 name="<%= $i->key. $n %>">
- <option selected>--------------------------------</option>
+ <option selected>----------------------------------------------------------------</option>
<% foreach my $line ( $conf->config($i->key) ) { %>
- <option value="$line">$line</option>
+ <option value="<%= $line %>"><%= $line %></option>
<% } %>
</select><br>
<input type="button" value="remove selected" onClick="doremove<%= $i->key. $n %>()">
- <script>SafeAddOnLoad(doremove<%= $i->key. $n %>)</script>
+ <script>SafeAddOnLoad(doremove<%= $i->key. $n %>);
+ SafeAddOnSubmit(selectall<%= $i->key. $n %>);</script>
<br>
+ <%= itable() %><tr>
<% if ( defined $i->editlist_parts ) { %>
<% my $pnum=0; foreach my $part ( @{$i->editlist_parts} ) { %>
+ <td>
<% if ( $part->{type} eq 'text' ) { %>
<input type="text" name="add<%= $i->key. $n."_$pnum" %>">
<% } elsif ( $part->{type} eq 'immutable' ) { %>
@@ -128,11 +145,13 @@ function SafeOnload()
<% } else { %>
<font color="#ff0000">unknown type <%= $part->type %></font>
<% } %>
+ </td>
<% $pnum++; } %>
<% } else { %>
- <input type="text" name="add<%= $i->key. $n %>_0">
+ <td><input type="text" name="add<%= $i->key. $n %>_0"></td>
<% } %>
- <input type="button" value="add" onClick="doadd<%= $i->key. $n %>(this.form)">
+ <td><input type="button" value="add" onClick="doadd<%= $i->key. $n %>(this.form)"></td>
+ </tr></table>
<% } else { %>
<font color="#ff0000">unknown type <%= $type %></font>
<% } %>
@@ -143,13 +162,15 @@ function SafeOnload()
</a></td>
</tr>
<% } %>
- </table><br><br>
-<% } %>
+ </table><br>
-You may need to restart Apache and/or freeside-queued for configuration
-changes to take effect.<BR>
+ You may need to restart Apache and/or freeside-queued for configuration
+ changes to take effect.<br>
+
+ <input type="submit" value="Apply changes"><br><br>
+
+<% } %>
-<input type="submit" value="Apply changes">
</form>
</body></html>
diff --git a/httemplate/docs/upgrade8.html b/httemplate/docs/upgrade8.html
index 2640be419..25e766b1e 100644
--- a/httemplate/docs/upgrade8.html
+++ b/httemplate/docs/upgrade8.html
@@ -308,8 +308,9 @@ ALTER TABLE cust_refund DROP COLUMN crednum;
<li><b>IMPORTANT</b>: run bin/create-history-tables
<li><b>IMPORTANT: After running bin/create-history-tables</b>, run bin/dbdef-create again.
<li>set the <a href="../config/config.cgi#username_policy">user_policy configuration value</a> as appropriate for your site.
+ <li>the mxmachines, nsmachines, arecords and cnamerecords configuration values have been deprecated. Set the <a href="../config/config.cgi#defaultrecords">defaultrecords configuration value</a> instead.
<li>Create the `/usr/local/etc/freeside/cache.<i>datasrc</i>' directory
- (ownded by the freeside user).
+ (owned by the freeside user).
<li>freeside-queued was installed with the Perl modules. Start it now and ensure that is run upon system startup.
<li>Set appropriate <a href="../browse/part_bill_event.cgi">invoice events</a> for your site. At the very least, you'll want to set some invoice events "<i>After 0 days</i>": a <i>BILL</i> invoice event to print invoices, a <i>CARD</i> invoice event to batch or run cards real-time, and a <i>COMP</i> invoice event to "pay" complimentary customers. If you were using the <i>-i</i> option to <a href="man/bin/freeside-bill.html">freeside-bill</a> it should be removed.
<li>Use <a href="man/bin/freeside-daily.html">freeside-daily</a> instead of <a href="man/bin/freeside-bill.html">freeside-bill</a>.