/[BackupPC]/trunk/lib/BackupPC/SearchLib.pm
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /trunk/lib/BackupPC/SearchLib.pm

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 86 by dpavlin, Sun Aug 28 12:35:59 2005 UTC revision 155 by dpavlin, Mon Oct 10 13:04:48 2005 UTC
# Line 15  my $pager_pages = 10; Line 15  my $pager_pages = 10;
15  my $dsn = $Conf{SearchDSN};  my $dsn = $Conf{SearchDSN};
16  my $db_user = $Conf{SearchUser} || '';  my $db_user = $Conf{SearchUser} || '';
17    
18  my $index_path = $Conf{HyperEstraierIndex};  my $hest_index_path = $Conf{HyperEstraierIndex};
 if ($index_path) {  
         $index_path = $TopDir . '/' . $index_path;  
         $index_path =~ s#//#/#g;  
 }  
19    
20  my $dbh;  my $dbh;
21    
# Line 62  sub dates_from_form($) { Line 58  sub dates_from_form($) {
58          sub mk_epoch_date($$) {          sub mk_epoch_date($$) {
59                  my ($name,$suffix) = @_;                  my ($name,$suffix) = @_;
60    
61                  my $yyyy = $param->{ $name . '_year_' . $suffix} || return;                  my $yyyy = $param->{ $name . '_year_' . $suffix} || return undef;
62                  my $mm .= $param->{ $name . '_month_' . $suffix} ||                  my $mm .= $param->{ $name . '_month_' . $suffix} ||
63                          ( $suffix eq 'from' ? 1 : 12);                          ( $suffix eq 'from' ? 1 : 12);
64                  my $dd .= $param->{ $name . '_day_' . $suffix} ||                  my $dd .= $param->{ $name . '_day_' . $suffix} ||
65                          ( $suffix eq 'from' ? 1 : 31);                          ( $suffix eq 'from' ? 1 : 31);
66    
67                    $yyyy =~ s/\D//g;
68                    $mm =~ s/\D//g;
69                    $dd =~ s/\D//g;
70    
71                  my $dt = new DateTime(                  my $dt = new DateTime(
72                          year => $yyyy,                          year => $yyyy,
73                          month => $mm,                          month => $mm,
74                          day => $dd                          day => $dd
75                  );                  );
76                    print STDERR "mk_epoch_date($name,$suffix) [$yyyy-$mm-$dd] = " . $dt->ymd . " " . $dt->hms . "\n";
77                  return $dt->epoch || 'NULL';                  return $dt->epoch || 'NULL';
78          }          }
79    
80          return (          my @ret = (
81                  mk_epoch_date('search_backup', 'from'),                  mk_epoch_date('search_backup', 'from'),
82                  mk_epoch_date('search_backup', 'to'),                  mk_epoch_date('search_backup', 'to'),
83                  mk_epoch_date('search', 'from'),                  mk_epoch_date('search', 'from'),
84                  mk_epoch_date('search', 'to'),                  mk_epoch_date('search', 'to'),
85          );          );
86    
87            return @ret;
88    
89  }  }
90    
91    
# Line 104  sub getWhere($) { Line 109  sub getWhere($) {
109  }  }
110    
111    
112  sub getFiles($$) {  sub getFiles($) {
113          my ($param, $offset) = @_;          my ($param) = @_;
114    
115            my $offset = $param->{'offset'} || 0;
116            $offset *= $on_page;
117    
118          my $dbh = get_dbh();          my $dbh = get_dbh();
119    
# Line 113  sub getFiles($$) { Line 121  sub getFiles($$) {
121                  files.id                        AS fid,                  files.id                        AS fid,
122                  hosts.name                      AS hname,                  hosts.name                      AS hname,
123                  shares.name                     AS sname,                  shares.name                     AS sname,
                 -- shares.share                 AS sharename,  
124                  files.backupnum                 AS backupnum,                  files.backupnum                 AS backupnum,
                 -- files.name                   AS filename,  
125                  files.path                      AS filepath,                  files.path                      AS filepath,
126                  files.date                      AS date,                  files.date                      AS date,
127                  files.type                      AS type,                  files.type                      AS type,
128                  files.size                      AS size,                  files.size                      AS size
                 -- dvds.name                    AS dvd  
                 null                            AS dvd  
129          };          };
130    
131          my $sql_from = qq{          my $sql_from = qq{
132                  FROM files                  FROM files
133                          INNER JOIN shares       ON files.shareID=shares.ID                          INNER JOIN shares       ON files.shareID=shares.ID
134                          INNER JOIN hosts        ON hosts.ID = shares.hostID                          INNER JOIN hosts        ON hosts.ID = shares.hostID
135                          INNER JOIN backups      ON backups.num = files.backupnum and backups.hostID = hosts.ID AND backups.shareID = shares.ID                          INNER JOIN backups      ON backups.num = files.backupnum and backups.hostID = hosts.ID AND backups.shareID = files.shareID
         };  
   
         my $sql_dvd_from = qq{  
                         -- LEFT  JOIN dvds              ON dvds.ID = files.dvdid  
136          };          };
137    
138          my $sql_where;          my $sql_where;
# Line 146  sub getFiles($$) { Line 146  sub getFiles($$) {
146          };          };
147    
148          my $sql_count = qq{ select count(files.id) $sql_from $sql_where };          my $sql_count = qq{ select count(files.id) $sql_from $sql_where };
149          my $sql_results = qq{ select $sql_cols $sql_from $sql_dvd_from $sql_where $sql_order };          my $sql_results = qq{ select $sql_cols $sql_from $sql_where $sql_order };
   
         $offset ||= 0;  
         $offset = ($offset * $on_page);  
