[freeside-commits] branch FREESIDE_3_BRANCH updated. 2eedee9c581db67f67abee82a54ed6dc06ce8bfa
Christopher Burger
burgerc at freeside.biz
Wed May 8 07:50:28 PDT 2019
The branch, FREESIDE_3_BRANCH has been updated
via 2eedee9c581db67f67abee82a54ed6dc06ce8bfa (commit)
via 8e69677f3f79b00d805627d8d8f998441824b0b1 (commit)
via bc0156386f7ce4f353cb98039e942b563bef3841 (commit)
from faf6ca7361f6500441f23d06f7cb3a3c11e92aa0 (commit)
Those revisions listed above that are new to this repository have
not appeared on any other notification email; so we list those
revisions in full, below.
- Log -----------------------------------------------------------------
commit 2eedee9c581db67f67abee82a54ed6dc06ce8bfa
Author: Christopher Burger <burgerc at freeside.biz>
Date: Wed May 8 09:35:40 2019 -0400
RT# 83251 - added option to only update null fields
diff --git a/bin/svc_broadband_update_speeds b/bin/svc_broadband_update_speeds
index 2dfb0c88e..6bbd93e63 100755
--- a/bin/svc_broadband_update_speeds
+++ b/bin/svc_broadband_update_speeds
@@ -11,17 +11,15 @@ use Data::Dumper;
# parse command line
###
-use vars qw( $opt_h $opt_v $opt_e $opt_s $opt_c $opt_r $opt_p $opt_d );
-getopts('hves:c:r:pd:');
-
-warn ("running\n");
+use vars qw( $opt_h $opt_v $opt_n $opt_e $opt_s $opt_c $opt_r $opt_p $opt_d );
+getopts('hvnes:c:r:pd:');
my $user = shift or die &usage;
adminsuidsetup $user;
sub usage { "
Usage:
- svc_broadband_update_speeds [ -h help] [ -v verbose] [ -e export service ] [ -s service_part_num (required) ] [ -c sibling service_part_num ] [ -r (speed rate in KB 'up,down') ] [ -p (get speed from package fcc rate) ] [ -d directory for exception file (required) ] user (required)\n
+ svc_broadband_update_speeds [ -h help] [ -v verbose] [ -n only update services with a null up/down speed] [ -e export service ] [ -s service_part_num (required) ] [ -c sibling service_part_num ] [ -r (speed rate in KB 'up,down') ] [ -p (get speed from package fcc rate) ] [ -d directory for exception file (required) ] user (required)\n
A directory for the exception file, freeside user name and a service to update is required.\n
Must set one or more of options p, c, or r. \n
Also must run this report as user freeside.\n
@@ -34,8 +32,11 @@ unless ($opt_d && $opt_s) { die &usage(); }
if ($opt_h) { die &usage(); }
unless ($opt_p || $opt_c || $opt_r) { die &usage(); }
+my $exception_file = "$opt_d/svcbroadband_update_exceptions_".time().".txt";
+
### get list of all provisioned services
-my $extra_sql = " WHERE cust_svc.svcpart = $opt_s";
+my $only_null_speed_services = " AND (svc_broadband.speed_up IS NULL OR svc_broadband.speed_down IS NULL)" if $opt_n;
+my $extra_sql = " WHERE cust_svc.svcpart = $opt_s $only_null_speed_services";
my @services = qsearch({
'select' => 'svc_broadband.*, cust_svc.svcpart, cust_svc.pkgnum, cust_pkg.pkgpart',
'table' => 'svc_broadband',
@@ -55,11 +56,12 @@ my $speed;
$speed = 'package' if $opt_p;
foreach my $svc (@services) {
- _update_service($svc);
+ _update_service($svc, $exception_file);
}
sub _update_service {
my $service = shift;
+ my $exception_file = shift;
my $speed_up;
my $speed_down;
@@ -107,11 +109,11 @@ sub _update_service {
###todo: if no error provision service if not provisioned ie new svc_broadband.
}
else {
- open(FILE, ">$opt_d/svcbroadband_update_exceptions.txt")
+ open(FILE, ">>$exception_file")
or die "can't open $opt_d: $!";
- print FILE $service->description."(".$service->svcnum.") Has no up or download speed and could not set one.\n";
+ print FILE "Service ".$service->description."(".$service->svcnum.") could not set a up or download speed.\n";
close FILE or die "can't close $opt_d: $!";
- warn($service->description."(".$service->svcnum.") Has no up or download speed\n") if $opt_v;
+ warn($service->description."(".$service->svcnum.") could not set a up or download speed, added to exception file.\n") if $opt_v;
}
return;
}
commit 8e69677f3f79b00d805627d8d8f998441824b0b1
Author: Christopher Burger <burgerc at freeside.biz>
Date: Fri May 3 13:06:58 2019 -0400
RT# 83251 - added documentation
diff --git a/bin/svc_broadband_update_speeds b/bin/svc_broadband_update_speeds
index 373ee2f4e..2dfb0c88e 100755
--- a/bin/svc_broadband_update_speeds
+++ b/bin/svc_broadband_update_speeds
@@ -34,16 +34,16 @@ unless ($opt_d && $opt_s) { die &usage(); }
if ($opt_h) { die &usage(); }
unless ($opt_p || $opt_c || $opt_r) { die &usage(); }
-my $extra_sql;
-$extra_sql = " WHERE cust_svc.svcpart = $opt_s" if $opt_s;
-
### get list of all provisioned services
+my $extra_sql = " WHERE cust_svc.svcpart = $opt_s";
my @services = qsearch({
'select' => 'svc_broadband.*, cust_svc.svcpart, cust_svc.pkgnum, cust_pkg.pkgpart',
'table' => 'svc_broadband',
'addl_from' => 'LEFT JOIN cust_svc USING ( svcnum ) LEFT JOIN cust_pkg USING (pkgnum)',
'extra_sql' => $extra_sql,
});
+
+### get list of all unprovisioned services
my $ups_extra_sql = "where cust_pkg.cancel is null and pkg_svc.quantity > 0 and pkg_svc.quantity > (select count(1) from cust_svc where cust_svc.pkgnum = cust_pkg.pkgnum and cust_svc.svcpart = pkg_svc.svcpart) and pkg_svc.svcpart = $opt_s";
my @unprovisioned_services = qsearchs({
'table' => 'cust_pkg',
@@ -117,3 +117,20 @@ sub _update_service {
}
exit;
+
+=head2 svc_broadband_update_speeds
+
+This script allows for the mas update of up and down speeds for a svc_broadband service.
+
+the script will obtain the new speed from option p (package fcc rates) first if set,
+if no rates found then checks for option c (rate of sibling service) if set,
+if still no rates found checks for rate in option r if set.
+If no rates found service will be placed in exception file.
+
+Script must be run as user freeside.
+Options -s, -d and freeside user are required.
+
+example:
+sudo -u freeside ./svc_broadband_update_speeds -v -s 4 -c 2 -r 148000,248000 -p -d /home/freeside/ freesideuser
+
+=cut
\ No newline at end of file
commit bc0156386f7ce4f353cb98039e942b563bef3841
Author: Christopher Burger <burgerc at freeside.biz>
Date: Fri May 3 10:49:54 2019 -0400
RT# 83251 - created script to update service speeds
diff --git a/FS/FS/svc_Common.pm b/FS/FS/svc_Common.pm
index 229cfdd1f..b4068ea2d 100644
--- a/FS/FS/svc_Common.pm
+++ b/FS/FS/svc_Common.pm
@@ -479,6 +479,7 @@ passed to export commands.
sub replace {
my $new = shift;
+ $noexport_hack = $new->no_export if $new->no_export;
my $old = ( blessed($_[0]) && $_[0]->isa('FS::Record') )
? shift
diff --git a/bin/svc_broadband_update_speeds b/bin/svc_broadband_update_speeds
new file mode 100755
index 000000000..373ee2f4e
--- /dev/null
+++ b/bin/svc_broadband_update_speeds
@@ -0,0 +1,119 @@
+#!/usr/bin/perl
+
+use strict;
+use Getopt::Std;
+use FS::UID qw(adminsuidsetup);
+use FS::Record qw(qsearch qsearchs);
+use FS::svc_broadband;
+use Data::Dumper;
+
+###
+# parse command line
+###
+
+use vars qw( $opt_h $opt_v $opt_e $opt_s $opt_c $opt_r $opt_p $opt_d );
+getopts('hves:c:r:pd:');
+
+warn ("running\n");
+
+my $user = shift or die &usage;
+adminsuidsetup $user;
+
+sub usage { "
+ Usage:
+ svc_broadband_update_speeds [ -h help] [ -v verbose] [ -e export service ] [ -s service_part_num (required) ] [ -c sibling service_part_num ] [ -r (speed rate in KB 'up,down') ] [ -p (get speed from package fcc rate) ] [ -d directory for exception file (required) ] user (required)\n
+ A directory for the exception file, freeside user name and a service to update is required.\n
+ Must set one or more of options p, c, or r. \n
+ Also must run this report as user freeside.\n
+ Option r up and down speed seperated by a comma in kbps.
+ Getting speed from option p (package fcc rates) first if set, if no rates found then checks for option c (rate of sibling service) if set, if still no rates found checks for rate in option r if set. If no rates found service will be placed in exception file.
+ By default serivce will not export if there is a export assigned to service. Setting option e will perform the export.
+" }
+
+unless ($opt_d && $opt_s) { die &usage(); }
+if ($opt_h) { die &usage(); }
+unless ($opt_p || $opt_c || $opt_r) { die &usage(); }
+
+my $extra_sql;
+$extra_sql = " WHERE cust_svc.svcpart = $opt_s" if $opt_s;
+
+### get list of all provisioned services
+my @services = qsearch({
+ 'select' => 'svc_broadband.*, cust_svc.svcpart, cust_svc.pkgnum, cust_pkg.pkgpart',
+ 'table' => 'svc_broadband',
+ 'addl_from' => 'LEFT JOIN cust_svc USING ( svcnum ) LEFT JOIN cust_pkg USING (pkgnum)',
+ 'extra_sql' => $extra_sql,
+});
+my $ups_extra_sql = "where cust_pkg.cancel is null and pkg_svc.quantity > 0 and pkg_svc.quantity > (select count(1) from cust_svc where cust_svc.pkgnum = cust_pkg.pkgnum and cust_svc.svcpart = pkg_svc.svcpart) and pkg_svc.svcpart = $opt_s";
+my @unprovisioned_services = qsearchs({
+ 'table' => 'cust_pkg',
+ 'addl_from' => 'JOIN pkg_svc using (pkgpart)',
+ 'extra_sql' => $ups_extra_sql,
+});
+
+my $speed;
+$speed = 'package' if $opt_p;
+
+foreach my $svc (@services) {
+ _update_service($svc);
+}
+
+sub _update_service {
+ my $service = shift;
+ my $speed_up;
+ my $speed_down;
+
+ my $package = qsearchs({
+ 'table' => 'part_pkg',
+ 'hashref' => { 'pkgpart' => $service->pkgpart, },
+ });
+
+ ## get speed from package fcc option first if option p
+ if ($opt_p) {
+ warn ("Getting speed for service ".$service->description."(".$service->svcnum.") from package fcc info\n") if $opt_v;
+ $speed_up = $package->fcc_option('broadband_upstream') * 1000;
+ $speed_down = $package->fcc_option('broadband_downstream') * 1000;
+ }
+
+ ## if no fcc option get speed from sibling broadband service if option c
+ if ((!$speed_up || !$speed_down) && $opt_c) {
+ warn ("Getting speed for service ".$service->description."(".$service->svcnum.") from sibling service of package ".$service->pkgnum) if $opt_v;
+ my $sibling_service = qsearchs({
+ 'select' => 'svc_broadband.*, cust_svc.svcpart',
+ 'table' => 'svc_broadband',
+ 'addl_from' => ' LEFT JOIN cust_svc USING ( svcnum )',
+ 'extra_sql' => ' WHERE cust_svc.pkgnum = '.$service->pkgnum.' AND cust_svc.svcpart = '.$opt_c.' AND (svc_broadband.speed_up IS NOT NULL AND svc_broadband.speed_down IS NOT NULL)',
+ });
+ $speed_up = $sibling_service->speed_up if $sibling_service;
+ $speed_down = $sibling_service->speed_down if $sibling_service;
+ }
+
+ ## if no fcc options and no speed from sibling service than get speed from option r if option r is set.
+ if ((!$speed_up || !$speed_down) && $opt_r) {
+ warn ("Getting speed for service ".$service->description."(".$service->svcnum.") from option r ($opt_r)\n") if $opt_v;
+ ($speed_up, $speed_down) = split /\,/, $opt_r;
+ warn ("Option r speeds not correct. Must be in kbps up and down seperated by comma. [ -r xxxxxx,xxxxxx ]\n") if $opt_v && (!$speed_up || !$speed_down);
+ }
+
+ ## update service with new speed.
+ if ($speed_up && $speed_down) {
+ $service->set('speed_up', $speed_up);
+ $service->set('speed_down', $speed_down);
+
+ warn("updating service ".$service->description."(".$service->svcnum.") with upload speed ($speed_up) and download speed ($speed_down)\n") if $opt_v;
+ $service->set('no_export', $opt_e);
+ my $error = $service->replace();
+ warn($error) if $error;
+ ###todo: if no error provision service if not provisioned ie new svc_broadband.
+ }
+ else {
+ open(FILE, ">$opt_d/svcbroadband_update_exceptions.txt")
+ or die "can't open $opt_d: $!";
+ print FILE $service->description."(".$service->svcnum.") Has no up or download speed and could not set one.\n";
+ close FILE or die "can't close $opt_d: $!";
+ warn($service->description."(".$service->svcnum.") Has no up or download speed\n") if $opt_v;
+ }
+ return;
+}
+
+exit;
-----------------------------------------------------------------------
Summary of changes:
FS/FS/svc_Common.pm | 1 +
bin/svc_broadband_update_speeds | 138 ++++++++++++++++++++++++++++++++++++++++
2 files changed, 139 insertions(+)
create mode 100755 bin/svc_broadband_update_speeds
More information about the freeside-commits
mailing list