X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=FS%2FFS%2Fpart_export%2Fwww_shellcommands.pm;h=0e50d607c4d411f23784d13b592f73c6a31fcbb1;hp=b3bfdfeff929f9dda1a9b738ff88c8c2183e978c;hb=63ccbe91bddf551d9a684fe099a3970aa705389e;hpb=7c5c428f8f102c672dd18ff0c02aaee82f5753d4 diff --git a/FS/FS/part_export/www_shellcommands.pm b/FS/FS/part_export/www_shellcommands.pm index b3bfdfeff..0e50d607c 100644 --- a/FS/FS/part_export/www_shellcommands.pm +++ b/FS/FS/part_export/www_shellcommands.pm @@ -1,11 +1,70 @@ package FS::part_export::www_shellcommands; use strict; -use vars qw(@ISA); +use vars qw(@ISA %info); +use Tie::IxHash; use FS::part_export; @ISA = qw(FS::part_export); +tie my %options, 'Tie::IxHash', + 'user' => { label=>'Remote username', default=>'root' }, + 'useradd' => { label=>'Insert command', + default=>'mkdir $homedir/$zone; chown $username $homedir/$zone; ln -s $homedir/$zone /var/www/$zone', + }, + 'userdel' => { label=>'Delete command', + default=>'[ -n "$zone" ] && rm -rf /var/www/$zone; rm -rf $homedir/$zone', + }, + 'usermod' => { label=>'Modify command', + default=>'[ -n "$old_zone" ] && rm /var/www/$old_zone; [ "$old_zone" != "$new_zone" -a -n "$new_zone" ] && ( mv $old_homedir/$old_zone $new_homedir/$new_zone; ln -sf $new_homedir/$new_zone /var/www/$new_zone ); [ "$old_username" != "$new_username" ] && chown -R $new_username $new_homedir/$new_zone; ln -sf $new_homedir/$new_zone /var/www/$new_zone', + }, +; + +%info = ( + 'svc' => 'svc_www', + 'desc' => 'Run remote commands via SSH, for virtual web sites (directory maintenance, FrontPage, ISPMan)', + 'options' => \%options, + 'notes' => <<'END' +Run remote commands via SSH, for virtual web sites. You will need to +setup SSH for unattended operation. +

Use these buttons for some useful presets: + +The following variables are available for interpolation (prefixed with +new_ or old_ for replace operations): + +END +); + + sub rebless { shift; } sub _export_insert { @@ -29,17 +88,12 @@ sub _export_command { ${$_} = $svc_www->getfield($_) foreach $svc_www->fields; } my $domain_record = $svc_www->domain_record; # or die ? - my $zone = $domain_record->reczone; # or die ? - if ( $zone =~ /\.$/ ) { - $zone =~ s/\.$//; - } else { - my $svc_domain = $domain_record->svc_domain; # or die ? - $zone .= '.'. $svc_domain->domain; - $zone =~ s/^\@\.//; - } - + my $zone = $domain_record->zone; # or die ? + my $domain = $domain_record->svc_domain->domain; + ( my $bare_zone = $zone ) =~ s/\.$domain$//; my $svc_acct = $svc_www->svc_acct; # or die ? my $username = $svc_acct->username; + my $_password = $svc_acct->_password; my $homedir = $svc_acct->dir; # or die ? #done setting variables for the command @@ -63,25 +117,20 @@ sub _export_replace { ${"new_$_"} = $new->getfield($_) foreach $new->fields; } my $old_domain_record = $old->domain_record; # or die ? - my $old_zone = $old_domain_record->reczone; # or die ? - unless ( $old_zone =~ /\.$/ ) { - my $old_svc_domain = $old_domain_record->svc_domain; # or die ? - $old_zone .= '.'. $old_svc_domain->domain; - } - + my $old_zone = $old_domain_record->zone; # or die ? + my $old_domain = $old_domain_record->svc_domain->domain; + ( my $old_bare_zone = $old_zone ) =~ s/\.$old_domain$//; my $old_svc_acct = $old->svc_acct; # or die ? my $old_username = $old_svc_acct->username; my $old_homedir = $old_svc_acct->dir; # or die ? my $new_domain_record = $new->domain_record; # or die ? - my $new_zone = $new_domain_record->reczone; # or die ? - unless ( $new_zone =~ /\.$/ ) { - my $new_svc_domain = $new_domain_record->svc_domain; # or die ? - $new_zone .= '.'. $new_svc_domain->domain; - } - + my $new_zone = $new_domain_record->zone; # or die ? + my $new_domain = $new_domain_record->svc_domain->domain; + ( my $new_bare_zone = $new_zone ) =~ s/\.$new_domain$//; my $new_svc_acct = $new->svc_acct; # or die ? my $new_username = $new_svc_acct->username; + #my $new__password = $new_svc_acct->_password; my $new_homedir = $new_svc_acct->dir; # or die ? #done setting variables for the command @@ -104,7 +153,7 @@ sub shellcommands_queue { } sub ssh_cmd { #subroutine, not method - use Net::SSH '0.07'; + use Net::SSH '0.08'; &Net::SSH::ssh_cmd( { @_ } ); }