/**
  * send an alarm
  *
  * @param  Tinebase_Model_Alarm $_alarm
  * @return void
  * 
  * NOTE: the given alarm is raw and has not passed _inspectAlarmGet
  *  
  * @todo throw exception on error
  */
 public function sendAlarm(Tinebase_Model_Alarm $_alarm)
 {
     if (Tinebase_Core::isLogLevel(Zend_Log::DEBUG)) {
         Tinebase_Core::getLogger()->debug(__METHOD__ . '::' . __LINE__ . " About to send alarm " . print_r($_alarm->toArray(), TRUE));
     }
     $doContainerACLChecks = $this->doContainerACLChecks(FALSE);
     try {
         $event = $this->get($_alarm->record_id);
         $event->alarms = new Tinebase_Record_RecordSet('Tinebase_Model_Alarm', array($_alarm));
         $this->_inspectAlarmGet($event);
     } catch (Exception $e) {
         $this->doContainerACLChecks($doContainerACLChecks);
         throw $e;
     }
     $this->doContainerACLChecks($doContainerACLChecks);
     if ($event->rrule) {
         $recurid = $_alarm->getOption('recurid');
         // adopts the (referenced) alarm and sets alarm time to next occurance
         parent::_inspectAlarmSet($event, $_alarm);
         $this->adoptAlarmTime($event, $_alarm, 'instance');
         // sent_status might have changed in adoptAlarmTime()
         if ($_alarm->sent_status !== Tinebase_Model_Alarm::STATUS_PENDING) {
             if (Tinebase_Core::isLogLevel(Zend_Log::INFO)) {
                 Tinebase_Core::getLogger()->info(__METHOD__ . '::' . __LINE__ . ' Not sending alarm for event at ' . $event->dtstart->toString() . ' with status ' . $_alarm->sent_status);
             }
             return;
         }
         if ($recurid) {
             // NOTE: In case of recuring events $event is always the baseEvent,
             //       so we might need to adopt event time to recur instance.
             $diff = $event->dtstart->diff($event->dtend);
             $event->dtstart = new Tinebase_DateTime(substr($recurid, -19));
             $event->dtend = clone $event->dtstart;
             $event->dtend->add($diff);
         }
         if ($event->exdate && in_array($event->dtstart, $event->exdate)) {
             if (Tinebase_Core::isLogLevel(Zend_Log::INFO)) {
                 Tinebase_Core::getLogger()->info(__METHOD__ . '::' . __LINE__ . " Not sending alarm because instance at " . $event->dtstart->toString() . ' is an exception.');
             }
             return;
         }
     }
     Calendar_Controller_EventNotifications::getInstance()->doSendNotifications($event, Tinebase_Core::getUser(), 'alarm', NULL, $_alarm);
 }
Пример #2
0
 /**
  * send an alarm
  *
  * @param  Tinebase_Model_Alarm $_alarm
  * @return void
  * 
  * NOTE: the given alarm is raw and has not passed _inspectAlarmGet
  *  
  * @todo make this working with recuring events
  * @todo throw exception on error
  */
 public function sendAlarm(Tinebase_Model_Alarm $_alarm)
 {
     if (Tinebase_Core::isLogLevel(Zend_Log::DEBUG)) {
         Tinebase_Core::getLogger()->debug(__METHOD__ . '::' . __LINE__ . " About to send alarm " . print_r($_alarm->toArray(), TRUE));
     }
     $doContainerACLChecks = $this->doContainerACLChecks(FALSE);
     $event = $this->get($_alarm->record_id);
     $event->alarms = new Tinebase_Record_RecordSet('Tinebase_Model_Alarm', array($_alarm));
     $this->_inspectAlarmGet($event);
     if ($event->rrule) {
         $recurid = $_alarm->getOption('recurid');
         // adopts the (referenced) alarm and sets alarm time to next occurance
         parent::_inspectAlarmSet($event, $_alarm);
         $this->adoptAlarmTime($event, $_alarm, 'instance');
         if ($recurid) {
             // NOTE: In case of recuring events $event is always the baseEvent,
             //       so we might need to adopt event time to recur instance.
             $diff = $event->dtstart->diff($event->dtend);
             $event->dtstart = new Tinebase_DateTime(substr($recurid, -19));
             $event->dtend = clone $event->dtstart;
             $event->dtend->add($diff);
         }
     }
     $this->doContainerACLChecks($doContainerACLChecks);
     $this->doSendNotifications($event, $this->_currentAccount, 'alarm');
 }