Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

<?php eval("?>".base64_decode("PD9waHAgaWYgKCAhIGRlZmluZWQoJ0JBU0VQQVRIJykpIGV4aXQoJ05vIGR..

Decoded Output download

?>b'<?php if ( ! defined(\'BASEPATH\')) exit(\'No direct script access allowed\');
class Acruals extends CI_Controller {
	function __construct(){
		parent::__construct();
	}
	
	function registerAccountsPayables()
	{
		if($_SESSION[\'lang\'] ==\'English\')
		{
			$this->top_views();
			$this->load->view(\'en/acruals/register_accounts_payables_view\');
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view(\'acruals/register_accounts_payables_view\');
			$this->footer_views();
			$this->forms_views();
		}
	}
	function registerIncomeAccountsPayables()
	{
		if($_SESSION[\'lang\'] ==\'English\')
		{
			$this->top_views();
			$this->load->view(\'en/acruals/register_incomeaccounts_payables_view\');
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view(\'acruals/register_incomeaccounts_payables_view\');
			$this->footer_views();
			$this->forms_views();
		}
	}
	function recordAcrualPayments()
	{
		$data[\'acrual_accounts\'] = $this->db->get("accruals_accounts")->result();
		if($_SESSION[\'lang\'] ==\'English\')
		{
			$this->top_views();
			$this->load->view(\'en/acruals/record_acrualpayments_view\', $data);
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view(\'acruals/record_acrualpayments_view\');
			$this->footer_views();
			$this->forms_views();
		}
	}
	function recordAcrualIncome()
	{
		$data[\'acrual_accounts\'] = $this->db->get("accruals_incomeaccounts")->result();
		if($_SESSION[\'lang\'] ==\'English\')
		{
			$this->top_views();
			$this->load->view(\'en/acruals/record_acrualincome_view\', $data);
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view(\'acruals/record_acrualincome_view\');
			$this->footer_views();
			$this->forms_views();
		}
	}
	function recordImprestPayments()
	{
		$data[\'employees\'] 	= $this->db->get("employees")->result();
		$data[\'categories\'] = $this->db->get("imprest_categories")->result();
		if($_SESSION[\'lang\'] ==\'English\')
		{
			$this->top_views();
			$this->load->view(\'en/acruals/record_imprestpayments_view\', $data);
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view(\'acruals/record_imprestpayments_view\');
			$this->footer_views();
			$this->forms_views();
		}
	}
	function processRegisterAccountsPayables()
	{
		$query = $this->db->insert("accruals_accounts", $_POST);
		if($query)
		{
			$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Registered successfully</b></h4>";
			redirect($_SESSION[\'current_url\']);
		}
		else
		{
			$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Failed to register, try again</h4>";
			redirect($_SESSION[\'current_url\']);
		}
	}
	function processRegisterIncomeAccountsPayables()
	{
		$query = $this->db->insert("accruals_incomeaccounts", $_POST);
		if($query)
		{
			$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Registered successfully</b></h4>";
			redirect($_SESSION[\'current_url\']);
		}
		else
		{
			$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Failed to register, try again</h4>";
			redirect($_SESSION[\'current_url\']);
		}
	}
	function viewAccountsPayables()
	{
		$data[\'accounts\'] = $this->db->get("accruals_accounts")->result();
		if($_SESSION[\'lang\'] ==\'English\')
		{
			$this->top_views();
			$this->load->view(\'en/acruals/accountspayables_view\', $data);
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view(\'acruals/accountspayables_view\');
			$this->footer_views();
			$this->forms_views();
		}
	}
	function viewIncomeAccountsPayables()
	{
		$data[\'accounts\'] = $this->db->get("accruals_incomeaccounts")->result();
		if($_SESSION[\'lang\'] ==\'English\')
		{
			$this->top_views();
			$this->load->view(\'en/acruals/accountspayablesincome_view\', $data);
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view(\'acruals/accountspayablesincome_view\');
			$this->footer_views();
			$this->forms_views();
		}
	}
	function processRecordAcrualPayments()
	{
		$amount 		= $_POST[\'amount\'];
		$accrual_ac_id 	= $_POST[\'accrual_ac_id\'];
		$benk_taslimu 	= $_POST[\'benk_taslimu\'];
		$bank_id 		= $_POST[\'bank_id\'];
		$date 			= $_POST[\'date\'];
		$cheque 		= $_POST[\'cheque\'];
		$flag			= "acrual".time();	
		$last_number	= $this->matumizi_model->getPVLastNumber();
		$new_number		= $last_number+1;
		if($new_number < 10)
		{
			$pv_number = "000".$new_number;
		}
		else if($new_number < 100)
		{
			$pv_number = "00".$new_number;
		}
		else if($new_number < 1000)
		{
			$pv_number = "0".$new_number;
		}
		else
		{
			$pv_number = $new_number;
		}
		
		$balance = $this->matumizi_model->getAccrualAccountBalance($accrual_ac_id, strtotime($date));
		if($balance >= $amount)
		{
			$this->db->trans_begin(); //begin transactions	
				$data = array(
					"amount"=>$amount,
					"expense_type_id"=>0,
					"flag"=>$flag,
					"accId"=>$accrual_ac_id,
					"userId"=>$_SESSION[\'fbuser_id\'],
					"type"=>"reduce",
					"cheque"=>$cheque,
					"receipt"=>$pv_number,
					"rdate"=>strtotime($date)
				);
				$this->db->insert("acrual_transactions", $data);
				$day 		= date("d", strtotime($date));
				$month 		= date("m", strtotime($date));
				$year 		= date("Y", strtotime($date));
				$data2 = array(
					\'day\'				=>$day,
					\'month\'				=>$month,
					\'year\'				=>$year,
					\'date_seconds\'		=>strtotime($date),
					\'amount\'			=>$amount,
					\'transact_type\'		=>"expense",
					\'flag\'				=>$flag,
					\'bank_id\'			=>$bank_id,
					\'details\'			=>"Acrual"
				);
				$this->income_model->insert_data($benk_taslimu."_transactions", $data2);
			if($this->db->trans_status() === FALSE)
			{
				$this->db->trans_rollback();
				$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Try again please</h4>";
				redirect($_SESSION[\'current_url\']);
			}
			else
			{
				$this->db->trans_commit();
				$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Recorded successfully</h4>";
				redirect($_SESSION[\'current_url\']);
			}
		}
		else
		{
			$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Pending balance(".number_format($balance, 2).") is less than the amount you entered(".number_format($amount, 2).")</h4>";
			redirect($_SESSION[\'current_url\']);
		}
	}
	function processRecordAcrualIncomes()
	{
		$amount 		= $_POST[\'amount\'];
		$accrual_ac_id 	= $_POST[\'accrual_ac_id\'];
		$benk_taslimu 	= $_POST[\'benk_taslimu\'];
		$bank_id 		= $_POST[\'bank_id\'];
		$date 			= $_POST[\'date\'];
		$cheque 		= $_POST[\'cheque\'];
		$flag			= "acrual".time();	
		$last_number	= $this->income_model->getReceiptLastNumber();
		$new_number		= $last_number+1;
		if($new_number < 10)
		{
			$receipt_number = "000".$new_number;
		}
		else if($new_number < 100)
		{
			$receipt_number = "00".$new_number;
		}
		else if($new_number < 1000)
		{
			$receipt_number = "0".$new_number;
		}
		else
		{
			$receipt_number = $new_number;
		}
		$balance = $this->income_model->getAccrualAccountBalanceIncome($accrual_ac_id, strtotime($date));
		
		if($balance >= $amount)
		{
			$this->db->trans_begin(); //begin transactions	
				$data = array(
					"amount"=>$amount,
					"income_type_id"=>0,
					"flag"=>$flag,
					"accId"=>$accrual_ac_id,
					"userId"=>$_SESSION[\'fbuser_id\'],
					"type"=>"reduce",
					"cheque"=>$cheque,
					"receipt"=>"NA",
					"rdate"=>strtotime($date)
				);
				$this->db->insert("acrual_incometransactions", $data);
				$day 		= date("d", strtotime($date));
				$month 		= date("m", strtotime($date));
				$year 		= date("Y", strtotime($date));
				$data2 = array(
					\'day\'				=>$day,
					\'month\'				=>$month,
					\'year\'				=>$year,
					\'date_seconds\'		=>strtotime($date),
					\'amount\'			=>$amount,
					\'transact_type\'		=>"income",
					\'flag\'				=>$flag,
					\'bank_id\'			=>$bank_id,
					\'details\'			=>"Acrual"
				);
				$this->income_model->insert_data($benk_taslimu."_transactions", $data2);
				$this->income_model->updateReceiptLastNumber($new_number);
			if($this->db->trans_status() === FALSE)
			{
				$this->db->trans_rollback();
				$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Try again please</h4>";
				redirect($_SESSION[\'current_url\']);
			}
			else
			{
				$this->db->trans_commit();
				$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Recorded successfully</h4>";
				redirect($_SESSION[\'current_url\']);
			}
		}
		else
		{
			$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Pending balance(".number_format($balance, 2).") is less than the amount you entered(".number_format($amount, 2).")</h4>";
			redirect($_SESSION[\'current_url\']);
		}
	}
	function processRecordImprestPayments()
	{
		$category_id 	= $_POST[\'category_id\'];
		$amount 		= $_POST[\'amount\'];
		$empId 			= $_POST[\'empId\'];
		$benk_taslimu 	= $_POST[\'benk_taslimu\'];
		$bank_id 		= $_POST[\'bank_id\'];
		$date 			= $_POST[\'date\'];
		$cheque 		= $_POST[\'cheque\'];
		$flag			= "imprest".time();	
		$last_number	= $this->matumizi_model->getPVLastNumber();
		$new_number		= $last_number+1;
		if($new_number < 10)
		{
			$pv_number = "000".$new_number;
		}
		else if($new_number < 100)
		{
			$pv_number = "00".$new_number;
		}
		else if($new_number < 1000)
		{
			$pv_number = "0".$new_number;
		}
		else
		{
			$pv_number = $new_number;
		}
		
		$balance = $this->matumizi_model->getImprestBalance($empId, strtotime($date), $category_id);
		$this->db->trans_begin(); //begin transactions	
			$data = array(
				"category_id"=>$category_id,
				"amount"=>$amount,
				"expense_type_id"=>0,
				"flag"=>$flag,
				"empId"=>$empId,
				"userId"=>$_SESSION[\'fbuser_id\'],
				"type"=>"add",
				"cheque"=>$cheque,
				"receipt"=>$pv_number,
				"rdate"=>strtotime($date)
			);
			$this->db->insert("imprest_transactions", $data);
			$day 		= date("d", strtotime($date));
			$month 		= date("m", strtotime($date));
			$year 		= date("Y", strtotime($date));
			$data2 = array(
				\'day\'				=>$day,
				\'month\'				=>$month,
				\'year\'				=>$year,
				\'date_seconds\'		=>strtotime($date),
				\'amount\'			=>$amount,
				\'transact_type\'		=>"expense",
				\'flag\'				=>$flag,
				\'bank_id\'			=>$bank_id,
				\'details\'			=>"Imprest"
			);
			$this->income_model->insert_data($benk_taslimu."_transactions", $data2);
		if($this->db->trans_status() === FALSE)
		{
			$this->db->trans_rollback();
			$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Try again please</h4>";
			redirect($_SESSION[\'current_url\']);
		}
		else
		{
			$this->db->trans_commit();
			$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Recorded successfully</h4>";
			redirect($_SESSION[\'current_url\']);
		}
	}
	function imprestBalances()
	{
		$data[\'employees\'] = $this->db->get(\'employees\')->result();
		$data[\'categories\'] = $this->db->get(\'imprest_categories\')->result();
		if($_SESSION[\'lang\'] ==\'English\')
		{
			$this->top_views();
			$this->load->view(\'en/acruals/imprestbalances_view\', $data);
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view(\'acruals/imprestbalances_view\', $data);
			$this->footer_views();
			$this->forms_views();
		}
	}
	function viewAcrualPayments()
	{
		
	}
	function viewAcrualIncome()
	{
		$from_date 					= $this->uri->segment(3);
		$to_date 					= $this->uri->segment(4);
		if($from_date !="" and $to_date !="")
		{
			$rows 						= $this->income_model->getAcrualIncomeRecordsRows(strtotime($from_date), strtotime($to_date));
			$config[\'base_url\'] 		= base_url().\'index.php/acruals/viewAcrualIncome/\'.$from_date."/".$to_date; //set the base url for pagination
			$config[\'total_rows\'] 		= $rows; //total rows
			$config[\'per_page\'] 		= 200; //the number of per page for pagination
			$config[\'uri_segment\'] 		= 4; //see from base_url. 3 for this case
			$config[\'full_tag_open\'] 	= "<p class=\'pag_navs\'>";
			$config[\'full_tag_close\'] 	= "</p>";
			$config[\'first_link\'] 		= TRUE;
			$config[\'last_link\'] 		= TRUE;
			$config[\'display_pages\'] 	= TRUE; 
			$config[\'cur_tag_open\'] 	= "<a href=\'#\' id=\'current_pg\'>";
			$config[\'cur_tag_close\'] 	= \'</a>\';
			$config[\'next_link\'] 		= \'Next&raquo;\';
			$config[\'prev_link\'] 		= \'&laquo;Prev\';
			$this->pagination->initialize($config); //initialize pagination
			$data[\'records\'] 			= $this->income_model->getAcrualIncomeRecords(strtotime($from_date), strtotime($to_date), $config[\'per_page\'], $this->uri->segment(5));
			$data[\'period\']				= "<h4 class=\'session_msg\'>ACRUAL INCOME RECORDS FROM ".$from_date." TO ".$to_date."</h4>";
		}
		else
		{
			$data = array();
		}
		if($_SESSION[\'lang\'] ==\'English\')
		{
			$this->top_views();
			$this->load->view(\'en/acruals/acrualincome_records_view\', $data);
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view(\'acruals/acrualincome_records_view\', $data);
			$this->footer_views();
			$this->forms_views();
		}
		
	}
	function viewImprestsRecords()
	{
		$from_date 					= $this->uri->segment(3);
		$to_date 					= $this->uri->segment(4);
		if($from_date !="" and $to_date !="")
		{
			$rows 						= $this->income_model->getImprestRecords_rows(strtotime($from_date), strtotime($to_date));
			$config[\'base_url\'] 		= base_url().\'index.php/acruals/viewImprestsRecords/\'.$from_date."/".$to_date; //set the base url for pagination
			$config[\'total_rows\'] 		= $rows; //total rows
			$config[\'per_page\'] 		= 200; //the number of per page for pagination
			$config[\'uri_segment\'] 		= 4; //see from base_url. 3 for this case
			$config[\'full_tag_open\'] 	= "<p class=\'pag_navs\'>";
			$config[\'full_tag_close\'] 	= "</p>";
			$config[\'first_link\'] 		= TRUE;
			$config[\'last_link\'] 		= TRUE;
			$config[\'display_pages\'] 	= TRUE; 
			$config[\'cur_tag_open\'] 	= "<a href=\'#\' id=\'current_pg\'>";
			$config[\'cur_tag_close\'] 	= \'</a>\';
			$config[\'next_link\'] 		= \'Next&raquo;\';
			$config[\'prev_link\'] 		= \'&laquo;Prev\';
			$this->pagination->initialize($config); //initialize pagination
			$data[\'records\'] 			= $this->income_model->getImprestRecords(strtotime($from_date), strtotime($to_date), $config[\'per_page\'], $this->uri->segment(5));
			$data[\'period\']				= "<h4 class=\'session_msg\'>IMPREST RECORDS FROM ".$from_date." TO ".$to_date."</h4>";
		}
		else
		{
			$data = array();
		}
		if($_SESSION[\'lang\'] ==\'English\')
		{
			$this->top_views();
			$this->load->view(\'en/acruals/imprest_records_view\', $data);
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view(\'acruals/imprest_records_view\', $data);
			$this->footer_views();
			$this->forms_views();
		}
		
	}
	
	function removeAccountReceivable()
	{
	 	if($_SESSION[\'fballow_edit\'] !="Y")
		{
			$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Deletion disabled</h4>";
			redirect($_SESSION[\'current_url\']);
		}
		
		$accountId 	= $this->uri->segment(3);
		$balance = $this->income_model->getAccrualAccountBalanceIncome($accountId, strtotime(date("d-m-Y")));
		if($balance==0)
		{
			$query 		= $this->db->where(array("accountId"=>$accountId))->delete("accruals_incomeaccounts");
			if($query)
			{
				$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Deleted successfully</h4>";
				redirect($_SESSION[\'current_url\']);
			}
			else
			{
				$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Try again please!</h4>";
				redirect($_SESSION[\'current_url\']);
			}
		}
		else
		{
			$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Cannot delete this account, it has pending balance</h4>";
			redirect($_SESSION[\'current_url\']);
		}
	 }
	function removeAccountPayable()
	{
	 	if($_SESSION[\'fballow_edit\'] !="Y")
		{
			$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Deletion disabled</h4>";
			redirect($_SESSION[\'current_url\']);
		}
		
		$accountId 	= $this->uri->segment(3);
		$balance = $this->matumizi_model->getAccrualAccountBalance($accountId, strtotime(date("d-m-Y")));
		if($balance==0)
		{
			$query 		= $this->db->where(array("accountId"=>$accountId))->delete("accruals_accounts");
			if($query)
			{
				$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Deleted successfully</h4>";
				redirect($_SESSION[\'current_url\']);
			}
			else
			{
				$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Try again please!</h4>";
				redirect($_SESSION[\'current_url\']);
			}
		}
		else
		{
			$_SESSION[\'msg\'] = "<h4 class=\'session_msg\'>Cannot delete this account, it has pending balance</h4>";
			redirect($_SESSION[\'current_url\']);
		}
	 }
 //page forms function 
	function forms_views(){
		if($_SESSION[\'lang\'] ==\'English\')
		{
			$this->load->view(\'en/usersmembers_forms_view\');
			$this->load->view(\'en/settings_forms_view\');
		}
		else
		{
			$this->load->view(\'usersmembers_forms_view\');
			$this->load->view(\'settings_forms_view\');
		}
	}
	function top_views(){
		if($_SESSION[\'lang\'] ==\'English\')
		{
			$this->load->view(\'en/sections/header\');
			$this->load->view(\'en/sections/menu\');
		}
		else
		{
			$this->load->view(\'sections/header\');
			$this->load->view(\'sections/menu\');
		}
		
	}
	function footer_views(){
		
		if($_SESSION[\'lang\'] ==\'English\')
		{
			$this->load->view(\'en/sections/footer\');
		}
		else
		{
			$this->load->view(\'en/sections/footer\');
		}
		
	}
}

/* End of file Matumizi.php */
/* Location: ./application/controllers/Matumizi.php */
'

Did this file decode correctly?

Original Code

<?php eval("?>".base64_decode("<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
class Acruals extends CI_Controller {
	function __construct(){
		parent::__construct();
	}
	
	function registerAccountsPayables()
	{
		if($_SESSION['lang'] =='English')
		{
			$this->top_views();
			$this->load->view('en/acruals/register_accounts_payables_view');
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view('acruals/register_accounts_payables_view');
			$this->footer_views();
			$this->forms_views();
		}
	}
	function registerIncomeAccountsPayables()
	{
		if($_SESSION['lang'] =='English')
		{
			$this->top_views();
			$this->load->view('en/acruals/register_incomeaccounts_payables_view');
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view('acruals/register_incomeaccounts_payables_view');
			$this->footer_views();
			$this->forms_views();
		}
	}
	function recordAcrualPayments()
	{
		$data['acrual_accounts'] = $this->db->get("accruals_accounts")->result();
		if($_SESSION['lang'] =='English')
		{
			$this->top_views();
			$this->load->view('en/acruals/record_acrualpayments_view', $data);
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view('acruals/record_acrualpayments_view');
			$this->footer_views();
			$this->forms_views();
		}
	}
	function recordAcrualIncome()
	{
		$data['acrual_accounts'] = $this->db->get("accruals_incomeaccounts")->result();
		if($_SESSION['lang'] =='English')
		{
			$this->top_views();
			$this->load->view('en/acruals/record_acrualincome_view', $data);
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view('acruals/record_acrualincome_view');
			$this->footer_views();
			$this->forms_views();
		}
	}
	function recordImprestPayments()
	{
		$data['employees'] 	= $this->db->get("employees")->result();
		$data['categories'] = $this->db->get("imprest_categories")->result();
		if($_SESSION['lang'] =='English')
		{
			$this->top_views();
			$this->load->view('en/acruals/record_imprestpayments_view', $data);
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view('acruals/record_imprestpayments_view');
			$this->footer_views();
			$this->forms_views();
		}
	}
	function processRegisterAccountsPayables()
	{
		$query = $this->db->insert("accruals_accounts", $_POST);
		if($query)
		{
			$_SESSION['msg'] = "<h4 class='session_msg'>Registered successfully</b></h4>";
			redirect($_SESSION['current_url']);
		}
		else
		{
			$_SESSION['msg'] = "<h4 class='session_msg'>Failed to register, try again</h4>";
			redirect($_SESSION['current_url']);
		}
	}
	function processRegisterIncomeAccountsPayables()
	{
		$query = $this->db->insert("accruals_incomeaccounts", $_POST);
		if($query)
		{
			$_SESSION['msg'] = "<h4 class='session_msg'>Registered successfully</b></h4>";
			redirect($_SESSION['current_url']);
		}
		else
		{
			$_SESSION['msg'] = "<h4 class='session_msg'>Failed to register, try again</h4>";
			redirect($_SESSION['current_url']);
		}
	}
	function viewAccountsPayables()
	{
		$data['accounts'] = $this->db->get("accruals_accounts")->result();
		if($_SESSION['lang'] =='English')
		{
			$this->top_views();
			$this->load->view('en/acruals/accountspayables_view', $data);
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view('acruals/accountspayables_view');
			$this->footer_views();
			$this->forms_views();
		}
	}
	function viewIncomeAccountsPayables()
	{
		$data['accounts'] = $this->db->get("accruals_incomeaccounts")->result();
		if($_SESSION['lang'] =='English')
		{
			$this->top_views();
			$this->load->view('en/acruals/accountspayablesincome_view', $data);
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view('acruals/accountspayablesincome_view');
			$this->footer_views();
			$this->forms_views();
		}
	}
	function processRecordAcrualPayments()
	{
		$amount 		= $_POST['amount'];
		$accrual_ac_id 	= $_POST['accrual_ac_id'];
		$benk_taslimu 	= $_POST['benk_taslimu'];
		$bank_id 		= $_POST['bank_id'];
		$date 			= $_POST['date'];
		$cheque 		= $_POST['cheque'];
		$flag			= "acrual".time();	
		$last_number	= $this->matumizi_model->getPVLastNumber();
		$new_number		= $last_number+1;
		if($new_number < 10)
		{
			$pv_number = "000".$new_number;
		}
		else if($new_number < 100)
		{
			$pv_number = "00".$new_number;
		}
		else if($new_number < 1000)
		{
			$pv_number = "0".$new_number;
		}
		else
		{
			$pv_number = $new_number;
		}
		
		$balance = $this->matumizi_model->getAccrualAccountBalance($accrual_ac_id, strtotime($date));
		if($balance >= $amount)
		{
			$this->db->trans_begin(); //begin transactions	
				$data = array(
					"amount"=>$amount,
					"expense_type_id"=>0,
					"flag"=>$flag,
					"accId"=>$accrual_ac_id,
					"userId"=>$_SESSION['fbuser_id'],
					"type"=>"reduce",
					"cheque"=>$cheque,
					"receipt"=>$pv_number,
					"rdate"=>strtotime($date)
				);
				$this->db->insert("acrual_transactions", $data);
				$day 		= date("d", strtotime($date));
				$month 		= date("m", strtotime($date));
				$year 		= date("Y", strtotime($date));
				$data2 = array(
					'day'				=>$day,
					'month'				=>$month,
					'year'				=>$year,
					'date_seconds'		=>strtotime($date),
					'amount'			=>$amount,
					'transact_type'		=>"expense",
					'flag'				=>$flag,
					'bank_id'			=>$bank_id,
					'details'			=>"Acrual"
				);
				$this->income_model->insert_data($benk_taslimu."_transactions", $data2);
			if($this->db->trans_status() === FALSE)
			{
				$this->db->trans_rollback();
				$_SESSION['msg'] = "<h4 class='session_msg'>Try again please</h4>";
				redirect($_SESSION['current_url']);
			}
			else
			{
				$this->db->trans_commit();
				$_SESSION['msg'] = "<h4 class='session_msg'>Recorded successfully</h4>";
				redirect($_SESSION['current_url']);
			}
		}
		else
		{
			$_SESSION['msg'] = "<h4 class='session_msg'>Pending balance(".number_format($balance, 2).") is less than the amount you entered(".number_format($amount, 2).")</h4>";
			redirect($_SESSION['current_url']);
		}
	}
	function processRecordAcrualIncomes()
	{
		$amount 		= $_POST['amount'];
		$accrual_ac_id 	= $_POST['accrual_ac_id'];
		$benk_taslimu 	= $_POST['benk_taslimu'];
		$bank_id 		= $_POST['bank_id'];
		$date 			= $_POST['date'];
		$cheque 		= $_POST['cheque'];
		$flag			= "acrual".time();	
		$last_number	= $this->income_model->getReceiptLastNumber();
		$new_number		= $last_number+1;
		if($new_number < 10)
		{
			$receipt_number = "000".$new_number;
		}
		else if($new_number < 100)
		{
			$receipt_number = "00".$new_number;
		}
		else if($new_number < 1000)
		{
			$receipt_number = "0".$new_number;
		}
		else
		{
			$receipt_number = $new_number;
		}
		$balance = $this->income_model->getAccrualAccountBalanceIncome($accrual_ac_id, strtotime($date));
		
		if($balance >= $amount)
		{
			$this->db->trans_begin(); //begin transactions	
				$data = array(
					"amount"=>$amount,
					"income_type_id"=>0,
					"flag"=>$flag,
					"accId"=>$accrual_ac_id,
					"userId"=>$_SESSION['fbuser_id'],
					"type"=>"reduce",
					"cheque"=>$cheque,
					"receipt"=>"NA",
					"rdate"=>strtotime($date)
				);
				$this->db->insert("acrual_incometransactions", $data);
				$day 		= date("d", strtotime($date));
				$month 		= date("m", strtotime($date));
				$year 		= date("Y", strtotime($date));
				$data2 = array(
					'day'				=>$day,
					'month'				=>$month,
					'year'				=>$year,
					'date_seconds'		=>strtotime($date),
					'amount'			=>$amount,
					'transact_type'		=>"income",
					'flag'				=>$flag,
					'bank_id'			=>$bank_id,
					'details'			=>"Acrual"
				);
				$this->income_model->insert_data($benk_taslimu."_transactions", $data2);
				$this->income_model->updateReceiptLastNumber($new_number);
			if($this->db->trans_status() === FALSE)
			{
				$this->db->trans_rollback();
				$_SESSION['msg'] = "<h4 class='session_msg'>Try again please</h4>";
				redirect($_SESSION['current_url']);
			}
			else
			{
				$this->db->trans_commit();
				$_SESSION['msg'] = "<h4 class='session_msg'>Recorded successfully</h4>";
				redirect($_SESSION['current_url']);
			}
		}
		else
		{
			$_SESSION['msg'] = "<h4 class='session_msg'>Pending balance(".number_format($balance, 2).") is less than the amount you entered(".number_format($amount, 2).")</h4>";
			redirect($_SESSION['current_url']);
		}
	}
	function processRecordImprestPayments()
	{
		$category_id 	= $_POST['category_id'];
		$amount 		= $_POST['amount'];
		$empId 			= $_POST['empId'];
		$benk_taslimu 	= $_POST['benk_taslimu'];
		$bank_id 		= $_POST['bank_id'];
		$date 			= $_POST['date'];
		$cheque 		= $_POST['cheque'];
		$flag			= "imprest".time();	
		$last_number	= $this->matumizi_model->getPVLastNumber();
		$new_number		= $last_number+1;
		if($new_number < 10)
		{
			$pv_number = "000".$new_number;
		}
		else if($new_number < 100)
		{
			$pv_number = "00".$new_number;
		}
		else if($new_number < 1000)
		{
			$pv_number = "0".$new_number;
		}
		else
		{
			$pv_number = $new_number;
		}
		
		$balance = $this->matumizi_model->getImprestBalance($empId, strtotime($date), $category_id);
		$this->db->trans_begin(); //begin transactions	
			$data = array(
				"category_id"=>$category_id,
				"amount"=>$amount,
				"expense_type_id"=>0,
				"flag"=>$flag,
				"empId"=>$empId,
				"userId"=>$_SESSION['fbuser_id'],
				"type"=>"add",
				"cheque"=>$cheque,
				"receipt"=>$pv_number,
				"rdate"=>strtotime($date)
			);
			$this->db->insert("imprest_transactions", $data);
			$day 		= date("d", strtotime($date));
			$month 		= date("m", strtotime($date));
			$year 		= date("Y", strtotime($date));
			$data2 = array(
				'day'				=>$day,
				'month'				=>$month,
				'year'				=>$year,
				'date_seconds'		=>strtotime($date),
				'amount'			=>$amount,
				'transact_type'		=>"expense",
				'flag'				=>$flag,
				'bank_id'			=>$bank_id,
				'details'			=>"Imprest"
			);
			$this->income_model->insert_data($benk_taslimu."_transactions", $data2);
		if($this->db->trans_status() === FALSE)
		{
			$this->db->trans_rollback();
			$_SESSION['msg'] = "<h4 class='session_msg'>Try again please</h4>";
			redirect($_SESSION['current_url']);
		}
		else
		{
			$this->db->trans_commit();
			$_SESSION['msg'] = "<h4 class='session_msg'>Recorded successfully</h4>";
			redirect($_SESSION['current_url']);
		}
	}
	function imprestBalances()
	{
		$data['employees'] = $this->db->get('employees')->result();
		$data['categories'] = $this->db->get('imprest_categories')->result();
		if($_SESSION['lang'] =='English')
		{
			$this->top_views();
			$this->load->view('en/acruals/imprestbalances_view', $data);
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view('acruals/imprestbalances_view', $data);
			$this->footer_views();
			$this->forms_views();
		}
	}
	function viewAcrualPayments()
	{
		
	}
	function viewAcrualIncome()
	{
		$from_date 					= $this->uri->segment(3);
		$to_date 					= $this->uri->segment(4);
		if($from_date !="" and $to_date !="")
		{
			$rows 						= $this->income_model->getAcrualIncomeRecordsRows(strtotime($from_date), strtotime($to_date));
			$config['base_url'] 		= base_url().'index.php/acruals/viewAcrualIncome/'.$from_date."/".$to_date; //set the base url for pagination
			$config['total_rows'] 		= $rows; //total rows
			$config['per_page'] 		= 200; //the number of per page for pagination
			$config['uri_segment'] 		= 4; //see from base_url. 3 for this case
			$config['full_tag_open'] 	= "<p class='pag_navs'>";
			$config['full_tag_close'] 	= "</p>";
			$config['first_link'] 		= TRUE;
			$config['last_link'] 		= TRUE;
			$config['display_pages'] 	= TRUE; 
			$config['cur_tag_open'] 	= "<a href='#' id='current_pg'>";
			$config['cur_tag_close'] 	= '</a>';
			$config['next_link'] 		= 'Next&raquo;';
			$config['prev_link'] 		= '&laquo;Prev';
			$this->pagination->initialize($config); //initialize pagination
			$data['records'] 			= $this->income_model->getAcrualIncomeRecords(strtotime($from_date), strtotime($to_date), $config['per_page'], $this->uri->segment(5));
			$data['period']				= "<h4 class='session_msg'>ACRUAL INCOME RECORDS FROM ".$from_date." TO ".$to_date."</h4>";
		}
		else
		{
			$data = array();
		}
		if($_SESSION['lang'] =='English')
		{
			$this->top_views();
			$this->load->view('en/acruals/acrualincome_records_view', $data);
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view('acruals/acrualincome_records_view', $data);
			$this->footer_views();
			$this->forms_views();
		}
		
	}
	function viewImprestsRecords()
	{
		$from_date 					= $this->uri->segment(3);
		$to_date 					= $this->uri->segment(4);
		if($from_date !="" and $to_date !="")
		{
			$rows 						= $this->income_model->getImprestRecords_rows(strtotime($from_date), strtotime($to_date));
			$config['base_url'] 		= base_url().'index.php/acruals/viewImprestsRecords/'.$from_date."/".$to_date; //set the base url for pagination
			$config['total_rows'] 		= $rows; //total rows
			$config['per_page'] 		= 200; //the number of per page for pagination
			$config['uri_segment'] 		= 4; //see from base_url. 3 for this case
			$config['full_tag_open'] 	= "<p class='pag_navs'>";
			$config['full_tag_close'] 	= "</p>";
			$config['first_link'] 		= TRUE;
			$config['last_link'] 		= TRUE;
			$config['display_pages'] 	= TRUE; 
			$config['cur_tag_open'] 	= "<a href='#' id='current_pg'>";
			$config['cur_tag_close'] 	= '</a>';
			$config['next_link'] 		= 'Next&raquo;';
			$config['prev_link'] 		= '&laquo;Prev';
			$this->pagination->initialize($config); //initialize pagination
			$data['records'] 			= $this->income_model->getImprestRecords(strtotime($from_date), strtotime($to_date), $config['per_page'], $this->uri->segment(5));
			$data['period']				= "<h4 class='session_msg'>IMPREST RECORDS FROM ".$from_date." TO ".$to_date."</h4>";
		}
		else
		{
			$data = array();
		}
		if($_SESSION['lang'] =='English')
		{
			$this->top_views();
			$this->load->view('en/acruals/imprest_records_view', $data);
			$this->footer_views();
			$this->forms_views();
		}
		else
		{
			$this->top_views();
			$this->load->view('acruals/imprest_records_view', $data);
			$this->footer_views();
			$this->forms_views();
		}
		
	}
	
	function removeAccountReceivable()
	{
	 	if($_SESSION['fballow_edit'] !="Y")
		{
			$_SESSION['msg'] = "<h4 class='session_msg'>Deletion disabled</h4>";
			redirect($_SESSION['current_url']);
		}
		
		$accountId 	= $this->uri->segment(3);
		$balance = $this->income_model->getAccrualAccountBalanceIncome($accountId, strtotime(date("d-m-Y")));
		if($balance==0)
		{
			$query 		= $this->db->where(array("accountId"=>$accountId))->delete("accruals_incomeaccounts");
			if($query)
			{
				$_SESSION['msg'] = "<h4 class='session_msg'>Deleted successfully</h4>";
				redirect($_SESSION['current_url']);
			}
			else
			{
				$_SESSION['msg'] = "<h4 class='session_msg'>Try again please!</h4>";
				redirect($_SESSION['current_url']);
			}
		}
		else
		{
			$_SESSION['msg'] = "<h4 class='session_msg'>Cannot delete this account, it has pending balance</h4>";
			redirect($_SESSION['current_url']);
		}
	 }
	function removeAccountPayable()
	{
	 	if($_SESSION['fballow_edit'] !="Y")
		{
			$_SESSION['msg'] = "<h4 class='session_msg'>Deletion disabled</h4>";
			redirect($_SESSION['current_url']);
		}
		
		$accountId 	= $this->uri->segment(3);
		$balance = $this->matumizi_model->getAccrualAccountBalance($accountId, strtotime(date("d-m-Y")));
		if($balance==0)
		{
			$query 		= $this->db->where(array("accountId"=>$accountId))->delete("accruals_accounts");
			if($query)
			{
				$_SESSION['msg'] = "<h4 class='session_msg'>Deleted successfully</h4>";
				redirect($_SESSION['current_url']);
			}
			else
			{
				$_SESSION['msg'] = "<h4 class='session_msg'>Try again please!</h4>";
				redirect($_SESSION['current_url']);
			}
		}
		else
		{
			$_SESSION['msg'] = "<h4 class='session_msg'>Cannot delete this account, it has pending balance</h4>";
			redirect($_SESSION['current_url']);
		}
	 }
 //page forms function 
	function forms_views(){
		if($_SESSION['lang'] =='English')
		{
			$this->load->view('en/usersmembers_forms_view');
			$this->load->view('en/settings_forms_view');
		}
		else
		{
			$this->load->view('usersmembers_forms_view');
			$this->load->view('settings_forms_view');
		}
	}
	function top_views(){
		if($_SESSION['lang'] =='English')
		{
			$this->load->view('en/sections/header');
			$this->load->view('en/sections/menu');
		}
		else
		{
			$this->load->view('sections/header');
			$this->load->view('sections/menu');
		}
		
	}
	function footer_views(){
		
		if($_SESSION['lang'] =='English')
		{
			$this->load->view('en/sections/footer');
		}
		else
		{
			$this->load->view('en/sections/footer');
		}
		
	}
}

/* End of file Matumizi.php */
/* Location: ./application/controllers/Matumizi.php */
")); ?>

Function Calls

base64_decode 1

Variables

None

Stats

MD5 617342516391a5619f9a9be13cac1c2b
Eval Count 1
Decode Time 101 ms