diff options
author | ivan <ivan> | 2005-09-07 09:37:26 +0000 |
---|---|---|
committer | ivan <ivan> | 2005-09-07 09:37:26 +0000 |
commit | 51ece2a921eda1257f424fe69d8ce9780b9ba13f (patch) | |
tree | 4a9e144f92af3b7172fbc1b64eccd7ad48b43307 /FS | |
parent | 6824eb2001d4b6091af082d0be58932fa3e569c0 (diff) |
add cpanel export
Diffstat (limited to 'FS')
-rw-r--r-- | FS/FS/part_export/cpanel.pm | 130 |
1 files changed, 130 insertions, 0 deletions
diff --git a/FS/FS/part_export/cpanel.pm b/FS/FS/part_export/cpanel.pm new file mode 100644 index 000000000..3bc47e422 --- /dev/null +++ b/FS/FS/part_export/cpanel.pm @@ -0,0 +1,130 @@ +package FS::part_export::cpanel; + +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 access username' }, + 'accesshash' => { label=>'Remote access key' }, +; + +%info = ( + 'svc' => 'svc_acct', + 'desc' => 'Real-time export to Cpanel control panel.', + 'options' => \%options, + 'nodomain' => 'Y', + 'notes' => 'Real time export to a the <a href="http://www.cpanel.net/">Cpanel</a> control panel software. Service definition names are exported as Cpanel packages. Requires installation of the Cpanel::Accounting perl module distributed with Cpanel.', +); + +sub rebless { shift; } + +sub _export_insert { + my($self, $svc_acct) = (shift, shift); + $err_or_queue = $self->cpanel_queue( $svc_acct->svcnum, 'insert', + $svc_acct->domain, + $svc_acct->username, + $svc_acct->_password, + $svc_acct->cust_svc->part_svc->svc, + ); + ref($err_or_queue) ? '' : $err_or_queue; +} + +sub _export_replace { + my( $self, $new, $old ) = (shift, shift, shift); + return "can't change username with cpanel" + if $old->username ne $new->username; + return "can't change password with cpanel" + if $old->_passsword ne $new->_password; + return "can't change domain with cpanel" + if $old->domain ne $new->domain; + + ''; + + ##return '' unless $old->_password ne $new->_password; + #$err_or_queue = $self->cpanel_queue( $new->svcnum, + # 'replace', $new->username, $new->_password ); + #ref($err_or_queue) ? '' : $err_or_queue; +} + +sub _export_delete { + my( $self, $svc_acct ) = (shift, shift); + $err_or_queue = $self->cpanel_queue( $svc_acct->svcnum, + 'delete', $svc_acct->username + ); + ref($err_or_queue) ? '' : $err_or_queue; +} + +sub _export_suspend { + my( $self, $svc_acct ) = (shift, shift); + $err_or_queue = $self->cpanel_queue( $svc_acct->svcnum, + 'suspend', $svc_acct->username ); + ref($err_or_queue) ? '' : $err_or_queue; +} + +sub _export_unsuspend { + my( $self, $svc_acct ) = (shift, shift); + $err_or_queue = $self->cpanel_queue( $svc_acct->svcnum, + 'unsuspend', $svc_acct->username ); + ref($err_or_queue) ? '' : $err_or_queue; +} + + +sub cpanel_queue { + my( $self, $svcnum, $method ) = (shift, shift, shift); + my $queue = new FS::queue { + 'svcnum' => $svcnum, + 'job' => "FS::part_export::cpanel::cpanel_$method", + }; + $queue->insert( + $self->machine, + $self->option('user'), + $self->option('accesshash'), + @_ + ) or $queue; +} + + +sub cpanel_insert { #subroutine, not method + my $whm = cpanel_connect(shift, shift, shift); + my $response = $whm->createacct(@_); + die $whm->{'error'} if $whm->{'error'}; +} + +#sub cpanel_replace { #subroutine, not method +#} + +sub cpanel_delete { #subroutine, not method + my $whm = cpanel_connect(shift, shift, shift); + my $response = $whm->killacct(shift); + die $whm->{'error'} if $whm->{'error'}; +} + +sub cpanel_suspend { #subroutine, not method + my $whm = cpanel_connect(shift, shift, shift); + my $response = $whm->suspend(shift); + die $whm->{'error'} if $whm->{'error'}; +} + +sub cpanel_unsuspend { #subroutine, not method + my $whm = cpanel_connect(shift, shift, shift); + my $response = $whm->unsuspend(shift); + die $whm->{'error'} if $whm->{'error'}; +} + +sub cpanel_connect { + my( $host, $user, $accesshash ) = @_; + + eval "use Cpanel::Accounting;"; + die $@ if $@; + + my $whm = new Cpanel::Accounting; + $whm->{'host'} = $host; + $whm->{'user'} = $user; + $whm->{'accesshash'} = $accesshash; + $whm->{'usessl'} = 1; + + $whm; +} |