X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=admin%2Finst_module.php;h=6c974ddb4bda02234902550237a7e75365b122e1;hb=48589f9ce6c51bb25e2fa8ed83c57d9dfa485e44;hp=52190ca7eabe2fe968df80479462ce59eb36f2d8;hpb=cef4b4de401511a4195b7b8ad04b47bec1895b20;p=fa-stable.git diff --git a/admin/inst_module.php b/admin/inst_module.php index 52190ca7..6c974ddb 100644 --- a/admin/inst_module.php +++ b/admin/inst_module.php @@ -14,7 +14,10 @@ $path_to_root=".."; include_once($path_to_root . "/includes/session.inc"); include_once($path_to_root."/includes/packages.inc"); -page(_($help_context = "Install/Activate extensions")); +if ($SysPrefs->use_popup_windows) { + $js = get_js_open_window(900, 500); +} +page(_($help_context = "Install/Activate extensions"), false, false, "", $js); include_once($path_to_root . "/includes/date_functions.inc"); include_once($path_to_root . "/admin/db/company_db.inc"); @@ -22,116 +25,43 @@ include_once($path_to_root . "/admin/db/maintenance_db.inc"); include_once($path_to_root . "/includes/ui.inc"); simple_page_mode(true); -//--------------------------------------------------------------------------------------------- -// Check third-party extension parameters -// -function check_data($id, $exts) -{ - if ($_POST['name'] == "") { - display_error(_("Extension name cannot be empty.")); - return false; - } - foreach($exts as $n =>$ext) { - if ($_POST['name'] == $ext['name'] && $id != $n) { - display_error(_("Extension name have to be unique.")); - return false; - } - } - - if ($_POST['title'] == "") { - display_error(_("Extension title cannot be empty.")); - return false; - } - if ($_POST['path'] == "") { - display_error(_("Extension folder name cannot be empty.")); - return false; - } - if ($id == -1 && !is_uploaded_file($_FILES['uploadfile']['tmp_name'])) { - display_error(_("You have to select plugin file to upload")); - return false; - } - return true; -} //--------------------------------------------------------------------------------------------- - -function handle_submit() +function local_extension($id) { - global $path_to_root, $db_connections, $selected_id, $next_extension_id; - - $extensions = get_company_extensions(); - if (!check_data($selected_id, $extensions)) - return false; - $id = $selected_id==-1 ? $next_extension_id : $selected_id; - - if ($selected_id != -1 && $extensions[$id]['type'] != 'plugin') { - display_error(_('Module installation support is not implemented.')); - return; - } - - $extensions[$id]['name'] = $_POST['name']; - $extensions[$id]['package'] = ''; - $extensions[$id]['version'] = ''; - $extensions[$id]['active'] = check_value('active'); - $entry = $selected_id == -1 ? array() : $extensions[$id]['entries'][0]; - - $entry['tab_id'] = $_POST['tab']; - $entry['title'] = $_POST['title']; - $entry['section'] = 2; // menu section aka module - - // Only plugin extensions can be installed manually. - $extensions[$id]['type'] = 'plugin'; - $directory = $path_to_root . "/modules/" . $_POST['path']; - if (!file_exists($directory)) - { - mkdir($directory); - } - if (is_uploaded_file($_FILES['uploadfile']['tmp_name'])) - { - $entry['url'] = '/modules/'.$_POST['path'].'/'.$_FILES['uploadfile']['name']; - $file1 = $_FILES['uploadfile']['tmp_name']; - $file2 = $directory . "/".$_FILES['uploadfile']['name']; - if (file_exists($file2)) - unlink($file2); - move_uploaded_file($file1, $file2); + global $next_extension_id, $Ajax, $path_to_root; + + $exts = get_company_extensions(); + $exts[$next_extension_id++] = array( + 'package' => $id, + 'name' => $id, + 'version' => '-', + 'available' => '', + 'type' => 'extension', + 'path' => 'modules/'.$id, + 'active' => false + ); + + $local_module_path = $path_to_root.'/modules/'.clean_file_name($id); + $local_config_file = $local_module_path.'/_init/config'; + $local_hook_file = $local_module_path.'/hooks.php'; + + if (file_exists($local_config_file)) { + $ctrl = get_control_file($local_config_file); + if (key_exists('Name', $ctrl)) $exts[$next_extension_id-1]['name'] = $ctrl['Name']; + if (key_exists('Version', $ctrl)) $exts[$next_extension_id-1]['version'] = $ctrl['Version']; } - else - $entry['url'] = '/modules/'.$_POST['path'].'/'.get_post('filename'); + if (file_exists($local_hook_file)) { + include_once($local_hook_file); - if (is_uploaded_file($_FILES['uploadfile2']['tmp_name'])) - { - $file1 = $_FILES['uploadfile2']['tmp_name']; - $db_name = $_SESSION["wa_current_user"]->company; - db_import($file1, $db_connections[$db_name]); } - - if (is_uploaded_file($_FILES['uploadfile3']['tmp_name'])) - { - $extensions[$id]['acc_file'] = '/modules/'.$_POST['path'].'/'.$_FILES['uploadfile3']['name']; - $file1 = $_FILES['uploadfile3']['tmp_name']; - $file2 = $directory . "/".$_FILES['uploadfile3']['name']; - if (file_exists($file2)) - unlink($file2); - move_uploaded_file($file1, $file2); - } - else - $extensions[$id]['acc_file'] = '/modules/'.$_POST['path'].'/'.get_post('acc_file'); - - // security area guess for plugins - $exttext = file_get_contents($path_to_root.$entry['url']); - $area = 'SA_OPEN'; - if (preg_match('/.*\$page_security\s*=\s*[\'"]([^\'"]*)/', $exttext, $match)) { - $area = trim($match[1]); - } - $entry['access'] = $area; - - $extensions[$id]['entries'] = array($entry); - - if ($selected_id == -1) - { - $next_extension_id++; + $hooks_class = 'hooks_'.$id; + if (class_exists($hooks_class, false)) { + $hooks = new $hooks_class; + $hooks->install_extension(false); } - if (!update_extensions($extensions)) + $Ajax->activate('ext_tbl'); // refresh settings display + if (!update_extensions($exts)) return false; return true; } @@ -141,17 +71,16 @@ function handle_delete($id) global $path_to_root; $extensions = get_company_extensions(); - - if ($extensions[$id]['package'] != '') { - if (!uninstall_package($extensions[$id]['package'])) + $ext = $extensions[$id]; + if ($ext['version'] != '-') { + if (!uninstall_package($ext['package'])) return false; } else { - - $dirname = dirname(@$extensions[$id]['entries'][0]['url']); - if ($dirname) { - $dirname = $path_to_root.$dirname; - flush_dir($dirname, true); - rmdir($dirname); + @include_once($path_to_root.'/'.$ext['path'].'/hooks.php'); + $hooks_class = 'hooks_'.$ext['package']; + if (class_exists($hooks_class)) { + $hooks = new $hooks_class; + $hooks->uninstall_extension(false); } } unset($extensions[$id]); @@ -175,9 +104,10 @@ function fmt_titles($defs) // // Display list of all extensions - installed and available from repository // -function display_extensions() +function display_extensions($mods) { - + global $installed_extensions; + div_start('ext_tbl'); start_table(TABLESTYLE); @@ -186,32 +116,33 @@ function display_extensions() table_header($th); $k = 0; - $mods = get_extensions_list(); foreach($mods as $pkg_name => $ext) { $available = @$ext['available']; $installed = @$ext['version']; $id = @$ext['local_id']; - $is_mod = $ext['type'] == 'module'; $entries = fmt_titles(@$ext['entries']); $tabs = fmt_titles(@$ext['tabs']); alt_table_row_color($k); -// label_cell(is_array($ext['Descr']) ? $ext['Descr'][0] : $ext['Descr']); + label_cell($available ? get_package_view_str($pkg_name, $ext['name']) : $ext['name']); label_cell($tabs); label_cell($entries); label_cell($id === null ? _("None") : - ($available && $installed ? $installed : _("Unknown"))); - label_cell($available ? $available : _("None")); - - if (!$available && $ext['type'] == 'plugin') // third-party plugin - button_cell('Edit'.$id, _("Edit"), _('Edit third-party extension parameters.'), - ICON_EDIT); - elseif (check_pkg_upgrade($installed, $available)) // outdated or not installed extension in repo + (($installed && ($installed != '-' || $installed != '')) ? $installed : _("Unknown"))); + label_cell($available ? $available : _("Unknown")); + + if (!$available && $ext['type'] == 'extension') {// third-party plugin + if (!$installed) + button_cell('Local'.$ext['package'], _("Install"), _('Install third-party extension.'), + ICON_DOWN); + else + label_cell(''); + } elseif (check_pkg_upgrade($installed, $available)) // outdated or not installed extension in repo button_cell('Update'.$pkg_name, $installed ? _("Update") : _("Install"), _('Upload and install latest extension package'), ICON_DOWN); else @@ -231,7 +162,6 @@ function display_extensions() end_table(1); submit_center_first('Refresh', _("Update"), '', null); - submit_center_last('Add', _("Add third-party plugin"), '', false); div_end(); } @@ -260,6 +190,7 @@ function company_extensions($id) $k = 0; foreach($mods as $i => $mod) { + if ($mod['type'] != 'extension') continue; alt_table_row_color($k); label_cell($mod['name']); $entries = fmt_titles(@$mod['entries']); @@ -277,86 +208,51 @@ function company_extensions($id) } //--------------------------------------------------------------------------------------------- -// -// Third-party plugin installation -// -function display_ext_edit($selected_id) -{ - global $Mode; - - $extensions = get_company_extensions(); - - start_table(TABLESTYLE2); - - if ($selected_id != -1 && $extensions[$selected_id]['type'] == 'plugin') - { - if ($Mode == 'Edit') { - $mod = $extensions[$selected_id]; - $entry = $mod['entries'][0]; - - $_POST['name'] = $mod['name']; - $_POST['tab'] = $entry['tab_id']; - $_POST['title'] = $entry['title']; - $_POST['path'] = substr(dirname($entry['url']), 9); //strip '/modules/' - $_POST['filename'] = basename($entry['url']); - $_POST['acc_file'] = @$mod['acc_file'] ? basename($mod['acc_file']) : null; - hidden('filename', $_POST['filename']); - hidden('acc_file', $_POST['acc_file']); - } - hidden('selected_id', $selected_id); - } - text_row_ex(_("Name"), 'name', 30); - text_row_ex(_("Folder"), 'path', 20); - - tab_list_row(_("Menu Tab"), 'tab', null, true); - text_row_ex(_("Menu Link Text"), 'title', 30); - - record_status_list_row(_("Default status"), 'active'); - - file_row(_("Module File"), 'uploadfile'); - file_row(_("Access Levels Extensions"), 'uploadfile3'); - file_row(_("SQL File"), 'uploadfile2'); - - end_table(0); - display_note(_("Select your module PHP file from your local harddisk."), 0, 1); - submit_add_or_update_center($selected_id == -1, '', 'both'); -} - -//--------------------------------------------------------------------------------------------- -if ($Mode=='ADD_ITEM' || $Mode == 'UPDATE_ITEM') { - if(handle_submit()) { - if ($selected_id != -1) - display_notification(_("Extension data has been updated.")); - else - display_notification(_("Extension has been installed.")); - $Mode = 'RESET'; - } -} if ($Mode == 'Delete') { handle_delete($selected_id); $Mode = 'RESET'; } + if (get_post('Refresh')) { - $exts = get_company_extensions(get_post('extset')); // $comp = get_post('extset'); - + $exts = get_company_extensions($comp); + + $result = true; foreach($exts as $i => $ext) { - if ($ext['package'] && ($ext['active'] ^ check_value('Active'.$i))) { - $pkg = new package($ext['package'].'-'.$ext['version'].'.pkg'); - $pkg->support(check_value('Active'.$i) ? 'activate':'deactivate', $comp); + if ($ext['package'] && ($ext['active'] ^ check_value('Active'.$i))) + { + if (check_value('Active'.$i) && !check_src_ext_version($ext['version'])) + { + display_warning(sprintf(_("Package '%s' is incompatible with current application version and cannot be activated.\n") + . _("Check Install/Activate page for newer package version."), $ext['name'])); + continue; + } + $activated = activate_hooks($ext['package'], $comp, !$ext['active']); // change active state + + if ($activated !== null) + $result &= $activated; + if ($activated || ($activated === null)) + $exts[$i]['active'] = check_value('Active'.$i); } - $exts[$i]['active'] = check_value('Active'.$i); } write_extensions($exts, get_post('extset')); if (get_post('extset') == user_company()) $installed_extensions = $exts; - display_notification(_('Current active extensions set has been saved.')); + + if(!$result) { + display_error(_('Status change for some extensions failed.')); + $Ajax->activate('ext_tbl'); // refresh settings display + }else + display_notification(_('Current active extensions set has been saved.')); } if ($id = find_submit('Update', false)) install_extension($id); +if ($id = find_submit('Local', false)) + local_extension($id); + if ($Mode == 'RESET') { $selected_id = -1; @@ -370,24 +266,21 @@ if (list_updated('extset')) $set = get_post('extset', -1); -if (isset($_GET['popup']) || get_post('Add') || $Mode == 'Edit' - || $Mode == 'ADD_ITEM' || $Mode == 'UPDATE_ITEM') +echo "
" . _('Extensions:') . "  "; +echo extset_list('extset', null, true); +echo "

"; + +if ($set == -1) { - display_ext_edit($selected_id); -} -else { - echo "
" . _('Extensions:') . "  "; - echo extset_list('extset', null, true); - echo "

"; - - if ($set == -1) - display_extensions(); - else - company_extensions($set); -} + $mods = get_extensions_list('extension'); + if (!$mods) + display_note(_("No optional extension module is currently available.")); + else + display_extensions($mods); +} else + company_extensions($set); //--------------------------------------------------------------------------------------------- end_form(); end_page(); -?> \ No newline at end of file