xref: /plugin/bez/mdl/Task.php (revision 6f38077355681f273cc9db672efab6fff436baea)
18a638198SSzymon Olewniczak<?php
28a638198SSzymon Olewniczak
38a638198SSzymon Olewniczaknamespace dokuwiki\plugin\bez\mdl;
48a638198SSzymon Olewniczak
58a638198SSzymon Olewniczakuse dokuwiki\plugin\bez\meta\Mailer;
68a638198SSzymon Olewniczakuse dokuwiki\plugin\bez\meta\PermissionDeniedException;
78a638198SSzymon Olewniczakuse dokuwiki\plugin\bez\meta\ValidationException;
814a1f0a4SSzymon Olewniczakuse dokuwiki\plugin\struct\types\DateTime;
98a638198SSzymon Olewniczak
108a638198SSzymon Olewniczakclass Task extends Entity {
118a638198SSzymon Olewniczak
128a638198SSzymon Olewniczak    protected $id;
138a638198SSzymon Olewniczak
14e8827d73SSzymon Olewniczak	protected $original_poster, $assignee, $closed_by;
158a638198SSzymon Olewniczak
168a638198SSzymon Olewniczak	protected $private, $lock;
178a638198SSzymon Olewniczak
188a638198SSzymon Olewniczak	protected $state, $type;
198a638198SSzymon Olewniczak
208a638198SSzymon Olewniczak	protected $create_date, $last_activity_date, $last_modification_date, $close_date;
218a638198SSzymon Olewniczak
228a638198SSzymon Olewniczak	protected $cost, $plan_date, $all_day_event, $start_time, $finish_time;
238a638198SSzymon Olewniczak
248a638198SSzymon Olewniczak	protected $content, $content_html;
258a638198SSzymon Olewniczak
268a638198SSzymon Olewniczak	protected $thread_id, $thread_comment_id, $task_program_id;
278a638198SSzymon Olewniczak
288a638198SSzymon Olewniczak	/** @var \dokuwiki\plugin\bez\mdl\Thread */
298a638198SSzymon Olewniczak	protected $thread;
308a638198SSzymon Olewniczak
318a638198SSzymon Olewniczak	/** @var Thread_comment */
328a638198SSzymon Olewniczak	protected $thread_comment;
338a638198SSzymon Olewniczak
348a638198SSzymon Olewniczak	//virtual
35ff14b107SSzymon Olewniczak    protected $task_program_name, $priority, $coordinator;
368a638198SSzymon Olewniczak
378a638198SSzymon Olewniczak	public static function get_columns() {
388a638198SSzymon Olewniczak		return array('id',
39e8827d73SSzymon Olewniczak            'original_poster', 'assignee', 'closed_by',
408a638198SSzymon Olewniczak            'private', 'lock',
418a638198SSzymon Olewniczak            'state', 'type',
428a638198SSzymon Olewniczak            'create_date', 'last_activity_date', 'last_modification_date', 'close_date',
438a638198SSzymon Olewniczak            'cost', 'plan_date', 'all_day_event', 'start_time', 'finish_time',
448a638198SSzymon Olewniczak            'content', 'content_html',
458a638198SSzymon Olewniczak            'thread_id', 'thread_comment_id', 'task_program_id');
468a638198SSzymon Olewniczak	}
478a638198SSzymon Olewniczak
48e8827d73SSzymon Olewniczak	public static function get_types() {
49e8827d73SSzymon Olewniczak	    return array('correction', 'corrective', 'preventive', 'program');
50e8827d73SSzymon Olewniczak    }
51e8827d73SSzymon Olewniczak
52e8827d73SSzymon Olewniczak    public static function get_states() {
53e8827d73SSzymon Olewniczak        return array('opened', 'done');
54e8827d73SSzymon Olewniczak    }
55e8827d73SSzymon Olewniczak
568a638198SSzymon Olewniczak    public function __get($property) {
57ff14b107SSzymon Olewniczak        if ($property == 'thread') {
58ff14b107SSzymon Olewniczak            if ($this->thread_id == null) {
59ff14b107SSzymon Olewniczak                return null;
60ff14b107SSzymon Olewniczak            }
61ff14b107SSzymon Olewniczak            if ($this->thread == null) {
62ff14b107SSzymon Olewniczak                $this->thread = $this->model->threadFactory->get_one($this->thread_id);
63ff14b107SSzymon Olewniczak            }
64ff14b107SSzymon Olewniczak            return $this->thread;
65ff14b107SSzymon Olewniczak
66ff14b107SSzymon Olewniczak        } elseif($property == 'thread_comment') {
67ff14b107SSzymon Olewniczak            if ($this->thread_comment_id == null) {
68ff14b107SSzymon Olewniczak                return null;
69ff14b107SSzymon Olewniczak            }
70ff14b107SSzymon Olewniczak            if ($this->thread_comment == null) {
7153df74e7SSzymon Olewniczak                $this->thread_comment = $this->model->thread_commentFactory->get_one($this->thread_comment_id);
72ff14b107SSzymon Olewniczak            }
73ff14b107SSzymon Olewniczak            return $this->thread_comment;
74ff14b107SSzymon Olewniczak
75ff14b107SSzymon Olewniczak        } elseif($property == 'priority' || $property == 'coordinator' || $property == 'task_program_name') {
768a638198SSzymon Olewniczak            return $this->$property;
778a638198SSzymon Olewniczak        }
788a638198SSzymon Olewniczak        return parent::__get($property);
798a638198SSzymon Olewniczak    }
808a638198SSzymon Olewniczak
818a638198SSzymon Olewniczak	public function __construct($model, $defaults=array()) {
828a638198SSzymon Olewniczak		parent::__construct($model, $defaults);
838a638198SSzymon Olewniczak
84a0cd8c78SSzymon Olewniczak		//virutal ACL columns (not in select)
85a0cd8c78SSzymon Olewniczak		$this->acl->add_column('participants');
86a0cd8c78SSzymon Olewniczak
878a638198SSzymon Olewniczak		$this->validator->set_rules(array(
888a638198SSzymon Olewniczak            'assignee' => array(array('dw_user'), 'NOT NULL'),
898a638198SSzymon Olewniczak            'cost' => array(array('numeric'), 'NULL'),
908a638198SSzymon Olewniczak			'plan_date' => array(array('iso_date'), 'NOT NULL'),
918a638198SSzymon Olewniczak			'all_day_event' => array(array('select', array('0', '1')), 'NOT NULL'),
928a638198SSzymon Olewniczak			'start_time' => array(array('time'), 'NULL'),
938a638198SSzymon Olewniczak			'finish_time' => array(array('time'), 'NULL'),
948a638198SSzymon Olewniczak            'content' => array(array('length', 10000), 'NOT NULL'),
95e8827d73SSzymon Olewniczak            'thread_comment_id' => array(array('numeric'), 'NULL'),
968a638198SSzymon Olewniczak            'task_program_id' => array(array('numeric'), 'NULL')
978a638198SSzymon Olewniczak		));
988a638198SSzymon Olewniczak
998a638198SSzymon Olewniczak		//we've created empty object
1008a638198SSzymon Olewniczak		if ($this->id === NULL) {
1018a638198SSzymon Olewniczak            $this->original_poster = $this->model->user_nick;
1028a638198SSzymon Olewniczak            $this->create_date = date('c');
1038a638198SSzymon Olewniczak            $this->last_activity_date = $this->create_date;
1048a638198SSzymon Olewniczak            $this->last_modification_date = $this->create_date;
1058a638198SSzymon Olewniczak
1068a638198SSzymon Olewniczak            $this->state = 'opened';
1078a638198SSzymon Olewniczak
1088a638198SSzymon Olewniczak            if (isset($defaults['thread'])) {
1098a638198SSzymon Olewniczak                $this->thread = $defaults['thread'];
1108a638198SSzymon Olewniczak                $this->thread_id = $this->thread->id;
11153df74e7SSzymon Olewniczak                $this->coordinator = $this->thread->coordinator;
112*6f380773SSzymon Olewniczak
113*6f380773SSzymon Olewniczak                if ($this->thread->private == '1') {
114*6f380773SSzymon Olewniczak                    $this->private = '1';
115*6f380773SSzymon Olewniczak                }
116*6f380773SSzymon Olewniczak
1178a638198SSzymon Olewniczak                $this->type = 'correction';
1188a638198SSzymon Olewniczak
1198a638198SSzymon Olewniczak                if (isset($defaults['thread_comment'])) {
1208a638198SSzymon Olewniczak                    $this->thread_comment = $defaults['thread_comment'];
1218a638198SSzymon Olewniczak                    $this->thread_comment_id = $this->thread_comment->id;
122e8827d73SSzymon Olewniczak
123e8827d73SSzymon Olewniczak                    if ($this->thread_comment->type == 'cause_real') {
1248a638198SSzymon Olewniczak                        $this->type = 'corrective';
125e8827d73SSzymon Olewniczak                    } else {
126e8827d73SSzymon Olewniczak                        $this->type = 'preventive';
127e8827d73SSzymon Olewniczak                    }
1288a638198SSzymon Olewniczak                }
129ff14b107SSzymon Olewniczak            } else {
130ff14b107SSzymon Olewniczak                $this->type = 'program';
1318a638198SSzymon Olewniczak            }
132a0cd8c78SSzymon Olewniczak
133*6f380773SSzymon Olewniczak
134*6f380773SSzymon Olewniczak            if ($this->thread_id == '') {
135*6f380773SSzymon Olewniczak                $this->validator->set_rules(array(
136*6f380773SSzymon Olewniczak                                                'task_program_id' => array(array('numeric'), 'NOT NULL'),
137*6f380773SSzymon Olewniczak                                            ));
138*6f380773SSzymon Olewniczak                //this field is unused in program tasks
139*6f380773SSzymon Olewniczak                $this->validator->delete_rule('thread_comment_id');
140*6f380773SSzymon Olewniczak            }
141*6f380773SSzymon Olewniczak
142a0cd8c78SSzymon Olewniczak            //everyone can report their own program tasks
143a0cd8c78SSzymon Olewniczak            if ($this->type == 'program') {
144a0cd8c78SSzymon Olewniczak                $this->acl->grant('content', BEZ_PERMISSION_CHANGE);
145a0cd8c78SSzymon Olewniczak                $this->acl->grant('plan_date', BEZ_PERMISSION_CHANGE);
146a0cd8c78SSzymon Olewniczak                $this->acl->grant('start_time', BEZ_PERMISSION_CHANGE);
147a0cd8c78SSzymon Olewniczak                $this->acl->grant('finish_time', BEZ_PERMISSION_CHANGE);
148a0cd8c78SSzymon Olewniczak                $this->acl->grant('all_day_event', BEZ_PERMISSION_CHANGE);
149a0cd8c78SSzymon Olewniczak                $this->acl->grant('task_program_id', BEZ_PERMISSION_CHANGE);
150a0cd8c78SSzymon Olewniczak                $this->acl->grant('cost', BEZ_PERMISSION_CHANGE);
151a0cd8c78SSzymon Olewniczak            }
152a0cd8c78SSzymon Olewniczak
153a0cd8c78SSzymon Olewniczak            if ($this->type == 'program' && $this->model->get_level() >= BEZ_AUTH_LEADER) {
154a0cd8c78SSzymon Olewniczak                $this->acl->grant('assignee', BEZ_PERMISSION_CHANGE);
155a0cd8c78SSzymon Olewniczak                $this->acl->grant('participants', BEZ_PERMISSION_CHANGE);
156a0cd8c78SSzymon Olewniczak            }
157a0cd8c78SSzymon Olewniczak
158a0cd8c78SSzymon Olewniczak            if ($this->type != 'program' && $this->coordinator == $this->model->user_nick) {
159a0cd8c78SSzymon Olewniczak                $this->acl->grant('content', BEZ_PERMISSION_CHANGE);
160a0cd8c78SSzymon Olewniczak                $this->acl->grant('plan_date', BEZ_PERMISSION_CHANGE);
161a0cd8c78SSzymon Olewniczak                $this->acl->grant('start_time', BEZ_PERMISSION_CHANGE);
162a0cd8c78SSzymon Olewniczak                $this->acl->grant('finish_time', BEZ_PERMISSION_CHANGE);
163a0cd8c78SSzymon Olewniczak                $this->acl->grant('all_day_event', BEZ_PERMISSION_CHANGE);
164a0cd8c78SSzymon Olewniczak                $this->acl->grant('task_program_id', BEZ_PERMISSION_CHANGE);
165a0cd8c78SSzymon Olewniczak                $this->acl->grant('cost', BEZ_PERMISSION_CHANGE);
166a0cd8c78SSzymon Olewniczak
167a0cd8c78SSzymon Olewniczak                $this->acl->grant('assignee', BEZ_PERMISSION_CHANGE);
168a0cd8c78SSzymon Olewniczak                $this->acl->grant('participants', BEZ_PERMISSION_CHANGE);
169a0cd8c78SSzymon Olewniczak            }
170a0cd8c78SSzymon Olewniczak
171e8827d73SSzymon Olewniczak        //we get object form db
172e8827d73SSzymon Olewniczak		} else {
173e8827d73SSzymon Olewniczak            if (isset($defaults['thread']) && $this->thread_id == $defaults['thread']->id) {
174e8827d73SSzymon Olewniczak                $this->thread = $defaults['thread'];
175e8827d73SSzymon Olewniczak            }
176e8827d73SSzymon Olewniczak
177e8827d73SSzymon Olewniczak            if (isset($defaults['thread_comment']) && $this->thread_comment_id == $defaults['thread_comment']->id) {
178e8827d73SSzymon Olewniczak                $this->thread_comment = $defaults['thread_comment'];
179e8827d73SSzymon Olewniczak            }
180e8827d73SSzymon Olewniczak
181*6f380773SSzymon Olewniczak            if ($this->thread_id == '') {
182*6f380773SSzymon Olewniczak                $this->validator->set_rules(array(
183*6f380773SSzymon Olewniczak                                                'task_program_id' => array(array('numeric'), 'NOT NULL'),
184*6f380773SSzymon Olewniczak                                            ));
185*6f380773SSzymon Olewniczak                //this field is unused in program tasks
186*6f380773SSzymon Olewniczak                $this->validator->delete_rule('thread_comment_id');
187*6f380773SSzymon Olewniczak            }
188*6f380773SSzymon Olewniczak
189*6f380773SSzymon Olewniczak            //private tasks
190*6f380773SSzymon Olewniczak            if ($this->model->level < BEZ_AUTH_ADMIN && $this->private == '1') {
191*6f380773SSzymon Olewniczak                if ($this->get_participant($this->model->user_nick) === false &&
192*6f380773SSzymon Olewniczak                    ($this->thread_id != '' && $this->__get('thread')->get_participant($this->model->user_nick) === false)) {
193*6f380773SSzymon Olewniczak                    $this->acl->revoke(self::get_select_columns(), BEZ_AUTH_LEADER);
194*6f380773SSzymon Olewniczak                    return;
195*6f380773SSzymon Olewniczak                }
196*6f380773SSzymon Olewniczak            }
197*6f380773SSzymon Olewniczak
198a0cd8c78SSzymon Olewniczak            //user can close their tasks
199a0cd8c78SSzymon Olewniczak            if ($this->assignee == $this->model->user_nick || $this->model->get_level() >= BEZ_AUTH_LEADER) {
200a0cd8c78SSzymon Olewniczak                $this->acl->grant('state', BEZ_PERMISSION_CHANGE);
201a0cd8c78SSzymon Olewniczak            }
202a0cd8c78SSzymon Olewniczak
203a0cd8c78SSzymon Olewniczak            if ($this->type == 'program' && $this->original_poster == $this->model->user_nick) {
204a0cd8c78SSzymon Olewniczak                $this->acl->grant('content', BEZ_PERMISSION_CHANGE);
205a0cd8c78SSzymon Olewniczak                $this->acl->grant('plan_date', BEZ_PERMISSION_CHANGE);
206a0cd8c78SSzymon Olewniczak                $this->acl->grant('start_time', BEZ_PERMISSION_CHANGE);
207a0cd8c78SSzymon Olewniczak                $this->acl->grant('finish_time', BEZ_PERMISSION_CHANGE);
208a0cd8c78SSzymon Olewniczak                $this->acl->grant('all_day_event', BEZ_PERMISSION_CHANGE);
209a0cd8c78SSzymon Olewniczak                $this->acl->grant('task_program_id', BEZ_PERMISSION_CHANGE);
210a0cd8c78SSzymon Olewniczak                $this->acl->grant('cost', BEZ_PERMISSION_CHANGE);
211a0cd8c78SSzymon Olewniczak            }
212a0cd8c78SSzymon Olewniczak
213a0cd8c78SSzymon Olewniczak            if (($this->type != 'program' && $this->coordinator == $this->model->user_nick) ||
214a0cd8c78SSzymon Olewniczak                ($this->model->get_level() >= BEZ_AUTH_LEADER)) {
215a0cd8c78SSzymon Olewniczak                $this->acl->grant('content', BEZ_PERMISSION_CHANGE);
216a0cd8c78SSzymon Olewniczak                $this->acl->grant('plan_date', BEZ_PERMISSION_CHANGE);
217a0cd8c78SSzymon Olewniczak                $this->acl->grant('start_time', BEZ_PERMISSION_CHANGE);
218a0cd8c78SSzymon Olewniczak                $this->acl->grant('finish_time', BEZ_PERMISSION_CHANGE);
219a0cd8c78SSzymon Olewniczak                $this->acl->grant('all_day_event', BEZ_PERMISSION_CHANGE);
220a0cd8c78SSzymon Olewniczak                $this->acl->grant('task_program_id', BEZ_PERMISSION_CHANGE);
221a0cd8c78SSzymon Olewniczak                $this->acl->grant('cost', BEZ_PERMISSION_CHANGE);
222a0cd8c78SSzymon Olewniczak
223a0cd8c78SSzymon Olewniczak                $this->acl->grant('assignee', BEZ_PERMISSION_CHANGE);
224a0cd8c78SSzymon Olewniczak                $this->acl->grant('participants', BEZ_PERMISSION_CHANGE);
225f7519ef1SSzymon Olewniczak                $this->acl->grant('state', BEZ_PERMISSION_CHANGE);
226a0cd8c78SSzymon Olewniczak            }
227e8827d73SSzymon Olewniczak        }
2288a638198SSzymon Olewniczak    }
2298a638198SSzymon Olewniczak
23014a1f0a4SSzymon Olewniczak    public function update_virutal() {
23114a1f0a4SSzymon Olewniczak        if ($this->state == 'done') {
23214a1f0a4SSzymon Olewniczak            $this->priority = '';
23314a1f0a4SSzymon Olewniczak        } else {
23414a1f0a4SSzymon Olewniczak            $now = date('Y-m-d');
23514a1f0a4SSzymon Olewniczak            $plus_1_month = date('Y-m-d', strtotime('+1 month'));
23614a1f0a4SSzymon Olewniczak
23714a1f0a4SSzymon Olewniczak            if ($this->plan_date >= $plus_1_month) {
23814a1f0a4SSzymon Olewniczak                $this->priority = '0';
23914a1f0a4SSzymon Olewniczak            } elseif ($this->plan_date >= $now) {
24014a1f0a4SSzymon Olewniczak                $this->priority = '1';
24114a1f0a4SSzymon Olewniczak            } else {
24214a1f0a4SSzymon Olewniczak                $this->priority = '2';
24314a1f0a4SSzymon Olewniczak            }
24414a1f0a4SSzymon Olewniczak        }
24514a1f0a4SSzymon Olewniczak    }
2468a638198SSzymon Olewniczak
2478a638198SSzymon Olewniczak	public function set_data($post, $filter=NULL) {
248ff14b107SSzymon Olewniczak        //all day event
249ff14b107SSzymon Olewniczak        if (!isset($post['all_day_event'])) {
250ff14b107SSzymon Olewniczak            $post['all_day_event'] = '0';
251ff14b107SSzymon Olewniczak        }
252ff14b107SSzymon Olewniczak
25353df74e7SSzymon Olewniczak        parent::set_data($post);
25453df74e7SSzymon Olewniczak
25553df74e7SSzymon Olewniczak        $this->content_html = p_render('xhtml',p_get_instructions($this->content), $ignore);
25653df74e7SSzymon Olewniczak
25753df74e7SSzymon Olewniczak        if (!isset($post['assignee'])) {
25853df74e7SSzymon Olewniczak            $this->assignee = $this->model->user_nick;
25953df74e7SSzymon Olewniczak        }
26053df74e7SSzymon Olewniczak
26153df74e7SSzymon Olewniczak        //update dates
26253df74e7SSzymon Olewniczak        $this->last_modification_date = date('c');
26353df74e7SSzymon Olewniczak        $this->last_activity_date = $this->last_modification_date;
26453df74e7SSzymon Olewniczak
26514a1f0a4SSzymon Olewniczak        //update virtual
26614a1f0a4SSzymon Olewniczak        $this->update_virutal();
26714a1f0a4SSzymon Olewniczak
2688a638198SSzymon Olewniczak		return true;
2698a638198SSzymon Olewniczak	}
2708a638198SSzymon Olewniczak
271e8827d73SSzymon Olewniczak    public function set_state($state) {
272e8827d73SSzymon Olewniczak	    if ($this->acl_of('state') < BEZ_PERMISSION_CHANGE) {
273e8827d73SSzymon Olewniczak	        throw new PermissionDeniedException();
274e8827d73SSzymon Olewniczak        }
275e8827d73SSzymon Olewniczak
276e8827d73SSzymon Olewniczak        if (!in_array($state, array('opened', 'done'))) {
277e8827d73SSzymon Olewniczak	        throw new ValidationException('task', array('sholud be opened or done'));
278e8827d73SSzymon Olewniczak        }
279e8827d73SSzymon Olewniczak
280e8827d73SSzymon Olewniczak        //nothing to do
281e8827d73SSzymon Olewniczak        if ($state == $this->state) {
282e8827d73SSzymon Olewniczak	        return;
283e8827d73SSzymon Olewniczak        }
284e8827d73SSzymon Olewniczak
285e8827d73SSzymon Olewniczak        if ($state == 'done') {
286e8827d73SSzymon Olewniczak            $this->model->sqlite->query("UPDATE {$this->get_table_name()} SET state=?, closed_by=?, close_date=? WHERE id=?",
287e8827d73SSzymon Olewniczak                $state,
288e8827d73SSzymon Olewniczak                $this->model->user_nick,
289e8827d73SSzymon Olewniczak                date('c'),
290e8827d73SSzymon Olewniczak                $this->id);
291e8827d73SSzymon Olewniczak        //reopen the task
292e8827d73SSzymon Olewniczak        } else {
293e8827d73SSzymon Olewniczak            $this->model->sqlite->query("UPDATE {$this->get_table_name()} SET state=? WHERE id=?", $state, $this->id);
294e8827d73SSzymon Olewniczak        }
295e8827d73SSzymon Olewniczak
296e8827d73SSzymon Olewniczak        $this->state = $state;
297e8827d73SSzymon Olewniczak    }
298e8827d73SSzymon Olewniczak
299e8827d73SSzymon Olewniczak    public function update_last_activity() {
300e8827d73SSzymon Olewniczak        $this->last_activity_date = date('c');
301e8827d73SSzymon Olewniczak        $this->model->sqlite->query('UPDATE task SET last_activity_date=? WHERE id=?',
302e8827d73SSzymon Olewniczak                                    $this->last_activity_date, $this->id);
303e8827d73SSzymon Olewniczak    }
304e8827d73SSzymon Olewniczak
305f7519ef1SSzymon Olewniczak    public function can_add_comments() {
306f7519ef1SSzymon Olewniczak        if ($this->thread_id != '' && $this->thread->state == 'closed') {
307f7519ef1SSzymon Olewniczak            return false;
308f7519ef1SSzymon Olewniczak        }
309f7519ef1SSzymon Olewniczak
310f7519ef1SSzymon Olewniczak        if ($this->state == 'opened' ||
311f7519ef1SSzymon Olewniczak            ($this->state == 'done' &&
312f7519ef1SSzymon Olewniczak                $this->acl_of('state') >= BEZ_PERMISSION_CHANGE)) {
313f7519ef1SSzymon Olewniczak            return true;
314f7519ef1SSzymon Olewniczak        }
315f7519ef1SSzymon Olewniczak
316f7519ef1SSzymon Olewniczak        return false;
317f7519ef1SSzymon Olewniczak    }
318f7519ef1SSzymon Olewniczak
319a0cd8c78SSzymon Olewniczak    public function can_add_participants() {
320a0cd8c78SSzymon Olewniczak        return in_array($this->state, array('opened'));
321a0cd8c78SSzymon Olewniczak    }
322a0cd8c78SSzymon Olewniczak
323e8827d73SSzymon Olewniczak    public function get_participants($filter='') {
324e8827d73SSzymon Olewniczak        if ($this->id === NULL) {
325e8827d73SSzymon Olewniczak            return array();
326e8827d73SSzymon Olewniczak        }
327e8827d73SSzymon Olewniczak
328e8827d73SSzymon Olewniczak        $sql = 'SELECT * FROM task_participant WHERE';
329e8827d73SSzymon Olewniczak        $possible_flags = array('original_poster', 'assignee', 'commentator', 'subscribent');
330e8827d73SSzymon Olewniczak        if ($filter != '') {
331e8827d73SSzymon Olewniczak            if (!in_array($filter, $possible_flags)) {
332e8827d73SSzymon Olewniczak                throw new \Exception("unknown flag $filter");
333e8827d73SSzymon Olewniczak            }
334e8827d73SSzymon Olewniczak            $sql .= " $filter=1 AND";
335e8827d73SSzymon Olewniczak        }
336e8827d73SSzymon Olewniczak        $sql .= ' task_id=? ORDER BY user_id';
337e8827d73SSzymon Olewniczak
338e8827d73SSzymon Olewniczak        $r = $this->model->sqlite->query($sql, $this->id);
339e8827d73SSzymon Olewniczak        $pars = $this->model->sqlite->res2arr($r);
340e8827d73SSzymon Olewniczak        $participants = array();
341e8827d73SSzymon Olewniczak        foreach ($pars as $par) {
342e8827d73SSzymon Olewniczak            $participants[$par['user_id']] = $par;
343e8827d73SSzymon Olewniczak        }
344e8827d73SSzymon Olewniczak
345e8827d73SSzymon Olewniczak        return $participants;
346e8827d73SSzymon Olewniczak    }
347e8827d73SSzymon Olewniczak
348e8827d73SSzymon Olewniczak    public function get_participant($user_id) {
349e8827d73SSzymon Olewniczak        if ($this->id === NULL) {
350e8827d73SSzymon Olewniczak            return array();
351e8827d73SSzymon Olewniczak        }
352e8827d73SSzymon Olewniczak
353e8827d73SSzymon Olewniczak        $r = $this->model->sqlite->query('SELECT * FROM task_participant WHERE task_id=? AND user_id=?', $this->id, $user_id);
354e8827d73SSzymon Olewniczak        $par = $this->model->sqlite->res2row($r);
355e8827d73SSzymon Olewniczak        if (!is_array($par)) {
356e8827d73SSzymon Olewniczak            return false;
357e8827d73SSzymon Olewniczak        }
358e8827d73SSzymon Olewniczak
359e8827d73SSzymon Olewniczak        return $par;
360e8827d73SSzymon Olewniczak    }
361e8827d73SSzymon Olewniczak
362e8827d73SSzymon Olewniczak    public function is_subscribent($user_id=null) {
363e8827d73SSzymon Olewniczak        if ($user_id == null) {
364e8827d73SSzymon Olewniczak            $user_id = $this->model->user_nick;
365e8827d73SSzymon Olewniczak        }
366e8827d73SSzymon Olewniczak        $par = $this->get_participant($user_id);
367e8827d73SSzymon Olewniczak        if ($par['subscribent'] == 1) {
368e8827d73SSzymon Olewniczak            return true;
369e8827d73SSzymon Olewniczak        }
370e8827d73SSzymon Olewniczak        return false;
371e8827d73SSzymon Olewniczak    }
372e8827d73SSzymon Olewniczak
373e8827d73SSzymon Olewniczak    public function remove_participant_flags($user_id, $flags) {
374e8827d73SSzymon Olewniczak        //thread not saved yet
375e8827d73SSzymon Olewniczak        if ($this->id === NULL) {
376e8827d73SSzymon Olewniczak            throw new \Exception('cannot remove flags from not saved thread');
377e8827d73SSzymon Olewniczak        }
378e8827d73SSzymon Olewniczak
379e8827d73SSzymon Olewniczak        $possible_flags = array('original_poster', 'assignee', 'commentator', 'subscribent');
380e8827d73SSzymon Olewniczak        if (array_intersect($flags, $possible_flags) != $flags) {
381e8827d73SSzymon Olewniczak            throw new \Exception('unknown flags');
382e8827d73SSzymon Olewniczak        }
383e8827d73SSzymon Olewniczak
384e8827d73SSzymon Olewniczak        $set = implode(',', array_map(function ($v) { return "$v=0"; }, $flags));
385e8827d73SSzymon Olewniczak
386e8827d73SSzymon Olewniczak        $sql = "UPDATE task_participant SET $set WHERE task_id=? AND user_id=?";
387e8827d73SSzymon Olewniczak        $this->model->sqlite->query($sql, $this->id, $user_id);
388e8827d73SSzymon Olewniczak
389e8827d73SSzymon Olewniczak    }
390e8827d73SSzymon Olewniczak
391e8827d73SSzymon Olewniczak    public function set_participant_flags($user_id, $flags=array()) {
392e8827d73SSzymon Olewniczak        //thread not saved yet
393e8827d73SSzymon Olewniczak        if ($this->id === NULL) {
394e8827d73SSzymon Olewniczak            throw new \Exception('cannot add flags to not saved thread');
395e8827d73SSzymon Olewniczak        }
396e8827d73SSzymon Olewniczak
397e8827d73SSzymon Olewniczak        //validate user
398e8827d73SSzymon Olewniczak        if (!$this->model->userFactory->exists($user_id)) {
399e8827d73SSzymon Olewniczak            throw new \Exception("$user_id isn't dokuwiki user");
400e8827d73SSzymon Olewniczak        }
401e8827d73SSzymon Olewniczak
402e8827d73SSzymon Olewniczak        $possible_flags = array('original_poster', 'assignee', 'commentator', 'subscribent');
403e8827d73SSzymon Olewniczak        if (array_intersect($flags, $possible_flags) != $flags) {
404e8827d73SSzymon Olewniczak            throw new \Exception('unknown flags');
405e8827d73SSzymon Olewniczak        }
406e8827d73SSzymon Olewniczak
407e8827d73SSzymon Olewniczak        $participant = $this->get_participant($user_id);
408e8827d73SSzymon Olewniczak        if ($participant == false) {
409e8827d73SSzymon Olewniczak            $participant = array_fill_keys($possible_flags, 0);
410e8827d73SSzymon Olewniczak
411e8827d73SSzymon Olewniczak            $participant['task_id'] = $this->id;
412e8827d73SSzymon Olewniczak            $participant['user_id'] = $user_id;
413e8827d73SSzymon Olewniczak            $participant['added_by'] = $this->model->user_nick;
414e8827d73SSzymon Olewniczak            $participant['added_date'] = date('c');
415e8827d73SSzymon Olewniczak        }
416e8827d73SSzymon Olewniczak        $values = array_merge($participant, array_fill_keys($flags, 1));
417e8827d73SSzymon Olewniczak
418e8827d73SSzymon Olewniczak        $keys = join(',', array_keys($values));
419e8827d73SSzymon Olewniczak        $vals = join(',', array_fill(0,count($values),'?'));
420e8827d73SSzymon Olewniczak
421e8827d73SSzymon Olewniczak        $sql = "REPLACE INTO task_participant ($keys) VALUES ($vals)";
422e8827d73SSzymon Olewniczak        $this->model->sqlite->query($sql, array_values($values));
423e8827d73SSzymon Olewniczak    }
424e8827d73SSzymon Olewniczak
425e8827d73SSzymon Olewniczak    public function invite($client) {
426e8827d73SSzymon Olewniczak        $this->set_participant_flags($client, array('subscribent'));
427e8827d73SSzymon Olewniczak        $this->mail_notify_invite($client);
428e8827d73SSzymon Olewniczak    }
429e8827d73SSzymon Olewniczak
43014a1f0a4SSzymon Olewniczak    public function mail_notify($content, $users=false, $attachedImages=array()) {
431*6f380773SSzymon Olewniczak        $mailer = new \Mailer();
43214a1f0a4SSzymon Olewniczak        $mailer->setBody($content, array(), array(), $content, false);
4338a638198SSzymon Olewniczak
4348a638198SSzymon Olewniczak        if ($users === FALSE) {
435e8827d73SSzymon Olewniczak            $users = $this->get_participants('subscribent');
4368a638198SSzymon Olewniczak
4378a638198SSzymon Olewniczak            //don't notify current user
4388a638198SSzymon Olewniczak            unset($users[$this->model->user_nick]);
4398a638198SSzymon Olewniczak        }
4408a638198SSzymon Olewniczak
4418a638198SSzymon Olewniczak        $emails = array_map(function($user) {
44220e189b9SSzymon Olewniczak            if (is_array($user)) {
44320e189b9SSzymon Olewniczak                $user = $user['user_id'];
44420e189b9SSzymon Olewniczak            }
44520e189b9SSzymon Olewniczak            return $this->model->userFactory->get_user_email($user);
4468a638198SSzymon Olewniczak        }, $users);
4478a638198SSzymon Olewniczak
4488a638198SSzymon Olewniczak        $mailer->to($emails);
44914a1f0a4SSzymon Olewniczak        $mailer->subject('#z'.$this->id. ' ' . $this->task_program_name);
4508a638198SSzymon Olewniczak
451a0cd8c78SSzymon Olewniczak        //add images
452a0cd8c78SSzymon Olewniczak        foreach ($attachedImages as $img) {
453a0cd8c78SSzymon Olewniczak            $mailer->attachFile($img['path'], $img['mime'], $img['name'], $img['embed']);
454a0cd8c78SSzymon Olewniczak        }
455a0cd8c78SSzymon Olewniczak
4568a638198SSzymon Olewniczak        $send = $mailer->send();
4578a638198SSzymon Olewniczak        if ($send === false) {
4588a638198SSzymon Olewniczak            //this may mean empty $emails
4598a638198SSzymon Olewniczak            //throw new Exception("can't send email");
4608a638198SSzymon Olewniczak        }
4618a638198SSzymon Olewniczak    }
4628a638198SSzymon Olewniczak
46314a1f0a4SSzymon Olewniczak    public function mail_task_box(&$attachedImages) {
46414a1f0a4SSzymon Olewniczak        $tpl = $this->model->action->get_tpl();
46514a1f0a4SSzymon Olewniczak
46614a1f0a4SSzymon Olewniczak        //render style
46714a1f0a4SSzymon Olewniczak        $less = new \lessc();
46814a1f0a4SSzymon Olewniczak        $less->addImportDir(DOKU_PLUGIN . 'bez/style/');
46914a1f0a4SSzymon Olewniczak        $style = $less->compileFile(DOKU_PLUGIN . 'bez/style/task.less');
47014a1f0a4SSzymon Olewniczak
47114a1f0a4SSzymon Olewniczak        //render content for mail
47214a1f0a4SSzymon Olewniczak        $old_content_html = $this->content_html;
47314a1f0a4SSzymon Olewniczak        $this->content_html = p_render('bez_xhtmlmail', p_get_instructions($this->content), $info);
47414a1f0a4SSzymon Olewniczak        $attachedImages = array_merge($attachedImages, $info['img']);
47514a1f0a4SSzymon Olewniczak
47614a1f0a4SSzymon Olewniczak        $tpl->set('task', $this);
47714a1f0a4SSzymon Olewniczak        $tpl->set('style', $style);
47814a1f0a4SSzymon Olewniczak        $tpl->set('no_actions', true);
47914a1f0a4SSzymon Olewniczak        $task_box = $this->model->action->bez_tpl_include('task_box', true);
48014a1f0a4SSzymon Olewniczak
48114a1f0a4SSzymon Olewniczak        $this->content_html = $old_content_html;
48214a1f0a4SSzymon Olewniczak
48314a1f0a4SSzymon Olewniczak        return $task_box;
484e8827d73SSzymon Olewniczak    }
485e8827d73SSzymon Olewniczak
48614a1f0a4SSzymon Olewniczak    public function mail_task(&$attachedImages) {
48714a1f0a4SSzymon Olewniczak        $tpl = $this->model->action->get_tpl();
48814a1f0a4SSzymon Olewniczak
48914a1f0a4SSzymon Olewniczak        $task_box = $this->mail_task_box($attachedImages);
49014a1f0a4SSzymon Olewniczak        $tpl->set('content', $task_box);
49114a1f0a4SSzymon Olewniczak        $content = $this->model->action->bez_tpl_include('mail/task', true);
49214a1f0a4SSzymon Olewniczak
49314a1f0a4SSzymon Olewniczak        return $content;
494e8827d73SSzymon Olewniczak    }
495e8827d73SSzymon Olewniczak
49614a1f0a4SSzymon Olewniczak    public function mail_notify_assignee() {
49714a1f0a4SSzymon Olewniczak        $tpl = $this->model->action->get_tpl();
498e8827d73SSzymon Olewniczak
49914a1f0a4SSzymon Olewniczak        //we don't want who
50014a1f0a4SSzymon Olewniczak        $tpl->set('who', $this->model->user_nick);
50114a1f0a4SSzymon Olewniczak        $tpl->set('action', 'mail_task_assignee');
50214a1f0a4SSzymon Olewniczak        $attachedImages = array();
50314a1f0a4SSzymon Olewniczak        $content = $this->mail_task($attachedImages);
50414a1f0a4SSzymon Olewniczak        $this->mail_notify($content, array($this->assignee), $attachedImages);
5058a638198SSzymon Olewniczak    }
5068a638198SSzymon Olewniczak
5078a638198SSzymon Olewniczak    public function mail_notify_remind($users=false) {
50814a1f0a4SSzymon Olewniczak        $tpl = $this->model->action->get_tpl();
5098a638198SSzymon Olewniczak
51014a1f0a4SSzymon Olewniczak        //we don't want who
51114a1f0a4SSzymon Olewniczak        $tpl->set('who', '');
51214a1f0a4SSzymon Olewniczak        $tpl->set('action', 'mail_task_remind');
51314a1f0a4SSzymon Olewniczak        $attachedImages = array();
51414a1f0a4SSzymon Olewniczak        $content = $this->mail_task($attachedImages);
51514a1f0a4SSzymon Olewniczak        $this->mail_notify($content, $users, $attachedImages);
5168a638198SSzymon Olewniczak    }
5178a638198SSzymon Olewniczak
5188a638198SSzymon Olewniczak    public function mail_notify_invite($client) {
5198a638198SSzymon Olewniczak        $users = array($client);
52014a1f0a4SSzymon Olewniczak        $tpl = $this->model->action->get_tpl();
52114a1f0a4SSzymon Olewniczak
52214a1f0a4SSzymon Olewniczak        //we don't want who
52314a1f0a4SSzymon Olewniczak        $tpl->set('who', $this->model->user_nick);
52414a1f0a4SSzymon Olewniczak        $tpl->set('action', 'mail_task_invite');
52514a1f0a4SSzymon Olewniczak        $attachedImages = array();
52614a1f0a4SSzymon Olewniczak        $content = $this->mail_task($attachedImages);
52714a1f0a4SSzymon Olewniczak        $this->mail_notify($content, $users, $attachedImages);
5288a638198SSzymon Olewniczak    }
52914a1f0a4SSzymon Olewniczak
53014a1f0a4SSzymon Olewniczak    public function mail_notify_change_state($action='') {
53114a1f0a4SSzymon Olewniczak        $tpl = $this->model->action->get_tpl();
53214a1f0a4SSzymon Olewniczak
53314a1f0a4SSzymon Olewniczak        $tpl->set('who', $this->model->user_nick);
53414a1f0a4SSzymon Olewniczak        $tpl->set('action', $action);
53514a1f0a4SSzymon Olewniczak        $attachedImages = array();
53614a1f0a4SSzymon Olewniczak        $content = $this->mail_task($attachedImages);
53714a1f0a4SSzymon Olewniczak        $this->mail_notify($content, false, $attachedImages);
53814a1f0a4SSzymon Olewniczak    }
53914a1f0a4SSzymon Olewniczak
5408a638198SSzymon Olewniczak}
541