150    
151          my $sth = $dbh->prepare($sql_count);          my $sth = $dbh->prepare($sql_count);
152          $sth->execute();          $sth->execute();
# Line 174  sub getFiles($$) { Line 171  sub getFiles($$) {
171          return ($results, \@ret);          return ($results, \@ret);
172  }  }
173    
174  sub getFilesHyperEstraier($$) {  sub getHyperEstraier_url($) {
175          my ($param, $offset) = @_;          my ($use_hest) = @_;
176    
177          die "no index_path?" unless ($index_path);          return unless $use_hest;
178    
179          use HyperEstraier;          use HyperEstraier;
180            my ($index_path, $index_node_url);
181    
182            if ($use_hest =~ m#^http://#) {
183                    $index_node_url = $use_hest;
184            } else {
185                    $index_path = $TopDir . '/' . $index_path;
186                    $index_path =~ s#//#/#g;
187            }
188            return ($index_path, $index_node_url);
189    }
190    
191    sub getFilesHyperEstraier($) {
192            my ($param) = @_;
193    
194            my $offset = $param->{'offset'} || 0;
195            $offset *= $on_page;
196    
197            die "no index_path?" unless ($hest_index_path);
198    
199            use HyperEstraier;
200    
201            my ($index_path, $index_node_url) = getHyperEstraier_url($hest_index_path);
202    
203          # open the database          # open the database
204          my $db = HyperEstraier::Database->new();          my $db;
205          $db->open($index_path, $HyperEstraier::ESTDBREADER);          if ($index_path) {
206                    $db = HyperEstraier::Database->new();
207                    $db->open($index_path, $HyperEstraier::ESTDBREADER);
208            } elsif ($index_node_url) {
209                    $db ||= HyperEstraier::Node->new($index_node_url);
210                    $db->set_auth('admin', 'admin');
211            } else {
212                    die "BUG: unimplemented";
213            }
214    
215          # create a search condition object          # create a search condition object
216          my $cond = HyperEstraier::Condition->new();          my $cond = HyperEstraier::Condition->new();
# Line 191  sub getFilesHyperEstraier($$) { Line 218  sub getFilesHyperEstraier($$) {
218          my $q = $param->{'search_filename'};          my $q = $param->{'search_filename'};
219          my $shareid = $param->{'search_share'};          my $shareid = $param->{'search_share'};
220    
221          if ($q) {          if (length($q) > 0) {
222                  $q =~ s/(.)/$1 /g;                  # exact match
223                    $cond->add_attr("filepath ISTRINC $q");
224    
225                    $q =~ s/(.)/$1 /g;
226                  # set the search phrase to the search condition object                  # set the search phrase to the search condition object
227                  $cond->set_phrase($q);                  $cond->set_phrase($q);
228            }
229    
230                  my ($backup_from, $backup_to, $files_from, $files_to) = dates_from_form($param);          my ($backup_from, $backup_to, $files_from, $files_to) = dates_from_form($param);
   
                 $cond->add_attr("backup_date NUMGE $backup_from") if ($backup_from);  
                 $cond->add_attr("backup_date NUMLE $backup_to") if ($backup_to);  
231    
232                  $cond->add_attr("date NUMGE $files_from") if ($files_from);          $cond->add_attr("backup_date NUMGE $backup_from") if ($backup_from);
233                  $cond->add_attr("date NUMLE $files_to") if ($files_to);          $cond->add_attr("backup_date NUMLE $backup_to") if ($backup_to);
234    
235                  $cond->add_attr("shareid NUMEQ $shareid") if ($shareid);          $cond->add_attr("date NUMGE $files_from") if ($files_from);
236          }          $cond->add_attr("date NUMLE $files_to") if ($files_to);
237    
238          $offset ||= 0;          $cond->add_attr("shareid NUMEQ $shareid") if ($shareid);
         $offset = ($offset * $on_page);  
239    
240  #       $cond->set_max( $offset + $on_page );  #       $cond->set_max( $offset + $on_page );
241          $cond->set_options( $HyperEstraier::Condition::SURE );          $cond->set_options( $HyperEstraier::Condition::SURE );
242          $cond->set_order( 'date NUMA' );          $cond->set_order( 'date NUMA' );
243    
244          # get the result of search          # get the result of search
         my $result = $db->search($cond, 0);  
         $result->get(0);  
   
245          my @res;          my @res;
246          my $hits = $result->size;          my ($result, $hits);
247    
248            if ($index_path) {
249                    $result = $db->search($cond, 0);
250                    $hits = $result->size;
251            } elsif ($index_node_url) {
252                    $result = $db->search($cond, 0);
253                    $hits = $result->doc_num;
254            } else {
255                    die "BUG: unimplemented";
256            }
257    
258          # for each document in result          # for each document in result
259          for my $i ($offset .. $result->size-1) {          for my $i ($offset .. ($offset + $on_page - 1)) {
260                  my $id = $result->get($i);                  last if ($i >= $hits);
261                  my $doc = $db->get_doc($id, 0);  
262                    my $doc;
263                    if ($index_path) {
264                            my $id = $result->get($i);
265                            $doc = $db->get_doc($id, 0);
266                    } elsif ($index_node_url) {
267                            $doc = $result->get_doc($i);
268                    } else {
269                            die "BUG: unimplemented";
270                    }
271    
272                  my $row;                  my $row;
273                  foreach my $c (qw/fid hname sname backupnum fiilename filepath date type size/) {                  foreach my $c (qw/fid hname sname backupnum fiilename filepath date type size/) {
# Line 237  sub getFilesHyperEstraier($$) { Line 279  sub getFilesHyperEstraier($$) {
279          return ($hits, \@res);          return ($hits, \@res);
280  }  }
281    
282    sub getGzipName($$$)
283    {
284            my ($host, $share, $backupnum) = @_;
285            my $ret = $Conf{GzipSchema};
286            
287            $share =~ s/\//_/g;
288            $ret =~ s/\\h/$host/ge;
289            $ret =~ s/\\s/$share/ge;
290            $ret =~ s/\\n/$backupnum/ge;
291    
292            $ret =~ s/__+/_/g;
293    
294            return $ret;
295            
296    }
297    
298    sub getGzipSize($$)
299    {
300            my ($hostID, $backupNum) = @_;
301            my $ret;
302            my $sql;
303            my $dbh = get_dbh();
304            
305            $sql = q{
306                                    SELECT hosts.name  as host,
307                                               shares.name as share,
308                                               backups.num as backupnum
309                                    FROM hosts, backups, shares
310                                    WHERE shares.id=backups.shareid AND
311                                              hosts.id =backups.hostid AND
312                                              hosts.id=? AND
313                                              backups.num=?
314                            };
315            my $sth = $dbh->prepare($sql);
316            $sth->execute($hostID, $backupNum);
317    
318            my $row = $sth->fetchrow_hashref();
319            
320            my (undef,undef,undef,undef,undef,undef,undef,$ret,undef,undef,undef,undef,undef) =
321                            stat( $Conf{InstallDir}.'/'.$Conf{GzipTempDir}.'/'.
322                                    getGzipName($row->{'host'}, $row->{share}, $row->{'backupnum'}));
323            
324            return $ret;    
325    }
326    
327  sub getBackupsNotBurned() {  sub getBackupsNotBurned() {
328    
329          my $dbh = get_dbh();          my $dbh = get_dbh();
330          my $sql = q{  
331          SELECT          my $sql = q{
332                  backups.hostID          AS hostid,                  SELECT
333                  min(hosts.name)         AS host,                          backups.hostID AS hostID,
334                  backups.num             AS backupnum,                          hosts.name AS host,
335                  min(backups.type)       AS type,                          shares.name AS share,
336                  min(backups.date)       AS date,                          backups.num AS backupnum,
337                  min(backups.size)       AS size                          backups.type AS type,
338          FROM files                          backups.date AS date,
339                  INNER JOIN shares       ON files.shareID=shares.ID                          backups.size AS size,
340                  INNER JOIN hosts        ON hosts.ID = shares.hostID                          backups.id AS id
341                  INNER JOIN backups      ON backups.num = files.backupnum and backups.hostID = hosts.ID AND backups.shareID = shares.ID                  FROM backups
342          WHERE                  INNER JOIN shares       ON backups.shareID=shares.ID
343                  files.dvdid     IS NULL                  INNER JOIN hosts        ON backups.hostID = hosts.ID
344          GROUP BY                  LEFT OUTER JOIN archive_backup ON archive_backup.backup_id = backups.id
345                  backups.hostID, backups.num                  WHERE backups.size > 0 AND archive_backup.backup_id IS NULL
346          ORDER BY min(backups.date)                  GROUP BY
347                            backups.hostID,
348                            hosts.name,
349                            shares.name,
350                            backups.num,
351                            backups.shareid,
352                            backups.id,
353                            backups.type,
354                            backups.date,
355                            backups.size
356                    ORDER BY backups.date
357          };          };
358          my $sth = $dbh->prepare( $sql );          my $sth = $dbh->prepare( $sql );
359          my @ret;          my @ret;
# Line 265  sub getBackupsNotBurned() { Line 362  sub getBackupsNotBurned() {
362          while ( my $row = $sth->fetchrow_hashref() ) {          while ( my $row = $sth->fetchrow_hashref() ) {
363                  $row->{'age'} = sprintf("%0.1f", ( (time() - $row->{'date'}) / 86400 ) );                  $row->{'age'} = sprintf("%0.1f", ( (time() - $row->{'date'}) / 86400 ) );
364                  $row->{'size'} = sprintf("%0.2f", $row->{'size'} / 1024 / 1024);                  $row->{'size'} = sprintf("%0.2f", $row->{'size'} / 1024 / 1024);
365                    my (undef,undef,undef,undef,undef,undef,undef,$fs_size,undef,undef,undef,undef,undef) =
366                            stat( $Conf{InstallDir}.'/'.$Conf{GzipTempDir}.'/'.
367                                    getGzipName($row->{'host'}, $row->{share}, $row->{'backupnum'}));
368                    $row->{'fs_size'} = $fs_size;
369                  push @ret, $row;                  push @ret, $row;
370          }          }
371                
372          return @ret;                return @ret;      
373  }  }
374    
375  sub displayBackupsGrid()  sub displayBackupsGrid() {
376    {  
377        my $retHTML = "";          my $retHTML .= q{
378        my $addForm = 1;                  <form id="forma" method="POST" action="}.$MyURL.q{?action=burn">
379                  };
       if ($addForm) {  
380    
381              $retHTML .= <<EOF3;          $retHTML .= <<'EOF3';
382  <script language="javascript" type="text/javascript">  <style type="text/css">
383  <!--  <!--
384    DIV#fixedBox {
385            position: absolute;
386            top: 50em;
387            left: -24%;
388            padding: 0.5em;
389            width: 20%;
390            background-color: #E0F0E0;
391            border: 1px solid #00C000;
392    }
393    
394    DIV#fixedBox, DIV#fixedBox INPUT, DIV#fixedBox TEXTAREA {
395            font-size: 10pt;
396    }
397    
398    FORM>DIV#fixedBox {
399            position: fixed !important;
400            left: 0.5em !important;
401            top: auto !important;
402            bottom: 1em !important;
403            width: 15% !important;
404    }
405    
406      function checkAll(location)  DIV#fixedBox INPUT[type=text], DIV#fixedBox TEXTAREA {
407      {          border: 1px solid #00C000;
408        for (var i=0;i<document.forma.elements.length;i++)  }
409        {  
410          var e = document.forma.elements[i];  DIV#fixedBox #note {
411          if ((e.checked || !e.checked) && e.name != \'all\') {          display: block;
412              if (eval("document.forma."+location+".checked")) {          width: 100%;
413                  e.checked = true;  }
414              } else {  
415                  e.checked = false;  DIV#fixedBox #submitBurner {
416              }          display: block;
417          }          width: 100%;
418        }          margin-top: 0.5em;
419      }          cursor: pointer;
420  //-->  }
421  </script>        
422    * HTML {
423            overflow-y: hidden;
424    }
425    
426    * HTML BODY {
427            overflow-y: auto;
428            height: 100%;
429            font-size: 100%;
430    }
431    
432    * HTML DIV#fixedBox {
433            position: absolute;
434    }
435    
436    #mContainer, #gradient, #mask, #progressIndicator {
437            display: block;
438            width: 100%;
439            font-size: 10pt;
440            font-weight: bold;
441            text-align: center;
442            vertical-align: middle;
443            padding: 1px;
444    }
445    
446    #gradient, #mask, #progressIndicator {
447            left: 0;
448            border-width: 1px;
449            border-style: solid;
450            border-color: #000000;
451            color: #404040;
452            margin: 0.4em;
453            position: absolute;
454            margin-left: -1px;
455            margin-top: -1px;
456            margin-bottom: -1px;
457            overflow: hidden;
458    }
459    
460    #mContainer {
461            display: block;
462            position: relative;
463            padding: 0px;
464            margin-top: 0.4em;
465            margin-bottom: 0.5em;
466    }
467    
468    #gradient {
469            z-index: 1;
470            background-color: #FFFF00;
471    }
472    
473    #mask {
474            z-index: 2;
475            background-color: #FFFFFF;
476    }
477    
478    #progressIndicator {
479            z-index: 3;
480            background-color: transparent;
481    }
482    -->
483    </style>
484    <script type="text/javascript">
485    <!--
486    
487    var debug_div = null;
488  EOF3  EOF3
489                $retHTML .= q{<form name="forma" method="GET" action="}."$MyURL"."?action=burn\"";  
490                $retHTML.= q{<input type="hidden" value="burn" name="action">};          # take maximum archive size from configuration
491                $retHTML .= q{<input type="hidden" value="results" name="search_results">};          $retHTML .= 'var media_size = '. $Conf{MaxArchiveSize} .';';
492    
493            $retHTML .= <<'EOF3';
494    
495    function debug(msg) {
496    //      return; // Disable debugging
497    
498            if (! debug_div) debug_div = document.getElementById('debug');
499    
500            // this will create debug div if it doesn't exist.
501            if (! debug_div) {
502                    debug_div = document.createElement('div');
503                    if (document.body) document.body.appendChild(debug_div);
504                    else debug_div = null;
505          }          }
506          $retHTML .= qq{          if (debug_div) {
507                  <table style="fview" border="1" cellspacing="0" cellpadding="3">                  debug_div.appendChild(document.createTextNode(msg));
508                  <tr class="tableheader">                  debug_div.appendChild(document.createElement("br"));
509          };          }
510    }
511    
512          if ($addForm) {  
513              $retHTML .= "<td class=\"tableheader\"><input type=\"checkbox\" name=\"allFiles\" onClick=\"checkAll('allFiles');\"></td>";  var element_id_cache = Array();
514    
515    function element_id(name,element) {
516            if (! element_id_cache[name]) {
517                    element_id_cache[name] = self.document.getElementById(name);
518          }          }
519          $retHTML .=  qq{          return element_id_cache[name];
520                  <td align="center">Host</td>  }
                 <td align="center">Backup no</td>  
                 <td align="center">Type</td>  
                 <td align="center">date</td>  
                 <td align="center">age/days</td>  
                 <td align="center">size/MB</td>  
                 </tr>  
         };  
