2013-01-18 10:56:46 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
// Pandora FMS - http://pandorafms.com
|
|
|
|
// ==================================================
|
|
|
|
// Copyright (c) 2005-2010 Artica Soluciones Tecnologicas
|
|
|
|
// Please see http://pandorafms.org for full contribution list
|
|
|
|
|
|
|
|
// This program is free software; you can redistribute it and/or
|
|
|
|
// modify it under the terms of the GNU General Public License
|
|
|
|
// as published by the Free Software Foundation for version 2.
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
|
2016-09-08 16:06:12 +02:00
|
|
|
if (check_acl ($id_user, 0, "ER"))
|
|
|
|
$groups = users_get_groups($id_user, 'ER');
|
|
|
|
elseif (check_acl ($id_user, 0, "EW"))
|
|
|
|
$groups = users_get_groups($id_user, 'EW');
|
|
|
|
elseif (check_acl ($id_user, 0, "EM"))
|
|
|
|
$groups = users_get_groups($id_user, 'EM');
|
|
|
|
|
2013-01-18 10:56:46 +01:00
|
|
|
|
2014-11-18 11:27:04 +01:00
|
|
|
$propagate = db_get_value('propagate','tgrupo','id_grupo',$id_group);
|
|
|
|
|
2014-11-18 15:18:00 +01:00
|
|
|
if ($id_group > 0) {
|
2017-02-28 15:41:03 +01:00
|
|
|
$filter_resume['groups'] = $id_group;
|
2014-11-18 11:27:04 +01:00
|
|
|
if ($propagate) {
|
|
|
|
$childrens_ids = array($id_group);
|
2015-03-06 16:58:21 +01:00
|
|
|
|
2014-11-18 11:27:04 +01:00
|
|
|
$childrens = groups_get_childrens($id_group);
|
2015-03-06 16:58:21 +01:00
|
|
|
|
2014-11-18 11:27:04 +01:00
|
|
|
if (!empty($childrens)) {
|
|
|
|
foreach ($childrens as $child) {
|
|
|
|
$childrens_ids[] = (int)$child['id_grupo'];
|
|
|
|
}
|
|
|
|
}
|
2015-03-06 16:58:21 +01:00
|
|
|
}
|
|
|
|
else {
|
2014-11-18 11:27:04 +01:00
|
|
|
$childrens_ids = array();
|
|
|
|
}
|
2015-03-06 16:58:21 +01:00
|
|
|
}
|
|
|
|
else {
|
2014-11-18 11:27:04 +01:00
|
|
|
$childrens_ids = array_keys($groups);
|
|
|
|
}
|
|
|
|
|
2013-01-18 10:56:46 +01:00
|
|
|
//Group selection
|
2013-07-17 17:58:15 +02:00
|
|
|
if ($id_group > 0 && in_array ($id_group, array_keys ($groups))) {
|
2014-11-18 11:27:04 +01:00
|
|
|
if ($propagate) {
|
|
|
|
$sql_post = " AND id_grupo IN (" . implode(',', $childrens_ids) . ")";
|
2013-01-18 10:56:46 +01:00
|
|
|
}
|
|
|
|
else {
|
2014-11-18 11:27:04 +01:00
|
|
|
//If a group is selected and it's in the groups allowed
|
|
|
|
$sql_post = " AND id_grupo = $id_group";
|
2013-01-18 10:56:46 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
2014-11-18 15:18:00 +01:00
|
|
|
$sql_post = " AND id_grupo IN (" . implode (",", array_keys ($groups)) . ")";
|
2013-01-18 10:56:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Skip system messages if user is not PM
|
|
|
|
if (!check_acl ($id_user, 0, "PM")) {
|
|
|
|
$sql_post .= " AND id_grupo != 0";
|
|
|
|
}
|
|
|
|
|
|
|
|
switch ($status) {
|
|
|
|
case 0:
|
|
|
|
case 1:
|
|
|
|
case 2:
|
2017-02-28 15:41:03 +01:00
|
|
|
$filter_resume['status'] = $status;
|
2013-01-18 10:56:46 +01:00
|
|
|
$sql_post .= " AND estado = " . $status;
|
|
|
|
break;
|
|
|
|
case 3:
|
2017-02-28 15:41:03 +01:00
|
|
|
$filter_resume['status'] = $status;
|
2013-01-18 10:56:46 +01:00
|
|
|
$sql_post .= " AND (estado = 0 OR estado = 2)";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2017-05-18 14:59:17 +02:00
|
|
|
|
|
|
|
$events_wi_cdata = db_get_all_rows_sql('SELECT id_evento,custom_data from tevento WHERE custom_data != ""');
|
|
|
|
$count_events = 0;
|
|
|
|
$events_wi_cdata_id = 'OR id_evento IN (';
|
|
|
|
foreach ($events_wi_cdata as $key => $value) {
|
|
|
|
if(strpos(base64_decode($value['custom_data']),$search) != false){
|
|
|
|
$events_wi_cdata_id .= $value['id_evento'];
|
|
|
|
$count_events++;
|
|
|
|
}
|
|
|
|
if ($value !== end($events_wi_cdata) && $count_events > 0) {
|
|
|
|
$events_wi_cdata_id .= ',';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$events_wi_cdata_id .= ')';
|
|
|
|
|
|
|
|
if($count_events == 0){
|
|
|
|
$events_wi_cdata_id = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-01-18 10:56:46 +01:00
|
|
|
if ($search != "") {
|
2017-02-28 15:41:03 +01:00
|
|
|
$filter_resume['free_search'] = $search;
|
2017-05-18 14:59:17 +02:00
|
|
|
$sql_post .= " AND (evento LIKE '%". io_safe_input($search) . "%' OR id_evento LIKE '%$search%' ".$events_wi_cdata_id.")";
|
2013-01-18 10:56:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($event_type != "") {
|
2017-02-28 15:41:03 +01:00
|
|
|
$filter_resume['event_type'] = $event_type;
|
2013-01-18 10:56:46 +01:00
|
|
|
// If normal, warning, could be several (going_up_warning, going_down_warning... too complex
|
|
|
|
// for the user so for him is presented only "warning, critical and normal"
|
2015-05-22 11:14:40 +02:00
|
|
|
if ($event_type == "warning" || $event_type == "critical" || $event_type == "normal") {
|
2013-01-18 10:56:46 +01:00
|
|
|
$sql_post .= " AND event_type LIKE '%$event_type%' ";
|
|
|
|
}
|
2015-05-22 11:14:40 +02:00
|
|
|
else if ($event_type == "not_normal") {
|
2013-11-19 14:28:35 +01:00
|
|
|
$sql_post .= " AND (event_type LIKE '%warning%' OR event_type LIKE '%critical%' OR event_type LIKE '%unknown%') ";
|
2013-01-18 10:56:46 +01:00
|
|
|
}
|
2015-05-22 11:14:40 +02:00
|
|
|
else if ($event_type != "all") {
|
2013-01-18 10:56:46 +01:00
|
|
|
$sql_post .= " AND event_type = '" . $event_type."'";
|
|
|
|
}
|
2013-03-20 Miguel de Dios <miguel.dedios@artica.es>
* mobile/operation/events.php, mobile/include/ui.class.php,
mobile/index.php: added first version of events section.
* include/functions_incidents.php, include/functions_users.php,
include/functions.php, include/functions_groups.php,
include/functions_events.php, include/functions_html.php,
operation/events/events.build_table.php,
operation/events/events.build_query.php,
operation/events/events_list.php: some changes for interact with
mobile version.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7872 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-03-20 13:29:33 +01:00
|
|
|
|
2013-01-18 10:56:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($severity != -1) {
|
2017-02-28 15:41:03 +01:00
|
|
|
$filter_resume['severity'] = $severity;
|
2013-03-20 Miguel de Dios <miguel.dedios@artica.es>
* mobile/operation/events.php, mobile/include/ui.class.php,
mobile/index.php: added first version of events section.
* include/functions_incidents.php, include/functions_users.php,
include/functions.php, include/functions_groups.php,
include/functions_events.php, include/functions_html.php,
operation/events/events.build_table.php,
operation/events/events.build_query.php,
operation/events/events_list.php: some changes for interact with
mobile version.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7872 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-03-20 13:29:33 +01:00
|
|
|
switch ($severity) {
|
2013-01-18 10:56:46 +01:00
|
|
|
case EVENT_CRIT_WARNING_OR_CRITICAL:
|
2014-09-01 15:23:45 +02:00
|
|
|
$sql_post .= "
|
|
|
|
AND (criticity = " . EVENT_CRIT_WARNING . " OR
|
|
|
|
criticity = " . EVENT_CRIT_CRITICAL . ")";
|
2013-01-18 10:56:46 +01:00
|
|
|
break;
|
2015-07-21 10:40:29 +02:00
|
|
|
case EVENT_CRIT_OR_NORMAL:
|
|
|
|
$sql_post .= "
|
|
|
|
AND (criticity = " . EVENT_CRIT_NORMAL . " OR
|
|
|
|
criticity = " . EVENT_CRIT_CRITICAL . ")";
|
|
|
|
break;
|
2013-01-18 10:56:46 +01:00
|
|
|
case EVENT_CRIT_NOT_NORMAL:
|
|
|
|
$sql_post .= " AND criticity != " . EVENT_CRIT_NORMAL;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
$sql_post .= " AND criticity = $severity";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// In metaconsole mode the agent search is performed by name
|
2013-03-20 Miguel de Dios <miguel.dedios@artica.es>
* mobile/operation/events.php, mobile/include/ui.class.php,
mobile/index.php: added first version of events section.
* include/functions_incidents.php, include/functions_users.php,
include/functions.php, include/functions_groups.php,
include/functions_events.php, include/functions_html.php,
operation/events/events.build_table.php,
operation/events/events.build_query.php,
operation/events/events_list.php: some changes for interact with
mobile version.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7872 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-03-20 13:29:33 +01:00
|
|
|
if ($meta) {
|
2017-03-02 12:48:40 +01:00
|
|
|
$text_agent = get_parameter("text_agent","");
|
|
|
|
$id_agent = get_parameter('id_agent',0);
|
|
|
|
if($id_agent){
|
|
|
|
$sql_post .= " AND agent_name IN (SELECT nombre FROM tmetaconsole_agent WHERE
|
|
|
|
id_tagente =".$id_agent." AND alias LIKE '".io_safe_input($text_agent)."')";
|
2017-02-28 17:43:39 +01:00
|
|
|
$filter_resume['agent'] = $text_agent;
|
2013-01-18 10:56:46 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
switch ($id_agent) {
|
|
|
|
case 0:
|
|
|
|
break;
|
|
|
|
case -1:
|
|
|
|
// Agent doesnt exist. No results will returned
|
|
|
|
$sql_post .= " AND 1 = 0";
|
|
|
|
break;
|
|
|
|
default:
|
2017-02-28 15:41:03 +01:00
|
|
|
$filter_resume['agent'] = $id_agent;
|
2013-01-18 10:56:46 +01:00
|
|
|
$sql_post .= " AND id_agente = " . $id_agent;
|
|
|
|
break;
|
|
|
|
}
|
2014-08-27 19:09:07 +02:00
|
|
|
}
|
|
|
|
|
2015-05-22 15:00:06 +02:00
|
|
|
|
|
|
|
|
2014-09-01 15:23:45 +02:00
|
|
|
if ($meta) {
|
|
|
|
//There is another filter.
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
if (!empty($text_module)) {
|
2017-02-28 15:41:03 +01:00
|
|
|
$filter_resume['module'] = $text_module;
|
2015-05-22 11:14:40 +02:00
|
|
|
$sql_post .= " AND id_agentmodule IN (
|
2014-09-01 15:23:45 +02:00
|
|
|
SELECT id_agente_modulo
|
|
|
|
FROM tagente_modulo
|
2015-05-22 11:14:40 +02:00
|
|
|
WHERE nombre = '$text_module'
|
|
|
|
)";
|
2014-09-01 15:23:45 +02:00
|
|
|
}
|
2013-01-18 10:56:46 +01:00
|
|
|
}
|
|
|
|
|
2017-02-28 15:41:03 +01:00
|
|
|
if ($id_user_ack != "0") {
|
|
|
|
$filter_resume['user_ack'] = $id_user_ack;
|
2013-01-18 10:56:46 +01:00
|
|
|
$sql_post .= " AND id_usuario = '" . $id_user_ack . "'";
|
2017-02-28 15:41:03 +01:00
|
|
|
}
|
2013-01-18 10:56:46 +01:00
|
|
|
|
2014-10-09 13:50:05 +02:00
|
|
|
if (!isset($date_from)) {
|
|
|
|
$date_from = "";
|
|
|
|
}
|
|
|
|
if (!isset($date_to)) {
|
|
|
|
$date_to = "";
|
|
|
|
}
|
2013-01-18 10:56:46 +01:00
|
|
|
|
2014-05-20 16:40:43 +02:00
|
|
|
if (($date_from == '') && ($date_to == '')) {
|
|
|
|
if ($event_view_hr > 0) {
|
2017-02-28 15:41:03 +01:00
|
|
|
$filter_resume['hours_max'] = $event_view_hr;
|
2014-05-20 16:40:43 +02:00
|
|
|
$unixtime = get_system_time () - ($event_view_hr * SECONDS_1HOUR);
|
|
|
|
$sql_post .= " AND (utimestamp > " . $unixtime . ")";
|
|
|
|
}
|
2014-10-09 13:50:05 +02:00
|
|
|
}
|
|
|
|
else {
|
2014-05-20 16:40:43 +02:00
|
|
|
if ($date_from != '') {
|
2016-08-19 12:46:27 +02:00
|
|
|
if($time_from != '') {
|
2017-02-28 15:41:03 +01:00
|
|
|
$filter_resume['time_from'] = $date_from . " " . $time_from;
|
2016-08-19 12:46:27 +02:00
|
|
|
$udate_from = strtotime($date_from . " " . $time_from);
|
|
|
|
$sql_post .= " AND (utimestamp >= " . $udate_from . ")";
|
|
|
|
} else {
|
2017-02-28 15:41:03 +01:00
|
|
|
$filter_resume['time_from'] = $date_from;
|
2016-08-19 12:46:27 +02:00
|
|
|
$udate_from = strtotime($date_from . " 00:00:00");
|
|
|
|
$sql_post .= " AND (utimestamp >= " . $udate_from . ")";
|
|
|
|
}
|
2014-05-20 16:40:43 +02:00
|
|
|
}
|
|
|
|
if ($date_to != '') {
|
2016-08-19 12:46:27 +02:00
|
|
|
if($time_to != '') {
|
2017-02-28 15:41:03 +01:00
|
|
|
$filter_resume['time_to'] = $date_to . " " . $time_to;
|
2016-08-19 12:46:27 +02:00
|
|
|
$udate_to = strtotime($date_to . " " . $time_to);
|
|
|
|
$sql_post .= " AND (utimestamp <= " . $udate_to . ")";
|
|
|
|
} else {
|
2017-02-28 15:41:03 +01:00
|
|
|
$filter_resume['time_to'] = $date_to;
|
2016-08-19 12:46:27 +02:00
|
|
|
$udate_to = strtotime($date_to . " 23:59:59");
|
|
|
|
$sql_post .= " AND (utimestamp <= " . $udate_to . ")";
|
|
|
|
}
|
2014-05-20 16:40:43 +02:00
|
|
|
}
|
2013-01-18 10:56:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//Search by tag
|
|
|
|
if (!empty($tag_with)) {
|
|
|
|
$sql_post .= ' AND ( ';
|
|
|
|
$first = true;
|
2017-02-28 15:41:03 +01:00
|
|
|
$filter_resume['tag_inc'] = $tag_with;
|
2013-01-18 10:56:46 +01:00
|
|
|
foreach ($tag_with as $id_tag) {
|
|
|
|
if ($first) $first = false;
|
2017-01-31 11:01:54 +01:00
|
|
|
else $sql_post .= " AND ";
|
2017-02-10 12:30:21 +01:00
|
|
|
$sql_post .= "tags LIKE '" . tags_get_name($id_tag) . "'";
|
|
|
|
$sql_post .= " OR ";
|
|
|
|
$sql_post .= "tags LIKE '" . tags_get_name($id_tag) . ",%'";
|
|
|
|
$sql_post .= " OR ";
|
|
|
|
$sql_post .= "tags LIKE '%, " . tags_get_name($id_tag) . "'";
|
|
|
|
$sql_post .= " OR ";
|
|
|
|
$sql_post .= "tags LIKE '%, " . tags_get_name($id_tag) . ",%'";
|
2013-01-18 10:56:46 +01:00
|
|
|
}
|
|
|
|
$sql_post .= ' ) ';
|
|
|
|
}
|
|
|
|
if (!empty($tag_without)) {
|
|
|
|
$sql_post .= ' AND ( ';
|
|
|
|
$first = true;
|
2017-02-28 15:41:03 +01:00
|
|
|
$filter_resume['tag_no_inc'] = $tag_without;
|
2013-01-18 10:56:46 +01:00
|
|
|
foreach ($tag_without as $id_tag) {
|
|
|
|
if ($first) $first = false;
|
2013-02-05 18:24:37 +01:00
|
|
|
else $sql_post .= " AND ";
|
2013-03-20 Miguel de Dios <miguel.dedios@artica.es>
* mobile/operation/events.php, mobile/include/ui.class.php,
mobile/index.php: added first version of events section.
* include/functions_incidents.php, include/functions_users.php,
include/functions.php, include/functions_groups.php,
include/functions_events.php, include/functions_html.php,
operation/events/events.build_table.php,
operation/events/events.build_query.php,
operation/events/events_list.php: some changes for interact with
mobile version.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7872 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-03-20 13:29:33 +01:00
|
|
|
|
2017-01-31 11:01:54 +01:00
|
|
|
$sql_post .= "tags NOT LIKE '%" . tags_get_name($id_tag) . "%'";
|
2013-01-18 10:56:46 +01:00
|
|
|
}
|
|
|
|
$sql_post .= ' ) ';
|
|
|
|
}
|
|
|
|
|
|
|
|
// Filter/Only alerts
|
|
|
|
if (isset($filter_only_alert)) {
|
2017-02-28 15:41:03 +01:00
|
|
|
if ($filter_only_alert == 0) {
|
|
|
|
$filter_resume['alerts'] = $filter_only_alert;
|
2013-01-18 10:56:46 +01:00
|
|
|
$sql_post .= " AND event_type NOT LIKE '%alert%'";
|
2017-02-28 15:41:03 +01:00
|
|
|
}
|
|
|
|
else if ($filter_only_alert == 1) {
|
|
|
|
$filter_resume['alerts'] = $filter_only_alert;
|
2013-01-18 10:56:46 +01:00
|
|
|
$sql_post .= " AND event_type LIKE '%alert%'";
|
2017-02-28 15:41:03 +01:00
|
|
|
}
|
2013-01-18 10:56:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Tags ACLS
|
2013-07-17 17:58:15 +02:00
|
|
|
if ($id_group > 0 && in_array ($id_group, array_keys ($groups))) {
|
|
|
|
$group_array = (array) $id_group;
|
2013-01-18 10:56:46 +01:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
$group_array = array_keys($groups);
|
|
|
|
}
|
2016-09-08 16:06:12 +02:00
|
|
|
if (check_acl ($id_user, 0, "ER"))
|
|
|
|
$tags_acls_condition = tags_get_acl_tags($id_user, $group_array, 'ER',
|
|
|
|
'event_condition', 'AND', '', $meta, array(), true); //FORCE CHECK SQL "(TAG = tag1 AND id_grupo = 1)"
|
|
|
|
elseif (check_acl ($id_user, 0, "EW"))
|
|
|
|
$tags_acls_condition = tags_get_acl_tags($id_user, $group_array, 'EW',
|
|
|
|
'event_condition', 'AND', '', $meta, array(), true); //FORCE CHECK SQL "(TAG = tag1 AND id_grupo = 1)"
|
|
|
|
elseif (check_acl ($id_user, 0, "EM"))
|
|
|
|
$tags_acls_condition = tags_get_acl_tags($id_user, $group_array, 'EM',
|
|
|
|
'event_condition', 'AND', '', $meta, array(), true); //FORCE CHECK SQL "(TAG = tag1 AND id_grupo = 1)"
|
2013-01-18 10:56:46 +01:00
|
|
|
|
2014-08-25 11:02:45 +02:00
|
|
|
if (($tags_acls_condition != ERR_WRONG_PARAMETERS) && ($tags_acls_condition != ERR_ACL)&& ($tags_acls_condition != -110000)) {
|
|
|
|
$sql_post .= $tags_acls_condition;
|
|
|
|
}
|
2013-01-18 10:56:46 +01:00
|
|
|
|
|
|
|
// Metaconsole fitlers
|
2013-03-20 Miguel de Dios <miguel.dedios@artica.es>
* mobile/operation/events.php, mobile/include/ui.class.php,
mobile/index.php: added first version of events section.
* include/functions_incidents.php, include/functions_users.php,
include/functions.php, include/functions_groups.php,
include/functions_events.php, include/functions_html.php,
operation/events/events.build_table.php,
operation/events/events.build_query.php,
operation/events/events_list.php: some changes for interact with
mobile version.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7872 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-03-20 13:29:33 +01:00
|
|
|
if ($meta) {
|
2015-02-17 17:06:12 +01:00
|
|
|
|
|
|
|
if ($server_id) {
|
2017-02-28 15:41:03 +01:00
|
|
|
$filter_resume['server'] = $server_id;
|
2015-02-17 17:06:12 +01:00
|
|
|
$sql_post .= " AND server_id = " . $server_id;
|
2015-06-30 16:48:32 +02:00
|
|
|
} else {
|
|
|
|
$enabled_nodes = db_get_all_rows_sql('
|
|
|
|
SELECT id
|
|
|
|
FROM tmetaconsole_setup
|
|
|
|
WHERE disabled = 0');
|
|
|
|
|
|
|
|
if (empty($enabled_nodes)) {
|
|
|
|
$sql_post .= ' AND 1 = 0';
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
if ($strict_user == 1) {
|
|
|
|
$enabled_nodes_id = array();
|
|
|
|
} else {
|
|
|
|
$enabled_nodes_id = array(0);
|
|
|
|
}
|
|
|
|
foreach ($enabled_nodes as $en) {
|
|
|
|
$enabled_nodes_id[] = $en['id'];
|
|
|
|
}
|
|
|
|
$sql_post .= ' AND server_id IN (' .
|
|
|
|
implode(',',$enabled_nodes_id) . ')';
|
|
|
|
}
|
2015-02-17 17:06:12 +01:00
|
|
|
}
|
2013-01-18 10:56:46 +01:00
|
|
|
}
|
|
|
|
?>
|