File size: 4.21Kb
<?php
/*
* @LitePanel
* @Version: 1.0.1
* @Date: 29.12.2012
* @Developed by QuickDevel
*/
class viewController extends Controller {
public function index($ticketid = null) {
$this->document->setActiveSection('admin');
$this->document->setActiveItem('tickets');
if(!$this->user->isLogged()) {
$this->session->data['error'] = "Вы не авторизированы!";
$this->response->redirect($this->config->url . 'account/login');
}
if($this->user->getAccessLevel() < 2) {
$this->session->data['error'] = "У вас нет доступа к данному разделу!";
$this->response->redirect($this->config->url);
}
$this->load->model('tickets');
$this->load->model('ticketsMessages');
$error = $this->validate($ticketid);
if($error) {
$this->session->data['error'] = $error;
$this->response->redirect($this->config->url . 'admin/tickets/index');
}
$ticket = $this->ticketsModel->getTicketById($ticketid, array('users'));
$messages = $this->ticketsMessagesModel->getTicketsMessages(array('ticket_id' => $ticketid), array('users'));
$this->data['ticket'] = $ticket;
$this->data['messages'] = $messages;
$this->getChild(array('common/header', 'common/footer'));
return $this->load->view('admin/tickets/view', $this->data);
}
public function ajax($ticketid = null) {
if(!$this->user->isLogged()) {
$this->data['status'] = "error";
$this->data['error'] = "Вы не авторизированы!";
return json_encode($this->data);
}
if($this->user->getAccessLevel() < 2) {
$this->data['status'] = "error";
$this->data['error'] = "У вас нет доступа к данному разделу!";
return json_encode($this->data);
}
$this->load->library('mail');
$this->load->model('tickets');
$this->load->model('ticketsMessages');
if($this->request->server['REQUEST_METHOD'] == 'POST') {
$errorPOST = $this->validatePOST($ticketid);
if(!$errorPOST) {
$text = @$this->request->post['text'];
$closeticket = @$this->request->post['closeticket'];
$userid = $this->user->getId();
if($closeticket) {
$this->ticketsModel->updateTicket($ticketid, array('ticket_status' => 0));
$this->data['status'] = "success";
$this->data['success'] = "Вы успешно закрыли тикет!";
} else {
$messageData = array(
'ticket_id' => $ticketid,
'user_id' => $userid,
'ticket_message' => $text
);
$this->ticketsMessagesModel->createTicketMessage($messageData);
$ticket = $this->ticketsModel->getTicketById($ticketid, array('users'));
$mailLib = new mailLibrary();
$mailLib->setFrom($this->config->mail_from);
$mailLib->setSender($this->config->mail_sender);
$mailLib->setTo($ticket['user_email']);
$mailLib->setSubject("Новый ответ в тикете #$ticketid");
$mailData = array();
$mailData['firstname'] = $ticket['user_firstname'];
$mailData['lastname'] = $ticket['user_lastname'];
$mailData['ticketid'] = $ticketid;
$text = $this->load->view('mail/tickets/newMessage', $mailData);
$mailLib->setText($text);
$mailLib->send();
$this->data['status'] = "success";
$this->data['success'] = "Вы успешно отправили сообщение!";
}
} else {
$this->data['status'] = "error";
$this->data['error'] = $errorPOST;
}
}
return json_encode($this->data);
}
private function validate($ticketid) {
$result = null;
if(!$this->ticketsModel->getTotalTickets(array('ticket_id' => (int)$ticketid))) {
$result = "Запрашиваемый тикет не существует!";
}
return $result;
}
private function validatePOST($ticketid) {
$result = null;
$text = @$this->request->post['text'];
$closeticket = @$this->request->post['closeticket'];
if(!$closeticket) {
if(mb_strlen($text) < 10 || mb_strlen($text) > 350) {
$result = "Текст сообщения должен содержать от 10 до 350 символов.";
}
}
return $result;
}
}