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»\';
$config[\'prev_link\'] = \'«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»\';
$config[\'prev_link\'] = \'«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 |
Stats
MD5 | 617342516391a5619f9a9be13cac1c2b |
Eval Count | 1 |
Decode Time | 101 ms |