2012-02-08 23:14:28 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
|
|
class ControllerMessageView extends Controller {
|
|
|
|
|
|
|
|
public function index(){
|
|
|
|
|
|
|
|
$this->id = "content";
|
2020-03-15 11:39:40 +01:00
|
|
|
if(ENABLE_MOBILE_PREVIEW && MOBILE_DEVICE) {
|
2020-03-15 11:10:24 +01:00
|
|
|
$this->template = "message/view-mobile.tpl";
|
|
|
|
} else {
|
|
|
|
$this->template = "message/view.tpl";
|
|
|
|
}
|
2012-02-08 23:14:28 +01:00
|
|
|
$this->layout = "common/layout-empty";
|
|
|
|
|
2013-11-18 19:24:33 +01:00
|
|
|
$session = Registry::get('session');
|
2012-02-08 23:14:28 +01:00
|
|
|
$request = Registry::get('request');
|
|
|
|
$db = Registry::get('db');
|
|
|
|
|
|
|
|
$this->load->model('search/search');
|
|
|
|
$this->load->model('search/message');
|
|
|
|
$this->load->model('audit/audit');
|
|
|
|
|
|
|
|
$this->load->model('user/user');
|
|
|
|
|
2015-09-18 14:56:09 +02:00
|
|
|
if(ENABLE_FOLDER_RESTRICTIONS == 1) {
|
|
|
|
$this->load->model('folder/folder');
|
|
|
|
}
|
|
|
|
|
2012-02-08 23:14:28 +01:00
|
|
|
$this->document->title = $this->data['text_message'];
|
|
|
|
|
|
|
|
$this->data['id'] = '';
|
2013-06-29 17:59:57 +02:00
|
|
|
$this->data['search'] = '';
|
2012-12-20 14:11:17 +01:00
|
|
|
$this->data['rcpt'] = array();
|
2012-02-08 23:14:28 +01:00
|
|
|
|
2012-12-20 14:11:17 +01:00
|
|
|
if(isset($_SERVER['REQUEST_URI'])) { $a = preg_split("/\//", $_SERVER['REQUEST_URI']); $this->data['id'] = $a[count($a)-1]; }
|
2012-02-08 23:14:28 +01:00
|
|
|
|
|
|
|
if($this->request->server['REQUEST_METHOD'] == 'POST') {
|
|
|
|
$this->data['id'] = $this->request->post['id'];
|
2013-06-29 17:59:57 +02:00
|
|
|
$this->data['search'] = $this->request->post['search'];
|
2012-02-08 23:14:28 +01:00
|
|
|
}
|
|
|
|
|
2014-01-23 21:39:47 +01:00
|
|
|
if(substr($this->data['id'], 0, 1) == 'a') {
|
|
|
|
$this->template = "message/auto.tpl";
|
|
|
|
$this->data['id'] = substr($this->data['id'], 1, 200);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-02-08 23:14:28 +01:00
|
|
|
if(!verify_piler_id($this->data['id'])) {
|
2012-09-06 15:27:20 +02:00
|
|
|
AUDIT(ACTION_UNKNOWN, '', '', $this->data['id'], 'unknown id: ' . $this->data['id']);
|
2012-02-08 23:14:28 +01:00
|
|
|
die("invalid id: " . $this->data['id']);
|
|
|
|
}
|
|
|
|
|
2012-09-06 15:27:20 +02:00
|
|
|
if(!$this->model_search_search->check_your_permission_by_id($this->data['id'])) {
|
2012-02-08 23:14:28 +01:00
|
|
|
AUDIT(ACTION_UNAUTHORIZED_VIEW_MESSAGE, '', '', $this->data['id'], '');
|
|
|
|
die("no permission for " . $this->data['id']);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
AUDIT(ACTION_VIEW_MESSAGE, '', '', $this->data['id'], '');
|
|
|
|
|
|
|
|
$this->data['username'] = Registry::get('username');
|
|
|
|
|
2012-12-20 14:11:17 +01:00
|
|
|
if(Registry::get('auditor_user') == 1) { $this->data['rcpt'] = $this->model_search_search->get_message_addresses_in_my_domain($this->data['id']); }
|
|
|
|
|
2012-02-08 23:14:28 +01:00
|
|
|
/* fix username if we are admin */
|
|
|
|
|
|
|
|
if(isset($this->request->get['user']) && strlen($this->request->get['user']) > 1 && (Registry::get('admin_user') == 1 || $this->model_user_user->isUserInMyDomain($this->request->get['user']) == 1) ) {
|
|
|
|
$this->data['username'] = $this->request->get['user'];
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-06-29 17:59:57 +02:00
|
|
|
if($this->request->server['REQUEST_METHOD'] == 'POST' && isset($this->request->post['tag'])) {
|
2013-11-18 19:24:33 +01:00
|
|
|
$this->model_search_message->add_message_tag($this->data['id'], $session->get("uid"), $this->request->post['tag']);
|
2012-02-08 23:14:28 +01:00
|
|
|
header("Location: " . $_SERVER['HTTP_REFERER']);
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
2012-09-06 15:27:20 +02:00
|
|
|
$this->data['piler_id'] = $this->model_search_message->get_piler_id_by_id($this->data['id']);
|
2012-02-08 23:14:28 +01:00
|
|
|
|
2012-10-04 10:00:54 +02:00
|
|
|
$this->data['attachments'] = $this->model_search_message->get_attachment_list($this->data['piler_id']);
|
|
|
|
|
2013-06-29 17:59:57 +02:00
|
|
|
$this->data['message'] = $this->model_search_message->extract_message($this->data['piler_id'], $this->data['search']);
|
2013-11-18 19:24:33 +01:00
|
|
|
$this->data['message']['tag'] = $this->model_search_message->get_message_tag($this->data['id'], $session->get("uid"));
|
|
|
|
$this->data['message']['note'] = $this->model_search_message->get_message_note($this->data['id'], $session->get("uid"));
|
2012-02-08 23:14:28 +01:00
|
|
|
|
2016-02-16 15:37:34 +01:00
|
|
|
$this->data['message']['private'] = $this->model_search_message->get_message_private($this->data['id']);
|
|
|
|
|
2014-06-03 23:17:43 +02:00
|
|
|
$this->data['spam'] = $this->model_search_message->is_message_spam($this->data['id']);
|
|
|
|
|
2013-11-16 15:34:30 +01:00
|
|
|
$this->data['images'] = array();
|
|
|
|
|
2015-07-28 21:56:50 +02:00
|
|
|
$this->data['can_download'] = $this->model_audit_audit->can_download();
|
2015-07-28 22:10:50 +02:00
|
|
|
$this->data['can_restore'] = $this->model_audit_audit->can_restore();
|
2015-07-28 21:56:50 +02:00
|
|
|
|
2015-09-18 14:56:09 +02:00
|
|
|
if(ENABLE_FOLDER_RESTRICTIONS == 1) {
|
|
|
|
$this->data['folders'] = $this->model_folder_folder->get_folders_for_user();
|
|
|
|
$this->data['folder_id'] = $this->model_folder_folder->get_folder_id_by_id($this->data['id']);
|
|
|
|
}
|
|
|
|
|
2013-11-16 15:34:30 +01:00
|
|
|
foreach($this->data['attachments'] as $a) {
|
|
|
|
if(preg_match("/image/", $a['type'])) {
|
|
|
|
$attachment = $this->model_search_message->get_attachment_by_id($a['id']);
|
2014-02-24 10:10:28 +01:00
|
|
|
$fp = fopen(DIR_BASE . 'tmp/' . "i." . $a['id'], "w+");
|
2013-11-16 15:34:30 +01:00
|
|
|
if($fp) {
|
|
|
|
fwrite($fp, $attachment['attachment']);
|
|
|
|
fclose($fp);
|
|
|
|
|
|
|
|
$this->data['images'][] = array(
|
2014-02-24 10:10:28 +01:00
|
|
|
'name' => "i." . $a['id']
|
2013-11-16 15:34:30 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-02-08 23:14:28 +01:00
|
|
|
$this->render();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
?>
|