piler/webui/controller/message/attachment.php
2013-03-21 20:26:49 +01:00

56 lines
1.5 KiB
PHP

<?php
class ControllerMessageAttachment extends Controller {
public function index(){
$this->id = "content";
$this->template = "message/headers.tpl";
$this->layout = "common/layout-empty";
$request = Registry::get('request');
$db = Registry::get('db');
$this->load->model('search/search');
$this->load->model('search/message');
$this->document->title = $this->data['text_message'];
$this->data['id'] = @$this->request->get['id'];
$messageid = 0;
if(!verify_piler_id($this->data['id'])) {
AUDIT(ACTION_UNKNOWN, '', '', $this->data['id'], 'unknown id: ' . $this->data['id']);
die("invalid id: " . $this->data['id']);
}
$this->data['attachment'] = $this->model_search_message->get_attachment_by_id($this->data['id']);
if(!isset($this->data['attachment']['filename'])) {
die("invalid filename");
}
$messageid = $this->model_search_message->get_id_by_piler_id($this->data['attachment']['piler_id']);
AUDIT(ACTION_DOWNLOAD_ATTACHMENT, '', '', $messageid, $this->data['id']);
header("Cache-Control: public, must-revalidate");
header("Pragma: no-cache");
header("Content-Type: application/octet-stream");
header("Content-Disposition: attachment; filename=\"" . $this->data['attachment']['filename'] . "\"");
header("Content-Transfer-Encoding: binary\n");
print $this->data['attachment']['attachment'];
exit;
}
}
?>