X-Git-Url: http://git.roojs.org/?p=Pman.Core;a=blobdiff_plain;f=DataObjects%2FCore_email.php;h=58ffc098914e113382ae18c2fec4d25f3f53584f;hp=4f7f05d3dc2d3630abf568ddf25b0b8d5d069b5b;hb=af6aa7e77888c6d0a94c4b03d7dccda2d4811825;hpb=9c011f3696a7822273be61ffdb56ab6d87a61907 diff --git a/DataObjects/Core_email.php b/DataObjects/Core_email.php index 4f7f05d3..58ffc098 100644 --- a/DataObjects/Core_email.php +++ b/DataObjects/Core_email.php @@ -41,6 +41,18 @@ class Pman_Core_DataObjects_Core_email extends DB_DataObject $tn.subject LIKE '%{$this->escape($q['search']['nameortitle'])}%' "); } + + $this->selectAdd(" + ( + SELECT + count(user_id) + FROM + core_group_member + WHERE + to_group_id = core_group_member.group_id + ) + AS group_member_count + "); } function beforeDelete($dependants_array, $roo) @@ -61,6 +73,23 @@ class Pman_Core_DataObjects_Core_email extends DB_DataObject $this->makeCopy($roo); } + + if ($this->to_group != -1) { + $c = DB_DataObject::factory('core_group_member'); + //$c->groud_id = $this->to_group; + + $c->setFrom(array( + 'groud_id' => $this->to_group + )); + + //if (!$c->find(true)) { + // + //} + + print_r($this->to_group); + //print_r($c); + print_r($c->count());exit; + } } function makeCopy($roo) @@ -306,32 +335,22 @@ class Pman_Core_DataObjects_Core_email extends DB_DataObject $p = new PEAR(); $contents = (array)$obj; - var_dump($content);exit; - - if (!empty($obj['subject_replace'])) { - $mapping = array( - '/{person.name}/' => $obj['person']->name - ); - $subject = $obj['subject']; - foreach ($mapping as $pattern => $replace) { - $subject = preg_replace($pattern,$replace,$subject); - } - $content['subject'] = $subject; - } - if(empty($this->id) && !empty($contents['template'])){ $this->get('name', $contents['template']); } + if(empty($this->active)){ return $p->raiseError("template [{$contents['template']}] is Disabled"); } + if(empty($this->id)){ return $p->raiseError("template [{$contents['template']}] has not been set"); } // fill in BCC + if (!empty($this->bcc_group) && empty($contents['rcpts_group'])) { $admin = DB_DAtaObject::Factory('core_group')->lookupMembersByGroupId($this->bcc_group,'email'); @@ -351,13 +370,20 @@ class Pman_Core_DataObjects_Core_email extends DB_DataObject $contents['rcpts'] = $admin; } + //subject replacement if(empty($contents['subject'])){ $contents['subject'] = $this->subject; } + + if (!empty($contents['subject_replace'])) { + foreach ($contents['mapping'] as $pattern => $replace) { + $contents['subject'] = preg_replace($pattern,$replace,$contents['subject']); + } + } if(!empty($contents['rcpts']) && is_array($contents['rcpts'])){ $contents['rcpts'] = implode(',', $contents['rcpts']); - } + } $ui = posix_getpwuid(posix_geteuid()); @@ -368,6 +394,7 @@ class Pman_Core_DataObjects_Core_email extends DB_DataObject } require_once 'Pman/Core/Mailer.php'; + $templateDir = session_save_path() . '/email-cache-' . $ui['name'] ; //print_r($this); @@ -418,7 +445,11 @@ class Pman_Core_DataObjects_Core_email extends DB_DataObject * DEPRICATED !!! - DO NOT USE THIS !!! * * use: toMailerData() -- to return the email data.. - * or toMailer($obj, false)->send() + * or + * $mailer = $core_email->toMailer($obj, false); + * $sent = is_a($mailer,'PEAR_Error') ? false : $mailer->send(); + + * toMailer($obj, false)->send() * * */