2009-12-07 14:25:30 +01:00
< ? php
2021-11-04 16:28:15 +01:00
// Pandora FMS - http://pandorafms.com
2009-12-07 14:25:30 +01:00
// ==================================================
2023-06-08 11:53:13 +02:00
// Copyright (c) 2005-2023 Pandora FMS
2011-03-17 Raul Mateos <raulofpandora@gmail.com>
* extensions/dbmanager.php, extensions/pandora_logs.php, general/*.php,
index.php, ajax.php, operation/search_*.php, operation/menu.php,
operation/extensions.php, godmode/menu.php, godmode/extensions.php,
admin_access_logs.php: Cleaned code and updated page disclaimers.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4108 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-03-17 23:01:01 +01:00
// Please see http://pandorafms.org for full contribution list
2009-12-07 14:25:30 +01:00
// This program is free software; you can redistribute it and/or
2011-03-23 Raul Mateos <raulofpandora@gmail.com>
* extensions/ssh_console.php, extensions/vnc_view.php,
extensions/update_manager.php, extensions/users_connected.php,
extensions/extension_uploader.php, extensions/insert_data.php,
extensions/module_groups.php, extensions/plugin_registration.php,
extensions/agent_modules.php, extensions/resource_registration.php,
extensions/resource_exportation.php, extensions/dbmanager.php,
extensions/pandora_logs.php, general/*.php, ajax.php,
operation/search_*.php, operation/menu.php, operation/extensions.php,
godmode/menu.php, godmode/extensions.php, godmode/admin_access_logs.php:
CReverted unwanted license changes.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4126 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-03-23 17:13:28 +01:00
// modify it under the terms of the GNU General Public License
2011-03-17 Raul Mateos <raulofpandora@gmail.com>
* extensions/dbmanager.php, extensions/pandora_logs.php, general/*.php,
index.php, ajax.php, operation/search_*.php, operation/menu.php,
operation/extensions.php, godmode/menu.php, godmode/extensions.php,
admin_access_logs.php: Cleaned code and updated page disclaimers.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4108 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-03-17 23:01:01 +01:00
// as published by the Free Software Foundation; version 2
2009-12-07 14:25:30 +01:00
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
2011-03-17 Raul Mateos <raulofpandora@gmail.com>
* extensions/dbmanager.php, extensions/pandora_logs.php, general/*.php,
index.php, ajax.php, operation/search_*.php, operation/menu.php,
operation/extensions.php, godmode/menu.php, godmode/extensions.php,
admin_access_logs.php: Cleaned code and updated page disclaimers.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4108 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-03-17 23:01:01 +01:00
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
2009-12-07 14:25:30 +01:00
// GNU General Public License for more details.
2023-03-09 17:21:18 +01:00
function view_logfile ( $file_name , $toggle = false )
2019-01-30 16:18:44 +01:00
{
global $config ;
$memory_limit = ini_get ( 'memory_limit' );
2023-03-09 17:21:18 +01:00
$code = '' ;
2019-01-30 16:18:44 +01:00
if ( strstr ( $memory_limit , 'M' ) !== false ) {
$memory_limit = str_replace ( 'M' , '' , $memory_limit );
$memory_limit = ( $memory_limit * 1024 * 1024 );
2009-12-07 14:25:30 +01:00
2019-01-30 16:18:44 +01:00
// Arbitrary size for the PHP program
$memory_limit = ( $memory_limit - ( 8 * 1024 * 1024 ));
}
if ( ! file_exists ( $file_name )) {
ui_print_error_message ( __ ( 'Cannot find file' ) . '(' . $file_name . ')' );
} else {
$file_size = filesize ( $file_name );
if ( $memory_limit < $file_size ) {
2023-03-09 17:21:18 +01:00
$code .= '<pre><h2>' . $file_name . ' (' . __ ( 'File is too large than PHP memory allocated in the system.' ) . ')</h2>' ;
$code .= '<h2>' . __ ( 'The preview file is imposible.' ) . '</h2>' ;
2019-01-30 16:18:44 +01:00
} else if ( $file_size > ( $config [ 'max_log_size' ] * 1000 )) {
$data = file_get_contents ( $file_name , false , null , ( $file_size - ( $config [ 'max_log_size' ] * 1000 )));
2023-03-09 17:21:18 +01:00
$code .= " <h2> $file_name ( " . format_numeric ( filesize ( $file_name ) / 1024 ) . ' KB) ' . ui_print_help_tip ( __ ( 'The folder /var/log/pandora must have pandora:apache and its content too.' ), true ) . ' </h2>' ;
$code .= " <textarea class='pandora_logs' name=' $file_name '> " ;
$code .= '... ' ;
$code .= $data ;
$code .= '</textarea><br><br>' ;
2019-01-30 16:18:44 +01:00
} else {
$data = file_get_contents ( $file_name );
2023-03-09 17:21:18 +01:00
$code .= " <h2> $file_name ( " . format_numeric ( filesize ( $file_name ) / 1024 ) . ' KB) ' . ui_print_help_tip ( __ ( 'The folder /var/log/pandora must have pandora:apache and its content too.' ), true ) . ' </h2>' ;
$code .= " <textarea class='pandora_logs' name=' $file_name '> " ;
$code .= $data ;
$code .= '</textarea><br><br></pre>' ;
}
if ( $toggle === true ) {
ui_toggle (
$code ,
'<span class="subsection_header_title">' . $file_name . '</span>' ,
$file_name ,
'a' ,
false ,
false ,
'' ,
'white-box-content no_border' ,
'filter-datatable-main box-flat white_table_graph'
);
} else {
echo $code ;
2019-01-30 16:18:44 +01:00
}
}
2009-12-07 14:25:30 +01:00
}
2019-01-30 16:18:44 +01:00
function pandoralogs_extension_main ()
{
global $config ;
if ( ! check_acl ( $config [ 'id_user' ], 0 , 'PM' ) && ! is_user_admin ( $config [ 'id_user' ])) {
2022-01-20 10:55:23 +01:00
db_pandora_audit (
AUDIT_LOG_ACL_VIOLATION ,
'Trying to access Setup Management'
);
2019-01-30 16:18:44 +01:00
include 'general/noaccess.php' ;
return ;
}
2023-03-09 17:21:18 +01:00
// Header.
ui_print_standard_header (
__ ( 'Extensions' ),
'images/extensions.png' ,
false ,
'' ,
true ,
[],
[
[
'link' => '' ,
'label' => __ ( 'Admin tools' ),
],
[
'link' => '' ,
'label' => __ ( 'Extension manager' ),
],
[
'link' => '' ,
'label' => __ ( 'System logfile viewer' ),
],
]
);
ui_print_info_message (
__ ( 'Use this tool to view your %s logfiles directly on the console' , get_product_name ()) . ' < br >
'.__(' You can choose the amount of information shown in general setup ( Log size limit in system logs viewer extension ), '.($config[' max_log_size '] * 1000).' B at the moment ' )
);
2019-01-30 16:18:44 +01:00
$logs_directory = ( ! empty ( $config [ 'server_log_dir' ])) ? io_safe_output ( $config [ 'server_log_dir' ]) : '/var/log/pandora' ;
2020-06-08 10:48:48 +02:00
// Do not attempt to show console log if disabled.
if ( $config [ 'console_log_enabled' ]) {
2023-03-09 17:21:18 +01:00
view_logfile ( $config [ 'homedir' ] . '/log/console.log' , true );
2020-06-08 10:48:48 +02:00
}
2023-03-09 17:21:18 +01:00
view_logfile ( $logs_directory . '/pandora_server.log' , true );
view_logfile ( $logs_directory . '/pandora_server.error' , true );
2009-12-07 14:25:30 +01:00
}
2019-01-30 16:18:44 +01:00
extensions_add_godmode_menu_option ( __ ( 'System logfiles' ), 'PM' , '' , null , 'v1r1' );
extensions_add_godmode_function ( 'pandoralogs_extension_main' );