* @author Slawkens * @copyright 2017 MyAAC * @version 0.6.6 * @link http://my-aac.org */ defined('MYAAC') or die('Direct access not allowed!'); $title = 'Bug tracker'; if(!$logged) { echo 'You are not logged in. Log in to post on the bug tracker.

'; return; } $showed = $post = $reply = false; // type (1 = question; 2 = answer) // status (1 = open; 2 = new message; 3 = closed;) $dark = $config['darkborder']; $light = $config['lightborder']; $tags = array(1 => "[MAP]", "[WEBSITE]", "[CLIENT]", "[MONSTER]", "[NPC]", "[OTHER]"); if(admin() and isset($_REQUEST['control']) && $_REQUEST['control'] == "true") { if(empty($_REQUEST['id']) and empty($_REQUEST['acc']) or !is_numeric($_REQUEST['acc']) or !is_numeric($_REQUEST['id']) ) $bug[1] = $db->query('SELECT * FROM '.$db->tableName(TABLE_PREFIX . 'bugtracker').' where `type` = 1 order by `uid` desc'); if(!empty($_REQUEST['id']) and is_numeric($_REQUEST['id']) and !empty($_REQUEST['acc']) and is_numeric($_REQUEST['acc'])) $bug[2] = $db->query('SELECT * FROM '.$db->tableName(TABLE_PREFIX . 'bugtracker').' where `account` = '.$_REQUEST['acc'].' and `id` = '.$_REQUEST['id'].' and `type` = 1')->fetch(); if(!empty($_REQUEST['id']) and is_numeric($_REQUEST['id']) and !empty($_REQUEST['acc']) and is_numeric($_REQUEST['acc'])) { if(!empty($_REQUEST['reply'])) $reply=true; $account = new OTS_Account(); $account->load($_REQUEST['acc']); $account->isLoaded(); $players = $account->getPlayersList(); if(!$reply) { if($bug[2]['status'] == 2) $value = "[OPEN]"; elseif($bug[2]['status'] == 3) $value = "[CLOSED]"; elseif($bug[2]['status'] == 1) $value = "[NEW ANSWER]"; echo ''; echo ''; echo ''; echo ''; echo ''; echo '
Bug Tracker
Subject'.$tags[$bug[2]['tag']].' '.$bug[2]['subject'].' '.$value.'
Posted by'; foreach($players as $player) { echo ''.$player->getName().'
'; } echo '
Description
'.nl2br($bug[2]['text']).'
'; $answers = $db->query('SELECT * FROM '.$db->tableName(TABLE_PREFIX . 'bugtracker').' where `account` = '.$_REQUEST['acc'].' and `id` = '.$_REQUEST['id'].' and `type` = 2 order by `reply`'); foreach($answers as $answer) { if($answer['who'] == 1) $who = "[ADMIN]"; else $who = "[PLAYER]"; echo '
'; echo ''; echo ''; echo ''; echo '
Answer #'.$answer['reply'].'
Posted by'.$who.'
Description
'.nl2br($answer['text']).'
'; } if($bug[2]['status'] != 3) echo '
[REPLY]'; } else { if($bug[2]['status'] != 3) { $reply = $db->query('SELECT MAX(reply) FROM `' . TABLE_PREFIX . 'bugtracker` where `account` = '.$_REQUEST['acc'].' and `id` = '.$_REQUEST['id'].' and `type` = 2')->fetch(); $reply = $reply[0] + 1; $iswho = $db->query('SELECT * FROM `' . TABLE_PREFIX . 'bugtracker` where `account` = '.$_REQUEST['acc'].' and `id` = '.$_REQUEST['id'].' and `type` = 2 order by `reply` desc limit 1')->fetch(); if(isset($_POST['finish'])) { if(empty($_POST['text'])) $error[] = "Description cannot be empty."; if($iswho['who'] == 1) $error[] = "You must wait for User answer."; if(empty($_POST['status'])) $error[] = "Status cannot be empty."; if(!empty($error)) { foreach($error as $errors) echo ''.$errors.'
'; } else { $type = 2; $INSERT = $db->query('INSERT INTO `' . TABLE_PREFIX . 'bugtracker` (`account`,`id`,`text`,`reply`,`type`, `who`) VALUES ('.$db->quote($_REQUEST['acc']).','.$db->quote($_REQUEST['id']).','.$db->quote($_POST['text']).','.$db->quote($reply).','.$db->quote($type).','.$db->quote(1).')'); $UPDATE = $db->query('UPDATE `' . TABLE_PREFIX . 'bugtracker` SET `status` = '.$_POST['status'].' where `account` = '.$_REQUEST['acc'].' and `id` = '.$_REQUEST['id'].''); header('Location: ?subtopic=bugtracker&control=true&id='.$_REQUEST['id'].'&acc='.$_REQUEST['acc'].''); } } echo '
Description
Status[OPEN]
Status[CLOSED]

