qa-event-updates.php 5.61 KB
Newer Older
Scott committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
<?php
/*
	Question2Answer by Gideon Greenspan and contributors
	http://www.question2answer.org/

	File: qa-include/qa-event-updates.php
	Description: Event module for maintaining events tables


	This program is free software; you can redistribute it and/or
	modify it under the terms of the GNU General Public License
	as published by the Free Software Foundation; either version 2
	of the License, or (at your option) any later version.

	This program is distributed in the hope that it will be useful,
	but WITHOUT ANY WARRANTY; without even the implied warranty of
	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
	GNU General Public License for more details.

	More about this license: http://www.question2answer.org/license.php
*/

Scott committed
23 24 25 26 27 28
class qa_event_updates
{
	public function process_event($event, $userid, $handle, $cookieid, $params)
	{
		if (@$params['silent']) // don't create updates about silent edits, and possibly other silent events in future
			return;
Scott committed
29

Scott committed
30 31
		require_once QA_INCLUDE_DIR.'db/events.php';
		require_once QA_INCLUDE_DIR.'app/events.php';
Scott committed
32

Scott committed
33 34 35 36
		switch ($event) {
			case 'q_post':
				if (isset($params['parent'])) // question is following an answer
					qa_create_event_for_q_user($params['parent']['parentid'], $params['postid'], QA_UPDATE_FOLLOWS, $userid, $params['parent']['userid']);
Scott committed
37

Scott committed
38 39 40 41
				qa_create_event_for_q_user($params['postid'], $params['postid'], null, $userid);
				qa_create_event_for_tags($params['tags'], $params['postid'], null, $userid);
				qa_create_event_for_category($params['categoryid'], $params['postid'], null, $userid);
				break;
Scott committed
42 43


Scott committed
44 45 46
			case 'a_post':
				qa_create_event_for_q_user($params['parentid'], $params['postid'], null, $userid, $params['parent']['userid']);
				break;
Scott committed
47 48


Scott committed
49 50
			case 'c_post':
				$keyuserids=array();
Scott committed
51

Scott committed
52 53 54
				foreach ($params['thread'] as $comment) // previous comments in thread (but not author of parent again)
					if (isset($comment['userid']))
						$keyuserids[$comment['userid']]=true;
Scott committed
55

Scott committed
56 57 58
				foreach ($keyuserids as $keyuserid => $dummy)
					if ($keyuserid != $userid)
						qa_db_event_create_not_entity($keyuserid, $params['questionid'], $params['postid'], QA_UPDATE_FOLLOWS, $userid);
Scott committed
59

Scott committed
60 61 62 63 64
				switch ($params['parent']['basetype'])
				{
					case 'Q':
						$updatetype=QA_UPDATE_C_FOR_Q;
						break;
Scott committed
65

Scott committed
66 67 68
					case 'A':
						$updatetype=QA_UPDATE_C_FOR_A;
						break;
Scott committed
69

Scott committed
70 71 72 73
					default:
						$updatetype=null;
						break;
				}
Scott committed
74

Scott committed
75 76 77 78
				qa_create_event_for_q_user($params['questionid'], $params['postid'], $updatetype, $userid,
					@$keyuserids[$params['parent']['userid']] ? null : $params['parent']['userid']);
						// give precedence to 'your comment followed' rather than 'your Q/A commented' if both are true
				break;
Scott committed
79 80


Scott committed
81 82 83 84 85 86 87
			case 'q_edit':
				if ($params['titlechanged'] || $params['contentchanged'])
					$updatetype=QA_UPDATE_CONTENT;
				elseif ($params['tagschanged'])
					$updatetype=QA_UPDATE_TAGS;
				else
					$updatetype=null;
Scott committed
88

Scott committed
89 90
				if (isset($updatetype)) {
					qa_create_event_for_q_user($params['postid'], $params['postid'], $updatetype, $userid, $params['oldquestion']['userid']);
Scott committed
91

Scott committed
92 93 94 95
					if ($params['tagschanged'])
						qa_create_event_for_tags($params['tags'], $params['postid'], QA_UPDATE_TAGS, $userid);
				}
				break;
Scott committed
96 97


Scott committed
98 99 100
			case 'a_select':
				qa_create_event_for_q_user($params['parentid'], $params['postid'], QA_UPDATE_SELECTED, $userid, $params['answer']['userid']);
				break;
Scott committed
101 102


Scott committed
103 104 105 106
			case 'q_reopen':
			case 'q_close':
				qa_create_event_for_q_user($params['postid'], $params['postid'], QA_UPDATE_CLOSED, $userid, $params['oldquestion']['userid']);
				break;
Scott committed
107 108


Scott committed
109 110 111 112
			case 'q_hide':
				if (isset($params['oldquestion']['userid']))
					qa_db_event_create_not_entity($params['oldquestion']['userid'], $params['postid'], $params['postid'], QA_UPDATE_VISIBLE, $userid);
				break;
Scott committed
113 114


Scott committed
115 116 117
			case 'q_reshow':
				qa_create_event_for_q_user($params['postid'], $params['postid'], QA_UPDATE_VISIBLE, $userid, $params['oldquestion']['userid']);
				break;
Scott committed
118 119


Scott committed
120 121 122 123
			case 'q_move':
				qa_create_event_for_q_user($params['postid'], $params['postid'], QA_UPDATE_CATEGORY, $userid, $params['oldquestion']['userid']);
				qa_create_event_for_category($params['categoryid'], $params['postid'], QA_UPDATE_CATEGORY, $userid);
				break;
Scott committed
124 125


Scott committed
126 127 128 129
			case 'a_edit':
				if ($params['contentchanged'])
					qa_create_event_for_q_user($params['parentid'], $params['postid'], QA_UPDATE_CONTENT, $userid, $params['oldanswer']['userid']);
				break;
Scott committed
130 131


Scott committed
132 133 134 135
			case 'a_hide':
				if (isset($params['oldanswer']['userid']))
					qa_db_event_create_not_entity($params['oldanswer']['userid'], $params['parentid'], $params['postid'], QA_UPDATE_VISIBLE, $userid);
				break;
Scott committed
136 137


Scott committed
138 139 140
			case 'a_reshow':
				qa_create_event_for_q_user($params['parentid'], $params['postid'], QA_UPDATE_VISIBLE, $userid, $params['oldanswer']['userid']);
				break;
Scott committed
141 142


Scott committed
143 144 145 146
			case 'c_edit':
				if ($params['contentchanged'])
					qa_create_event_for_q_user($params['questionid'], $params['postid'], QA_UPDATE_CONTENT, $userid, $params['oldcomment']['userid']);
				break;
Scott committed
147 148


Scott committed
149 150 151 152 153 154
			case 'a_to_c':
				if ($params['contentchanged'])
					qa_create_event_for_q_user($params['questionid'], $params['postid'], QA_UPDATE_CONTENT, $userid, $params['oldanswer']['userid']);
				else
					qa_create_event_for_q_user($params['questionid'], $params['postid'], QA_UPDATE_TYPE, $userid, $params['oldanswer']['userid']);
				break;
Scott committed
155 156


Scott committed
157 158 159 160
			case 'c_hide':
				if (isset($params['oldcomment']['userid']))
					qa_db_event_create_not_entity($params['oldcomment']['userid'], $params['questionid'], $params['postid'], QA_UPDATE_VISIBLE, $userid);
				break;
Scott committed
161 162


Scott committed
163 164 165
			case 'c_reshow':
				qa_create_event_for_q_user($params['questionid'], $params['postid'], QA_UPDATE_VISIBLE, $userid, $params['oldcomment']['userid']);
				break;
Scott committed
166 167
		}
	}
Scott committed
168
}