MOON
Server: Apache
System: Linux nserver.cafsindia.com 4.18.0-553.104.1.lve.el8.x86_64 #1 SMP Tue Feb 10 20:07:30 UTC 2026 x86_64
User: cafsindia (1002)
PHP: 8.2.30
Disabled: NONE
Upload Files
File: /home/cafsindia/allyindian_com/sbltt/application/controllers/Customers.php
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');

require_once("Persons.php");

class Customers extends Persons
{
	public function __construct()
	{
		parent::__construct('customers');
	}

	public function index()
	{
		if(!$this->Appconfig->isAppvalid()){
			redirect('config');
		}
		$data['table_headers'] = $this->xss_clean(get_people_manage_table_headers());

		$this->load->view('people/manage', $data);
	}

	/*
	Returns customer table data rows. This will be called with AJAX.
	*/
	public function search()
	{
		$search = $this->input->get('search');
		$limit  = $this->input->get('limit');
		$offset = $this->input->get('offset');
		$sort   = $this->input->get('sort');
		$order  = $this->input->get('order');

		$customers = $this->Customer->search($search, $limit, $offset, $sort, $order);
		$total_rows = $this->Customer->get_found_rows($search);

		$data_rows = array();
		foreach($customers->result() as $person)
		{
			$data_rows[] = get_person_data_row($person, $this);
		}

		$data_rows = $this->xss_clean($data_rows);

		echo json_encode(array('total' => $total_rows, 'rows' => $data_rows));
	}

	/*
	Gives search suggestions based on what is being searched for
	*/
	public function suggest()
	{
		$suggestions = $this->xss_clean($this->Customer->get_search_suggestions($this->input->get('term'), TRUE));

		echo json_encode($suggestions);
	}

	public function suggest_search()
	{
		$suggestions = $this->xss_clean($this->Customer->get_search_suggestions($this->input->post('term'), FALSE));

		echo json_encode($suggestions);
	}

	/*
	Loads the customer edit form
	*/
	public function view($customer_id = -1)
	{
		$info = $this->Customer->get_info($customer_id);
// print_r($info); die;

		foreach(get_object_vars($info) as $property => $value)
		{
			$info->$property = $this->xss_clean($value);
		}
		$data['person_info'] = $info;

		$state_info[""] = "--Select State--";
		foreach($this->Customer->get_state()->result_array() as $row){
		    $state_info[$this->xss_clean($row['state_code'])] = $this->xss_clean($row['state_name']);
		}
		$data['state_info'] = $state_info;
		
		$booking_type[""] = "--Select Customer Type--";
		foreach($this->Customer->get_booking_type()->result_array() as $row){
		    $booking_type[$this->xss_clean($row['booking_type_id'])] = $this->xss_clean($row['booking_type_name']);
		}
		$data['booking_type'] = $booking_type;


		$this->load->view("customers/form", $data);
	}

	/*
	Inserts/updates a customer
	*/
	public function save($customer_id = -1)
	{

		$customer_data = array(
			'cust_id'        => $this->input->post('cust_id'),
			'customer_name'  => $this->input->post('customer_name'),
			//'billing_name'   => $this->input->post('billing_name'),
			'phone_number'   => $this->input->post('phone_number'),
			'alt_number'     => $this->input->post('alt_number'),
			'land_line'      => $this->input->post('land_line'),
			'cust_email'     => $this->input->post('email'),
			'cust_address'   => $this->input->post('cust_address'),
			//'report_address' => $this->input->post('report_address'),
			'city'           => $this->input->post('city'),
			'state'          => $this->input->post('state'),
			'dob'            => date('Y-m-d',strtotime($this->input->post('dob'))),
			//'cust_type'      => $this->input->post('cust_type'),
			'referral_type'  => $this->input->post('referral_type'),
			'allow_contract' => $this->input->post('allow_contract'),
			'cust_sts'       => $this->input->post('cust_sts'),
			'cust_zone'      => $this->input->post('cust_zone'),
			'csut_gst'       => $this->input->post('csut_gst'),
			'csut_pan'       => $this->input->post('csut_pan'),
			'includ_gst'     => $this->input->post('includ_gst')
		);

		if($this->Customer->save_customer($customer_data, $customer_id)){

			$customer_data = $this->xss_clean($customer_data);


			//New customer
			if($customer_id == -1)
			{

				echo json_encode(array('success' => TRUE, 'message' => $this->lang->line('customers_successful_adding').' '.
								$customer_data['cust_name'], 'id' => $customer_data['cust_id']));
			}else {
				//Existing customer
				echo json_encode(array('success' => TRUE, 'message' => $this->lang->line('customers_successful_updating').' '.
								$customer_data['cust_name'], 'id' => $customer_id));
			}
		}else{
			//failure
			$customer_data = $this->xss_clean($customer_data);
			echo json_encode(array('success' => FALSE, 'message' => $this->lang->line('customers_error_adding_updating').' '.
							$customer_data['cust_name'], 'id' => -1));
		}

	}

