X-Git-Url: http://git.roojs.org/?a=blobdiff_plain;f=Import%2FCore_email.php;h=db526e76185f5e4f2a300b04aa51bccda120fe9f;hb=cd0367f0b1c72b3bf7140f594c7e54ef2ed94c9e;hp=f8877642ea6469f8f93ef4002c3baac59b2ae0da;hpb=4410f1c5939c56a7df22b9153f102de025de843f;p=Pman.Core diff --git a/Import/Core_email.php b/Import/Core_email.php index f8877642..db526e76 100644 --- a/Import/Core_email.php +++ b/Import/Core_email.php @@ -16,7 +16,28 @@ class Pman_Core_Import_Core_email extends Pman 'max' => 1, ), - + 'master' => array( + 'desc' => 'Master template (wrapper to body)', + 'short' => 'm', + 'default' => '', + 'min' => 1, + 'max' => 1, + + ), + 'update' => array( + 'desc' => 'Update template (deletes old version?)', + 'short' => 'u', + 'default' => '', + 'min' => 0, + 'max' => 0, + ), + 'use-file' => array( + 'desc' => 'Force usage of file (so content is not editable in Management system)', + 'short' => 'F', + 'default' => '', + 'min' => 0, + 'max' => 0, + ), ); function getAuth() @@ -26,32 +47,59 @@ class Pman_Core_Import_Core_email extends Pman if (!$ff->cli) { die("cli only"); } - + } + + function get($part = '', $opts=array()) { + $this->updateOrCreateEmail($part, $opts, false); } - function get($part='', $opts){ + function updateOrCreateEmail($part='', $opts, $cm = false, $mapping = false){ + // DB_DataObject::debugLevel(1); $template_name = preg_replace('/\.[a-z]+$/i', '', basename($opts['file'])); if (!file_exists($opts['file'])) { $this->jerr("file does not exist : " . $opts['file']); } - - $c = DB_dataObject::factory('core_email'); - $ret = $c->get('name',$template_name); - if($ret ) { - $this->jerr("we do not support updating the files ... - especially if the user has changed them!!"); + + + if (!empty($opts['master']) && !file_exists($opts['master'])) { + $this->jerr("master file does not exist : " . $opts['master']); } + + if (empty($cm)) { + $cm = DB_dataObject::factory('core_email'); + $ret = $cm->get('name',$template_name); + if($ret && empty($opts['update'])) { + $this->jerr("use --update to update the template.."); + } + } $mailtext = file_get_contents($opts['file']); - + + if (!empty($opts['master'])) { + $body = $mailtext; + $mailtext = file_get_contents($opts['master']); + $mailtext = str_replace('{outputBody():h}', $body, $mailtext); + } + + if($mapping) { + foreach ($mapping as $k => $v) { + $mailtext = str_replace($k, $v, $mailtext); + } + } + require_once 'Mail/mimeDecode.php'; require_once 'Mail/RFC822.php'; $decoder = new Mail_mimeDecode($mailtext); $parts = $decoder->getSendArray(); - + if (is_a($parts,'PEAR_Error')) { + echo $parts->toString() . "\n"; + exit; + } + $headers = $parts[1]; $from = new Mail_RFC822(); $from_str = $from->parseAddressList($headers['From']); @@ -61,15 +109,39 @@ class Pman_Core_Import_Core_email extends Pman $from_email = $from_str[0]->mailbox . '@' . $from_str[0]->host; - $c->setFrom(array( - 'from_name' => $from_name, - 'from_email' => $from_email, - 'subject' => $parts[1]['Subject'], - 'name' => $template_name, - 'bodytext' => $parts[2] - )); - $c->insert(); + if (!empty($opts['use-file'])) { + $parts[2] = ''; + } + + if ($cm->id) { + + $cc =clone($cm); + $cm->setFrom(array( + 'bodytext' => !empty($opts['use-file']) ? '' : $parts[2], + 'updated_dt' => date('Y-m-d H:i:s'), + 'use_file' => !empty($opts['use-file']) ? realpath($opts['file']) : '', + )); + + $cm->update($cc); + } else { + + $cm->setFrom(array( + 'from_name' => $from_name, + 'from_email' => $from_email, + 'subject' => $headers['Subject'], + 'name' => $template_name, + 'bodytext' => !empty($opts['use-file']) ? '' : $parts[2], + 'updated_dt' => date('Y-m-d H:i:s'), + 'created_dt' => date('Y-m-d H:i:s'), + 'use_file' => !empty($opts['use-file']) ? realpath($opts['file']) : '', + )); + + $cm->insert(); + } + return $cm; + } + function output() { die("done\n"); } } \ No newline at end of file