521    
522          my @backups = getBackupsNotBurned();  function checkAll(location) {
523          my $backup;          var f = element_id('forma') || null;
524            if (!f) return false;
525    
526            var len = f.elements.length;
527            var check_all = element_id('allFiles');
528            var suma = check_all.checked ? (parseInt(f.elements['totalsize'].value) || 0) : 0;
529    
530            for (var i = 0; i < len; i++) {
531                    var e = f.elements[i];
532                    if (e.name != 'all' && e.name.substr(0, 3) == 'fcb') {
533                            if (check_all.checked) {
534                                    if (e.checked) continue;
535                                    var el = element_id("fss" + e.name.substr(3));
536                                    var size = parseInt(el.value) || 0;
537                                    debug('suma: '+suma+' size: '+size);
538                                    if ((suma + size) < media_size) {
539                                            suma += size;
540                                            e.checked = true;
541                                    } else {
542                                            break;
543                                    }
544                            } else {
545                                    e.checked = false;
546                            }
547                    }
548            }
549            update_sum(suma);
550    }
551    
552          if ($addForm) {  function update_sum(suma) {
553                  $retHTML .= qq{          element_id('forma').elements['totalsize'].value = suma;
554                          <tr><td colspan=7 style="tableheader">          pbar_set(suma, media_size);
555                          <input type="submit" value="Burn selected backups on medium" name="submitBurner">          debug('total size: ' + suma);
556                          </td></tr>  }
557                  };  
558    function sumiraj(e) {
559            var suma = parseInt(element_id('forma').elements['totalsize'].value) || 0;
560            var len = element_id('forma').elements.length;
561            if (e) {
562                    var size = parseInt( element_id("fss" + e.name.substr(3)).value);
563                    if (e.checked) {
564                            suma += size;
565                    } else {
566                            suma -= size;
567                    }
568            } else {
569                    suma = 0;
570                    for (var i = 0; i < len; i++) {
571                            var e = element_id('forma').elements[i];
572                            if (e.name != 'all' && e.checked && e.name.substr(0,3) == 'fcb') {
573                                    var el = element_id("fss" + e.name.substr(3));
574                                    if (el && el.value) suma += parseInt(el.value) || 0;
575                            }
576                    }
577          }          }
578            update_sum(suma);
579            return suma;
580    }
581    
582    /* progress bar */
583    
584          foreach $backup(@backups) {  var _pbar_width = null;
585    var _pbar_warn = 10;    // change color in last 10%
586    
587    function pbar_reset() {
588            element_id("mask").style.left = "0px";
589            _pbar_width = element_id("mContainer").offsetWidth - 2;
590            element_id("mask").style.width = _pbar_width + "px";
591            element_id("mask").style.display = "block";
592            element_id("progressIndicator").style.zIndex  = 10;
593            element_id("progressIndicator").innerHTML = "0";
594    }
595    
596    function dec2hex(d) {
597            var hch = '0123456789ABCDEF';
598            var a = d % 16;
599            var q = (d - a) / 16;
600            return hch.charAt(q) + hch.charAt(a);
601    }
602    
603    function pbar_set(amount, max) {
604            debug('pbar_set('+amount+', '+max+')');
605    
606            if (_pbar_width == null) {
607                    var _mc = element_id("mContainer");
608                    if (_pbar_width == null) _pbar_width = parseInt(_mc.offsetWidth ? (_mc.offsetWidth - 2) : 0) || null;
609                    if (_pbar_width == null) _pbar_width = parseInt(_mc.clientWidth ? (_mc.clientWidth + 2) : 0) || null;
610                    if (_pbar_width == null) _pbar_width = 0;
611            }
612    
613            var pcnt = Math.floor(amount * 100 / max);
614            var p90 = 100 - _pbar_warn;
615            var pcol = pcnt - p90;
616            if (Math.round(pcnt) <= 100) {
617                    if (pcol < 0) pcol = 0;
618                    var e = element_id("submitBurner");
619                    debug('enable_button');
620                    e.disabled = false;
621                    var a = e.getAttributeNode('disabled') || null;
622                    if (a) e.removeAttributeNode(a);
623            } else {
624                    debug('disable button');
625                    pcol = _pbar_warn;
626                    var e = element_id("submitBurner");
627                    if (!e.disabled) e.disabled = true;
628            }
629            var col_g = Math.floor((_pbar_warn - pcol) * 255 / _pbar_warn);
630            var col = '#FF' + dec2hex(col_g) + '00';
631    
632            //debug('pcol: '+pcol+' g:'+col_g+' _pbar_warn:'+ _pbar_warn + ' color: '+col);
633            element_id("gradient").style.backgroundColor = col;
634    
635            element_id("progressIndicator").innerHTML = pcnt + '%';
636            //element_id("progressIndicator").innerHTML = amount;
637    
638            element_id("mask").style.clip = 'rect(' + Array(
639                    '0px',
640                    element_id("mask").offsetWidth + 'px',
641                    element_id("mask").offsetHeight + 'px',
642                    Math.round(_pbar_width * amount / max) + 'px'
643            ).join(' ') + ')';
644    }
645    
646    if (!self.body) self.body = new Object();
647    self.onload = self.document.onload = self.body.onload = function() {
648            //pbar_reset();
649            sumiraj();
650    };
651    
652    // -->
653    </script>
654    <div id="fixedBox">
655    
656    Size: <input type="text" name="totalsize" size="7" readonly="readonly" style="text-align:right;" value="0" /> kB
657    
658    <div id="mContainer">
659            <div id="gradient">&nbsp;</div>
660            <div id="mask">&nbsp;</div>
661            <div id="progressIndicator">0%</div>
662    </div>
663    <br/>
664    
665    Note:
666    <textarea name="note" cols="10" rows="5" id="note"></textarea>
667    
668    <input type="submit" id="submitBurner" value="Burn selected" name="submitBurner" />
669    
670    </div>
671    <!--
672    <div id="debug" style="float: right; width: 10em; border: 1px #ff0000 solid; background-color: #ffe0e0; -moz-opacity: 0.7;">
673    no debug output yet
674    </div>
675    -->
676    EOF3
677            $retHTML .= q{
678                            <input type="hidden" value="burn" name="action">
679                            <input type="hidden" value="results" name="search_results">
680                            <table style="fview" border="0" cellspacing="0" cellpadding="2">
681                            <tr class="tableheader">
682                            <td class="tableheader">
683                                    <input type="checkbox" name="allFiles" id="allFiles" onClick="checkAll('allFiles');">
684                            </td>
685                            <td align="center">Share</td>
686                            <td align="center">Backup no</td>
687                            <td align="center">Type</td>
688                            <td align="center">date</td>
689                            <td align="center">age/days</td>
690                            <td align="center">size/MB</td>
691                            <td align="center">gzip size</td>
692                            </tr>
693    
694            };
695    
696            my @color = (' bgcolor="#e0e0e0"', '');
697    
698            my $i = 0;
699            my $host = '';
700    
701            foreach my $backup ( getBackupsNotBurned() ) {
702    
703                    if ($host ne $backup->{'host'}) {
704                            $i++;
705                            $host = $backup->{'host'};
706                    }
707                  my $ftype = "";                  my $ftype = "";
               
                 $retHTML .= "<tr>";  
                 if ($addForm) {  
                         $retHTML .= '<td class="fview"><input type="checkbox" name="fcb' .  
                                 $backup->{'hostid'}.'_'.$backup->{'backupnum'} .  
                                 '" value="' . $backup->{'hostid'}.'_'.$backup->{'backupnum'} .  
                                 '"></td>';  
                 }            
               
                 $retHTML .= '<td class="fviewborder">' . $backup->{'host'} . '</td>' .  
                         '<td class="fviewborder">' . $backup->{'backupnum'} . '</td>' .  
                         '<td class="fviewborder">' . $backup->{'type'} . '</td>' .  
                         '<td class="fviewborder">' . epoch_to_iso( $backup->{'date'} ) . '</td>' .  
                         '<td class="fviewborder">' . $backup->{'age'} . '</td>' .  
                         '<td class="fviewborder">' . $backup->{'size'} . '</td>' .  
                         '</tr>';  
         }  
708    
709          $retHTML .= "</table>";                  my $checkbox_key = $backup->{'hostid'}. '_' .$backup->{'backupnum'} . '_' . $backup->{'id'};
710    
711          if ($addForm) {                  $retHTML .=
712                  $retHTML .= "</form>";                          '<tr' . $color[$i %2 ] . '>
713                            <td class="fview">';
714    
715                    # FIXME
716                    $backup->{'fs_size'} = int($backup->{'size'} * 1024);
717    
718                    if (($backup->{'fs_size'} || 0) > 0) {
719                            $retHTML .= '
720                            <input type="checkbox" name="fcb' . $checkbox_key . '" value="' . $checkbox_key . '" onClick="sumiraj(this);">';
721                    }
722    
723                    $retHTML .=
724                            '</td>' .
725                            '<td align="right">' . $backup->{'host'} . ':' . $backup->{'share'} . '</td>' .
726                            '<td align="center">' . $backup->{'backupnum'} . '</td>' .
727                            '<td align="center">' . $backup->{'type'} . '</td>' .
728                            '<td align="center">' . epoch_to_iso( $backup->{'date'} ) . '</td>' .
729                            '<td align="center">' . $backup->{'age'} . '</td>' .
730                            '<td align="right">' . $backup->{'size'} . '</td>' .
731                            '<td align="right">' . $backup->{'fs_size'} .
732                            '<input type="hidden" iD="fss'.$checkbox_key .'" value="'. $backup->{'fs_size'} .'"></td>' .
733    
734                            "</tr>\n";
735          }          }
736    
737            $retHTML .= "</table>";
738            $retHTML .= "</form>";
739                
740          return $retHTML;          return $retHTML;
741  }        }      
# Line 373  sub displayGrid($) { Line 751  sub displayGrid($) {
751          my $start_t = time();          my $start_t = time();
752    
753          my ($results, $files);          my ($results, $files);
754          if ($param->{'use_hest'}) {          if ($param->{'use_hest'} && length($hilite) > 0) {
755                  ($results, $files) = getFilesHyperEstraier($param, $offset);                  ($results, $files) = getFilesHyperEstraier($param);
756          } else {          } else {
757                  ($results, $files) = getFiles($param, $offset);                  ($results, $files) = getFiles($param);
758          }          }
759    
760          my $dur_t = time() - $start_t;          my $dur_t = time() - $start_t;
# Line 402  sub displayGrid($) { Line 780  sub displayGrid($) {
780          </div>          </div>
781          <table style="fview" width="100%" border="0" cellpadding="2" cellspacing="0">          <table style="fview" width="100%" border="0" cellpadding="2" cellspacing="0">
782                  <tr class="fviewheader">                  <tr class="fviewheader">
783                    <td></td>
784                  <td align="center">Share</td>                  <td align="center">Share</td>
785                  <td align="center">Type and Name</td>                  <td align="center">Type and Name</td>
786                  <td align="center">#</td>                  <td align="center">#</td>
# Line 426  sub displayGrid($) { Line 805  sub displayGrid($) {
805                  return sprintf(qq{<a href="?action=%s&host=%s&num=%d&share=%s&dir=%s">%s</a>}, $action, @_);                  return sprintf(qq{<a href="?action=%s&host=%s&num=%d&share=%s&dir=%s">%s</a>}, $action, @_);
806          }          }
807    
808            my $i = $offset * $on_page;
809    
810          foreach $file (@{ $files }) {          foreach $file (@{ $files }) {
811                    $i++;
812    
813                  my $typeStr  = BackupPC::Attrib::fileType2Text(undef, $file->{'type'});                  my $typeStr  = BackupPC::Attrib::fileType2Text(undef, $file->{'type'});
814                  $retHTML .= qq{<tr class="fviewborder">};                  $retHTML .= qq{<tr class="fviewborder">};
815    
816                    $retHTML .= qq{<td class="fviewborder">$i</td>};
817    
818                  $retHTML .=                  $retHTML .=
819                          qq{<td class="fviewborder" align="right">} . $file->{'hname'} . ':' . $file->{'sname'} . qq{</td>} .                          qq{<td class="fviewborder" align="right">} . $file->{'hname'} . ':' . $file->{'sname'} . qq{</td>} .
820                          qq{<td class="fviewborder"><img src="$Conf{CgiImageDirURL}/icon-$typeStr.gif" alt="$typeStr" align="middle">&nbsp;} . hilite_html( $file->{'filepath'}, $hilite ) . qq{</td>} .                          qq{<td class="fviewborder"><img src="$Conf{CgiImageDirURL}/icon-$typeStr.gif" alt="$typeStr" align="middle">&nbsp;} . hilite_html( $file->{'filepath'}, $hilite ) . qq{</td>} .
821                          qq{<td class="fviewborder" align="center">} . restore_link( $typeStr, ${EscURI( $file->{'hname'} )}, $file->{'backupnum'}, ${EscURI( $file->{'sname'})}, ${EscURI( $file->{'filepath'} )}, $file->{'backupnum'} ) . qq{</td>} .                          qq{<td class="fviewborder" align="center">} . restore_link( $typeStr, ${EscURI( $file->{'hname'} )}, $file->{'backupnum'}, ${EscURI( $file->{'sname'})}, ${EscURI( $file->{'filepath'} )}, $file->{'backupnum'} ) . qq{</td>} .
822                          qq{<td class="fviewborder" align="right">} . $file->{'size'} . qq{</td>} .                          qq{<td class="fviewborder" align="right">} . $file->{'size'} . qq{</td>} .
823                          qq{<td class="fviewborder">} . epoch_to_iso( $file->{'date'} ) . qq{</td>} .                          qq{<td class="fviewborder">} . epoch_to_iso( $file->{'date'} ) . qq{</td>} .
824                          qq{<td class="fviewborder">} . $file->{'dvd'} . qq{</td>};                          qq{<td class="fviewborder">} . '?' . qq{</td>};
825    
826                  $retHTML .= "</tr>";                  $retHTML .= "</tr>";
827          }          }

Legend:
Removed from v.86  
changed lines
  Added in v.155

  ViewVC Help
Powered by ViewVC 1.1.26