	public function get_row($customer_ids)
	{
  // echo "SAT :: $customer_ids"; die;
		$customer_infos = $this->Customer->get_multiple_info($customer_ids);

		$result = array();
		foreach($customer_infos as $item_info)
		{
			$result[$item_info->customer_id] = $this->xss_clean(get_item_data_row($item_info, $this));
		}

		echo json_encode($result);
	}

	/*
	This deletes customers from the customers table
	*/
	public function delete(){
		$customers_to_delete = $this->xss_clean($this->input->post('ids'));

		if($this->Customer->delete_list($customers_to_delete))
		{
			echo json_encode(array('success' => TRUE, 'message' => $this->lang->line('customers_successful_deleted').' '.
							count($customers_to_delete).' '.$this->lang->line('customers_one_or_multiple')));
		}
		else
		{
			echo json_encode(array('success' => FALSE, 'message' => $this->lang->line('customers_cannot_be_deleted')));
		}
	}

	/*
	Customer import from excel spreadsheet
	*/
	public function excel()
	{
		$name = 'import_customers.csv';
		$data = file_get_contents($name);
		force_download($name, $data);
	}

	public function excel_import()
	{
		$this->load->view('customers/form_excel_import', NULL);
	}

	public function do_excel_import()
	{
		if($_FILES['file_path']['error'] != UPLOAD_ERR_OK)
		{
			echo json_encode(array('success' => FALSE, 'message' => $this->lang->line('customers_excel_import_failed')));
		}
		else
		{
			if(($handle = fopen($_FILES['file_path']['tmp_name'], 'r')) !== FALSE)
			{
                // Skip the first row as it's the table description
				fgetcsv($handle);
				$i = 1;

				$failCodes = array();

				while(($data = fgetcsv($handle)) !== FALSE)
				{
					// XSS file data sanity check
					$data = $this->xss_clean($data);

					if(sizeof($data) >= 15)
					{
						$person_data = array(
							'first_name'	=> $data[0],
							'last_name'		=> $data[1],
							'gender'		  => $data[2],
							'email'			  => $data[3],
							'phone_number'	=> $data[4],
							'address_1'		=> $data[5],
							'address_2'		=> $data[6],
							'city'			  => $data[7],
							'state'			  => $data[8],
							'zip'			    => $data[9],
							'country'		  => $data[10],
							'comments'		=> $data[11]
						);

						$customer_data = array(
							'shop_id' => $this->session->userdata('shop_id'),
							'company_name'		=> $data[12],
							'discount_percent'	=> $data[14],
							'taxable'			=> $data[15] == '' ? 0 : 1
						);

						$account_number = $data[13];
						$invalidated = FALSE;
						if($account_number != '')
						{
							$customer_data['account_number'] = $account_number;
							$invalidated = $this->Customer->account_number_exists($account_number);
						}
					}
					else
					{
						$invalidated = TRUE;
					}

					if($invalidated || !$this->Customer->save_customer($person_data, $customer_data))
					{
						$failCodes[] = $i;
					}

					++$i;
				}

				if(count($failCodes) > 0)
				{
					$message = $this->lang->line('customers_excel_import_partially_failed') . ' (' . count($failCodes) . '): ' . implode(', ', $failCodes);

					echo json_encode(array('success' => FALSE, 'message' => $message));
				}
				else
				{
					echo json_encode(array('success' => TRUE, 'message' => $this->lang->line('customers_excel_import_success')));
				}
			}
			else
			{
                echo json_encode(array('success' => FALSE, 'message' => $this->lang->line('customers_excel_import_nodata_wrongformat')));
			}
		}
	}
}
?>