242 lines
7.8 KiB
PHP
242 lines
7.8 KiB
PHP
<?php
|
|
|
|
// Pandora FMS - http://pandorafms.com
|
|
// ==================================================
|
|
// Copyright (c) 2005-2011 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; 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.
|
|
function pandora_files_repo_install()
|
|
{
|
|
global $config;
|
|
|
|
if (isset($config['files_repo_installed']) && $config['files_repo_installed'] == 1) {
|
|
return;
|
|
}
|
|
|
|
$full_extensions_dir = $config['homedir'].'/'.EXTENSIONS_DIR.'/';
|
|
$full_sql_dir = $full_extensions_dir.'files_repo/sql/';
|
|
|
|
$file_path = '';
|
|
switch ($config['dbtype']) {
|
|
case 'mysql':
|
|
$file_path = $full_sql_dir.'files_repo.sql';
|
|
break;
|
|
|
|
case 'postgresql':
|
|
$file_path = $full_sql_dir.'files_repo.postgreSQL.sql';
|
|
break;
|
|
|
|
case 'oracle':
|
|
$file_path = $full_sql_dir.'files_repo.oracle.sql';
|
|
break;
|
|
}
|
|
|
|
if (!empty($file_path)) {
|
|
$result = db_process_file($file_path);
|
|
|
|
if ($result) {
|
|
// Configuration values
|
|
$values = [
|
|
'token' => 'files_repo_installed',
|
|
'value' => 1,
|
|
];
|
|
db_process_sql_insert('tconfig', $values);
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
function pandora_files_repo_uninstall()
|
|
{
|
|
global $config;
|
|
|
|
switch ($config['dbtype']) {
|
|
case 'mysql':
|
|
db_process_sql('DROP TABLE `tfiles_repo_group`');
|
|
db_process_sql('DROP TABLE `tfiles_repo`');
|
|
db_process_sql(
|
|
'DELETE FROM `tconfig`
|
|
WHERE `token` LIKE "files_repo_%"'
|
|
);
|
|
break;
|
|
|
|
case 'postgresql':
|
|
db_process_sql('DROP TABLE "tfiles_repo_group"');
|
|
db_process_sql('DROP TABLE "tfiles_repo"');
|
|
db_process_sql(
|
|
'DELETE FROM "tconfig"
|
|
WHERE "token" LIKE \'files_repo_%\''
|
|
);
|
|
break;
|
|
|
|
case 'oracle':
|
|
db_process_sql('DROP TRIGGER "tfiles_repo_group_inc"');
|
|
db_process_sql('DROP SEQUENCE "tfiles_repo_group_s"');
|
|
db_process_sql('DROP TABLE "tfiles_repo_group"');
|
|
db_process_sql('DROP TRIGGER "tfiles_repo_inc"');
|
|
db_process_sql('DROP SEQUENCE "tfiles_repo_s"');
|
|
db_process_sql('DROP TABLE "tfiles_repo"');
|
|
db_process_sql(
|
|
'DELETE FROM tconfig
|
|
WHERE token LIKE \'files_repo_%\''
|
|
);
|
|
break;
|
|
}
|
|
|
|
if (!empty($config['attachment_store'])) {
|
|
delete_dir($config['attachment_store'].'/files_repo');
|
|
}
|
|
}
|
|
|
|
|
|
function pandora_files_repo_godmode()
|
|
{
|
|
global $config;
|
|
|
|
if (!isset($config['files_repo_installed']) || !$config['files_repo_installed']) {
|
|
ui_print_error_message(__('Extension not installed'));
|
|
}
|
|
|
|
// ACL Check
|
|
check_login();
|
|
if (! check_acl($config['id_user'], 0, 'PM')) {
|
|
db_pandora_audit('ACL Violation', 'Trying to access to Files repository');
|
|
include 'general/noaccess.php';
|
|
return;
|
|
}
|
|
|
|
// Header tabs
|
|
$godmode['text'] = '<a href="index.php?sec=godmode/extensions&sec2=extensions/files_repo">'.html_print_image('images/setup.png', true, ['title' => __('Administration view')]).'</a>';
|
|
$godmode['godmode'] = 1;
|
|
$godmode['active'] = 1;
|
|
|
|
$operation['text'] = '<a href="index.php?sec=extensions&sec2=extensions/files_repo">'.html_print_image('images/operation.png', true, ['title' => __('Operation view')]).'</a>';
|
|
$operation['operation'] = 1;
|
|
|
|
$onheader = [
|
|
'godmode' => $godmode,
|
|
'operation' => $operation,
|
|
];
|
|
// Header
|
|
ui_print_page_header(__('Files repository manager'), 'images/extensions.png', false, '', true, $onheader);
|
|
|
|
$full_extensions_dir = $config['homedir'].'/'.EXTENSIONS_DIR.'/';
|
|
include_once $full_extensions_dir.'files_repo/functions_files_repo.php';
|
|
|
|
// Directory files_repo check
|
|
if (!files_repo_check_directory(true)) {
|
|
return;
|
|
}
|
|
|
|
$server_content_length = 0;
|
|
if (isset($_SERVER['CONTENT_LENGTH'])) {
|
|
$server_content_length = $_SERVER['CONTENT_LENGTH'];
|
|
}
|
|
|
|
// Check for an anoying error that causes the $_POST and $_FILES arrays
|
|
// were empty if the file is larger than the post_max_size
|
|
if (intval($server_content_length) > 0 && empty($_POST)) {
|
|
ui_print_error_message(__('The file exceeds the maximum size'));
|
|
}
|
|
|
|
// GET and POST parameters
|
|
$file_id = (int) get_parameter('file_id');
|
|
$add_file = (bool) get_parameter('add_file');
|
|
$update_file = (bool) get_parameter('update_file');
|
|
$delete_file = (bool) get_parameter('delete');
|
|
|
|
// File add or update
|
|
if ($add_file || ($update_file && $file_id > 0)) {
|
|
$groups = get_parameter('groups', []);
|
|
$public = (bool) get_parameter('public');
|
|
$description = io_safe_output((string) get_parameter('description'));
|
|
if (mb_strlen($description, 'UTF-8') > 200) {
|
|
$description = mb_substr($description, 0, 200, 'UTF-8');
|
|
}
|
|
|
|
$description = io_safe_input($description);
|
|
|
|
if ($add_file) {
|
|
$result = files_repo_add_file('upfile', $description, $groups, $public);
|
|
} else if ($update_file) {
|
|
$result = files_repo_update_file($file_id, $description, $groups, $public);
|
|
$file_id = 0;
|
|
}
|
|
|
|
if ($result['status'] == false) {
|
|
ui_print_error_message($result['message']);
|
|
}
|
|
}
|
|
|
|
// File delete
|
|
if ($delete_file && $file_id > 0) {
|
|
$result = files_repo_delete_file($file_id);
|
|
if ($result !== -1) {
|
|
ui_print_result_message($result, __('Successfully deleted'), __('Could not be deleted'));
|
|
}
|
|
|
|
$file_id = 0;
|
|
}
|
|
|
|
// FORM
|
|
include $full_extensions_dir.'files_repo/files_repo_form.php';
|
|
if (!$file_id) {
|
|
// LIST
|
|
$manage = true;
|
|
include $full_extensions_dir.'files_repo/files_repo_list.php';
|
|
}
|
|
}
|
|
|
|
|
|
function pandora_files_repo_operation()
|
|
{
|
|
global $config;
|
|
|
|
// Header tabs
|
|
$onheader = [];
|
|
if (check_acl($config['id_user'], 0, 'PM')) {
|
|
$godmode['text'] = '<a href="index.php?sec=godmode/extensions&sec2=extensions/files_repo">'.html_print_image('images/setup.png', true, ['title' => __('Administration view')]).'</a>';
|
|
$godmode['godmode'] = 1;
|
|
|
|
$operation['text'] = '<a href="index.php?sec=extensions&sec2=extensions/files_repo">'.html_print_image('images/operation.png', true, ['title' => __('Operation view')]).'</a>';
|
|
$operation['operation'] = 1;
|
|
$operation['active'] = 1;
|
|
|
|
$onheader = [
|
|
'godmode' => $godmode,
|
|
'operation' => $operation,
|
|
];
|
|
}
|
|
|
|
// Header
|
|
ui_print_page_header(__('Files repository'), 'images/extensions.png', false, '', false, $onheader);
|
|
|
|
$full_extensions_dir = $config['homedir'].'/'.EXTENSIONS_DIR.'/';
|
|
include_once $full_extensions_dir.'files_repo/functions_files_repo.php';
|
|
|
|
// Directory files_repo check
|
|
if (!files_repo_check_directory(true)) {
|
|
return;
|
|
}
|
|
|
|
// LIST
|
|
$full_extensions_dir = $config['homedir'].'/'.EXTENSIONS_DIR.'/';
|
|
|
|
include $full_extensions_dir.'files_repo/files_repo_list.php';
|
|
}
|
|
|
|
|
|
extensions_add_operation_menu_option(__('Files repository'), null, null, 'v1r1');
|
|
extensions_add_main_function('pandora_files_repo_operation');
|
|
extensions_add_godmode_menu_option(__('Files repository manager'), 'PM', null, null, 'v1r1');
|
|
extensions_add_godmode_function('pandora_files_repo_godmode');
|
|
|
|
// pandora_files_repo_uninstall();
|
|
pandora_files_repo_install();
|