Permalink
| <?php if ( ! defined('BASEPATH')) exit('No direct script access allowed'); | |
| class Message_model extends DB_Model | |
| { | |
| public function __construct() | |
| { | |
| parent::__construct(); | |
| require_once APPPATH.'config/message.php'; | |
| //$this->load->helper('language'); | |
| $this->lang->load('message'); | |
| } | |
| /** ----------------------------------------------------------------- | |
| * get_message() - will return a single message, including the status for specified user. | |
| * | |
| * @param integer $msg_id EQUIRED | |
| * @param integer $user_id REQUIRED | |
| * @return array | |
| */ | |
| function getMessage($msg_id, $user_id) | |
| { | |
| // Validate | |
| if (empty($msg_id)) | |
| { | |
| return $this->_invalid_id(MSG_ERR_INVALID_MSG_ID); | |
| } | |
| if (empty($user_id)) | |
| { | |
| return $this->_invalid_id(MSG_ERR_INVALID_USER_ID); | |
| } | |
| $sql = 'SELECT m.*, s.status, t.subject, ' . USER_TABLE_USERNAME . | |
| ' FROM ' . $this->db->dbprefix . 'msg_messages m ' . | |
| ' JOIN ' . $this->db->dbprefix . 'msg_threads t ON (m.thread_id = t.id) ' . | |
| ' JOIN ' . $this->db->dbprefix . USER_TABLE_TABLENAME . ' ON (' . USER_TABLE_ID . ' = m.sender_id) '. | |
| ' JOIN ' . $this->db->dbprefix . 'msg_status s ON (s.message_id = m.id AND s.user_id = ? ) ' . | |
| ' WHERE m.id = ? ' ; | |
| $result = $this->db->query($sql, array($user_id, $msg_id)); | |
| if ($result) | |
| return $this->_success($result->result_array()); | |
| else | |
| return $this->_general_error(); | |
| } | |
| /** ----------------------------------------------------------------- | |
| * Get a Full Thread | |
| * get_full_thread() - will return a entire thread, including the status for specified user. | |
| * | |
| * @param integer $thread_id REQUIRED | |
| * @param integer $user_id REQUIRED | |
| * @param boolean $full_thread OPTIONAL - If true, user will also see messages from thread posted BEFORE user became participant | |
| * @param string $order_by OPTIONAL | |
| * @return array | |
| */ | |
| function get_full_thread($thread_id, $user_id, $full_thread = FALSE, $order_by = 'ASC') | |
| { | |
| // Validate | |
| if (empty($thread_id)) | |
| { | |
| return $this->_invalid_id(MSG_ERR_INVALID_THREAD_ID); | |
| } | |
| if (empty($user_id)) | |
| { | |
| return $this->_invalid_id(MSG_ERR_INVALID_USER_ID); | |
| } | |
| $sql = 'SELECT m.*, s.status, t.subject, '.USER_TABLE_USERNAME . | |
| ' FROM ' . $this->db->dbprefix . 'msg_participants p ' . | |
| ' JOIN ' . $this->db->dbprefix . 'msg_threads t ON (t.id = p.thread_id) ' . | |
| ' JOIN ' . $this->db->dbprefix . 'msg_messages m ON (m.thread_id = t.id) ' . | |
| ' JOIN ' . $this->db->dbprefix . USER_TABLE_TABLENAME . ' ON (' . USER_TABLE_ID . ' = m.sender_id) '. | |
| ' JOIN ' . $this->db->dbprefix . 'msg_status s ON (s.message_id = m.id AND s.user_id = ? ) ' . | |
| ' WHERE p.user_id = ? ' . | |
| ' AND p.thread_id = ? '; | |
| if ( ! $full_thread) | |
| { | |
| $sql .= ' AND m.cdate >= p.cdate'; | |
| } | |
| $sql .= ' ORDER BY m.cdate ' . $order_by; | |
| $result = $this->db->query($sql, array($user_id, $user_id, $thread_id)); | |
| if ($result) | |
| return $this->_success($result->result_array()); | |
| else | |
| return $this->_general_error(); | |
| } | |
| /** ----------------------------------------------------------------- | |
| * get_all_threads() - will return all threads for user, including the status for specified user. | |
| * | |
| * @param integer $user_id REQUIRED | |
| * @param boolean $full_thread OPTIONAL - If true, user will also see messages from thread posted BEFORE user became participant | |
| * @param string $order_by OPTIONAL | |
| * @return array | |
| */ | |
| function get_all_threads($user_id, $full_thread = FALSE, $order_by = 'asc') | |
| { | |
| if (empty($user_id)) | |
| { | |
| return $this->_invalid_id(MSG_ERR_INVALID_USER_ID); | |
| } | |
| $sql = 'SELECT m.*, s.status, t.subject, '.USER_TABLE_USERNAME . | |
| ' FROM ' . $this->db->dbprefix . 'msg_participants p ' . | |
| ' JOIN ' . $this->db->dbprefix . 'msg_threads t ON (t.id = p.thread_id) ' . | |
| ' JOIN ' . $this->db->dbprefix . 'msg_messages m ON (m.thread_id = t.id) ' . | |
| ' JOIN ' . $this->db->dbprefix . USER_TABLE_TABLENAME . ' ON (' . USER_TABLE_ID . ' = m.sender_id) '. | |
| ' JOIN ' . $this->db->dbprefix . 'msg_status s ON (s.message_id = m.id AND s.user_id = ? ) ' . | |
| ' WHERE p.user_id = ? ' ; | |
| if (!$full_thread) | |
| { | |
| $sql .= ' AND m.cdate >= p.cdate'; | |
| } | |
| $sql .= ' ORDER BY t.id ' . $order_by. ', m.cdate '. $order_by; | |
| $result = $this->db->query($sql, array($user_id, $user_id)); | |
| if ($result) | |
| return $this->_success($result->result_array()); | |
| else | |
| return $this->_general_error(); | |
| } | |
| /** ----------------------------------------------------------------- | |
| * Get all Threads Grouped | |
| * get_all_threads_grouped() - will return all threads for user, including the status for specified user. | |
| * - messages are grouped in threads. | |
| * | |
| * @param integer $user_id REQUIRED | |
| * @param boolean $full_thread OPTIONAL - If true, user will also see messages from thread posted BEFORE user became participant | |
| * @param string $order_by OPTIONAL | |
| * @return array | |
| */ | |
| function get_all_threads_grouped($user_id, $full_thread = FALSE, $order_by = 'ASC') | |
| { | |
| if (empty($user_id)) | |
| { | |
| return $this->_invalid_id(MSG_ERR_INVALID_USER_ID); | |
| } | |
| $message = $this->get_all_threads($user_id, $full_thread, $order_by); | |
| if (is_array($message)) | |
| { | |
| $threads = array(); | |
| foreach ($message as $msg) | |
| { | |
| if ( ! isset($threads[$msg['thread_id']])) | |
| { | |
| $threads[$msg['thread_id']]['thread_id'] = $msg['thread_id']; | |
| $threads[$msg['thread_id']]['messages'] = array($msg); | |
| } | |
| else | |
| { | |
| $threads[$msg['thread_id']]['messages'][] = $msg; | |
| } | |
| } | |
| return $this->_success($threads); | |
| } | |
| // General Error Occurred | |
| return $this->_general_error(); | |
| } | |
| /** ----------------------------------------------------------------- | |
| * Change Message Status | |
| * update_message_status() - will change status on message for particular user | |
| * | |
| * @param integer $msg_id REQUIRED | |
| * @param integer $user_id REQUIRED | |
| * @param integer $status_id REQUIRED - should come from config/message.php list of constants | |
| * @return array | |
| */ | |
| function update_message_status($msg_id, $user_id, $status_id) | |
| { | |
| // Validate | |
| if (empty($msg_id)) | |
| { | |
| return $this->_invalid_id(MSG_ERR_INVALID_MSG_ID); | |
| } | |
| if (empty($user_id)) | |
| { | |
| return $this->_invalid_id(MSG_ERR_INVALID_USER_ID); | |
| } | |
| if (empty($status_id)) | |
| { | |
| return $this->_invalid_id(MSG_ERR_INVALID_STATUS_ID); | |
| } | |
| $this->db->where(array('message_id' => $msg_id, 'user_id' => $user_id )); | |
| $this->db->update('msg_status', array('status' => $status_id )); | |
| $rows = $this->db->affected_rows(); | |
| if ($rows == 1) | |
| return $this->_success($rows, MSG_STATUS_UPDATE); | |
| else | |
| return $this->_general_error(); | |
| } | |
| /** ----------------------------------------------------------------- | |
| * Add a Participant | |
| * add_participant() - adds user to existing thread | |
| * | |
| * @param integer $thread_id REQUIRED | |
| * @param integer $user_id REQUIRED | |
| * @return array | |
| */ | |
| function add_participant($thread_id, $user_id) | |
| { | |
| if (empty($thread_id)) | |
| { | |
| return $this->_invalid_id(MSG_ERR_INVALID_THREAD_ID); | |
| } | |
| if (empty($user_id)) | |
| { | |
| return $this->_invalid_id(MSG_ERR_INVALID_USER_ID); | |
| } | |
| if ( ! $this->valid_new_participant($thread_id, $user_id)) | |
| { | |
| $this->_participant_error(MSG_ERR_PARTICIPANT_EXISTS); | |
| } | |
| if ( ! $this->application_user($user_id)) | |
| { | |
| $this->_participant_error(MSG_ERR_PARTICIPANT_NONSYSTEM); | |
| } | |
| $this->db->trans_start(); | |
| $participants[] = array('thread_id' => $thread_id,'user_id' => $user_id); | |
| $this->_insert_participants($participants); | |
| // Get Messages by Thread | |
| $messages = $this->_get_messages_by_thread_id($thread_id); | |
| foreach ($messages as $message) | |
| { | |
| $statuses[] = array('message_id' => $message['id'], 'user_id' => $user_id, 'status' => MSG_STATUS_UNREAD); | |
| } | |
| $this->_insert_statuses($statuses); | |
| $this->db->trans_complete(); | |
| if ($this->db->trans_status() === FALSE) | |
| { | |
| $this->db->trans_rollback(); | |
| return $this->_general_error(); | |
| } | |
| return $this->_success(NULL, MSG_PARTICIPANT_ADDED); | |
| } | |
| /** --------------------------------------------------------------- | |
| * Remove a Participant | |
| * remove_participant() - removes user from existing thread | |
| * | |
| * @param integer $thread_id REQUIRED | |
| * @param integer $user_id REQUIRED | |
| * @return array | |
| */ | |
| function remove_participant($thread_id, $user_id) | |
| { | |
| // Validate | |
| if (empty($thread_id)) | |
| { | |
| return $this->_invalid_id(MSG_ERR_INVALID_THREAD_ID); | |
| } | |
| if (empty($user_id)) | |
| { | |
| return $this->_invalid_id(MSG_ERR_INVALID_USER_ID); | |
| } | |
| $this->db->trans_start(); | |
| $this->_delete_participant($thread_id, $user_id); | |
| $this->_delete_statuses($thread_id, $user_id); | |
| $this->db->trans_complete(); | |
| if ($this->db->trans_status() === FALSE) | |
| { | |
| $this->db->trans_rollback(); | |
| return $this->_success(NULL, MSG_PARTICIPANT_REMOVED); | |
| } | |
| return $this->_general_error(); | |
| } | |
| /** ---------------------------------------------------------------- | |
| * Send a New Message | |
| * send_new_message() - sends new internal message. This function will create a new thread | |
| * | |
| * @param integer $sender_id REQUIRED | |
| * @param mixed $recipients REQUIRED - a single integer or an array of integers, representing user_ids | |
| * @param string $subject | |
| * @param string $body | |
| * @param integer $priority | |
| * @return array | |
| */ | |
| function send_new_message($sender_id, $recipients, $subject, $body, $priority) | |
| { | |
| // Validate | |
| if (empty($sender_id)) | |
| { | |
| return $this->_invalid_id(MSG_ERR_INVALID_SENDER_ID); | |
| } | |
| if (empty($recipients)) | |
| { | |
| return array( | |
| 'err' => 1, | |
| 'code' => MSG_ERR_INVALID_RECIPIENTS, | |
| 'msg' => lang('mahana_'.MSG_ERR_INVALID_RECIPIENTS) | |
| ); | |
| } | |
| $this->db->trans_start(); | |
| $thread_id = $this->_insert_thread($subject); | |
| $msg_id = $this->_insert_message($thread_id, $sender_id, $body, $priority); | |
| // Create batch inserts | |
| $participants[] = array('thread_id' => $thread_id,'user_id' => $sender_id); | |
| $statuses[] = array('message_id' => $msg_id, 'user_id' => $sender_id,'status' => MSG_STATUS_READ); | |
| if ( ! is_array($recipients) ) | |
| { | |
| if ($sender_id != $recipients) | |
| { | |
| $participants[] = array('thread_id' => $thread_id,'user_id' => $recipients); | |
| $statuses[] = array('message_id' => $msg_id, 'user_id' => $recipients, 'status' => MSG_STATUS_UNREAD); | |
| } | |
| } | |
| else | |
| { | |
| foreach ($recipients as $recipient) | |
| { | |
| if ($sender_id != $recipient) | |
| { | |
| $participants[] = array('thread_id' => $thread_id,'user_id' => $recipient); | |
| $statuses[] = array('message_id' => $msg_id, 'user_id' => $recipient, 'status' => MSG_STATUS_UNREAD); | |
| } | |
| } | |
| } | |
| $participants=array_unique($participants, SORT_REGULAR); // Clean if sender and recipient is the same | |
| $this->_insert_participants($participants); | |
| $this->_insert_statuses($statuses); | |
| $this->db->trans_complete(); | |
| if ($this->db->trans_status() === FALSE) | |
| { | |
| $this->db->trans_rollback(); | |
| return $this->_general_error(); | |
| } | |
| return $this->_success($thread_id, MSG_MESSAGE_SENT); | |
| } | |
| /** -------------------------------------------------------------- | |
| * Reply to Message | |
| * reply_to_message() - replies to internal message. This function will NOT create a new thread or participant list | |
| * | |
| * @param integer $msg_id REQUIRED | |
| * @param integer $sender_id REQUIRED | |
| * @param string $subject | |
| * @param string $body | |
| * @param integer $priority | |
| * @return array | |
| */ | |
| function reply_to_message($reply_msg_id, $sender_id, $body, $priority) | |
| { | |
| // Validate | |
| if (empty($sender_id)) | |
| { | |
| return $this->_invalid_id(MSG_ERR_INVALID_SENDER_ID); | |
| } | |
| if (empty($msg_id)) | |
| { | |
| return $this->_invalid_id(MSG_ERR_INVALID_MSG_ID); | |
| } | |
| $this->db->trans_start(); | |
| // Get the thread id to keep messages together | |
| if ( ! $thread_id = $this->_get_thread_id_from_message($reply_msg_id)) | |
| { | |
| return FALSE; | |
| } | |
| // Add this message | |
| $msg_id = $this->_insert_message($thread_id, $sender_id, $body, $priority); | |
| if ($recipients = $this->_get_thread_participants($thread_id, $sender_id)) | |
| { | |
| $statuses[] = array('message_id' => $msg_id, 'user_id' => $sender_id,'status' => MSG_STATUS_READ); | |
| foreach ($recipients as $recipient) | |
| { | |
| $statuses[] = array('message_id' => $msg_id, 'user_id' => $recipient['user_id'], 'status' => MSG_STATUS_UNREAD); | |
| } | |
| $this->_insert_statuses($statuses); | |
| } | |
| $this->db->trans_complete(); | |
| if ($this->db->trans_status() === FALSE) | |
| { | |
| $this->db->trans_rollback(); | |
| return $this->_general_error(); | |
| } | |
| return $this->_success($msg_id, MSG_MESSAGE_SENT); | |
| } | |
| /** ---------------------------------------------------------------- | |
| * Get Participant List | |
| * get_participant_list() - returns list of participants on given thread. If sender_id set, sender_id will be left off list | |
| * | |
| * @param integer $thread_id REQUIRED | |
| * @param integer $sender_id REQUIRED | |
| * @return array | |
| */ | |
| function get_participant_list($thread_id, $sender_id = 0) | |
| { | |
| // Validate | |
| if (empty($thread_id)) | |
| { | |
| return $this->_invalid_id(MSG_ERR_INVALID_THREAD_ID); | |
| } | |
| if ($results = $this->_get_thread_participants($thread_id, $sender_id)) | |
| return $this->_success($results); | |
| else | |
| return $this->_general_error(); | |
| } | |
| /** ---------------------------------------------------------------- | |
| * Get Message Count | |
| * get_msg_count() - returns integer with count of message for user, by status. defaults to new messages | |
| * | |
| * @param integer $user_id REQUIRED | |
| * @param integer $status_id OPTIONAL - defaults to "Unread" | |
| * @return array | |
| */ | |
| function get_msg_count($user_id, $status_id = MSG_STATUS_UNREAD) | |
| { | |
| if (empty($user_id)) | |
| { | |
| return $this->_invalid_id(MSG_ERR_INVALID_USER_ID); | |
| } | |
| $result = $this->db->select('COUNT(*) AS msg_count')->where(array('user_id' => $user_id, 'status' => $status_id ))->get('msg_status'); | |
| $rows = $result->row()->msg_count; | |
| if (is_numeric($rows)) | |
| return $this->_success($rows); | |
| else | |
| return $this->_general_error(); | |
| } | |
| // ------------------------------------------------------------------------ | |
| /** | |
| * Valid New Participant - because of CodeIgniter's DB Class return style, | |
| * it is safer to check for uniqueness first | |
| * | |
| * @param integer $thread_id | |
| * @param integer $user_id | |
| * @return boolean | |
| */ | |
| function valid_new_participant($thread_id, $user_id) | |
| { | |
| $sql = 'SELECT COUNT(*) AS count ' . | |
| ' FROM ' . $this->db->dbprefix . 'msg_participants p ' . | |
| ' WHERE p.thread_id = ? ' . | |
| ' AND p.user_id = ? '; | |
| $query = $this->db->query($sql, array($thread_id, $user_id)); | |
| if ($query->row()->count) | |
| { | |
| return FALSE; | |
| } | |
| return TRUE; | |
| } | |
| /** --------------------------------------------------------------- | |
| * Application User | |
| * | |
| * @param integer $user_id` | |
| * @return boolean | |
| */ | |
| function application_user($user_id) | |
| { | |
| $sql = 'SELECT COUNT(*) AS count ' . | |
| ' FROM ' . $this->db->dbprefix . USER_TABLE_TABLENAME . | |
| ' WHERE ' . USER_TABLE_ID . ' = ?' ; | |
| $query = $this->db->query($sql, array($user_id)); | |
| if ($query->row()->count) | |
| { | |
| return TRUE; | |
| } | |
| return FALSE; | |
| } | |
| // ------------------------------------------------------------------------ | |
| // Private Functions from here out! | |
| // ------------------------------------------------------------------------ | |
| /** | |
| * Insert Thread | |
| * | |
| * @param string $subject | |
| * @return integer | |
| */ | |
| private function _insert_thread($subject) | |
| { | |
| $insert_id = $this->db->insert('msg_threads', array('subject' => $subject)); | |
| return $this->db->insert_id(); | |
| } | |
| /** | |
| * Insert Message | |
| * | |
| * @param integer $thread_id | |
| * @param integer $sender_id | |
| * @param string $body | |
| * @param integer $priority | |
| * @return integer | |
| */ | |
| private function _insert_message($thread_id, $sender_id, $body, $priority) | |
| { | |
| $insert['thread_id'] = $thread_id; | |
| $insert['sender_id'] = $sender_id; | |
| $insert['body'] = $body; | |
| $insert['priority'] = $priority; | |
| $insert_id = $this->db->insert('msg_messages', $insert); | |
| return $this->db->insert_id(); | |
| } | |
| /** | |
| * Insert Participants | |
| * | |
| * @param array $participants | |
| * @return bool | |
| */ | |
| private function _insert_participants($participants) | |
| { | |
| return $this->db->insert_batch('msg_participants', $participants); | |
| } | |
| /** | |
| * Insert Statuses | |
| * | |
| * @param array $statuses | |
| * @return bool | |
| */ | |
| private function _insert_statuses($statuses) | |
| { | |
| return $this->db->insert_batch('msg_status', $statuses); | |
| } | |
| /** | |
| * Get Thread ID from Message | |
| * | |
| * @param integer $msg_id | |
| * @return integer | |
| */ | |
| private function _get_thread_id_from_message($msg_id) | |
| { | |
| $query = $this->db->select('thread_id')->get_where('msg_messages', array('id' => $msg_id)); | |
| if ($query->num_rows()) | |
| { | |
| return $query->row()->thread_id; | |
| } | |
| return 0; | |
| } | |
| /** | |
| * Get Messages by Thread | |
| * | |
| * @param integer $thread_id | |
| * @return array | |
| */ | |
| private function _get_messages_by_thread_id($thread_id) | |
| { | |
| $query = $this->db->get_where('msg_messages', array('thread_id' => $thread_id)); | |
| return $query->result_array(); | |
| } | |
| /** | |
| * Get Thread Particpiants | |
| * | |
| * @param integer $thread_id | |
| * @param integer $sender_id | |
| * @return array | |
| */ | |
| private function _get_thread_participants($thread_id, $sender_id = 0) | |
| { | |
| $array['thread_id'] = $thread_id; | |
| if ($sender_id) // If $sender_id 0, no one to exclude | |
| { | |
| $array['msg_participants.user_id != '] = $sender_id; | |
| } | |
| $this->db->select('msg_participants.user_id, '.USER_TABLE_USERNAME, FALSE); | |
| $this->db->join(USER_TABLE_TABLENAME, 'msg_participants.user_id = ' . USER_TABLE_ID); | |
| $query = $this->db->get_where('msg_participants', $array); | |
| return $query->result_array(); | |
| } | |
| /** | |
| * Delete Participant | |
| * | |
| * @param integer $thread_id | |
| * @param integer $user_id | |
| * @return boolean | |
| */ | |
| private function _delete_participant($thread_id, $user_id) | |
| { | |
| $this->db->delete('msg_participants', array('thread_id' => $thread_id, 'user_id' => $user_id)); | |
| if ($this->db->affected_rows() > 0) | |
| { | |
| return TRUE; | |
| } | |
| return FALSE; | |
| } | |
| /** | |
| * Delete Statuses | |
| * | |
| * @param integer $thread_id | |
| * @param integer $user_id | |
| * @return boolean | |
| */ | |
| private function _delete_statuses($thread_id, $user_id) | |
| { | |
| $sql = 'DELETE s FROM msg_status s ' . | |
| ' JOIN ' . $this->db->dbprefix . 'msg_messages m ON (m.id = s.message_id) ' . | |
| ' WHERE m.thread_id = ? ' . | |
| ' AND s.user_id = ? '; | |
| $query = $this->db->query($sql, array($thread_id, $user_id)); | |
| return TRUE; | |
| } | |
| /** --------------------------------------------------------------- | |
| * Error Particpant Exists | |
| * | |
| * @return array | |
| */ | |
| private function _participant_error($error = '') | |
| { | |
| return array( | |
| 'err' => 1, | |
| 'code' => 1, | |
| 'msg' => lang('mahana_' . $error) | |
| ); | |
| } | |
| } | |
| /* end of file message_model.php */ |