1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
|
package FS::part_export::domain_shellcommands;
use strict;
use vars qw(@ISA);
use FS::part_export;
@ISA = qw(FS::part_export);
sub rebless { shift; }
sub _export_insert {
my($self) = shift;
$self->_export_command('useradd', @_);
}
sub _export_delete {
my($self) = shift;
$self->_export_command('userdel', @_);
}
sub _export_command {
my ( $self, $action, $svc_domain) = (shift, shift, shift);
my $command = $self->option($action);
#set variable for the command
no strict 'vars';
{
no strict 'refs';
${$_} = $svc_domain->getfield($_) foreach $svc_domain->fields;
}
( $qdomain = $domain ) =~ s/\./:/g; #see dot-qmail(5): EXTENSION ADDRESSES
if ( $svc_domain->catchall ) {
no strict 'refs';
my $svc_acct = $svc_domain->catchall_svc_acct;
${$_} = $svc_acct->getfield($_) foreach qw(uid gid dir);
} else {
${$_} = '' foreach qw(uid gid dir);
}
#done setting variables for the command
$self->shellcommands_queue( $svc_domain->svcnum,
user => $self->option('user')||'root',
host => $self->machine,
command => eval(qq("$command")),
);
}
sub _export_replace {
my($self, $new, $old ) = (shift, shift, shift);
my $command = $self->option('usermod');
#set variable for the command
no strict 'vars';
{
no strict 'refs';
${"old_$_"} = $old->getfield($_) foreach $old->fields;
${"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_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_svc_acct = $new->svc_acct; # or die ?
# my $new_username = $new_svc_acct->username;
# my $new_homedir = $new_svc_acct->dir; # or die ?
#done setting variables for the command
$self->shellcommands_queue( $new->svcnum,
user => $self->option('user')||'root',
host => $self->machine,
command => eval(qq("$command")),
);
}
#a good idea to queue anything that could fail or take any time
sub shellcommands_queue {
my( $self, $svcnum ) = (shift, shift);
my $queue = new FS::queue {
'svcnum' => $svcnum,
'job' => "FS::part_export::domain_shellcommands::ssh_cmd",
};
$queue->insert( @_ );
}
sub ssh_cmd { #subroutine, not method
use Net::SSH '0.07';
&Net::SSH::ssh_cmd( { @_ } );
}
#sub shellcommands_insert { #subroutine, not method
#}
#sub shellcommands_replace { #subroutine, not method
#}
#sub shellcommands_delete { #subroutine, not method
#}
|