[freeside-commits] freeside/FS/FS/part_export grandstream.pm, 1.1, 1.2 netsapiens.pm, 1.10, 1.11
Jeff Finucane,420,,
jeff at wavetail.420.am
Mon Feb 8 07:37:30 PST 2010
- Previous message: [freeside-commits] freeside/FS/FS export_device.pm, 1.1, 1.2 Mason.pm, 1.28, 1.29 Schema.pm, 1.189, 1.190 part_device.pm, 1.1, 1.2 part_export.pm, 1.102, 1.103 phone_device.pm, 1.3, 1.4
- Next message: [freeside-commits] freeside/FS/t export_device.t,1.1,1.2
- Messages sorted by:
[ date ]
[ thread ]
[ subject ]
[ author ]
Update of /home/cvs/cvsroot/freeside/FS/FS/part_export
In directory wavetail.420.am:/tmp/cvs-serv9013/FS/FS/part_export
Modified Files:
netsapiens.pm
Added Files:
grandstream.pm
Log Message:
grandstream device configuration support #4220
--- NEW FILE: grandstream.pm ---
package FS::part_export::grandstream;
use vars qw(@ISA $me %info $GAPSLITE_HOME $JAVA_HOME);
use URI;
use MIME::Base64;
use Tie::IxHash;
use FS::part_export;
use FS::CGI qw(rooturl);
@ISA = qw(FS::part_export);
$me = '[' . __PACKAGE__ . ']';
$GAPSLITE_HOME = '/usr/local/src/GS/GS_CFG_GEN/';
$JAVA_HOME = '/usr/lib/jvm/java-6-sun/';
$JAVA_HOME = '/usr/lib/jvm/java-1.4.2-gcj-4.1-1.4.2.0/';
tie my %options, 'Tie::IxHash',
'upload' => { label=>'Enable upload to tftpserver',
type=>'checkbox',
},
'user' => { label=>'User name for ssh to tftp server' },
'tftproot' => { label=>'Directory in which to upload configuration' },
'java_home' => { label=>'Path to java to be used',
default=>$JAVA_HOME,
},
'gapslite_home' => { label=>'Path to grandstream configuration tool',
default=>$GAPSLITE_HOME,
},
'template' => { label=>'Configuration template',
type=>'textarea',
notes=>'Type or paste the configuration template here',
},
;
%info = (
'svc' => [ qw( part_device ) ], # svc_phone
'desc' => 'Provision phone numbers to Grandstream Networks phones',
'options' => \%options,
'notes' => '',
);
sub rebless { shift; }
sub gs_create_config {
my($self, $mac, %opt) = (@_);
eval "use Net::SCP;";
die $@ if $@;
warn "gs_create_config called with mac of $mac\n";
$mac = sprintf('%012s', lc($mac));
my $dir = '%%%FREESIDE_CONF%%%/cache.'. $FS::UID::datasrc;
my $fh = new File::Temp(
TEMPLATE => "grandstream.$mac.XXXXXXXX",
DIR => $dir,
UNLINK => 0,
);
my $filename = $fh->filename;
#my $template = new Text::Template (
# TYPE => 'ARRAY',
# SOURCE => $self->option('template'),
# DELIMITERS => $delimiters,
# OUTPUT => $fh,
#);
#$template->compile or die "Can't compile template: $Text::Template::ERROR\n";
#my $config = $template->fill_in( HASH => { mac_addr => $mac } );
print $fh $self->option('template') or die "print failed: $!";
close $fh;
system( "export GAPSLITE_HOME=$GAPSLITE_HOME; export JAVA_HOME=$JAVA_HOME; ".
"cd $dir; $GAPSLITE_HOME/bin/encode.sh $mac $filename $dir/cfg$mac"
) == 0
or die "grandstream encode failed: $!";
unlink $filename;
open my $encoded, "$dir/cfg$mac" or die "open cfg$mac failed: $!";
my $content;
if ($opt{upload}) {
if ($self->option('upload')) {
my $scp = new Net::SCP ( {
'host' => $self->machine,
'user' => $self->option('user'),
'cwd' => $self->option('tftproot'),
} );
$scp->put( "$dir/cfg$mac" ) or die "upload failed: ". $scp->errstr;
}
} else {
local $/;
$content = <$encoded>;
}
close $encoded;
unlink "$dir/cfg$mac";
$content;
}
sub gs_create {
my($self, $mac) = (shift, shift);
return unless $mac; # be more alarmed? Or check upstream?
$self->gs_create_config($mac, 'upload' => 1);
'';
}
sub gs_delete {
my($self, $mac) = (shift, shift);
$mac = sprintf('%012s', lc($mac));
ssh_cmd( user => $self->option('user'),
host => $self->machine,
command => 'rm',
args => [ '-f', $self->option(tftproot). "/cfg$mac" ],
);
'';
}
sub ssh_cmd { #subroutine, not method
use Net::SSH '0.08';
&Net::SSH::ssh_cmd( { @_ } );
}
sub _export_insert {
# my( $self, $svc_phone ) = (shift, shift);
# $self->gs_create($svc_phone->mac_addr);
'';
}
sub _export_replace {
# my( $self, $new_svc, $old_svc ) = (shift, shift, shift);
# $self->gs_delete($old_svc->mac_addr);
# $self->gs_create($new_svc->mac_addr);
'';
}
sub _export_delete {
# my( $self, $svc_phone ) = (shift, shift);
# $self->gs_delete($svc_phone->mac_addr);
'';
}
sub _export_suspend {
'';
}
sub _export_unsuspend {
'';
}
sub export_device_insert {
my( $self, $svc_phone, $phone_device ) = (shift, shift, shift);
$self->gs_create($phone_device->mac_addr);
'';
}
sub export_device_delete {
my( $self, $svc_phone, $phone_device ) = (shift, shift, shift);
$self->gs_delete($phone_device->mac_addr);
'';
}
sub export_device_config {
my( $self, $svc_phone, $phone_device ) = (shift, shift, shift);
my $mac;
# if ($phone_device) {
$mac = $phone_device->mac_addr;
# } else {
# $mac = $svc_phone->mac_addr;
# }
return '' unless $mac; # be more alarmed? Or check upstream?
$self->gs_create_config($mac);
}
sub export_device_replace {
my( $self, $svc_phone, $new_svc_or_device, $old_svc_or_device ) =
(shift, shift, shift, shift);
$self->gs_delete($old_svc_or_device->mac_addr);
$self->gs_create($new_svc_or_device->mac_addr);
'';
}
# bad overloading?
sub export_links {
my($self, $svc_phone, $arrayref) = (shift, shift, shift);
return; # remove if we actually support being an export for svc_phone;
my @deviceparts = map { $_->devicepart } $self->export_device;
my @devices = grep { my $part = $_->devicepart;
scalar( grep { $_ == $part } @deviceparts );
} $svc_phone->phone_device;
my $export = $self->exportnum;
my $fsurl = rooturl();
if (@devices) {
foreach my $device ( @devices ) {
next unless $device->mac_addr;
my $num = $device->devicenum;
push @$arrayref,
qq!<A HREF="$fsurl/misc/phone_device_config.html?exportnum=$export;devicenum=$num">!.
qq! Phone config </A>!;
}
} elsif ($svc_phone->mac_addr) {
my $num = $svc_phone->svcnum;
push @$arrayref,
qq!<A HREF="$fsurl/misc/phone_device_config.html?exportnum=$export;svcnum=$num">!.
qq! Phone config </A>!;
} #else
'';
}
sub export_device_links {
my($self, $svc_phone, $device, $arrayref) = (shift, shift, shift, shift);
return unless $device && $device->mac_addr;
my $export = $self->exportnum;
my $fsurl = rooturl();
my $num = $device->devicenum;
push @$arrayref,
qq!<A HREF="$fsurl/misc/phone_device_config.html?exportnum=$export;devicenum=$num">!.
qq! Phone config </A>!;
'';
}
1;
Index: netsapiens.pm
===================================================================
RCS file: /home/cvs/cvsroot/freeside/FS/FS/part_export/netsapiens.pm,v
retrieving revision 1.10
retrieving revision 1.11
diff -u -d -r1.10 -r1.11
--- netsapiens.pm 20 Oct 2009 20:43:45 -0000 1.10
+++ netsapiens.pm 8 Feb 2010 15:37:28 -0000 1.11
@@ -21,7 +21,7 @@
;
%info = (
- 'svc' => 'svc_phone',
+ 'svc' => [ 'svc_phone', ], # 'part_device',
'desc' => 'Provision phone numbers to NetSapiens',
'options' => \%options,
'notes' => <<'END'
- Previous message: [freeside-commits] freeside/FS/FS export_device.pm, 1.1, 1.2 Mason.pm, 1.28, 1.29 Schema.pm, 1.189, 1.190 part_device.pm, 1.1, 1.2 part_export.pm, 1.102, 1.103 phone_device.pm, 1.3, 1.4
- Next message: [freeside-commits] freeside/FS/t export_device.t,1.1,1.2
- Messages sorted by:
[ date ]
[ thread ]
[ subject ]
[ author ]
More information about the freeside-commits
mailing list