mirror of
https://github.com/opensourcepos/opensourcepos.git
synced 2026-01-01 14:07:54 -05:00
439 lines
15 KiB
PHP
439 lines
15 KiB
PHP
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
|
|
|
|
require_once("Secure_Controller.php");
|
|
|
|
class Config extends Secure_Controller
|
|
{
|
|
public function __construct()
|
|
{
|
|
parent::__construct('config');
|
|
|
|
$this->load->library('barcode_lib');
|
|
}
|
|
|
|
/*
|
|
* This function loads all the licenses starting with the first one being OSPOS one
|
|
*/
|
|
private function _licenses()
|
|
{
|
|
$i = 0;
|
|
$various = FALSE;
|
|
$license = array();
|
|
|
|
$license[$i]['title'] = 'Open Source Point Of Sale ' . $this->config->item('application_version');
|
|
|
|
if(file_exists('COPYING'))
|
|
{
|
|
$license[$i]['text'] = $this->xss_clean(file_get_contents('COPYING', NULL, NULL, 0, 2000));
|
|
}
|
|
else
|
|
{
|
|
$license[$i]['text'] = 'COPYING file must be in OSPOS root directory. You are not allowed to use OSPOS application until the distribution copy of COPYING file is present.';
|
|
}
|
|
|
|
// read all the files in the dir license
|
|
$dir = new DirectoryIterator('license');
|
|
|
|
foreach($dir as $fileinfo)
|
|
{
|
|
// license files must be in couples: .version (name & version) & .license (license text)
|
|
if($fileinfo->isFile())
|
|
{
|
|
if($fileinfo->getExtension() == 'version')
|
|
{
|
|
++$i;
|
|
|
|
$basename = 'license/' . $fileinfo->getBasename('.version');
|
|
|
|
$license[$i]['title'] = $this->xss_clean(file_get_contents($basename . '.version', NULL, NULL, 0, 100));
|
|
|
|
$license_text_file = $basename . '.license';
|
|
|
|
if(file_exists($license_text_file))
|
|
{
|
|
$license[$i]['text'] = $this->xss_clean(file_get_contents($license_text_file , NULL, NULL, 0, 2000));
|
|
}
|
|
else
|
|
{
|
|
$license[$i]['text'] = $license_text_file . ' file is missing';
|
|
}
|
|
}
|
|
elseif($fileinfo->getBasename() == 'LICENSES')
|
|
{
|
|
// set a flag to indicate that the LICENSES file is available and needs to be attached at the end
|
|
$various = TRUE;
|
|
}
|
|
}
|
|
}
|
|
|
|
// attach the licenses from the LICENSES file generated by bower
|
|
if($various)
|
|
{
|
|
++$i;
|
|
$license[$i]['title'] = 'Plugins';
|
|
$license[$i]['text'] = '';
|
|
|
|
$file = file_get_contents('license/LICENSES');
|
|
$array = json_decode($file, true);
|
|
|
|
foreach($array as $key => $val)
|
|
{
|
|
if(is_array($val))
|
|
{
|
|
$license[$i]['text'] .= 'component: ' . $key . "\n";
|
|
|
|
foreach($val as $key1 => $val1)
|
|
{
|
|
if(is_array($val1))
|
|
{
|
|
$license[$i]['text'] .= $key1 . ': ';
|
|
|
|
foreach($val1 as $key2 => $val2)
|
|
{
|
|
$license[$i]['text'] .= $val2 . ' ';
|
|
}
|
|
|
|
$license[$i]['text'] .= "\n";
|
|
}
|
|
else
|
|
{
|
|
$license[$i]['text'] .= $key1 . ': ' . $val1 . "\n";
|
|
}
|
|
}
|
|
|
|
$license[$i]['text'] .= "\n";
|
|
}
|
|
}
|
|
|
|
$license[$i]['text'] = $this->xss_clean($license[$i]['text']);
|
|
}
|
|
|
|
return $license;
|
|
}
|
|
|
|
public function index()
|
|
{
|
|
$data['stock_locations'] = $this->Stock_location->get_all()->result_array();
|
|
$data['support_barcode'] = $this->barcode_lib->get_list_barcodes();
|
|
$data['logo_exists'] = $this->Appconfig->get('company_logo') != '';
|
|
|
|
$data = $this->xss_clean($data);
|
|
|
|
// load all the license statements, they are already XSS cleaned in the private function
|
|
$data['licenses'] = $this->_licenses();
|
|
|
|
$this->load->view("configs/manage", $data);
|
|
}
|
|
|
|
public function save_info()
|
|
{
|
|
$upload_success = $this->_handle_logo_upload();
|
|
$upload_data = $this->upload->data();
|
|
|
|
$batch_save_data = array(
|
|
'company' => $this->input->post('company'),
|
|
'address' => $this->input->post('address'),
|
|
'phone' => $this->input->post('phone'),
|
|
'email' => $this->input->post('email'),
|
|
'fax' => $this->input->post('fax'),
|
|
'website' => $this->input->post('website'),
|
|
'return_policy' => $this->input->post('return_policy')
|
|
);
|
|
|
|
if (!empty($upload_data['orig_name']))
|
|
{
|
|
// XSS file image sanity check
|
|
if ($this->xss_clean($upload_data['raw_name'], TRUE) === TRUE)
|
|
{
|
|
$batch_save_data['company_logo'] = $upload_data['raw_name'] . $upload_data['file_ext'];
|
|
}
|
|
}
|
|
|
|
$result = $this->Appconfig->batch_save($batch_save_data);
|
|
$success = $upload_success && $result ? TRUE : FALSE;
|
|
$message = $this->lang->line('config_saved_' . ($success ? '' : 'un') . 'successfully');
|
|
$message = $upload_success ? $message : strip_tags($this->upload->display_errors());
|
|
|
|
echo json_encode(array('success' => $success, 'message' => $message));
|
|
}
|
|
|
|
public function save_general()
|
|
{
|
|
$batch_save_data = array(
|
|
'default_tax_1_rate' => parse_decimals($this->input->post('default_tax_1_rate')),
|
|
'default_tax_1_name' => $this->input->post('default_tax_1_name'),
|
|
'default_tax_2_rate' => parse_decimals($this->input->post('default_tax_2_rate')),
|
|
'default_tax_2_name' => $this->input->post('default_tax_2_name'),
|
|
'tax_included' => $this->input->post('tax_included') != NULL,
|
|
'receiving_calculate_average_price' => $this->input->post('receiving_calculate_average_price') != NULL,
|
|
'lines_per_page' => $this->input->post('lines_per_page'),
|
|
'default_sales_discount' => $this->input->post('default_sales_discount'),
|
|
'notify_horizontal_position' => $this->input->post('notify_horizontal_position'),
|
|
'notify_vertical_position' => $this->input->post('notify_vertical_position'),
|
|
'custom1_name' => $this->input->post('custom1_name'),
|
|
'custom2_name' => $this->input->post('custom2_name'),
|
|
'custom3_name' => $this->input->post('custom3_name'),
|
|
'custom4_name' => $this->input->post('custom4_name'),
|
|
'custom5_name' => $this->input->post('custom5_name'),
|
|
'custom6_name' => $this->input->post('custom6_name'),
|
|
'custom7_name' => $this->input->post('custom7_name'),
|
|
'custom8_name' => $this->input->post('custom8_name'),
|
|
'custom9_name' => $this->input->post('custom9_name'),
|
|
'custom10_name' => $this->input->post('custom10_name')
|
|
);
|
|
|
|
$result = $this->Appconfig->batch_save($batch_save_data);
|
|
$success = $result ? TRUE : FALSE;
|
|
|
|
echo json_encode(array('success' => $success, 'message' => $this->lang->line('config_saved_' . ($success ? '' : 'un') . 'successfully')));
|
|
}
|
|
|
|
public function check_number_locale()
|
|
{
|
|
$number_locale = $this->input->post('number_locale');
|
|
$fmt = new \NumberFormatter($number_locale, \NumberFormatter::CURRENCY);
|
|
$currency_symbol = empty($this->input->post('currency_symbol')) ? $fmt->getSymbol(\NumberFormatter::CURRENCY_SYMBOL) : $this->input->post('currency_symbol');
|
|
if ($this->input->post('thousands_separator') == "false")
|
|
{
|
|
$fmt->setAttribute(\NumberFormatter::GROUPING_SEPARATOR_SYMBOL, '');
|
|
}
|
|
$fmt->setSymbol(\NumberFormatter::CURRENCY_SYMBOL, $currency_symbol);
|
|
$number_local_example = $fmt->format(1234567890.12300);
|
|
echo json_encode(array(
|
|
'success' => $number_local_example != FALSE,
|
|
'number_locale_example' => $number_local_example,
|
|
'currency_symbol' => $currency_symbol,
|
|
'thousands_separator' => $fmt->getAttribute(\NumberFormatter::GROUPING_SEPARATOR_SYMBOL) != ''
|
|
));
|
|
}
|
|
|
|
public function save_locale()
|
|
{
|
|
$batch_save_data = array(
|
|
'currency_symbol' => $this->input->post('currency_symbol'),
|
|
'language' => $this->input->post('language'),
|
|
'timezone' => $this->input->post('timezone'),
|
|
'dateformat' => $this->input->post('dateformat'),
|
|
'timeformat' => $this->input->post('timeformat'),
|
|
'thousands_separator' => $this->input->post('thousands_separator'),
|
|
'number_locale' => $this->input->post('number_locale'),
|
|
'currency_decimals' => $this->input->post('currency_decimals'),
|
|
'tax_decimals' => $this->input->post('tax_decimals'),
|
|
'quantity_decimals' => $this->input->post('quantity_decimals'),
|
|
'country_codes' => $this->input->post('country_codes'),
|
|
'payment_options_order' => $this->input->post('payment_options_order')
|
|
);
|
|
|
|
$result = $this->Appconfig->batch_save($batch_save_data);
|
|
$success = $result ? TRUE : FALSE;
|
|
|
|
echo json_encode(array('success' => $success, 'message' => $this->lang->line('config_saved_' . ($success ? '' : 'un') . 'successfully')));
|
|
}
|
|
|
|
public function save_email()
|
|
{
|
|
$batch_save_data = array(
|
|
'protocol' => $this->input->post('protocol'),
|
|
'mailpath' => $this->input->post('mailpath'),
|
|
'smtp_host' => $this->input->post('smtp_host'),
|
|
'smtp_user' => $this->input->post('smtp_user'),
|
|
'smtp_pass' => $this->input->post('smtp_pass'),
|
|
'smtp_port' => $this->input->post('smtp_port'),
|
|
'smtp_timeout' => $this->input->post('smtp_timeout'),
|
|
'smtp_crypto' => $this->input->post('smtp_crypto')
|
|
);
|
|
|
|
$result = $this->Appconfig->batch_save($batch_save_data);
|
|
$success = $result ? TRUE : FALSE;
|
|
|
|
echo json_encode(array('success' => $success, 'message' => $this->lang->line('config_saved_' . ($success ? '' : 'un') . 'successfully')));
|
|
}
|
|
|
|
public function save_message()
|
|
{
|
|
$batch_save_data = array(
|
|
'msg_msg' => $this->input->post('msg_msg'),
|
|
'msg_uid' => $this->input->post('msg_uid'),
|
|
'msg_pwd' => $this->input->post('msg_pwd'),
|
|
'msg_src' => $this->input->post('msg_src')
|
|
);
|
|
|
|
$result = $this->Appconfig->batch_save($batch_save_data);
|
|
$success = $result ? TRUE : FALSE;
|
|
|
|
echo json_encode(array('success' => $success, 'message' => $this->lang->line('config_saved_' . ($success ? '' : 'un') . 'successfully')));
|
|
}
|
|
|
|
public function stock_locations()
|
|
{
|
|
$stock_locations = $this->Stock_location->get_all()->result_array();
|
|
|
|
$stock_locations = $this->xss_clean($stock_locations);
|
|
|
|
$this->load->view('partial/stock_locations', array('stock_locations' => $stock_locations));
|
|
}
|
|
|
|
private function _clear_session_state()
|
|
{
|
|
$this->load->library('sale_lib');
|
|
$this->sale_lib->clear_sale_location();
|
|
$this->sale_lib->clear_all();
|
|
$this->load->library('receiving_lib');
|
|
$this->receiving_lib->clear_stock_source();
|
|
$this->receiving_lib->clear_stock_destination();
|
|
$this->receiving_lib->clear_all();
|
|
}
|
|
|
|
public function save_locations()
|
|
{
|
|
$this->db->trans_start();
|
|
|
|
$deleted_locations = $this->Stock_location->get_allowed_locations();
|
|
foreach($this->input->post() as $key => $value)
|
|
{
|
|
if (strstr($key, 'stock_location'))
|
|
{
|
|
$location_id = preg_replace("/.*?_(\d+)$/", "$1", $key);
|
|
unset($deleted_locations[$location_id]);
|
|
// save or update
|
|
$location_data = array('location_name' => $value);
|
|
if ($this->Stock_location->save($location_data, $location_id))
|
|
{
|
|
$this->_clear_session_state();
|
|
}
|
|
}
|
|
}
|
|
|
|
// all locations not available in post will be deleted now
|
|
foreach ($deleted_locations as $location_id => $location_name)
|
|
{
|
|
$this->Stock_location->delete($location_id);
|
|
}
|
|
|
|
$this->db->trans_complete();
|
|
|
|
$success = $this->db->trans_status();
|
|
|
|
echo json_encode(array('success' => $success, 'message' => $this->lang->line('config_saved_' . ($success ? '' : 'un') . 'successfully')));
|
|
}
|
|
|
|
public function save_barcode()
|
|
{
|
|
$batch_save_data = array(
|
|
'barcode_type' => $this->input->post('barcode_type'),
|
|
'barcode_quality' => $this->input->post('barcode_quality'),
|
|
'barcode_width' => $this->input->post('barcode_width'),
|
|
'barcode_height' => $this->input->post('barcode_height'),
|
|
'barcode_font' => $this->input->post('barcode_font'),
|
|
'barcode_font_size' => $this->input->post('barcode_font_size'),
|
|
'barcode_first_row' => $this->input->post('barcode_first_row'),
|
|
'barcode_second_row' => $this->input->post('barcode_second_row'),
|
|
'barcode_third_row' => $this->input->post('barcode_third_row'),
|
|
'barcode_num_in_row' => $this->input->post('barcode_num_in_row'),
|
|
'barcode_page_width' => $this->input->post('barcode_page_width'),
|
|
'barcode_page_cellspacing' => $this->input->post('barcode_page_cellspacing'),
|
|
'barcode_generate_if_empty' => $this->input->post('barcode_generate_if_empty') != NULL,
|
|
'barcode_content' => $this->input->post('barcode_content')
|
|
);
|
|
|
|
$result = $this->Appconfig->batch_save($batch_save_data);
|
|
$success = $result ? TRUE : FALSE;
|
|
|
|
echo json_encode(array('success' => $success, 'message' => $this->lang->line('config_saved_' . ($success ? '' : 'un') . 'successfully')));
|
|
}
|
|
|
|
public function save_receipt()
|
|
{
|
|
$batch_save_data = array (
|
|
'receipt_template' => $this->input->post('receipt_template'),
|
|
'receipt_show_taxes' => $this->input->post('receipt_show_taxes') != NULL,
|
|
'receipt_show_total_discount' => $this->input->post('receipt_show_total_discount') != NULL,
|
|
'receipt_show_description' => $this->input->post('receipt_show_description') != NULL,
|
|
'receipt_show_serialnumber' => $this->input->post('receipt_show_serialnumber') != NULL,
|
|
'print_silently' => $this->input->post('print_silently') != NULL,
|
|
'print_header' => $this->input->post('print_header') != NULL,
|
|
'print_footer' => $this->input->post('print_footer') != NULL,
|
|
'print_top_margin' => $this->input->post('print_top_margin'),
|
|
'print_left_margin' => $this->input->post('print_left_margin'),
|
|
'print_bottom_margin' => $this->input->post('print_bottom_margin'),
|
|
'print_right_margin' => $this->input->post('print_right_margin')
|
|
);
|
|
|
|
$result = $this->Appconfig->batch_save($batch_save_data);
|
|
$success = $result ? TRUE : FALSE;
|
|
|
|
echo json_encode(array('success' => $success, 'message' => $this->lang->line('config_saved_' . ($success ? '' : 'un') . 'successfully')));
|
|
}
|
|
|
|
public function save_invoice()
|
|
{
|
|
$batch_save_data = array (
|
|
'invoice_enable' => $this->input->post('invoice_enable') != NULL,
|
|
'sales_invoice_format' => $this->input->post('sales_invoice_format'),
|
|
'recv_invoice_format' => $this->input->post('recv_invoice_format'),
|
|
'invoice_default_comments' => $this->input->post('invoice_default_comments'),
|
|
'invoice_email_message' => $this->input->post('invoice_email_message')
|
|
);
|
|
|
|
$result = $this->Appconfig->batch_save($batch_save_data);
|
|
$success = $result ? TRUE : FALSE;
|
|
|
|
echo json_encode(array('success' => $success, 'message' => $this->lang->line('config_saved_' . ($success ? '' : 'un') . 'successfully')));
|
|
}
|
|
|
|
public function remove_logo()
|
|
{
|
|
$result = $this->Appconfig->batch_save(array('company_logo' => ''));
|
|
|
|
echo json_encode(array('success' => $result));
|
|
}
|
|
|
|
private function _handle_logo_upload()
|
|
{
|
|
$this->load->helper('directory');
|
|
|
|
// load upload library
|
|
$config = array('upload_path' => './uploads/',
|
|
'allowed_types' => 'gif|jpg|png',
|
|
'max_size' => '1024',
|
|
'max_width' => '800',
|
|
'max_height' => '680',
|
|
'file_name' => 'company_logo');
|
|
$this->load->library('upload', $config);
|
|
$this->upload->do_upload('company_logo');
|
|
|
|
return strlen($this->upload->display_errors()) == 0 || !strcmp($this->upload->display_errors(), '<p>'.$this->lang->line('upload_no_file_selected').'</p>');
|
|
}
|
|
|
|
public function backup_db()
|
|
{
|
|
$employee_id = $this->Employee->get_logged_in_employee_info()->person_id;
|
|
if($this->Employee->has_module_grant('config', $employee_id))
|
|
{
|
|
$this->load->dbutil();
|
|
|
|
$prefs = array(
|
|
'format' => 'zip',
|
|
'filename' => 'ospos.sql'
|
|
);
|
|
|
|
$backup = $this->dbutil->backup($prefs);
|
|
|
|
$file_name = 'ospos-' . date("Y-m-d-H-i-s") .'.zip';
|
|
$save = 'uploads/' . $file_name;
|
|
$this->load->helper('download');
|
|
while(ob_get_level())
|
|
{
|
|
ob_end_clean();
|
|
}
|
|
|
|
force_download($file_name, $backup);
|
|
}
|
|
else
|
|
{
|
|
redirect('no_access/config');
|
|
}
|
|
}
|
|
}
|
|
?>
|