Prune.php
[Pman.Core] / Prune.php
1 <?php
2
3
4 /**
5  * Description of Prune
6  *
7  * @author chris
8  */
9
10 require_once 'Pman.php';
11 class Pman_Core_Prune extends Pman
12 {
13     //put your code here
14     static $cli_desc = "Core Prune -- remove old event data (6 months is normally a good idea).";
15     static $cli_opts = array(
16         'months' => array(
17             'desc' => 'How many months',
18             //'default' => 0,
19             'short' => 'm',
20             'min' => 1,
21             'max' => 1,
22             
23         )
24     );
25     var $cli = false;
26     
27     function getAuth() {
28         $ff = HTML_FlexyFramework::get();
29         if (!empty($ff->cli)) {
30             $this->cli = true;
31             return true;
32         }
33 //        return true;// for test only
34         return false;
35     }
36     
37     function get($m="", $opts)
38     {
39         
40         // prune irrelivant stuff..
41        
42         
43         
44         $this->prune((int)$opts['months']);
45     }
46     
47     function prune($inM)
48     {
49         // 40 seconds ? to delete 100K records..
50        // DB_DataObject::debugLevel(1);
51         $f = DB_DataObject::Factory('reader_article');
52         $f->query("
53             DELETE FROM Events where 
54                   event_when < NOW() - INTERVAL {$inM} MONTH
55                   LIMIT 100000
56         ");
57         
58         // notificication events occur alot - so we should trash them more frequently..
59         $f = DB_DataObject::Factory('reader_article');
60         $f->query("
61             DELETE FROM Events where 
62                   event_when < NOW() - INTERVAL 1 MONTH
63                   AND
64                   action IN ('NOTIFY')
65                   LIMIT 100000
66         ");
67         
68         // rather than deleting them all, it's probably best to just delete notify events that occured to often.
69         // eg. when we tried to deliver multiple times without success...
70         
71         
72         
73         // pruning is for our press project - so we do not clean up dependant tables at present..
74         
75         if (function_exists('posix_getpwuid')) {
76             $uinfo = posix_getpwuid( posix_getuid () ); 
77          
78             $user = $uinfo['name'];
79         } else {
80             $user = getenv('USERNAME'); // windows.
81         }
82         
83         $ff = HTML_Flexyframework::get()->Pman;
84         
85         $y = date("Y");
86         $m = date("m");
87         $rootDir = $ff['storedir'].'/_events_/'.$user;
88         
89         $dirs = array_filter(glob($rootDir."/*"), 'is_dir');
90         foreach($dirs as $d){
91             $mdirs = array_filter(glob($d."/*"), 'is_dir');
92             foreach($mdirs as $md){
93                 $dirDate = str_replace($rootDir."/", '', $md);
94                 if(strtotime($dirDate."/01") < strtotime("now - {$inM} months")){
95                     //echo "remove $md\n";
96                     $this->delTree($md);
97                       //  echo $md . " is removed. \n";
98                     
99                 }
100             }
101         }
102         
103         exit;
104     }
105     
106     function delTree($dir)
107     {
108         $files = array_diff(scandir($dir), array('.','..'));
109         echo "$dir : Removing " . count($files) . " files\n";
110         clearstatcache();
111         foreach ($files as $file){
112             if (!file_exists("$dir/$file")) {
113                 continue;
114             }
115             if (is_dir("$dir/$file")) {
116                 $this->delTree("$dir/$file");
117                 continue;
118             }
119             unlink("$dir/$file");
120         }
121         return rmdir($dir); 
122     }
123     
124 }