DataObjects/Core_curr_rate.php
[Pman.Core] / Mailer.php
index 4b04b6a..7ab5f95 100644 (file)
@@ -55,7 +55,7 @@
  */
 
 class Pman_Core_Mailer {
-    var $debug          = false;
+    var $debug          = 0;
     var $page           = false; /* usually a html_flexyframework_page */
     var $contents       = false; /* object or array */
     var $template       = false; /* string */
@@ -63,6 +63,7 @@ class Pman_Core_Mailer {
     var $rcpts   = false;
     var $templateDir = false;
     var $locale = false; // eg. 'en' or 'zh_HK'
+    var $urlmap = array();
     
     
     var $html_locale = false; // eg. 'en' or 'zh_HK'
@@ -86,7 +87,8 @@ class Pman_Core_Mailer {
         if (!empty($ff->Core_Mailer['debug'])) {
             $this->debug = $ff->Core_Mailer['debug'];
         }
-        
+        $this->log("URL MAP");
+        $this->log($this->urlmap);
         
     }
      
@@ -297,9 +299,9 @@ class Pman_Core_Mailer {
             
             return $email;
         }
-        if ($this->debug) {
-            echo '<PRE>';echo htmlspecialchars(print_r($email,true));
-        }
+        
+        //$this->log( htmlspecialchars(print_r($email,true)));
+        
         ///$recipents = array($this->email);
         $mailOptions = PEAR::getStaticProperty('Mail','options');
         //print_R($mailOptions);exit;
@@ -311,7 +313,7 @@ class Pman_Core_Mailer {
         
         $mail = Mail::factory($this->mail_method,$mailOptions);
         if ($this->debug) {
-            $mail->debug = $this->debug;
+            $mail->debug = (bool) $this->debug;
         }
         
         $email['headers']['Date'] = date('r'); 
@@ -403,7 +405,7 @@ class Pman_Core_Mailer {
                     continue;
                 }
             } else {
-               $file = $url;  
+               $file = $this->mapurl($url);  
             }
             
             $par = $link->parentNode;
@@ -423,9 +425,10 @@ class Pman_Core_Mailer {
     
     function fetchImage($url)
     {
-        if($this->debug) {
-            echo "FETCH : $url\n";
-        }
+        
+        
+        $this->log( "FETCH : $url\n");
+        
         if ($url[0] == '/') {
             $ff = HTML_FlexyFramework::get();
             $file = $ff->rootDir . $url;
@@ -477,6 +480,7 @@ class Pman_Core_Mailer {
                 filemtime($cache) > strtotime('NOW - 1 WEEK')
             ) {
             $ret =  json_decode(file_get_contents($cache), true);
+            $this->log("fetched from cache");
             $ret['file'] = $cache . '.data';
             return $ret;
         }
@@ -485,9 +489,15 @@ class Pman_Core_Mailer {
         }
         
         require_once 'HTTP/Request.php';
-        $a = new HTTP_Request($url);
+        $a = new HTTP_Request($this->mapurl($url));
         $a->sendRequest();
-        file_put_contents($cache .'.data', $a->getResponseBody());
+        $data = $a->getResponseBody();
+        
+        $this->log("got file of size " . strlen($data));
+        $this->log("save contentid " . md5($url));
+        
+        file_put_contents($cache .'.data', $data);
+        
         
         $mt = $a->getResponseHeader('Content-Type');
         
@@ -512,13 +522,31 @@ class Pman_Core_Mailer {
         
         foreach($this->urlmap as $o=>$n) {
             if (strpos($in,$o) === 0) {
-                return $n . substr($in,strlen($o));
+                $ret =$n . substr($in,strlen($o));
+                $this->log("mapURL in $in = $ret");
+                return $ret;
             }
         }
+        $this->log("mapurl no change - $in");
         return $in;
          
         
     }
     
+    function log($val)
+    {
+        if (!$this->debug) {
+            return;
+        }
+        if ($this->debug < 2) {
+            echo '<PRE>' . $val. "\n";
+            return;
+        }
+        $fh = fopen('/tmp/core_mailer.log', 'a');
+        fwrite($fh, date('Y-m-d H:i:s -') . json_encode($val) . "\n");
+        fclose($fh);
+        
+        
+    }
     
 }
\ No newline at end of file