1 package FS::part_export::www_shellcommands;
4 use vars qw(@ISA %info);
8 @ISA = qw(FS::part_export);
10 tie my %options, 'Tie::IxHash',
11 'user' => { label=>'Remote username', default=>'root' },
12 'useradd' => { label=>'Insert command',
13 default=>'mkdir /var/www/$zone; chown $username /var/www/$zone; ln -s /var/www/$zone $homedir/$zone',
15 'userdel' => { label=>'Delete command',
16 default=>'[ -n "$zone" ] && rm -rf /var/www/$zone; rm $homedir/$zone',
18 'usermod' => { label=>'Modify command',
19 default=>'[ -n "$old_zone" ] && rm $old_homedir/$old_zone; [ "$old_zone" != "$new_zone" -a -n "$new_zone" ] && mv /var/www/$old_zone /var/www/$new_zone; [ "$old_username" != "$new_username" ] && chown -R $new_username /var/www/$new_zone; ln -s /var/www/$new_zone $new_homedir/$new_zone',
25 'desc' => 'Run remote commands via SSH, for virtual web sites.',
26 'options' => \%options,
28 Run remote commands via SSH, for virtual web sites. You will need to
29 <a href="../docs/ssh.html">setup SSH for unattended operation</a>.
30 <BR><BR>The following variables are available for interpolation (prefixed with
31 <code>new_</code> or <code>old_</code> for replace operations):
33 <LI><code>$zone</code>
34 <LI><code>$username</code>
35 <LI><code>$homedir</code>
36 <LI>All other fields in <a href="../docs/schema.html#svc_www">svc_www</a>
43 sub rebless { shift; }
47 $self->_export_command('useradd', @_);
52 $self->_export_command('userdel', @_);
56 my ( $self, $action, $svc_www) = (shift, shift, shift);
57 my $command = $self->option($action);
59 #set variable for the command
63 ${$_} = $svc_www->getfield($_) foreach $svc_www->fields;
65 my $domain_record = $svc_www->domain_record; # or die ?
66 my $zone = $domain_record->zone; # or die ?
67 my $svc_acct = $svc_www->svc_acct; # or die ?
68 my $username = $svc_acct->username;
69 my $homedir = $svc_acct->dir; # or die ?
71 #done setting variables for the command
73 $self->shellcommands_queue( $svc_www->svcnum,
74 user => $self->option('user')||'root',
75 host => $self->machine,
76 command => eval(qq("$command")),
81 my($self, $new, $old ) = (shift, shift, shift);
82 my $command = $self->option('usermod');
84 #set variable for the command
88 ${"old_$_"} = $old->getfield($_) foreach $old->fields;
89 ${"new_$_"} = $new->getfield($_) foreach $new->fields;
91 my $old_domain_record = $old->domain_record; # or die ?
92 my $old_zone = $old_domain_record->reczone; # or die ?
93 unless ( $old_zone =~ /\.$/ ) {
94 my $old_svc_domain = $old_domain_record->svc_domain; # or die ?
95 $old_zone .= '.'. $old_svc_domain->domain;
98 my $old_svc_acct = $old->svc_acct; # or die ?
99 my $old_username = $old_svc_acct->username;
100 my $old_homedir = $old_svc_acct->dir; # or die ?
102 my $new_domain_record = $new->domain_record; # or die ?
103 my $new_zone = $new_domain_record->reczone; # or die ?
104 unless ( $new_zone =~ /\.$/ ) {
105 my $new_svc_domain = $new_domain_record->svc_domain; # or die ?
106 $new_zone .= '.'. $new_svc_domain->domain;
109 my $new_svc_acct = $new->svc_acct; # or die ?
110 my $new_username = $new_svc_acct->username;
111 my $new_homedir = $new_svc_acct->dir; # or die ?
113 #done setting variables for the command
115 $self->shellcommands_queue( $new->svcnum,
116 user => $self->option('user')||'root',
117 host => $self->machine,
118 command => eval(qq("$command")),
122 #a good idea to queue anything that could fail or take any time
123 sub shellcommands_queue {
124 my( $self, $svcnum ) = (shift, shift);
125 my $queue = new FS::queue {
127 'job' => "FS::part_export::www_shellcommands::ssh_cmd",
129 $queue->insert( @_ );
132 sub ssh_cmd { #subroutine, not method
134 &Net::SSH::ssh_cmd( { @_ } );
137 #sub shellcommands_insert { #subroutine, not method
139 #sub shellcommands_replace { #subroutine, not method
141 #sub shellcommands_delete { #subroutine, not method