'; } else { echo "
You can't add answer to closed bug thread."; } } $post=true; } if(!$post) { echo ''; $i=1; foreach($bug[1] as $report) { if($report['status'] == 2) $value = "[OPEN]"; elseif($report['status'] == 3) $value = "[CLOSED]"; elseif($report['status'] == 1) $value = "[NEW ANSWER]"; echo ''; $showed=true; $i++; } echo '
Bug Tracker Admin
'.$tags[$report['tag']].' '.$report['subject'].''.$value.'
'; } } else { $acc = $account_logged->getId(); $account_players = $account_logged->getPlayersList(); foreach($account_players as $player) { $allow=true; } if(!empty($_REQUEST['id'])) $id = addslashes(htmlspecialchars(trim($_REQUEST['id']))); if(empty($_REQUEST['id'])) $bug[1] = $db->query('SELECT * FROM '.$db->tableName(TABLE_PREFIX . 'bugtracker').' where `account` = '.$account_logged->getId().' and `type` = 1 order by `id` desc'); if(!empty($_REQUEST['id']) and is_numeric($_REQUEST['id'])) $bug[2] = $db->query('SELECT * FROM '.$db->tableName(TABLE_PREFIX . 'bugtracker').' where `account` = '.$account_logged->getId().' and `id` = '.$id.' and `type` = 1')->fetch(); else $bug[2] = NULL; if(!empty($_REQUEST['id']) and $bug[2] != NULL) { if(!empty($_REQUEST['reply'])) $reply=true; if(!$reply) { if($bug[2]['status'] == 1) $value = "[OPEN]"; elseif($bug[2]['status'] == 2) $value = "[NEW ANSWER]"; elseif($bug[2]['status'] == 3) $value = "[CLOSED]"; echo ''; echo ''; echo ''; echo ''; echo '
Bug Tracker
Subject'.$tags[$bug[2]['tag']].' '.$bug[2]['subject'].' '.$value.'
Description
'.nl2br($bug[2]['text']).'
'; $answers = $db->query('SELECT * FROM '.$db->tableName('myaac_bugtracker').' where `account` = '.$account_logged->getId().' and `id` = '.$id.' and `type` = 2 order by `reply`'); foreach($answers as $answer) { if($answer['who'] == 1) $who = "[ADMIN]"; else $who = "[YOU]"; echo '
'; echo ''; echo ''; echo ''; echo '
Answer #'.$answer['reply'].'
Posted by'.$who.'
Description
'.nl2br($answer['text']).'
'; } if($bug[2]['status'] != 3) echo '
[REPLY]'; } else { if($bug[2]['status'] != 3) { $reply = $db->query('SELECT MAX(reply) FROM `' . TABLE_PREFIX . 'bugtracker` where `account` = '.$acc.' and `id` = '.$id.' and `type` = 2')->fetch(); $reply = $reply[0] + 1; $iswho = $db->query('SELECT * FROM `myaac_bugtracker` where `account` = '.$acc.' and `id` = '.$id.' and `type` = 2 order by `reply` desc limit 1')->fetch(); if(isset($_POST['finish'])) { if(empty($_POST['text'])) $error[] = "Description cannot be empty."; if($iswho['who'] == 0) $error[] = "You must wait for Administrator answer."; if(!$allow) $error[] = "You haven't any characters on account."; if(!empty($error)) { foreach($error as $errors) echo ''.$errors.'
'; } else { $type = 2; $INSERT = $db->query('INSERT INTO `myaac_bugtracker` (`account`,`id`,`text`,`reply`,`type`) VALUES ('.$db->quote($acc).','.$db->quote($id).','.$db->quote($_POST['text']).','.$db->quote($reply).','.$db->quote($type).')'); $UPDATE = $db->query('UPDATE `myaac_bugtracker` SET `status` = 1 where `account` = '.$acc.' and `id` = '.$id.''); header('Location: ?subtopic=bugtracker&id='.$id.''); } } echo '
Description

'; } else { echo "
You can't add answer to closed bug thread."; } } $post=true; } elseif(!empty($_REQUEST['id']) and $bug[2] == NULL) { echo ''; echo ''; echo '
Bug Tracker
Bug doesn\'t exist.
'; $post=true; } if(!$post) { if(!isset($_REQUEST['add']) || $_REQUEST['add'] != TRUE) { echo ''; foreach($bug[1] as $report) { if($report['status'] == 1) $value = "[OPEN]"; elseif($report['status'] == 2) $value = "[NEW ANSWER]"; elseif($report['status'] == 3) $value = "[CLOSED]"; if(is_int($report['id'] / 2)) { $bgcolor = $dark; } else { $bgcolor = $light; } echo ''; $showed=true; } if(!$showed) { echo ''; } echo '
Bug Tracker
'.$tags[$report['tag']].' '.$report['subject'].''.$value.'
You don\'t have reported any bugs.
'; echo '
[ADD REPORT]'; } elseif(isset($_REQUEST['add']) && $_REQUEST['add'] == TRUE) { $thread = $db->query('SELECT * FROM `' . TABLE_PREFIX . 'bugtracker` where `account` = '.$acc.' and `type` = 1 order by `id` desc')->fetch(); $id_next = $db->query('SELECT MAX(id) FROM `' . TABLE_PREFIX . 'bugtracker` where `account` = '.$acc.' and `type` = 1')->fetch(); $id_next = $id_next[0] + 1; if(empty($thread)) $thread['status'] = 3; if(isset($_POST['submit'])) { if($thread['status'] != 3) $error[] = "Can be only 1 open bug thread."; if(empty($_POST['subject'])) $error[] = "Subject cannot be empty."; if(empty($_POST['text'])) $error[] = "Description cannot be empty."; if(!$allow) $error[] = "You haven't any characters on account."; if(empty($_POST['tags'])) $error[] = "Tag cannot be empty."; if(!empty($error)) { foreach($error as $errors) echo ''.$errors.'
'; } else { $type = 1; $status = 1; $INSERT = $db->query('INSERT INTO `' . TABLE_PREFIX . 'bugtracker` (`account`,`id`,`text`,`type`,`subject`, `reply`,`status`,`tag`) VALUES ('.$db->quote($acc).','.$db->quote($id_next).','.$db->quote($_POST['text']).','.$db->quote($type).','.$db->quote($_POST['subject']).', 0,'.$db->quote($status).','.$db->quote($_POST['tags']).')'); header('Location: ?subtopic=bugtracker&id='.$id_next.''); } } echo '
Subject
Description
TAG

'; } } } if(admin() and empty($_REQUEST['control'])) { echo '

[ADMIN PANEL]'; } ?>