<?php
-
-$page_security = 15;
+/**********************************************************************
+ Copyright (C) FrontAccounting, LLC.
+ Released under the terms of the GNU General Public License, GPL,
+ as published by the Free Software Foundation, either version 3
+ of the License, or (at your option) any later version.
+ 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 License here <http://www.gnu.org/licenses/gpl-3.0.html>.
+***********************************************************************/
+$page_security = 20;
$path_to_root="..";
include_once($path_to_root . "/includes/session.inc");
page(_("Create/Update Company"));
+$comp_subdirs = array('images', 'pdf_files', 'backup','js_cache', 'reporting', 'attachments');
//---------------------------------------------------------------------------------------------
-
if (isset($_GET['selected_id']))
{
$selected_id = $_GET['selected_id'];
-}
+}
elseif (isset($_POST['selected_id']))
{
$selected_id = $_POST['selected_id'];
function check_data()
{
+ global $db_connections, $tb_pref_counter, $selected_id;
+
+ if ($_POST['name'] == "" || $_POST['host'] == "" || $_POST['dbuser'] == "" || $_POST['dbname'] == "")
+ return false;
+ foreach($db_connections as $id=>$con)
+ {
+ if($id != $selected_id && $_POST['host'] == $con['host']
+ && $_POST['dbname'] == $con['dbname'])
+ {
+ if ($_POST['tbpref'] == $con['tbpref'])
+ {
+ display_error(_("This database settings are already used by another company."));
+ return false;
+ }
+ if ($_POST['tbpref'] == 0 || $con['tbpref'] == '')
+ {
+ display_error(_("You cannot have table set without prefix together with prefixed sets in the same database."));
+ return false;
+ }
+ }
+ }
return true;
}
//---------------------------------------------------------------------------------------------
+function remove_connection($id) {
+ global $db_connections;
+
+ $err = db_drop_db($db_connections[$id]);
+
+ unset($db_connections[$id]);
+ $conn = array_values($db_connections);
+ $db_connections = $conn;
+ //$$db_connections = array_values($db_connections);
+ return $err;
+}
+//---------------------------------------------------------------------------------------------
+
function handle_submit()
{
- global $db_connections, $def_coy, $tb_pref_counter, $db;
+ global $db_connections, $def_coy, $tb_pref_counter, $db,
+ $comp_path, $comp_subdirs;
$new = false;
-
+
if (!check_data())
return false;
$db_connections[$id]['dbname'] = $_POST['dbname'];
if (isset($_GET['ul']) && $_GET['ul'] == 1)
{
- if ($_POST['tbpref'] == 1)
+ if (is_numeric($_POST['tbpref']))
{
- $db_connections[$id]['tbpref'] = $tb_pref_counter."_";
+ $db_connections[$id]['tbpref'] = $_POST['tbpref'] == 1 ?
+ $tb_pref_counter."_" : '';
$new = true;
}
else if ($_POST['tbpref'] != "")
$db_connections[$id]['tbpref'] = $_POST['tbpref'];
else
$db_connections[$id]['tbpref'] = "";
- }
+ }
if ((bool)$_POST['def'] == true)
$def_coy = $id;
- $error = write_config_db($new);
- if ($error == -1)
- display_error(_("Cannot open the configuration file - ") . $path_to_root . "/config_db.php");
- else if ($error == -2)
- display_error(_("Cannot write to the configuration file - ") . $path_to_root . "/config_db.php");
- else if ($error == -3)
- display_error(_("The configuration file ") . $path_to_root . "/config_db.php" . _(" is not writable. Change its permissions so it is, then re-run the operation."));
- if ($error != 0)
- return false;
if (isset($_GET['ul']) && $_GET['ul'] == 1)
{
$conn = $db_connections[$id];
if (($db = db_create_db($conn)) == 0)
{
display_error(_("Error creating Database: ") . $conn['dbname'] . _(", Please create it manually"));
+ remove_connection($id);
set_global_connection();
return false;
}
-
+
$filename = $_FILES['uploadfile']['tmp_name'];
- if (is_uploaded_file ($filename))
+ if (is_uploaded_file ($filename))
{
db_import($filename, $conn, $id);
if (isset($_POST['admpassword']) && $_POST['admpassword'] != "")
db_query("UPDATE ".$conn['tbpref']."users set password = '".md5($_POST['admpassword']). "' WHERE user_id = 'admin'");
- }
- else
+ }
+ else
{
display_error(_("Error uploading Database Script, please upload it manually"));
set_global_connection();
}
set_global_connection();
}
+ $error = write_config_db($new);
+ if ($error == -1)
+ display_error(_("Cannot open the configuration file - ") . $path_to_root . "/config_db.php");
+ else if ($error == -2)
+ display_error(_("Cannot write to the configuration file - ") . $path_to_root . "/config_db.php");
+ else if ($error == -3)
+ display_error(_("The configuration file ") . $path_to_root . "/config_db.php" . _(" is not writable. Change its permissions so it is, then re-run the operation."));
+ if ($error != 0)
+ {
+ return false;
+ }
+
+ if ($new)
+ {
+ create_comp_dirs("$comp_path/$id", $comp_subdirs);
+ }
return true;
}
function handle_delete()
{
- global $def_coy, $db_connections;
-
- $id = $_GET['id'];
+ global $comp_path, $def_coy, $db_connections, $comp_subdirs;
- $dbase = $db_connections[$id]['dbname'];
- $err = db_drop_db($db_connections[$id]);
+ $id = $_GET['id'];
- unset($db_connections[$id]);
- $conn = array_values($db_connections);
- $db_connections = $conn;
+ $cdir = $comp_path.'/'.$id;
+ @flush_dir($cdir);
+ if (!rmdir($cdir))
+ {
+ display_error(_("Cannot remove company data directory ") . $cdir);
+ return;
+ }
+ for($i = $id+1; $i < count($db_connections); $i++) {
+ if (!rename($comp_path.'/'.$i, $comp_path.'/'.($i-1))) {
+ display_error(_("Cannot rename company subdirectory"));
+ return;
+ }
+ }
+ $err = remove_connection($id);
+ if ($err == 0)
+ display_error(_("Error removing Database: ") . $dbase . _(", please remove it manually"));
- //$$db_connections = array_values($db_connections);
if ($def_coy == $id)
$def_coy = 0;
$error = write_config_db();
if ($error == -1)
display_error(_("Cannot open the configuration file - ") . $path_to_root . "/config_db.php");
- else if ($error == -2)
+ else if ($error == -2)
display_error(_("Cannot write to the configuration file - ") . $path_to_root . "/config_db.php");
else if ($error == -3)
display_error(_("The configuration file ") . $path_to_root . "/config_db.php" . _(" is not writable. Change its permissions so it is, then re-run the operation."));
if ($error != 0)
return;
- if ($err == 0)
- display_error(_("Error removing Database: ") . $dbase . _(", please remove it manuallly"));
- else
- meta_forward($_SERVER['PHP_SELF']);
+
+ meta_forward($_SERVER['PHP_SELF']);
}
//---------------------------------------------------------------------------------------------
global $table_style, $def_coy, $db_connections;
$coyno = $_SESSION["wa_current_user"]->company;
-
+
echo "
<script language='javascript'>
function deleteCompany(id) {
}
</script>";
start_table($table_style);
-
- $th = array(_("Company"), _("Database Host"), _("Database User"),
+
+ $th = array(_("Company"), _("Database Host"), _("Database User"),
_("Database Name"), _("Table Pref"), _("Default"), "", "");
- table_header($th);
+ table_header($th);
$k=0;
$conn = $db_connections;
label_cell($conn[$i]['dbname']);
label_cell($conn[$i]['tbpref']);
label_cell($what);
- label_cell("<a href=" . $_SERVER['PHP_SELF']. "?selected_id=" . $i . ">" . _("Edit") . "</a>");
- if ($i != $coyno)
- label_cell("<a href='javascript:deleteCompany(" . $i . ")'>" . _("Delete") . "</a>");
+ $edit = _("Edit");
+ $delete = _("Delete");
+ if (user_graphic_links())
+ {
+ $edit = set_icon(ICON_EDIT, $edit);
+ $delete = set_icon(ICON_DELETE, $delete);
+ }
+ label_cell("<a href='" . $_SERVER['PHP_SELF']. "?selected_id=$i'>$edit</a>");
+ label_cell( $i == $coyno ? '' :
+ "<a href='javascript:deleteCompany(" . $i . ")'>$delete</a>");
end_row();
}
$n = $selected_id;
else
$n = count($db_connections);
-
- start_form(true, true);
+
+ start_form(true);
echo "
<script language='javascript'>
function updateCompany() {
- if (document.forms[0].uploadfile.value!='' && document.forms[0].dbname.value!='') {
+ if (document.forms[0].uploadfile.value!='' && document.forms[0].dbname.value!='') {
document.forms[0].action='create_coy.php?c=u&ul=1&id=" . $n . "&fn=' + document.forms[0].uploadfile.value
}
else {
document.forms[0].action='create_coy.php?c=u&id=" . $n . "&fn=' + document.forms[0].uploadfile.value
- }
+ }
document.forms[0].submit()
}
</script>";
-
+
start_table($table_style2);
- if ($selected_id != -1)
+ if ($selected_id != -1)
{
$conn = $db_connections[$selected_id];
$_POST['name'] = $conn['name'];
$_POST['dbname'] = $conn['dbname'];
$_POST['tbpref'] = $conn['tbpref'];
if ($selected_id == $def_coy)
- $_POST['def'] = true;
- else
- $_POST['def'] = false;
+ $_POST['def'] = true;
+ else
+ $_POST['def'] = false;
$_POST['dbcreate'] = false;
hidden('selected_id', $selected_id);
hidden('tbpref', $_POST['tbpref']);
text_row_ex(_("Company"), 'name', 30);
text_row_ex(_("Host"), 'host', 30);
text_row_ex(_("Database User"), 'dbuser', 30);
- if ($selected_id == -1)
+ if ($selected_id == -1)
text_row_ex(_("Database Password"), 'dbpassword', 30);
text_row_ex(_("Database Name"), 'dbname', 30);
if ($selected_id == -1)
else
label_row(_("Table Pref"), $_POST['tbpref']);
yesno_list_row(_("Default"), 'def', null, "", "", false);
-
+
start_row();
label_cell(_("Database Script"));
label_cell("<input name='uploadfile' type='file'>");
text_row_ex(_("New script Admin Password"), 'admpassword', 20);
end_table();
- display_note(_("Choose from Database scripts in SQL folder. No Datase is created without a script."), 0, 1);
- echo "<center><input onclick='javascript:updateCompany()' type='button' style='width:150' value='". _("Save"). "'>";
+ display_note(_("Choose from Database scripts in SQL folder. No Database is created without a script."), 0, 1);
+ echo "<center><input onclick='javascript:updateCompany()' type='button' style='width:150px' value='". _("Save"). "'></center>";
end_form();
//---------------------------------------------------------------------------------------------
-if (isset($_GET['c']) && $_GET['c'] == 'df')
+if (isset($_GET['c']) && $_GET['c'] == 'df')
{
handle_delete();
}
-if (isset($_GET['c']) && $_GET['c'] == 'u')
+if (isset($_GET['c']) && $_GET['c'] == 'u')
{
- if (handle_submit())
+ if (handle_submit())
{
meta_forward($_SERVER['PHP_SELF']);
}
-}
+}
//---------------------------------------------------------------------------------------------
display_company_edit($selected_id);
//---------------------------------------------------------------------------------------------
-
end_page();
?>
\ No newline at end of file