sub _export_insert {
my( $self, $svc_acct ) = (shift, shift);
- $self->communigate_pro_queue( $svc_acct->svcnum, 'CreateAccount',
+ my @options = ( $svc_acct->svcnum, 'CreateAccount',
'accountName' => $svc_acct->email,
'accountType' => $self->option('accountType'),
- 'externalFlag' => $self->option('externalFlag'),
'AccessModes' => $self->option('AccessModes'),
'RealName' => $svc_acct->finger,
- 'MaxAccountSize' => $svc_acct->quota,
'Password' => $svc_acct->_password,
);
+ push @options, 'MaxAccountSize' => $svc_acct->quota if $svc_acct->quota;
+ push @options, 'externalFlag' => $self->option('externalFlag')
+ if $self->option('externalFlag');
+
+ $self->communigate_pro_queue( @options );
}
sub _export_replace {
);
}
-#sub _export_suspend {
-#}
+sub _export_suspend {
+ my( $self, $svc_acct ) = (shift, shift);
+ $self->communigate_pro_queue( $svc_acct->svcnum, 'UpdateAccountSettings',
+ 'accountName' => $svc_acct->email,
+ 'AccessModes' => 'Mail',
+ );
+}
-#sub _export_unsuspend {
-#}
+sub _export_unsuspend {
+ my( $self, $svc_acct ) = (shift, shift);
+ $self->communigate_pro_queue( $svc_acct->svcnum, 'UpdateAccountSettings',
+ 'accountName' => $svc_acct->email,
+ 'AccessModes' => $self->option('AccessModes'),
+ );
+}
sub communigate_pro_queue {
my( $self, $svcnum, $method ) = (shift, shift, shift);
- my $sub = $method eq 'CreateAccount'
- ? 'CreateAccount'
+ my @kludge_methods = qw(CreateAccount UpdateAccountSettings);
+ my $sub = grep { $method eq $_ } @kludge_methods
+ ? $method
: 'communigate_pro_command';
my $queue = new FS::queue {
'svcnum' => $svcnum,
}
sub CreateAccount {
- my( $machine, $port, $login, $password, $method, @args ) = @_;
-
- my %args = @args;
+ my( $machine, $port, $login, $password, $method, %args ) = @_;
my $accountName = delete $args{'accountName'};
my $accountType = delete $args{'accountType'};
my $externalFlag = delete $args{'externalFlag'};
$args{'AccessModes'} = [ split(' ', $args{'AccessModes'}) ];
- @args = ( accountName => $accountName,
- accountType => $accountType,
- externalFlag => $externalFlag,
- settings => \%args,
- );
+ my @args = ( accountName => $accountName,
+ accountType => $accountType,
+ settings => \%args,
+ );
+ #externalFlag => $externalFlag,
+ push @args, externalFlag => $externalFlag if $externalFlag;
communigate_pro_command( $machine, $port, $login, $password, $method, @args );
}
+sub UpdateAccountSettings {
+ my( $machine, $port, $login, $password, $method, %args ) = @_;
+ my $accountName = delete $args{'accountName'};
+ $args{'AccessModes'} = [ split(' ', $args{'AccessModes'}) ];
+ @args = ( $accountName, \%args );
+ communigate_pro_command( $machine, $port, $login, $password, $method, @args );
+}
+
sub communigate_pro_command { #subroutine, not method
my( $machine, $port, $login, $password, $method, @args ) = @_;