3 * Table Definition for core_watch
5 * works with 'core_notify'
8 * $watch->notify($ontable, $onid)
10 * in which case it should create a core_notify event.
13 * Should 'event' trigger this..
14 * -> eg. somebody makes a 'EDIT' on 'person'
15 * -> a watch exists for
17 * onid = -1 <<-- every entry..
18 * person_id -> who is goes to.
19 * event = CRUD (eg. shortcut for edit/create/delete)
20 * medium = "REVIEW" << eg. review needed..
26 require_once 'DB/DataObject.php';
28 class Pman_Core_DataObjects_Core_watch extends DB_DataObject
31 /* the code below is auto generated do not remove the above tag */
33 public $__table = 'core_watch'; // table name
34 public $id; // int(11) not_null primary_key auto_increment
35 public $ontable; // string(128) not_null
36 public $onid; // int(11) not_null
37 public $person_id; // int(11) not_null
38 public $event; // string(128) not_null
39 public $medium; // string(128) not_null
40 public $active; // int(11) not_null
43 /* the code above is auto generated do not remove the tag below */
45 /** make sure there is a watch for this user.. */
53 function ensureNotify( $ontable, $onid, $person_id, $whereAdd)
55 //DB_DAtaObject::debugLevel(1);
56 $w = DB_DataObject::factory('core_watch');
57 $w->person_id = $person_id;
58 if (empty($w->person_id)) {
63 $w->whereAdd($whereAdd);
69 $nw->ontable = $ontable;
72 $nw->medium = 'email';
78 * Generate a notify event based on watches (matching whereAdd)
81 function notify($ontable , $onid, $whereAdd)
83 $w = DB_DataObject::factory('core_watch');
84 $w->whereAdd($whereAdd);
86 $w->selectAdd('distinct(person_id) as person_id');
87 $people = $w->fetchAll('person_id');
89 $nn = DB_DataObject::Factory('core_notify');
90 $nn->ontable = $ontable;
92 foreach($people as $p) {
93 if (!$p) { // no people??? bugs in watch table
99 $nf->whereAdd('sent < act_when');
101 // we have a item in the queue for that waiting to be sent..
104 $n->act_start( date("Y-m-d H:i:s") );
112 function notifyEvent($event)
114 //DB_DataObject::DebugLevel(1);
115 // see if there are any watches on events..
116 // notify everyone flagged except the person doing it...
117 // this is very basic logic... -
118 // if more intelligence is needed...
119 // then it 'rules' will have to be added by the watched object....
120 // anyway leave that for another day..
121 if (empty($event->action)) {
124 $w = DB_DataObject::factory('core_watch');
125 $w->ontable = $event->on_table;
126 $w->whereAdd('onid = 0 OR onid='. ((int) $event->on_id));
128 $w->event = $event->action;
132 $w->whereAdd('person_id != '. (int) $event->person_id);
135 $watches = $w->fetchAll();
137 $nn = DB_DataObject::Factory('core_notify');
138 $nn->ontable = $event->on_table;
139 $nn->onid = $event->on_id;
141 foreach($watches as $watch) {
142 if (!$watch->person_id) { // no people??? bugs in watch table
147 $n->trigger_person_id = $event->person_id;
148 $n->trigger_event_id = $event->id;
149 $n->person_id = $watch->person_id;
150 $n->watch_id = $watch->id;
152 // does this watch already have a flag...
154 $nf->whereAdd('sent < act_when');
156 // we have a item in the queue for that waiting to be sent..
160 $n->act_start( date("Y-m-d H:i:s") );