use vars qw(%info $me);
use Tie::IxHash;
+use URI::Escape;
use Frontier::Client;
$me = '['.__PACKAGE__.']';
#'server' => { label => 'Thirdlane server name or IP address', },
'username' => { label => 'Thirdlane username', },
'password' => { label => 'Thirdlane password', },
+ 'ssl' => { label => 'Enable HTTPS (SSL) connection',
+ type => 'checkbox',
+ },
+ 'port' => { label => 'Port number if not 80 or 443', },
'prototype_tenant' => { label => 'Prototype tenant name', },
+ 'omit_countrycode' => { label => 'Omit country code', type => 'checkbox' },
'debug' => { label => 'Checkbox label', type => 'checkbox' },
# 'select_option' => { label => 'Select option description',
# type => 'select', options=>[qw(chocolate vanilla)],
;
%info = (
- 'svc' => [qw( svc_pbx svc_phone )],
+ 'svc' => [qw( svc_pbx svc_phone svc_acct )],
'desc' =>
- 'Export tenants and DIDs to Thirdlane PBX manager',
+ 'Export tenants, DIDs and admins to Thirdlane PBX manager',
'options' => \%options,
'notes' => <<'END'
-Exports tenants and DIDs to Thirdlane PBX manager using the XML-RPC API.
+Exports tenants, DIDs and admins to Thirdlane PBX manager using the XML-RPC API.
END
);
#use Data::Dumper;
#warn Dumper(\$result);
- $result eq '0' ? '' : 'Thirdlane API failure';
+ $result eq '0' ? '' : 'Thirdlane API failure (rpc_tenant_create)';
} elsif ( $svc_x->isa('FS::svc_phone') ) {
my $result = $self->_thirdlane_command(
'asterisk::rpc_did_create',
- $svc_x->countrycode. $svc_x->phonenum,
+ $self->_thirdlane_did($svc_x)
);
#use Data::Dumper;
$result = $self->_thirdlane_command(
'asterisk::rpc_did_assign',
- $svc_x->countrycode. $svc_x->phonenum,
+ $self->_thirdlane_did($svc_x),
$svc_x->pbx_title,
);
#warn Dumper(\$result);
$result eq '0' ? '' : 'Thirdlane API failure (rpc_did_assign)';
+ } elsif ( $svc_x->isa('FS::svc_acct') ) {
+
+ return 'Must select a PBX' unless $svc_x->pbxsvc;
+
+ my $result = $self->_thirdlane_command(
+ 'asterisk::rpc_admin_create',
+ $svc_x->username,
+ $svc_x->_password,
+ $svc_x->pbx_title,
+ );
+
+ #use Data::Dumper;
+ #warn Dumper(\$result);
+ $result eq '0' ? '' : 'Thirdlane API failure (rpc_admin_create)';
+
} else {
- die "guru meditation #10: $svc_x is not FS::svc_pbx or FS::svc_phone";
+ die "guru meditation #10: $svc_x is not FS::svc_pbx, FS::svc_phone or FS::svc_acct";
}
}
#use Data::Dumper;
#warn Dumper(\$result);
- $result eq '0' ? '' : 'Thirdlane API failure';
+ $result eq '0' ? '' : 'Thirdlane API failure (rpc_tenant_update)';
} elsif ( $new->isa('FS::svc_phone') ) {
if ( $old->pbxsvc ) {
my $result = $self->_thirdlane_command(
'asterisk::rpc_did_unassign',
- $new->countrycode. $new->phonenum,
+ $self->_thirdlane_did($old),
);
$result eq '0' or return 'Thirdlane API failure (rpc_did_unassign)';
}
if ( $new->pbxsvc ) {
my $result = $self->_thirdlane_command(
'asterisk::rpc_did_assign',
- $new->countrycode. $new->phonenum,
+ $self->_thirdlane_did($new),
$new->pbx_title,
);
$result eq '0' or return 'Thirdlane API failure (rpc_did_assign)';
'';
+ } elsif ( $new->isa('FS::svc_acct') ) {
+
+ return "can't change uesrname with thirdlane"
+ if $old->username ne $new->username;
+
+ return "can't change password with thirdlane"
+ if $old->_password ne $new->_password;
+
+ return "can't change PBX for user with thirdlane"
+ if $old->pbxsvc != $new->pbxsvc;
+
+ ''; #we don't care then
+
} else {
- die "guru meditation #11: $new is not FS::svc_pbx or FS::svc_phone";
+ die "guru meditation #11: $new is not FS::svc_pbx, FS::svc_phone or FS::svc_acct";
}
}
#use Data::Dumper;
#warn Dumper(\$result);
- $result eq '0' ? '' : 'Thirdlane API failure';
+ #$result eq '0' ? '' : 'Thirdlane API failure (rpc_tenant_delete)';
+ warn "Thirdlane API failure (rpc_tenant_delete); deleting anyway\n"
+ if $result ne '0';
+ '';
} elsif ( $svc_x->isa('FS::svc_phone') ) {
if ( $svc_x->pbxsvc ) {
my $result = $self->_thirdlane_command(
'asterisk::rpc_did_unassign',
- $svc_x->countrycode. $svc_x->phonenum,
+ $self->_thirdlane_did($svc_x),
);
$result eq '0' or return 'Thirdlane API failure (rpc_did_unassign)';
}
my $result = $self->_thirdlane_command(
'asterisk::rpc_did_delete',
- $svc_x->countrycode. $svc_x->phonenum,
+ $self->_thirdlane_did($svc_x),
);
$result eq '0' ? '' : 'Thirdlane API failure (rpc_did_delete)';
+ } elsif ( $svc_x->isa('FS::svc_acct') ) {
+
+ return '' unless $svc_x->pbxsvc; #error out? nah
+
+ my $result = $self->_thirdlane_command(
+ 'asterisk::rpc_admin_delete',
+ $svc_x->username,
+ $svc_x->pbx_title,
+ );
+
+ #use Data::Dumper;
+ #warn Dumper(\$result);
+ #$result eq '0' ? '' : 'Thirdlane API failure (rpc_admin_delete)';
+ warn "Thirdlane API failure (rpc_admin_delete); deleting anyway\n"
+ if $result ne '0';
+ '';
+
} else {
- die "guru meditation #11: $svc_x is not FS::svc_pbx or FS::svc_phone";
+ die "guru meditation #12: $svc_x is not FS::svc_pbx, FS::svc_phone or FS::svc_acct";
}
}
sub _thirdlane_command {
my($self, @param) = @_;
- my $url = 'http://'.
- $self->option('username'). ':'. $self->option('password'). '@'.
- $self->machine. '/xmlrpc.cgi';
+ my $url = $self->option('ssl') ? 'https://' : 'http://';
+ $url .= uri_escape($self->option('username')). ':'.
+ uri_escape($self->option('password')). '@'.
+ $self->machine;
+ $url .= ':'. $self->option('port') if $self->option('port');
+ $url .= '/xmlrpc.cgi';
warn "$me connecting to $url\n"
if $self->option('debug');
my $conn = Frontier::Client->new( 'url' => $url,
- 'debug' => $self->option('debug'),
+ #no, spews output to browser
+ #'debug' => $self->option('debug'),
);
warn "$me sending command: ". join(' ', @param). "\n"
}
+sub _thirdlane_did {
+ my($self, $svc_phone) = @_;
+ if ( $self->option('omit_countrycode') ) {
+ $svc_phone->phonenum;
+ } else {
+ $svc_phone->countrycode. $svc_phone->phonenum;
+ }
+}
+
#my( $self, $svc_something ) = (shift, shift);
#$err_or_queue = $self->thirdlane_queue( $svc_something->svcnum,
# 'delete', $svc_something->username );