diff options
| author | Mark Wells <mark@freeside.biz> | 2015-08-04 11:16:41 -0700 | 
|---|---|---|
| committer | Mark Wells <mark@freeside.biz> | 2015-08-04 11:51:19 -0700 | 
| commit | 1d091fcec0fb8a78fe5b6a640c67a17a85c06092 (patch) | |
| tree | a127fef456454685b2d1ca6e80b9cda1e24e2a45 | |
| parent | d9001528ce9202171e228cf30d66bd1d09e6f019 (diff) | |
de-randomization fixes for testing, #37340
| -rw-r--r-- | FS/FS/Conf.pm | 7 | ||||
| -rw-r--r-- | FS/FS/Mason.pm | 2 | ||||
| -rw-r--r-- | FS/FS/Record.pm | 1 | ||||
| -rw-r--r-- | FS/FS/UI/Web.pm | 33 | ||||
| -rw-r--r-- | httemplate/elements/bill.html | 2 | ||||
| -rw-r--r-- | httemplate/elements/columnstart.html | 2 | ||||
| -rw-r--r-- | httemplate/elements/create_uri_query | 2 | ||||
| -rw-r--r-- | httemplate/elements/input-fcc_options.html | 2 | ||||
| -rw-r--r-- | httemplate/elements/pickcolor.html | 2 | ||||
| -rw-r--r-- | httemplate/elements/popup_link_onclick.html | 2 | ||||
| -rw-r--r-- | httemplate/elements/progress-init.html | 2 | ||||
| -rw-r--r-- | httemplate/elements/tr-input-mask.html | 2 | ||||
| -rw-r--r-- | httemplate/graph/elements/report.html | 2 | 
13 files changed, 50 insertions, 11 deletions
| diff --git a/FS/FS/Conf.pm b/FS/FS/Conf.pm index 2e52db7be..eec6febbb 100644 --- a/FS/FS/Conf.pm +++ b/FS/FS/Conf.pm @@ -6071,6 +6071,13 @@ and customer address. Include units.',    { key => "vonage-password", section => "deprecated", description => "<b>DEPRECATED</b>", type => "text" },    { key => "vonage-fromnumber", section => "deprecated", description => "<b>DEPRECATED</b>", type => "text" }, +  { +    'key'         => 'no_random_ids', +    'section'     => '', +    'description' => 'Replace random identifiers in UI code with a static string, for repeatable testing. Don\'t use in production.', +    'type'        => 'checkbox', +  }, +  );  1; diff --git a/FS/FS/Mason.pm b/FS/FS/Mason.pm index aa98ad32a..467eb6ab1 100644 --- a/FS/FS/Mason.pm +++ b/FS/FS/Mason.pm @@ -136,7 +136,7 @@ if ( -e $addl_handler_use_file ) {    use FS::Conf;    use FS::CGI qw(header menubar table itable ntable idiot                   eidiot myexit http_header); -  use FS::UI::Web qw(svc_url); +  use FS::UI::Web qw(svc_url random_id);    use FS::UI::Web::small_custview qw(small_custview);    use FS::UI::bytecount;    use FS::Msgcat qw(gettext geterror); diff --git a/FS/FS/Record.pm b/FS/FS/Record.pm index 72745fe13..ef0d88d80 100644 --- a/FS/FS/Record.pm +++ b/FS/FS/Record.pm @@ -519,6 +519,7 @@ sub qsearch {      # Check for encrypted fields and decrypt them.     ## only in the local copy, not the cached object +    no warnings 'deprecated'; # XXX silence the warning for now      if ( $conf_encryption            && eval 'defined(@FS::'. $table . '::encrypted_fields)' ) {        foreach my $record (@return) { diff --git a/FS/FS/UI/Web.pm b/FS/FS/UI/Web.pm index b301e99b5..69de5e157 100644 --- a/FS/FS/UI/Web.pm +++ b/FS/FS/UI/Web.pm @@ -15,11 +15,13 @@ use FS::cust_main;  # are sql_balance and sql_date_balance in the right module?  #@ISA = qw( FS::UI );  @ISA = qw( Exporter ); -@EXPORT_OK = qw( svc_url ); +@EXPORT_OK = qw( svc_url random_id );  $DEBUG = 0;  $me = '[FS::UID::Web]'; +our $NO_RANDOM_IDS; +  ###  # date parsing  ### @@ -608,6 +610,35 @@ sub is_mobile {    return 0;  } +=item random_id [ DIGITS ] + +Returns a random number of length DIGITS, or if unspecified, a long random  +identifier consisting of the timestamp, process ID, and a random number. +Anything in the UI that needs a random identifier should use this. + +=cut + +sub random_id { +  my $digits = shift; +  if (!defined $NO_RANDOM_IDS) { +    my $conf = FS::Conf->new; +    $NO_RANDOM_IDS = $conf->exists('no_random_ids') ? 1 : 0; +  } +  if ( $NO_RANDOM_IDS ) { +    if ( $digits > 0 ) { +      return 0; +    } else { +      return '0000000000-0000-000000000.000000'; +    } +  } else { +    if ($digits > 0) { +      return int(rand(10 ** $digits)); +    } else { +      return time . "-$$-" . rand() * 2**32; +    } +  } +} +  =back  =cut diff --git a/httemplate/elements/bill.html b/httemplate/elements/bill.html index 64a1a6d2c..420a7489b 100644 --- a/httemplate/elements/bill.html +++ b/httemplate/elements/bill.html @@ -45,7 +45,7 @@ my $label     = $opt{'label'};  # formname no longer needs to be passed from outside, but we still   # need one and it needs to be unique  my $formname  = $opt{'formname'} || -                'bill'.sprintf('%04d',int(rand(10000))).$custnum; +                'bill'.sprintf('%04d',random_id(4)).$custnum;  my $url       = $opt{'url'} || '';  my $message   = $opt{'message'} || 'Finished!';  my $bill_opts = $opt{'bill_opts'} || {}; diff --git a/httemplate/elements/columnstart.html b/httemplate/elements/columnstart.html index 1ffbcb9e8..245c308a7 100644 --- a/httemplate/elements/columnstart.html +++ b/httemplate/elements/columnstart.html @@ -10,7 +10,7 @@  Pass 'aligned' => 1 to have corresponding rows in the columns line up.  </%doc> -% my $id = sprintf('table%08d', rand(100000000)); +% my $id = sprintf('table%08d', random_id(8));  <TR>    <TD CLASS="background" COLSPAN=99>      <TABLE BORDER=0 CELLSPACING=0 CELLPADDING=0 id="<%$id%>"> diff --git a/httemplate/elements/create_uri_query b/httemplate/elements/create_uri_query index ce6249e0e..414d53ba4 100644 --- a/httemplate/elements/create_uri_query +++ b/httemplate/elements/create_uri_query @@ -18,7 +18,7 @@ my $query = $cgi->query_string;  if ( length($query) > 1920 || $opt{secure} ) { #stupid IE 2083 URL limit -  my $session = int(rand(4294967296)); #XXX +  my $session = random_id(9);    my $pref = new FS::access_user_pref({      'usernum'    => $FS::CurrentUser::CurrentUser->usernum,      'prefname'   => "redirect$session", diff --git a/httemplate/elements/input-fcc_options.html b/httemplate/elements/input-fcc_options.html index 064c647fc..080b40f88 100644 --- a/httemplate/elements/input-fcc_options.html +++ b/httemplate/elements/input-fcc_options.html @@ -9,7 +9,7 @@  % }  % unless ($opt{html_only}) {  %   my $popup = $fsurl.'misc/part_pkg_fcc_options.html?id='; -%   my $popup_name = 'popup-'.time. "-$$-". rand() * 2**32; +%   my $popup_name = 'popup-'.random_id();  <SCRIPT TYPE="text/javascript">  function edit_fcc_options() {    var id = this.dataset['target']; diff --git a/httemplate/elements/pickcolor.html b/httemplate/elements/pickcolor.html index d410ebfc7..2b0647fbf 100644 --- a/httemplate/elements/pickcolor.html +++ b/httemplate/elements/pickcolor.html @@ -38,7 +38,7 @@ my %opt = @_;  my $value = length($opt{curr_value}) ? $opt{curr_value} : $opt{value}; -my $unum = int(rand(100000)); +my $unum = random_id(5);  my $id = $opt{'id'} || $opt{'field'}.$unum; diff --git a/httemplate/elements/popup_link_onclick.html b/httemplate/elements/popup_link_onclick.html index 5173115a5..09ce93e7a 100644 --- a/httemplate/elements/popup_link_onclick.html +++ b/httemplate/elements/popup_link_onclick.html @@ -62,7 +62,7 @@ $scrolling   = $params->{'scrolling'}   if exists $params->{'scrolling'};  #stupid safari is caching the "location" of popup iframs, and submitting them  #instead of displaying them.  this should prevent that. -my $popup_name = 'popup-'.time. "-$$-". rand() * 2**32; +my $popup_name = 'popup-'.random_id();  my $onclick =    "overlib( OLiframeContent($action, $width, $height, '$popup_name', 0, '$scrolling' ), ". diff --git a/httemplate/elements/progress-init.html b/httemplate/elements/progress-init.html index 5b42aa1a8..2728240ef 100644 --- a/httemplate/elements/progress-init.html +++ b/httemplate/elements/progress-init.html @@ -170,6 +170,6 @@ $progress_url->query_form(  #stupid safari is caching the "location" of popup iframs, and submitting them  #instead of displaying them.  this should prevent that. -my $popup_name = 'popup-'.time. "-$$-". rand() * 2**32; +my $popup_name = 'popup-'.random_id();  </%init> diff --git a/httemplate/elements/tr-input-mask.html b/httemplate/elements/tr-input-mask.html index fdd20962d..93e322c6c 100644 --- a/httemplate/elements/tr-input-mask.html +++ b/httemplate/elements/tr-input-mask.html @@ -68,7 +68,7 @@ my $init = 0;  <%init>  my %opt = @_;  # must have a DOM id -my $id = $opt{id} || sprintf('input%04d',int(rand(10000))); +my $id = $opt{id} || sprintf('input%04d',random_id(4));  my $value = length($opt{curr_value}) ? $opt{curr_value} : $opt{value} || '';  my $clipboard_hack = $FS::CurrentUser::CurrentUser->option('enable_mask_clipboard_hack'); diff --git a/httemplate/graph/elements/report.html b/httemplate/graph/elements/report.html index cffc82816..f1b0d166d 100644 --- a/httemplate/graph/elements/report.html +++ b/httemplate/graph/elements/report.html @@ -331,7 +331,7 @@ if ( $cgi->param('session') =~ /^(\d+)$/ ) {    %opt = %{ $m->cache->get($session) };  }  else { -  $session = sprintf("%010d%06d", time, int(rand(1000000))); +  $session = sprintf("%010d", random_id(10));    $m->cache->set($session, \%opt, '1h');  } | 
