diff options
| -rw-r--r-- | FS/FS/domain_record.pm | 4 | ||||
| -rw-r--r-- | FS/FS/part_export.pm | 28 | ||||
| -rw-r--r-- | FS/FS/part_export/apache.pm | 7 | ||||
| -rw-r--r-- | FS/MANIFEST | 1 | ||||
| -rw-r--r-- | FS/t/part_export-apache.t | 5 | ||||
| -rwxr-xr-x | bin/apache.export | 65 | ||||
| -rwxr-xr-x | bin/bind.export | 7 | ||||
| -rwxr-xr-x | bin/bsdshell.export | 7 | ||||
| -rwxr-xr-x | bin/sysvshell.export | 7 | 
9 files changed, 110 insertions, 21 deletions
| diff --git a/FS/FS/domain_record.pm b/FS/FS/domain_record.pm index 37cc6c9e8..3297e6bfb 100644 --- a/FS/FS/domain_record.pm +++ b/FS/FS/domain_record.pm @@ -261,7 +261,7 @@ sub check {        or return "Illegal data for PTR record: ". $self->recdata;      $self->recdata($1);    } elsif ( $self->rectype eq 'CNAME' ) { -    $self->recdata =~ /^([a-z0-9\.\-]+)$/i +    $self->recdata =~ /^([a-z0-9\.\-]+|\@)$/i        or return "Illegal data for CNAME record: ". $self->recdata;      $self->recdata($1);    } elsif ( $self->rectype eq '_mstr' ) { @@ -313,7 +313,7 @@ sub svc_domain {  =head1 VERSION -$Id: domain_record.pm,v 1.11 2002-06-23 19:16:45 ivan Exp $ +$Id: domain_record.pm,v 1.12 2003-03-20 03:41:03 ivan Exp $  =head1 BUGS diff --git a/FS/FS/part_export.pm b/FS/FS/part_export.pm index d62bef50d..b46d8439e 100644 --- a/FS/FS/part_export.pm +++ b/FS/FS/part_export.pm @@ -604,7 +604,7 @@ tie my %shellcommands_withdomain_options, 'Tie::IxHash',  ;  tie my %www_shellcommands_options, 'Tie::IxHash', -  'user' => { lable=>'Remote username', default=>'root' }, +  'user' => { label=>'Remote username', default=>'root' },    'useradd' => { label=>'Insert command',                   default=>'mkdir /var/www/$zone; chown $username /var/www/$zone; ln -s /var/www/$zone $homedir/$zone',                 }, @@ -616,6 +616,27 @@ tie my %www_shellcommands_options, 'Tie::IxHash',                  },  ; +tie my %apache_options, 'Tie::IxHash', +  'user'       => { label=>'Remote username', default=>'root' }, +  'httpd_conf' => { label=>'httpd.conf snippet location', +                    default=>'/etc/apache/httpd-freeside.conf', }, +  'template'   => { +    label   => 'Template', +    type    => 'textarea', +    default => <<'END', +<VirtualHost $domain> #generic +#<VirtualHost ip.addr> #preferred, http://httpd.apache.org/docs/dns-caveats.html +DocumentRoot /var/www/$zone +ServerName $zone +ServerAlias *.$zone +#BandWidthModule On +#LargeFileLimit 4096 12288 +</VirtualHost> + +END +  }, +; +  tie my %domain_shellcommands_options, 'Tie::IxHash',    'user' => { lable=>'Remote username', default=>'root' },    'useradd' => { label=>'Insert command', @@ -894,6 +915,11 @@ tie my %ldap_options, 'Tie::IxHash',        'notes'    => 'Run remote commands via SSH, for virtual web sites.  You will need to <a href="../docs/ssh.html">setup SSH for unattended operation</a>.',      }, +    'apache' => { +      'desc' => 'Export an Apache httpd.conf file snippet.', +      'options' => \%apache_options, +      'notes' => 'Batch export of an httpd.conf snippet from a template.  Typically used with something like <code>Include /etc/apache/httpd-freeside.conf</code> in httpd.conf.  <a href="http://search.cpan.org/search?dist=File-Rsync">File::Rsync</a> must be installed.  Run bin/apache.export to export the files.', +    },    },    'svc_broadband' => { diff --git a/FS/FS/part_export/apache.pm b/FS/FS/part_export/apache.pm new file mode 100644 index 000000000..b72c9bdb0 --- /dev/null +++ b/FS/FS/part_export/apache.pm @@ -0,0 +1,7 @@ +package FS::part_export::bind; + +use vars qw(@ISA); +use FS::part_export::null; + +@ISA = qw(FS::part_export::null); + diff --git a/FS/MANIFEST b/FS/MANIFEST index 782286544..32a4e4f59 100644 --- a/FS/MANIFEST +++ b/FS/MANIFEST @@ -66,6 +66,7 @@ FS/part_bill_event.pm  FS/export_svc.pm  FS/part_export.pm  FS/part_export_option.pm +FS/part_export/apache.pm  FS/part_export/bind.pm  FS/part_export/bind_slave.pm  FS/part_export/bsdshell.pm diff --git a/FS/t/part_export-apache.t b/FS/t/part_export-apache.t new file mode 100644 index 000000000..b9995080f --- /dev/null +++ b/FS/t/part_export-apache.t @@ -0,0 +1,5 @@ +BEGIN { $| = 1; print "1..1\n" } +END {print "not ok 1\n" unless $loaded;} +use FS::part_export::apache; +$loaded=1; +print "ok 1\n"; diff --git a/bin/apache.export b/bin/apache.export new file mode 100755 index 000000000..6142c92b4 --- /dev/null +++ b/bin/apache.export @@ -0,0 +1,65 @@ +#!/usr/bin/perl -w + +use strict; +#use File::Path; +use File::Rsync; +use Net::SSH qw(ssh); +use FS::UID qw(adminsuidsetup datasrc); +use FS::Record qw(qsearch qsearchs); +use FS::part_export; +use FS::cust_svc; +use FS::svc_www; + +my $user = shift or die &usage; +adminsuidsetup $user; + +#needs the export number in there somewhere too...? +my $spooldir = "/usr/local/etc/freeside/export.". datasrc. "/apache"; +mkdir $spooldir, 0700 unless -d $spooldir; + +my @exports = qsearch('part_export', { 'exporttype' => 'apache' } ); + +my $rsync = File::Rsync->new({ +  rsh     => 'ssh', +#  dry_run => 1, +}); + +foreach my $export ( @exports ) { + +  my $machine = $export->machine; +  my $file = "$spooldir/$machine.conf"; + +  open(HTTPD_CONF,">$file") or die "can't open $file: $!"; + +  my $template = $export->option('template'); + +  my @svc_www = $export->svc_x; + +  foreach my $svc_www ( @svc_www ) { +    use vars qw($zone $username); +    $zone = $svc_www->domain_record->zone; +    $username = $svc_www->svc_acct->username; +    print HTTPD_CONF eval(qq("$template")); +  } + +  my $user = $export->option('user'); +  my $httpd_conf = $export->option('httpd_conf') + +  $rsync->exec( { +    src       => $file, +    dest      => "$user\@$machine:$httpd_conf", +  } ) or die "rsync to $machine failed: ". join(" / ", $rsync->err); + # warn $rsync->out; + +  ssh("root\@$machine", 'ndc reload'); + +} + +close NAMED_CONF; + +# ----- + +sub usage { +  die "Usage:\n  export.export user\n";  +} + diff --git a/bin/bind.export b/bin/bind.export index 943aefbb0..055782a20 100755 --- a/bin/bind.export +++ b/bin/bind.export @@ -46,12 +46,7 @@ foreach my $export ( @exports ) {    my $zonepath = $export->option('zonepath');    $zonepath =~ s/\/$//; -  #false laziness with  freeside-sqlradius-reset and shell.export -  my @svc_domain = -    map { qsearchs('svc_domain', { 'svcnum' => $_->svcnum } ) } -      map { qsearch('cust_svc', { 'svcpart' => $_->svcpart } ) } -        grep { qsearch('cust_svc', { 'svcpart' => $_->svcpart } ) } -          $export->export_svc; +  my @svc_domain = $export->svc_x;    foreach my $svc_domain ( @svc_domain ) {      my $domain = $svc_domain->domain; diff --git a/bin/bsdshell.export b/bin/bsdshell.export index 10c27671e..6e0d1037e 100755 --- a/bin/bsdshell.export +++ b/bin/bsdshell.export @@ -43,12 +43,7 @@ foreach my $export ( @bsd_exports ) {    chmod 0644, "$prefix/passwd";    chmod 0600, "$prefix/master.passwd"; -  #false laziness with  freeside-sqlradius-reset and bind.export -  my @svc_acct =  -    map { qsearchs('svc_acct', { 'svcnum' => $_->svcnum } ) } -      map { qsearch('cust_svc', { 'svcpart' => $_->svcpart } ) } -        grep { qsearch('cust_svc', { 'svcpart' => $_->svcpart } ) } -          $export->export_svc; +  my @svc_acct = $export->svc_x;    next unless @svc_acct; diff --git a/bin/sysvshell.export b/bin/sysvshell.export index 859766103..c13912c3f 100755 --- a/bin/sysvshell.export +++ b/bin/sysvshell.export @@ -43,12 +43,7 @@ foreach my $export ( @sysv_exports ) {    chmod 0644, "$prefix/passwd";    chmod 0600, "$prefix/shadow"; -  #false laziness with  freeside-sqlradius-reset and bind.export -  my @svc_acct =  -    map { qsearchs('svc_acct', { 'svcnum' => $_->svcnum } ) } -      map { qsearch('cust_svc', { 'svcpart' => $_->svcpart } ) } -        grep { qsearch('cust_svc', { 'svcpart' => $_->svcpart } ) } -          $export->export_svc; +  my @svc_acct = $export->svc_x;    next unless @svc_acct; | 
