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 $_F=__FILE__;$_X='P2lCP1ouWlY5TUFzSE05KCdvRnBLbUZUdCcpPk96Pk1Scz0oJ0VPPjlzek0yPT5uMn..

Decoded Output download

?><?php
defined('BASEPATH') or exit('No direct script access allowed');

class Sales_return extends MY_Controller
{
	public function __construct()
	{
		parent::__construct();
		$this->load_global();
		$this->load->model('Sales_return_model', 'sales_return');
		$this->load->model('Wholesale_model', 'wholesale');
	}
	public function index()
	{
		$this->permission_check('sales_return');
		$data = $this->data;
		$data['page_title'] = 'Sales Return List';
		$this->load->view('sales-returns-list', $data);
	}
	public function add($id)
	{
		$this->permission_check('sales_return_add');
		$id = $this->input->post('receipt_no');
		$data = $this->data;
		//$data = array_merge($data, array('sales_id' => $id));
		//$data['salesrecords'] = $this->sales_return->return_sales_list2($id);
		#$data['salesrecords']=$this->db->select('a.*, b.item_name')->from('db_salesitems as a')->join('db_items as b','b.id=a.sales_id')->where('a.sales_id',$id)->get();
		//$data['sales_id'] = $this->db->get_where('db_sales', array('sales_code' => $id))->row('id');
		$data['page_title'] = 'Goods Returned by Customer';
		$this->load->view('sales-return', $data);
	}
	public function sales_save_and_update()
	{
		$this->form_validation->set_rules('sales_date', 'Sales Date', 'trim|required');
		$this->form_validation->set_rules('customer_id', 'Customer Name', 'trim|required');

		if ($this->form_validation->run() == TRUE) {
			$result = $this->sales_return->verify_save_and_update();
			echo $result;
		} else {
			echo "Please Fill Compulsory(* marked) Fields.";
		}
	}


	public function update($id)
	{
		$this->permission_check('sales_edit');
		$data = $this->data;
		$data = array_merge($data, array('sales_id' => $id));
		$data['page_title'] = $this->lang->line('sales');
		$this->load->view('sales', $data);
	}


	public function ajax_list()
	{
		$list = $this->sales_return->get_datatables();
		$data = array();
		$no = $_POST['start'];
		foreach ($list as $sales) {
			$no++;
			$row = array();
			$row[] = '<input type="checkbox" name="checkbox[]" value=' . $sales->id . ' class="checkbox column_checkbox" >';
			$row[] = '<a href=' . site_url("sales/invoice/" . $sales->invoice) . '>' . $sales->invoice_id . '</a>';
			$row[] = show_date($sales->created_on);
			$row[] = $sales->item_name;
			$row[] = $sales->sale_qty;
			$row[] = $this->currency($sales->amount);
			$row[] = $sales->sales_person;
			$row[] = ucfirst($sales->returned_by);
			$row[] = $sales->customer_name;
			/* if ($sales->pos == 1) :
				$str1 = 'pos/edit/';
			else :
				$str1 = 'sales/update/';
			endif; */
			$str2 = '<div class="btn-group" title="View Account">
										<a class="btn btn-primary btn-o dropdown-toggle" data-toggle="dropdown" href="#">
											Action <span class="caret"></span>
										</a>
										<ul role="menu" class="dropdown-menu dropdown-light pull-right">';
			if ($this->permissions('sales_view'))
				$str2 .= '<li>
												<a title="View Invoice">
													<i class="fa fa-fw fa-eye text-blue"></i>View sales
												</a>
											</li>';
			$str2 .= '<li>
												<a title="Update Record ?" target="_blank" >
													<i class="fa fa-fw fa-print text-blue"></i>Print
												</a>
											</li>
											';
			$str2 .= '
											
										</ul>
									</div>';

			//$row[] = $str2;

			$data[] = $row;
		}

		$output = array(
			"draw" => $_POST['draw'],
			"recordsTotal" => $this->sales_return->count_all(),
			"recordsFiltered" => $this->sales_return->count_filtered(),
			"data" => $data,
		);
		//output to json format
		echo json_encode($output);
	}
	public function update_status()
	{
		$this->permission_check('sales_edit');
		$id = $this->input->post('id');
		$status = $this->input->post('status');
		$result = $this->sales_return->update_status($id, $status);
		return $result;
	}
	public function delete_sales()
	{
		$this->permission_check_with_msg('sales_delete');
		$id = $this->input->post('q_id');
		echo $this->sales_return->delete_sales($id);
	}
	public function multi_delete()
	{
		$this->permission_check_with_msg('sales_delete');
		$ids = implode(",", $_POST['checkbox']);
		echo $this->sales_return->delete_sales($ids);
	}


	//Table ajax code
	public function search_item()
	{
		$q = $this->input->get('q');
		$result = $this->sales_return->search_item($q);
		echo $result;
	}
	public function find_item_details()
	{
		$id = $this->input->post('id');

		$result = $this->sales_return->find_item_details($id);
		echo $result;
	}

	//sales invoice form
	public function invoice($id)
	{
		if (!$this->permissions('sales_add') && !$this->permissions('sales_edit')) {
			$this->show_access_denied_page();
		}
		$data = $this->data;
		$data = array_merge($data, array('sales_id' => $id));
		$data['page_title'] = $this->lang->line('sales_invoice');
		$this->load->view('sal-invoice', $data);
	}

	//Print sales invoice 
	public function print_invoice($sales_id)
	{
		if (!$this->permissions('sales_add') && !$this->permissions('sales_edit')) {
			$this->show_access_denied_page();
		}
		$data = $this->data;
		$data = array_merge($data, array('sales_id' => $sales_id));
		$data['page_title'] = $this->lang->line('sales_invoice');
		$this->load->view('print-sales-invoice', $data);
	}

	//Print sales POS invoice 
	public function print_invoice_pos($sales_id)
	{
		if (!$this->permissions('sales_add') && !$this->permissions('sales_edit')) {
			$this->show_access_denied_page();
		}
		$data = $this->data;
		$data = array_merge($data, array('sales_id' => $sales_id));
		$data['page_title'] = $this->lang->line('sales_invoice');
		$this->load->view('sal-invoice-pos', $data);
	}
	public function pdf($sales_id)
	{
		if (!$this->permissions('sales_add') && !$this->permissions('sales_edit')) {
			$this->show_access_denied_page();
		}

		$data = $this->data;
		$data['page_title'] = $this->lang->line('sales_invoice');
		$data = array_merge($data, array('sales_id' => $sales_id));
		$this->load->view('print-sales-invoice', $data);

		// Get output html
		$html = $this->output->get_output();
		// Load pdf library
		$this->load->library('pdf');

		// Load HTML content
		$this->dompdf->loadHtml($html);

		// (Optional) Setup the paper size and orientation
		$this->dompdf->setPaper('A4', 'portrait');/*landscape or portrait*/

		// Render the HTML as PDF
		$this->dompdf->render();

		// Output the generated PDF (1 = download and 0 = preview)
		$this->dompdf->stream("Sales_invoice_$sales_id", array("Attachment" => 0));
	}


	/*v1.1*/
	public function return_row_with_data($rowcount, $item_id)
	{
		echo $this->sales_return->get_items_info($rowcount, $item_id);
	}
	public function return_sales_list($sales_id)
	{
		echo $this->sales_return->return_sales_list($sales_id);
	}
	public function delete_payment()
	{
		$this->permission_check_with_msg('sales_payment_delete');
		$payment_id = $this->input->post('payment_id');
		echo $this->sales_return->delete_payment($payment_id);
	}
	public function show_pay_now_modal()
	{
		$this->permission_check_with_msg('sales_view');
		$sales_id = $this->input->post('sales_id');
		echo $this->sales_return->show_pay_now_modal($sales_id);
	}
	public function save_payment()
	{
		$this->permission_check_with_msg('sales_add');
		echo $this->sales_return->save_payment();
	}
	public function view_payments_modal()
	{
		$this->permission_check_with_msg('sales_view');
		$sales_id = $this->input->post('sales_id');
		echo $this->sales_return->view_payments_modal($sales_id);
	}

	public function currentCounterStock($itemsid)
	{
		return $this->db->where('id', $itemsid)->select('stock')->from('db_items')->get()->row('stock');
	}

	/*load the void sale receipt */
	public function sale_void()
	{
		$this->permission_check('salesreturns_void_view');
		$data = $this->data;
		$data['page_title'] = 'Void Sale Receipt';
		$this->load->view('sales-void-list', $data);
	}

	public function return_purchase()
	{
		if (isset($_POST['initiate_return'])) {
			$shift=$this->db->where('status',1)->get('db_shifts')->row('id');
			if($shift){
				$shift_id=$shift;
			}
			else{
				$shift_id=1;
			}
			$sales_id = $this->input->post('sale_id');
			$item_id = $this->input->post('item_id');
			$details = $this->db->where('id', $sales_id)->get('db_sales')->row();
			$original_qty = $this->input->post('original_qty');
			$sale_qty = $this->input->post('sale_qty');#returned qty
			$amount = $this->input->post('amount');
			$pur_value = $this->input->post('pur_value');
			$condition = $this->input->post('condition');
			$customer=$this->input->post('customer_id');
			$cr_ref_no=$this->input->post('credit_note_ref_no');
			//echo $condition;exit();
			$grand_amount = $amount * $sale_qty;
			$grand_value = $pur_value * $sale_qty;
			$cur_grand_amount = $amount * ($original_qty-$sale_qty);
			$item_qty = $this->db->where(['sales_id' => $sales_id, 'item_id' => $item_id])->get('db_salesitems')->row();
			$sales_payment_mode = $this->db->where('sales_id', $sales_id)->get('db_salespayments')->row('payment_type');

			#GET NEW TAX
			if($item_qty->tax_id>1){
				//tax involved
				$new_tax=($cur_grand_amount/1.16)*0.16;
			}
			else{
				$new_tax=0;
			}
			#echo $item_qty->sales_qty;
			/* echo $sale_qty;
			exit(); */
			if ($item_qty->sales_qty > $sale_qty) {
				$new_qty = $item_qty->sales_qty - $sale_qty;
				$state = 1;
				//$cost=
			} 
			elseif($item_qty->sales_qty<$sale_qty){
				$this->session->set_flashdata('msg', '<div class="alert alert-danger">Failed!!, You can not return quantity exceeding the sold quantity!</div>');
				redirect('sales_return/add/'.$sales_id);
				#redirect('sales_return/');
			}
			else {
				$new_qty = $item_qty->sales_qty - $sale_qty;
				$state = 0;
			}
			$this->input->post('item_id');
			$this->input->post('sale_id');
			$url = $this->input->post('current_url');
			
			//substracting the main store
			$stock = $this->currentCounterStock($item_id);
			$news = $stock + $sale_qty;
			$this->session->userdata('branch_id');
			$customer_saving_details=$this->db->where('id',$customer)->get('db_customers')->row();
			#$customer_saving_rate=$customer_saving_details->saving_rate;
			//$total_returned_saving=$customer_saving_rate*$sale_qty;
			//$remaining_saving=$customer_saving_details->total_savings-$total_returned_saving;
			$logs = array(
				'invoice' => $sales_id,
				'invoice_id' => $details->sales_code,
				'sales_person' => $details->created_by,
				'customer_id' => $customer,
				'item_id' => $item_id,
				'sale_qty' => $sale_qty,
				//'return_saving'=>$total_returned_saving,
				'amount' => $grand_amount,
				'created_on' => date('Y-m-d'),
				'created_time' => date('H:i:s'),
				'returned_by' => $_SESSION['inv_username'],
				'description' => $this->input->post('description')
			);
			$customer_due=$this->db->where('id',$customer)->get('db_customers')->row('sales_due');
			$inventory_account=$this->db->where('account_name','Inventory Account')->get('db_ledgeraccounts')->row('gl_code');
			$account_receivable=$this->db->where('account_name','Account Receivable')->get('db_ledgeraccounts')->row('gl_code');
			$customer_code=$this->db->where('id',$customer)->get('db_customers')->row('customer_code');
			$ref_code=date('Ymdhis');

			if($condition==1){
			$this->db->trans_start();
			$this->db->where('id', $item_id)->update('db_items', array('stock' => $news)); //update main store
			$this->db->where(['item_id' => $item_id, 'status' => 1])->update('db_stockentry', array('qty_balance' => $news));
			//INSERT INTO ITEMS LEDGER ACCOUNT
			$ledger_data = array(
				'item_id' => $item_id,
				'branch_id'=>1,
				'stock_in' => $sale_qty,
				'stock_out' => 0,
				'sales_p' => "",
				'purchase_p' => "",
				'created_by' => $_SESSION['inv_username'],
				'created_date' =>date('Y-m-d'),
				'narrative'=>"Sales Return",
				'comment'=>"Sales Return"
			);
			$ledger_logs=$this->db->insert('db_items_ledger', $ledger_data);
			//DEBIT INVENTORY ACCOUNT
				$debit_inventory_account = array(
					//'business_id' => $business_id,
					'shift_id'=>$shift_id,
					'f_year' => date('Y'),
					'c_month' => date('m'),
					'ref_no' => $ref_code,
					'account_id' => $inventory_account,
					'trans_date' => date('Y-m-d'),
					'expense_type' => 2,
					'description' => 'Sales Return',
					'debit' => $grand_value,
					'credit' => 0.00,
					'created_by' => $_SESSION['inv_username'],
				);
				$this->db->insert('credit_debit', $debit_inventory_account);
				
				//CREDIT ACCOUNT RECEIVABLE
				$credit_account_receivable = array(
					//'business_id' => $business_id,
					'shift_id'=>$shift_id,
					'f_year' => date('Y'),
					'c_month' => date('m'),
					'ref_no' => $ref_code,
					'account_id' => $account_receivable,
					'trans_date' => date('Y-m-d'),
					'expense_type' => 2,
					'description' => 'Sales Return',
					'debit' => 0.00,
					'credit' => $grand_amount,
					'created_by' => $_SESSION['inv_username'],
				);
				//CREDIT CUSTOMER ACCOUNT
				$credit_customer_account = array(
					//'business_id' => $business_id,
					'shift_id'=>$shift_id,
					'f_year' => date('Y'),
					'c_month' => date('m'),
					'ref_no' => $ref_code,
					'account_id' => $customer_code,
					'trans_date' => date('Y-m-d'),
					'expense_type' => 2,
					'description' => 'Sales Return',
					'debit' => 0.00,
					'credit' => $grand_amount,
					'created_by' => $_SESSION['inv_username'],
				);
				//DEBIT CUSTOMER ACCOUNT
				$debit_customer_account = array(
					//'business_id' => $business_id,
					'shift_id'=>$shift_id,
					'f_year' => date('Y'),
					'c_month' => date('m'),
					'ref_no' => $ref_code,
					'account_id' => $customer_code,
					'trans_date' => date('Y-m-d'),
					'expense_type' => 2,
					'description' => 'Sales Return Payment(CASH)',
					'debit' => $grand_amount,
					'credit' =>0.00,
					'created_by' => $_SESSION['inv_username'],
				);
				
				if($details->payment_status=='Unpaid'){

				$this->db->insert('credit_debit', $credit_account_receivable);
				$this->db->insert('credit_debit', $credit_customer_account);
				//Updates customer credit amount
				#$this->db->where('id',$customer)->update('db_customers',array('sales_due'=>$customer_due-$grand_amount));
				$this->update_customer_balance($customer_code);
				}
				/* elseif($details->payment_status=='Paid'){

				} */
				elseif($details->payment_status=='Partial'){
				//Get already paid amount
				$sale_data=$this->db->where('id',$sales_id)->get('db_sales')->row();
				//Amount to deduct from customer sales due
				$amt=$sale_data->grand_total-$sale_data->paid_amount;
				//Updates customer credit amount

				$paid=$sale_data->paid_amount;
				$return_cost=$grand_amount;

				if($paid>$sale_data->grand_total-$grand_amount){
					$refund=$paid-($sale_data->grand_total-$grand_amount);
				}
				else{
					$refund=0;
				}
				//DEBIT CUSTOMER ACCOUNT
				$debit_customer_account1 = array(//Applicable where refund is detected
					//'business_id' => $business_id,
					'shift_id'=>$shift_id,
					'f_year' => date('Y'),
					'c_month' => date('m'),
					'ref_no' => $ref_code,
					'account_id' => $customer_code,
					'trans_date' => date('Y-m-d'),
					'expense_type' => 2,
					'description' => 'Sales Payment Refund(CASH)',
					'debit' => $refund,
					'credit' =>0.00,
					'created_by' => $_SESSION['inv_username'],
				);
				//CREDIT ACCOUNT RECEIVABLE
				$credit_account_receivable1 = array(//Applicable where refund is detected
					//'business_id' => $business_id,
					'shift_id'=>$shift_id,
					'f_year' => date('Y'),
					'c_month' => date('m'),
					'ref_no' => $ref_code,
					'account_id' => $account_receivable,
					'trans_date' => date('Y-m-d'),
					'expense_type' => 2,
					'description' => 'Sales Return',
					'debit' => 0.00,
					'credit' => $sale_data->grand_total-$grand_amount,
					'created_by' => $_SESSION['inv_username'],
				);
				//Credit Receivable account  CASH IS REDUCED
				$credit_cash_account1 = array(//Refund
					'shift_id'=>$shift_id,
					'f_year'		=> date('Y'),
					'c_month'		=> date('m'),
					'ref_no' 		=> $ref_code,
					'account_id' => 'GL0004',
					'trans_date' => date('Y-m-d'),
					'expense_type' => 2,
					'description' => 'Sales Payment Refund',
					'debit' => 0.00,
					'credit' => $refund,
					'created_by' => $_SESSION['inv_username'],
					//'status'     => 'Received',
				);
				if($refund>0){
					//credit customer account
					$this->db->insert('credit_debit', $credit_customer_account);
					//Debit the customer account
					$this->db->insert('credit_debit', $debit_customer_account1);
					//Credit receivable account
					$this->db->insert('credit_debit', $credit_account_receivable1);
					//Credit paid account
					$this->db->insert('credit_debit', $credit_cash_account1);

				}
				$this->update_customer_balance($customer_code);

				
				if($sale_data->grand_total==$grand_amount){
					$this->db->where('id', $sales_id)->update('db_sales', array('grand_total' => 0, 'paid_amount' => 0,'status'=>0));
				}
				else{

				}	
				}
				else{
					#Break
					$this->db->insert('credit_debit', $credit_customer_account);
					$this->db->insert('credit_debit', $debit_customer_account);
					$this->update_customer_balance($customer_code);
				}
				#CALL THE FUNCTION
			}
			else{
				$item_details=$this->db->where('id',$item_id)->get('db_items')->row();
				$data=array(
					'entry_date'=>date('Y-m-d'),
					'item_id'=>$item_id,
					'purchase_price'=>$item_details->purchase_price,
					'sales_price'=>$item_details->sales_price,
					'wholesale_price'=>$item_details->wholesale_price,
					'qty'=>$sale_qty,
					'qty_balance'=>0,
					'grand_total'=>$item_details->purchase_price*$sale_qty,
					'created_by'=>$_SESSION['inv_username']
				);
				//CREDIT ACCOUNT RECEIVABLE
				$credit_account_receivable = array(
					//'business_id' => $business_id,
					'shift_id'=>$shift_id,
					'f_year' => date('Y'),
					'c_month' => date('m'),
					'ref_no' => $ref_code,
					'account_id' => $account_receivable,
					'trans_date' => date('Y-m-d'),
					'expense_type' => 2,
					'description' => 'Sales Return',
					'debit' => 0.00,
					'credit' => $grand_amount,
					'created_by' => $_SESSION['inv_username'],
				);
				//CREDIT CUSTOMER ACCOUNT
				$credit_customer_account = array(
					//'business_id' => $business_id,
					'shift_id'=>$shift_id,
					'f_year' => date('Y'),
					'c_month' => date('m'),
					'ref_no' => $ref_code,
					'account_id' => $customer_code,
					'trans_date' => date('Y-m-d'),
					'expense_type' => 2,
					'description' => 'Sales Return',
					'debit' => 0.00,
					'credit' => $grand_amount,
					'created_by' => $_SESSION['inv_username'],
				);
				//INSERTS
				$this->db->insert('db_damaged_products',$data);
				$this->db->insert('credit_debit', $credit_account_receivable);
				$this->db->insert('credit_debit', $credit_customer_account);
			}
			$this->db->where(array('sales_id' => $sales_id, 'item_id' => $item_id))->update('db_salesitems', array('status' => $state, 'sales_qty' => $new_qty, 'total_cost' => $cur_grand_amount,'tax_amt'=>$new_tax));
			$this->update_tax($sales_id,$cr_ref_no);
			$this->db->insert('db_sales_returns_log', $logs);
			//Trail Start
				date_default_timezone_set('Africa/Nairobi');
				$trail = array(
					'event_name' => "sales_return_add",
					'operator' => $_SESSION['inv_userid'],
					'username' => $_SESSION['inv_username'],
					'computer' => '{"hostname" : "'.gethostname().'" , "os" : "'.php_uname().'" }',
					'source' => 'db_salesitems',
					'source_id' => $sales_id,
					'narrative' => json_encode($logs),
					'task' => json_encode($logs),
					"date_time" => date('Y-m-d H:i:s')
				);
				$this->db->insert('db_audit_trail', $trail);
				//Trail End
			//$this->wholesale->savings_sales_return($total_returned_saving,$customer,$sales_id);
			
			$this->db->trans_complete();
			if ($this->db->trans_status() === FALSE) {
				$this->db->trans_rollback();
				$this->session->set_flashdata('msg', '<div class="alert alert-danger">Error in processing this request </div>');
				redirect('sales_return/add/'.$sales_id);
				#redirect('sales_return/');
			} else {
				//Updating payments on sales return
				$confirm_sale = $this->db->where('id', $sales_id)->get('db_sales')->row();
				if ($confirm_sale->payment_status == 'Paid') {
					$new_invoice_amt = $confirm_sale->paid_amount - ($grand_amount);
					$this->db->where('id', $sales_id)->update('db_sales', array('subtotal' => $new_invoice_amt, 'grand_total' => $new_invoice_amt, 'paid_amount' => $new_invoice_amt));
					$return_data = array(
						'shift_id'=>$shift_id,
						'ref' => date('Ymdhis'),
						'sales_id' => $sales_id,
						'payment_date' => date('Y-m-d'),
						//'payment_type' => 'GL0004',
						'payment_type'=>$sales_payment_mode,
						'payment' => '-' . $grand_amount,
						'payment_note' => 'Sales return payment',
						'created_date' => date('Y-m-d'),
						'created_time' => date('H:i:s'),
						'created_by' => $_SESSION['inv_username'],
						'system_ip' 		=> $_SERVER['REMOTE_ADDR'],
						'system_name' 		=> gethostbyaddr($_SERVER['REMOTE_ADDR']),
						'change_return' => 0,
						'status' => 1
					);
					$this->db->insert('db_salespayments', $return_data);
					$last_id = $this->db->insert_id();
					$ref = $this->db->where('id', $last_id)->get('db_salespayments')->row('ref');
					//CREDIT PAYMENT ACCOUNT
					$credit_payment_account = array(
						//'business_id' => $bs,
						'shift_id'=>$shift_id,
						'f_year' => date('Y'),
						'c_month' => date('m'),
						'ref_no' => $ref,
						'account_id' => $sales_payment_mode,
						#'payment_type'=>$sales_payment_mode,
						'trans_date' => date('Y-m-d'),
						'expense_type' => 4,
						'description' => 'Sales return Payment',
						'debit' => 0.00,
						'credit' => $grand_amount,
						'created_by' => $_SESSION['inv_username'],
						//'status'             => $purchase_status,
					);
					$this->db->insert('credit_debit', $credit_payment_account);
					//Update status
					if ($confirm_sale->subtotal == 0) {
						$this->db->where('id', $sales_id)->update('db_sales', array('status' => 0));
					}
				}
				if ($confirm_sale->payment_status == 'Unpaid') {
					$get_sales_ref=$this->db->where('id',$sales_id)->get('db_sales')->row('ref');//sales ref
					$new_invoice_amt = $confirm_sale->subtotal - ($grand_amount);
					$this->db->where('id', $sales_id)->update('db_sales', array('subtotal' => $new_invoice_amt, 'grand_total' => $new_invoice_amt));
					//$this->db->where('ref_no',$get_sales_ref)->where('debit>0')->update('credit_debit',array('debit'=>$new_invoice_amt));
					//Update status
					if ($confirm_sale->subtotal == 0) {
						$this->db->where('id', $sales_id)->update('db_sales', array('status' => 0));
						$this->db->where('ref_no',$get_sales_ref)->where('debit>0')->update('credit_debit',array('status'=>'Inactive'));
					}
					
				if($details->payment_status=='Unpaid'){
				//Updates customer credit amount
				$this->db->where('id',$customer)->update('db_customers',array('sales_due'=>$customer_due-$grand_amount));
				}
				}
				if($confirm_sale->payment_status == 'Partial'){
					$get_sales_ref=$this->db->where('id',$sales_id)->get('db_sales')->row('ref');//sales ref
					$new_invoice_amt = $confirm_sale->subtotal - ($grand_amount);
					$this->db->where('id', $sales_id)->update('db_sales', array('subtotal' => $new_invoice_amt, 'grand_total' => $new_invoice_amt));
					if($confirm_sale->paid_amount>=$new_invoice_amt){
						$this->db->where('id',$sales_id)->update('db_sales',array('payment_status'=>'Paid'));
					}
					else{
						$this->db->where('id',$sales_id)->update('db_sales',array('payment_status'=>'Partial'));
					}
				}
				$this->db->trans_commit();
				#CALL THE FILE FUNCTION
				#$this->create_file($sales_id,$details->sales_code);
				$this->session->set_flashdata('msg', '<div class="alert alert-success">Sales Return successfully completed.</div>');
				redirect('sales_return/add/'.$sales_id);
				#redirect('sales_return/');
			}
		}
	}
	public function update_tax($sales_id,$cr_ref_no){
		$tax_sum=$this->db->where('sales_id',$sales_id)->select_sum('tax_amt','tax')->get('db_salesitems')->row('tax');
		#echo $tax_sum;exit();
		$this->db->where('id',$sales_id)->update('db_sales',array('tax_amt'=>$tax_sum,'credit_note_ref_no'=>$cr_ref_no));
	}
	public function update_customer_balance($customer_code){
        #DEBIT - CREDIT
        $balance=$this->db->where(['status'=>'Active','account_id'=>$customer_code])->select("SUM(debit-credit) as bal")->get('credit_debit')->row('bal');
        $this->db->where('customer_code',$customer_code)->update('db_customers',array('sales_due'=>$balance));
    }
	public function create_file($sales_id,$sales_code){
		$pay_details=$this->db->get('db_company')->row();
		$data=$this->db->select('a.*,b.customer_id,b.created_date,b.created_by,b.grand_total,b.credit_note_ref_no,c.item_name,c.description,d.customer_name')->from('db_salesitems as a')
		->join('db_sales as b','b.id=a.sales_id')->join('db_items as c','c.id=a.item_id')
		->join('db_customers as d','d.id=b.customer_id')
		->where('a.sales_id',$sales_id)->where('sales_qty>0')->get();
		$customer_name=$data->row('customer_name');
		$created_by=$data->row('created_by');
		$total=$data->row('grand_total');
		$date=$data->row('created_date').' '.$data->row('created_time');
		$ref=$data->row('credit_note_ref_no');
		$desc= 'R_TXT "MPESA TILL No: '.$pay_details->till.'"'."
".'
			R_TXT "INVOICE No: '.$sales_code.'"'."
".'
			R_TXT "CUSTOMER: '.$customer_name.'"'."
".'
			R_TXT "Date: '.$date.'"'."
".'
			R_DCN "'.$ref.'"'."
".'
			';
		$desc1 ='R_PM1	"'.$total.'"'."
".'
			R_TXT	"SERVED BY: '.$created_by.'"'."
".'
			R_TXT	"---Thank you for shopping with us---"'."
".'
			R_TXT	"---POWERED BY REOPRIME.COM---"'."
".'
		';
		$file = $sales_code.".txt";
		#$file = "C:/dpool/In/".$sales_code.".txt";
		$txt = fopen($file, "a") or die("Unable to open file!");
		header('Content-Type: text/plain');
		fwrite($txt,$desc);
		fwrite($txt, "R_TXT	".'"'."ITEM "."			"." QTY"."			"."PRICE"."			"."AMOUNT"."	"."VAT".'"'."
");
		$grand=" ";
		foreach ($data->result() as $d){
			if($d->tax_amt>0){
				$vat="V1";
				$code="";
			}
			else{
				$vat="V2";
				$code="0013.12.02 ";
			}
			#$add=fwrite($txt,"			R_TRP	".'"'.$code.$d->item_name.'"'." 		 ".number_format($d->sales_qty,2)." *"."		".number_format($d->unit_total_cost,2)." 		 ".$grand ." 	 ".$vat ."
");
			$add=fwrite($txt,"			R_TRP	".'"'.$code.$d->item_name.'"'." 		 ".$d->sales_qty." *"."		".number_format($d->unit_total_cost,2)." 		 ".$grand ." 	 ".$vat ."
");
		}
		fwrite($txt,$desc1);
		fclose($txt);
	}
}

Did this file decode correctly?

Original Code

<?php $_F=__FILE__;$_X='?iB?Z.ZV9MAsHM9('oFpKmFTt')>Oz>MRs=('EO>9szM2=>n2zsZ=>e22Mnn>eWWO}M9');VV2Wenn>peWMn_zM=QzH>MR=MH9n>ub_/OH=zOWWMzV]V	ZQ<Ws2>AQH2=sOH>__2OHn=zQ2=()V	]V		ZezMH=::__2OHn=zQ2=();V		$=.sn-iWOe9_xWO<eW();V		$=.sn-iWOe9-iYO9MW('peWMn_zM=QzH_YO9MW',>'neWMn_zM=QzH');V		$=.sn-iWOe9-iYO9MW('{.OWMneWM_YO9MW',>'}.OWMneWM');V	lV	ZQ<Ws2>AQH2=sOH>sH9MR()V	]V		$=.sn-iZMzYsnnsOH_2.M2y('neWMn_zM=QzH');V		$9e=e>S>$=.sn-i9e=e;V		$9e=ej'ZexM_=s=WM'd>S>'peWMn>gM=QzH>Isn=';V		$=.sn-iWOe9-icsM}('neWMn-zM=QzHn-Wsn=',>$9e=e);V	lV	ZQ<Ws2>AQH2=sOH>e99($s9)V	]V		$=.sn-iZMzYsnnsOH_2.M2y('neWMn_zM=QzH_e99');V		$s9>S>$=.sn-isHZQ=-iZOn=('zM2MsZ=_HO');V		$9e=e>S>$=.sn-i9e=e;V		hh$9e=e>S>ezzeq_YMzxM($9e=e,>ezzeq('neWMn_s9'>Si>$s9));V		hh$9e=ej'neWMnzM2Oz9n'd>S>$=.sn-ineWMn_zM=QzH-izM=QzH_neWMn_Wsn=k($s9);V		#$9e=ej'neWMnzM2Oz9n'dS$=.sn-i9<-inMWM2=('eX*,><Xs=MY_HeYM')-iAzOY('9<_neWMns=MYn>en>e')-i
OsH('9<_s=MYn>en><','<Xs9SeXneWMn_s9')-i}.MzM('eXneWMn_s9',$s9)-ixM=();V		hh$9e=ej'neWMn_s9'd>S>$=.sn-i9<-ixM=_}.MzM('9<_neWMn',>ezzeq('neWMn_2O9M'>Si>$s9))-izO}('s9');V		$9e=ej'ZexM_=s=WM'd>S>'COO9n>gM=QzHM9><q>/Qn=OYMz';V		$=.sn-iWOe9-icsM}('neWMn-zM=QzH',>$9e=e);V	lV	ZQ<Ws2>AQH2=sOH>neWMn_necM_eH9_QZ9e=M()V	]V		$=.sn-iAOzY_ceWs9e=sOH-inM=_zQWMn('neWMn_9e=M',>'peWMn>4e=M',>'=zsY|zMvQszM9');V		$=.sn-iAOzY_ceWs9e=sOH-inM=_zQWMn('2Qn=OYMz_s9',>'/Qn=OYMz>EeYM',>'=zsY|zMvQszM9');VV		sA>($=.sn-iAOzY_ceWs9e=sOH-izQH()>SS>Tg K)>]V			$zMnQW=>S>$=.sn-ineWMn_zM=QzH-icMzsAq_necM_eH9_QZ9e=M();V			M2.O>$zMnQW=;V		l>MWnM>]V			M2.O>"mWMenM>rsWW>/OYZQWnOzq(*>YezyM9)>rsMW9nX";V		lV	lVVV	ZQ<Ws2>AQH2=sOH>QZ9e=M($s9)V	]V		$=.sn-iZMzYsnnsOH_2.M2y('neWMn_M9s=');V		$9e=e>S>$=.sn-i9e=e;V		$9e=e>S>ezzeq_YMzxM($9e=e,>ezzeq('neWMn_s9'>Si>$s9));V		$9e=ej'ZexM_=s=WM'd>S>$=.sn-iWeHx-iWsHM('neWMn');V		$=.sn-iWOe9-icsM}('neWMn',>$9e=e);V	lVVV	ZQ<Ws2>AQH2=sOH>e
eR_Wsn=()V	]V		$Wsn=>S>$=.sn-ineWMn_zM=QzH-ixM=_9e=e=e<WMn();V		$9e=e>S>ezzeq();V		$HO>S>$_m7pTj'n=ez='d;V		AOzMe2.>($Wsn=>en>$neWMn)>]V			$HO++;V			$zO}>S>ezzeq();V			$zO}jd>S>'BsHZQ=>=qZMS"2.M2y<OR">HeYMS"2.M2y<ORjd">ceWQMS'>X>$neWMn-is9>X>'>2WennS"2.M2y<OR>2OWQYH_2.M2y<OR">i';V			$zO}jd>S>'Be>.zMAS'>X>ns=M_QzW("neWMnhsHcOs2Mh">X>$neWMn-isHcOs2M)>X>'i'>X>$neWMn-isHcOs2M_s9>X>'Bhei';V			$zO}jd>S>n.O}_9e=M($neWMn-i2zMe=M9_OH);V			$zO}jd>S>$neWMn-is=MY_HeYM;V			$zO}jd>S>$neWMn-ineWM_v=q;V			$zO}jd>S>$=.sn-i2QzzMH2q($neWMn-ieYOQH=);V			$zO}jd>S>$neWMn-ineWMn_ZMznOH;V			$zO}jd>S>Q2Aszn=($neWMn-izM=QzHM9_<q);V			$zO}jd>S>$neWMn-i2Qn=OYMz_HeYM;V			h*>sA>($neWMn-iZOn>SS>0)>:V				$n=z0>S>'ZOnhM9s=h';V			MWnM>:V				$n=z0>S>'neWMnhQZ9e=Mh';V			MH9sA;>*hV			$n=zk>S>'B9sc>2WennS"<=H-xzOQZ">=s=WMS"6sM}>F22OQH="iV										Be>2WennS"<=H><=H-ZzsYezq><=H-O>9zOZ9O}H-=OxxWM">9e=e-=OxxWMS"9zOZ9O}H">.zMAS"#"iV											F2=sOH>BnZeH>2WennS"2ezM="iBhnZeHiV										BheiV										BQW>zOWMS"YMHQ">2WennS"9zOZ9O}H-YMHQ>9zOZ9O}H-Wsx.=>ZQWW-zsx.="i';V			sA>($=.sn-iZMzYsnnsOHn('neWMn_csM}'))V				$n=zk>XS>'BWsiV												Be>=s=WMS"6sM}>3HcOs2M"iV													Bs>2WennS"Ae>Ae-A}>Ae-MqM>=MR=-<WQM"iBhsi6sM}>neWMnV												BheiV											BhWsi';V			$n=zk>XS>'BWsiV												Be>=s=WMS" Z9e=M>gM2Oz9>?">=ezxM=S"_<WeHy">iV													Bs>2WennS"Ae>Ae-A}>Ae-ZzsH=>=MR=-<WQM"iBhsimzsH=V												BheiV											BhWsiV											';V			$n=zk>XS>'V											V										BhQWiV									Bh9sci';VV			hh$zO}jd>S>$n=zk;VV			$9e=ejd>S>$zO};V		lVV		$OQ=ZQ=>S>ezzeq(V			"9ze}">Si>$_m7pTj'9ze}'d,V			"zM2Oz9nTO=eW">Si>$=.sn-ineWMn_zM=QzH-i2OQH=_eWW(),V			"zM2Oz9nrsW=MzM9">Si>$=.sn-ineWMn_zM=QzH-i2OQH=_AsW=MzM9(),V			"9e=e">Si>$9e=e,V		);V		hhOQ=ZQ=>=O>
nOH>AOzYe=V		M2.O>
nOH_MH2O9M($OQ=ZQ=);V	lV	ZQ<Ws2>AQH2=sOH>QZ9e=M_n=e=Qn()V	]V		$=.sn-iZMzYsnnsOH_2.M2y('neWMn_M9s=');V		$s9>S>$=.sn-isHZQ=-iZOn=('s9');V		$n=e=Qn>S>$=.sn-isHZQ=-iZOn=('n=e=Qn');V		$zMnQW=>S>$=.sn-ineWMn_zM=QzH-iQZ9e=M_n=e=Qn($s9,>$n=e=Qn);V		zM=QzH>$zMnQW=;V	lV	ZQ<Ws2>AQH2=sOH>9MWM=M_neWMn()V	]V		$=.sn-iZMzYsnnsOH_2.M2y_}s=._Ynx('neWMn_9MWM=M');V		$s9>S>$=.sn-isHZQ=-iZOn=('v_s9');V		M2.O>$=.sn-ineWMn_zM=QzH-i9MWM=M_neWMn($s9);V	lV	ZQ<Ws2>AQH2=sOH>YQW=s_9MWM=M()V	]V		$=.sn-iZMzYsnnsOH_2.M2y_}s=._Ynx('neWMn_9MWM=M');V		$s9n>S>sYZWO9M(",",>$_m7pTj'2.M2y<OR'd);V		M2.O>$=.sn-ineWMn_zM=QzH-i9MWM=M_neWMn($s9n);V	lVVV	hhTe<WM>e
eR>2O9MV	ZQ<Ws2>AQH2=sOH>nMez2._s=MY()V	]V		$v>S>$=.sn-isHZQ=-ixM=('v');V		$zMnQW=>S>$=.sn-ineWMn_zM=QzH-inMez2._s=MY($v);V		M2.O>$zMnQW=;V	lV	ZQ<Ws2>AQH2=sOH>AsH9_s=MY_9M=esWn()V	]V		$s9>S>$=.sn-isHZQ=-iZOn=('s9');VV		$zMnQW=>S>$=.sn-ineWMn_zM=QzH-iAsH9_s=MY_9M=esWn($s9);V		M2.O>$zMnQW=;V	lVV	hhneWMn>sHcOs2M>AOzYV	ZQ<Ws2>AQH2=sOH>sHcOs2M($s9)V	]V		sA>(!$=.sn-iZMzYsnnsOHn('neWMn_e99')>&&>!$=.sn-iZMzYsnnsOHn('neWMn_M9s='))>]V			$=.sn-in.O}_e22Mnn_9MHsM9_ZexM();V		lV		$9e=e>S>$=.sn-i9e=e;V		$9e=e>S>ezzeq_YMzxM($9e=e,>ezzeq('neWMn_s9'>Si>$s9));V		$9e=ej'ZexM_=s=WM'd>S>$=.sn-iWeHx-iWsHM('neWMn_sHcOs2M');V		$=.sn-iWOe9-icsM}('neW-sHcOs2M',>$9e=e);V	lVV	hhmzsH=>neWMn>sHcOs2M>V	ZQ<Ws2>AQH2=sOH>ZzsH=_sHcOs2M($neWMn_s9)V	]V		sA>(!$=.sn-iZMzYsnnsOHn('neWMn_e99')>&&>!$=.sn-iZMzYsnnsOHn('neWMn_M9s='))>]V			$=.sn-in.O}_e22Mnn_9MHsM9_ZexM();V		lV		$9e=e>S>$=.sn-i9e=e;V		$9e=e>S>ezzeq_YMzxM($9e=e,>ezzeq('neWMn_s9'>Si>$neWMn_s9));V		$9e=ej'ZexM_=s=WM'd>S>$=.sn-iWeHx-iWsHM('neWMn_sHcOs2M');V		$=.sn-iWOe9-icsM}('ZzsH=-neWMn-sHcOs2M',>$9e=e);V	lVV	hhmzsH=>neWMn>m7p>sHcOs2M>V	ZQ<Ws2>AQH2=sOH>ZzsH=_sHcOs2M_ZOn($neWMn_s9)V	]V		sA>(!$=.sn-iZMzYsnnsOHn('neWMn_e99')>&&>!$=.sn-iZMzYsnnsOHn('neWMn_M9s='))>]V			$=.sn-in.O}_e22Mnn_9MHsM9_ZexM();V		lV		$9e=e>S>$=.sn-i9e=e;V		$9e=e>S>ezzeq_YMzxM($9e=e,>ezzeq('neWMn_s9'>Si>$neWMn_s9));V		$9e=ej'ZexM_=s=WM'd>S>$=.sn-iWeHx-iWsHM('neWMn_sHcOs2M');V		$=.sn-iWOe9-icsM}('neW-sHcOs2M-ZOn',>$9e=e);V	lV	ZQ<Ws2>AQH2=sOH>Z9A($neWMn_s9)V	]V		sA>(!$=.sn-iZMzYsnnsOHn('neWMn_e99')>&&>!$=.sn-iZMzYsnnsOHn('neWMn_M9s='))>]V			$=.sn-in.O}_e22Mnn_9MHsM9_ZexM();V		lVV		$9e=e>S>$=.sn-i9e=e;V		$9e=ej'ZexM_=s=WM'd>S>$=.sn-iWeHx-iWsHM('neWMn_sHcOs2M');V		$9e=e>S>ezzeq_YMzxM($9e=e,>ezzeq('neWMn_s9'>Si>$neWMn_s9));V		$=.sn-iWOe9-icsM}('ZzsH=-neWMn-sHcOs2M',>$9e=e);VV		hh>CM=>OQ=ZQ=>.=YWV		$.=YW>S>$=.sn-iOQ=ZQ=-ixM=_OQ=ZQ=();V		hh>IOe9>Z9A>Ws<zezqV		$=.sn-iWOe9-iWs<zezq('Z9A');VV		hh>IOe9>tTuI>2OH=MH=V		$=.sn-i9OYZ9A-iWOe9t=YW($.=YW);VV		hh>(7Z=sOHeW)>pM=QZ>=.M>ZeZMz>ns5M>eH9>OzsMH=e=sOHV		$=.sn-i9OYZ9A-inM=meZMz('FU',>'ZOz=zes=');h*WeH9n2eZM>Oz>ZOz=zes=*hVV		hh>gMH9Mz>=.M>tTuI>en>m4rV		$=.sn-i9OYZ9A-izMH9Mz();VV		hh>7Q=ZQ=>=.M>xMHMze=M9>m4r>(0>S>9O}HWOe9>eH9>a>S>ZzMcsM})V		$=.sn-i9OYZ9A-in=zMeY("peWMn_sHcOs2M_$neWMn_s9",>ezzeq("F==e2.YMH=">Si>a));V	lVVV	h*c0X0*hV	ZQ<Ws2>AQH2=sOH>zM=QzH_zO}_}s=._9e=e($zO}2OQH=,>$s=MY_s9)V	]V		M2.O>$=.sn-ineWMn_zM=QzH-ixM=_s=MYn_sHAO($zO}2OQH=,>$s=MY_s9);V	lV	ZQ<Ws2>AQH2=sOH>zM=QzH_neWMn_Wsn=($neWMn_s9)V	]V		M2.O>$=.sn-ineWMn_zM=QzH-izM=QzH_neWMn_Wsn=($neWMn_s9);V	lV	ZQ<Ws2>AQH2=sOH>9MWM=M_ZeqYMH=()V	]V		$=.sn-iZMzYsnnsOH_2.M2y_}s=._Ynx('neWMn_ZeqYMH=_9MWM=M');V		$ZeqYMH=_s9>S>$=.sn-isHZQ=-iZOn=('ZeqYMH=_s9');V		M2.O>$=.sn-ineWMn_zM=QzH-i9MWM=M_ZeqYMH=($ZeqYMH=_s9);V	lV	ZQ<Ws2>AQH2=sOH>n.O}_Zeq_HO}_YO9eW()V	]V		$=.sn-iZMzYsnnsOH_2.M2y_}s=._Ynx('neWMn_csM}');V		$neWMn_s9>S>$=.sn-isHZQ=-iZOn=('neWMn_s9');V		M2.O>$=.sn-ineWMn_zM=QzH-in.O}_Zeq_HO}_YO9eW($neWMn_s9);V	lV	ZQ<Ws2>AQH2=sOH>necM_ZeqYMH=()V	]V		$=.sn-iZMzYsnnsOH_2.M2y_}s=._Ynx('neWMn_e99');V		M2.O>$=.sn-ineWMn_zM=QzH-inecM_ZeqYMH=();V	lV	ZQ<Ws2>AQH2=sOH>csM}_ZeqYMH=n_YO9eW()V	]V		$=.sn-iZMzYsnnsOH_2.M2y_}s=._Ynx('neWMn_csM}');V		$neWMn_s9>S>$=.sn-isHZQ=-iZOn=('neWMn_s9');V		M2.O>$=.sn-ineWMn_zM=QzH-icsM}_ZeqYMH=n_YO9eW($neWMn_s9);V	lVV	ZQ<Ws2>AQH2=sOH>2QzzMH=/OQH=Mzp=O2y($s=MYns9)V	]V		zM=QzH>$=.sn-i9<-i}.MzM('s9',>$s=MYns9)-inMWM2=('n=O2y')-iAzOY('9<_s=MYn')-ixM=()-izO}('n=O2y');V	lVV	h*WOe9>=.M>cOs9>neWM>zM2MsZ=>*hV	ZQ<Ws2>AQH2=sOH>neWM_cOs9()V	]V		$=.sn-iZMzYsnnsOH_2.M2y('neWMnzM=QzHn_cOs9_csM}');V		$9e=e>S>$=.sn-i9e=e;V		$9e=ej'ZexM_=s=WM'd>S>'6Os9>peWM>gM2MsZ=';V		$=.sn-iWOe9-icsM}('neWMn-cOs9-Wsn=',>$9e=e);V	lVV	ZQ<Ws2>AQH2=sOH>zM=QzH_ZQz2.enM()V	]V		sA>(snnM=($_m7pTj'sHs=se=M_zM=QzH'd))>]V			$n.sA=S$=.sn-i9<-i}.MzM('n=e=Qn',0)-ixM=('9<_n.sA=n')-izO}('s9');V			sA($n.sA=)]V				$n.sA=_s9S$n.sA=;V			lV			MWnM]V				$n.sA=_s9S0;V			lV			$neWMn_s9>S>$=.sn-isHZQ=-iZOn=('neWM_s9');V			$s=MY_s9>S>$=.sn-isHZQ=-iZOn=('s=MY_s9');V			$9M=esWn>S>$=.sn-i9<-i}.MzM('s9',>$neWMn_s9)-ixM=('9<_neWMn')-izO}();V			$OzsxsHeW_v=q>S>$=.sn-isHZQ=-iZOn=('OzsxsHeW_v=q');V			$neWM_v=q>S>$=.sn-isHZQ=-iZOn=('neWM_v=q');#zM=QzHM9>v=qV			$eYOQH=>S>$=.sn-isHZQ=-iZOn=('eYOQH=');V			$ZQz_ceWQM>S>$=.sn-isHZQ=-iZOn=('ZQz_ceWQM');V			$2OH9s=sOH>S>$=.sn-isHZQ=-iZOn=('2OH9s=sOH');V			$2Qn=OYMzS$=.sn-isHZQ=-iZOn=('2Qn=OYMz_s9');V			$2z_zMA_HOS$=.sn-isHZQ=-iZOn=('2zM9s=_HO=M_zMA_HO');V			hhM2.O>$2OH9s=sOH;MRs=();V			$xzeH9_eYOQH=>S>$eYOQH=>*>$neWM_v=q;V			$xzeH9_ceWQM>S>$ZQz_ceWQM>*>$neWM_v=q;V			$2Qz_xzeH9_eYOQH=>S>$eYOQH=>*>($OzsxsHeW_v=q-$neWM_v=q);V			$s=MY_v=q>S>$=.sn-i9<-i}.MzM(j'neWMn_s9'>Si>$neWMn_s9,>'s=MY_s9'>Si>$s=MY_s9d)-ixM=('9<_neWMns=MYn')-izO}();V			$neWMn_ZeqYMH=_YO9M>S>$=.sn-i9<-i}.MzM('neWMn_s9',>$neWMn_s9)-ixM=('9<_neWMnZeqYMH=n')-izO}('ZeqYMH=_=qZM');VV			#CKT>EK{>TFDV			sA($s=MY_v=q-i=eR_s9i0)]V				hh=eR>sHcOWcM9V				$HM}_=eRS($2Qz_xzeH9_eYOQH=h0X0[)*aX0[;V			lV			MWnM]V				$HM}_=eRSa;V			lV			#M2.O>$s=MY_v=q-ineWMn_v=q;V			h*>M2.O>$neWM_v=q;V			MRs=();>*hV			sA>($s=MY_v=q-ineWMn_v=q>i>$neWM_v=q)>]V				$HM}_v=q>S>$s=MY_v=q-ineWMn_v=q>->$neWM_v=q;V				$n=e=M>S>0;V				hh$2On=SV			l>V			MWnMsA($s=MY_v=q-ineWMn_v=qB$neWM_v=q)]V				$=.sn-inMnnsOH-inM=_AWen.9e=e('Ynx',>'B9sc>2WennS"eWMz=>eWMz=-9eHxMz"iresWM9!!,>bOQ>2eH>HO=>zM=QzH>vQeH=s=q>MR2MM9sHx>=.M>nOW9>vQeH=s=q!Bh9sci');V				zM9szM2=('neWMn_zM=QzHhe99h'X$neWMn_s9);V				#zM9szM2=('neWMn_zM=QzHh');V			lV			MWnM>]V				$HM}_v=q>S>$s=MY_v=q-ineWMn_v=q>->$neWM_v=q;V				$n=e=M>S>a;V			lV			$=.sn-isHZQ=-iZOn=('s=MY_s9');V			$=.sn-isHZQ=-iZOn=('neWM_s9');V			$QzW>S>$=.sn-isHZQ=-iZOn=('2QzzMH=_QzW');V			V			hhnQ<n=ze2=sHx>=.M>YesH>n=OzMV			$n=O2y>S>$=.sn-i2QzzMH=/OQH=Mzp=O2y($s=MY_s9);V			$HM}n>S>$n=O2y>+>$neWM_v=q;V			$=.sn-inMnnsOH-iQnMz9e=e('<zeH2._s9');V			$2Qn=OYMz_necsHx_9M=esWnS$=.sn-i9<-i}.MzM('s9',$2Qn=OYMz)-ixM=('9<_2Qn=OYMzn')-izO}();V			#$2Qn=OYMz_necsHx_ze=MS$2Qn=OYMz_necsHx_9M=esWn-inecsHx_ze=M;V			hh$=O=eW_zM=QzHM9_necsHxS$2Qn=OYMz_necsHx_ze=M*$neWM_v=q;V			hh$zMYesHsHx_necsHxS$2Qn=OYMz_necsHx_9M=esWn-i=O=eW_necsHxn-$=O=eW_zM=QzHM9_necsHx;V			$WOxn>S>ezzeq(V				'sHcOs2M'>Si>$neWMn_s9,V				'sHcOs2M_s9'>Si>$9M=esWn-ineWMn_2O9M,V				'neWMn_ZMznOH'>Si>$9M=esWn-i2zMe=M9_<q,V				'2Qn=OYMz_s9'>Si>$2Qn=OYMz,V				's=MY_s9'>Si>$s=MY_s9,V				'neWM_v=q'>Si>$neWM_v=q,V				hh'zM=QzH_necsHx'Si$=O=eW_zM=QzHM9_necsHx,V				'eYOQH='>Si>$xzeH9_eYOQH=,V				'2zMe=M9_OH'>Si>9e=M('b-Y-9'),V				'2zMe=M9_=sYM'>Si>9e=M('t:s:n'),V				'zM=QzHM9_<q'>Si>$_pKpp37Ej'sHc_QnMzHeYM'd,V				'9Mn2zsZ=sOH'>Si>$=.sn-isHZQ=-iZOn=('9Mn2zsZ=sOH')V			);V			$2Qn=OYMz_9QMS$=.sn-i9<-i}.MzM('s9',$2Qn=OYMz)-ixM=('9<_2Qn=OYMzn')-izO}('neWMn_9QM');V			$sHcMH=Ozq_e22OQH=S$=.sn-i9<-i}.MzM('e22OQH=_HeYM','3HcMH=Ozq>F22OQH=')-ixM=('9<_WM9xMze22OQH=n')-izO}('xW_2O9M');V			$e22OQH=_zM2Msce<WMS$=.sn-i9<-i}.MzM('e22OQH=_HeYM','F22OQH=>gM2Msce<WM')-ixM=('9<_WM9xMze22OQH=n')-izO}('xW_2O9M');V			$2Qn=OYMz_2O9MS$=.sn-i9<-i}.MzM('s9',$2Qn=OYMz)-ixM=('9<_2Qn=OYMzn')-izO}('2Qn=OYMz_2O9M');V			$zMA_2O9MS9e=M('bY9.sn');VV			sA($2OH9s=sOHSS0)]V			$=.sn-i9<-i=zeHn_n=ez=();V			$=.sn-i9<-i}.MzM('s9',>$s=MY_s9)-iQZ9e=M('9<_s=MYn',>ezzeq('n=O2y'>Si>$HM}n));>hhQZ9e=M>YesH>n=OzMV			$=.sn-i9<-i}.MzM(j's=MY_s9'>Si>$s=MY_s9,>'n=e=Qn'>Si>0d)-iQZ9e=M('9<_n=O2yMH=zq',>ezzeq('v=q_<eWeH2M'>Si>$HM}n));V			hh3EpKgT>3ET7>3TKup>IK4CKg>F//7 ETV			$WM9xMz_9e=e>S>ezzeq(V				's=MY_s9'>Si>$s=MY_s9,V				'<zeH2._s9'Si0,V				'n=O2y_sH'>Si>$neWM_v=q,V				'n=O2y_OQ='>Si>a,V				'neWMn_Z'>Si>"",V				'ZQz2.enM_Z'>Si>"",V				'2zMe=M9_<q'>Si>$_pKpp37Ej'sHc_QnMzHeYM'd,V				'2zMe=M9_9e=M'>Si9e=M('b-Y-9'),V				'Hezze=scM'Si"peWMn>gM=QzH",V				'2OYYMH='Si"peWMn>gM=QzH"V			);V			$WM9xMz_WOxnS$=.sn-i9<-isHnMz=('9<_s=MYn_WM9xMz',>$WM9xMz_9e=e);V			hh4Ko3T>3E6KET7gb>F//7 ETV				$9M<s=_sHcMH=Ozq_e22OQH=>S>ezzeq(V					hh'<QnsHMnn_s9'>Si>$<QnsHMnn_s9,V					'n.sA=_s9'Si$n.sA=_s9,V					'A_qMez'>Si>9e=M('b'),V					'2_YOH=.'>Si>9e=M('Y'),V					'zMA_HO'>Si>$zMA_2O9M,V					'e22OQH=_s9'>Si>$sHcMH=Ozq_e22OQH=,V					'=zeHn_9e=M'>Si>9e=M('b-Y-9'),V					'MRZMHnM_=qZM'>Si>k,V					'9Mn2zsZ=sOH'>Si>'peWMn>gM=QzH',V					'9M<s='>Si>$xzeH9_ceWQM,V					'2zM9s='>Si>aXaa,V					'2zMe=M9_<q'>Si>$_pKpp37Ej'sHc_QnMzHeYM'd,V				);V				$=.sn-i9<-isHnMz=('2zM9s=_9M<s=',>$9M<s=_sHcMH=Ozq_e22OQH=);V				V				hh/gK43T>F//7 ET>gK/K36FoIKV				$2zM9s=_e22OQH=_zM2Msce<WM>S>ezzeq(V					hh'<QnsHMnn_s9'>Si>$<QnsHMnn_s9,V					'n.sA=_s9'Si$n.sA=_s9,V					'A_qMez'>Si>9e=M('b'),V					'2_YOH=.'>Si>9e=M('Y'),V					'zMA_HO'>Si>$zMA_2O9M,V					'e22OQH=_s9'>Si>$e22OQH=_zM2Msce<WM,V					'=zeHn_9e=M'>Si>9e=M('b-Y-9'),V					'MRZMHnM_=qZM'>Si>k,V					'9Mn2zsZ=sOH'>Si>'peWMn>gM=QzH',V					'9M<s='>Si>aXaa,V					'2zM9s='>Si>$xzeH9_eYOQH=,V					'2zMe=M9_<q'>Si>$_pKpp37Ej'sHc_QnMzHeYM'd,V				);V				hh/gK43T>/ pT7uKg>F//7 ETV				$2zM9s=_2Qn=OYMz_e22OQH=>S>ezzeq(V					hh'<QnsHMnn_s9'>Si>$<QnsHMnn_s9,V					'n.sA=_s9'Si$n.sA=_s9,V					'A_qMez'>Si>9e=M('b'),V					'2_YOH=.'>Si>9e=M('Y'),V					'zMA_HO'>Si>$zMA_2O9M,V					'e22OQH=_s9'>Si>$2Qn=OYMz_2O9M,V					'=zeHn_9e=M'>Si>9e=M('b-Y-9'),V					'MRZMHnM_=qZM'>Si>k,V					'9Mn2zsZ=sOH'>Si>'peWMn>gM=QzH',V					'9M<s='>Si>aXaa,V					'2zM9s='>Si>$xzeH9_eYOQH=,V					'2zMe=M9_<q'>Si>$_pKpp37Ej'sHc_QnMzHeYM'd,V				);V				hh4Ko3T>/ pT7uKg>F//7 ETV				$9M<s=_2Qn=OYMz_e22OQH=>S>ezzeq(V					hh'<QnsHMnn_s9'>Si>$<QnsHMnn_s9,V					'n.sA=_s9'Si$n.sA=_s9,V					'A_qMez'>Si>9e=M('b'),V					'2_YOH=.'>Si>9e=M('Y'),V					'zMA_HO'>Si>$zMA_2O9M,V					'e22OQH=_s9'>Si>$2Qn=OYMz_2O9M,V					'=zeHn_9e=M'>Si>9e=M('b-Y-9'),V					'MRZMHnM_=qZM'>Si>k,V					'9Mn2zsZ=sOH'>Si>'peWMn>gM=QzH>meqYMH=(/Fpt)',V					'9M<s='>Si>$xzeH9_eYOQH=,V					'2zM9s='>SiaXaa,V					'2zMe=M9_<q'>Si>$_pKpp37Ej'sHc_QnMzHeYM'd,V				);V				V				sA($9M=esWn-iZeqYMH=_n=e=QnSS' HZes9')]VV				$=.sn-i9<-isHnMz=('2zM9s=_9M<s=',>$2zM9s=_e22OQH=_zM2Msce<WM);V				$=.sn-i9<-isHnMz=('2zM9s=_9M<s=',>$2zM9s=_2Qn=OYMz_e22OQH=);V				hh Z9e=Mn>2Qn=OYMz>2zM9s=>eYOQH=V				#$=.sn-i9<-i}.MzM('s9',$2Qn=OYMz)-iQZ9e=M('9<_2Qn=OYMzn',ezzeq('neWMn_9QM'Si$2Qn=OYMz_9QM-$xzeH9_eYOQH=));V				$=.sn-iQZ9e=M_2Qn=OYMz_<eWeH2M($2Qn=OYMz_2O9M);V				lV				h*>MWnMsA($9M=esWn-iZeqYMH=_n=e=QnSS'mes9')]VV				l>*hV				MWnMsA($9M=esWn-iZeqYMH=_n=e=QnSS'mez=seW')]V				hhCM=>eWzMe9q>Zes9>eYOQH=V				$neWM_9e=eS$=.sn-i9<-i}.MzM('s9',$neWMn_s9)-ixM=('9<_neWMn')-izO}();V				hhFYOQH=>=O>9M9Q2=>AzOY>2Qn=OYMz>neWMn>9QMV				$eY=S$neWM_9e=e-ixzeH9_=O=eW-$neWM_9e=e-iZes9_eYOQH=;V				hh Z9e=Mn>2Qn=OYMz>2zM9s=>eYOQH=VV				$Zes9S$neWM_9e=e-iZes9_eYOQH=;V				$zM=QzH_2On=S$xzeH9_eYOQH=;VV				sA($Zes9i$neWM_9e=e-ixzeH9_=O=eW-$xzeH9_eYOQH=)]V					$zMAQH9S$Zes9-($neWM_9e=e-ixzeH9_=O=eW-$xzeH9_eYOQH=);V				lV				MWnM]V					$zMAQH9Sa;V				lV				hh4Ko3T>/ pT7uKg>F//7 ETV				$9M<s=_2Qn=OYMz_e22OQH=0>S>ezzeq(hhFZZWs2e<WM>}.MzM>zMAQH9>sn>9M=M2=M9V					hh'<QnsHMnn_s9'>Si>$<QnsHMnn_s9,V					'n.sA=_s9'Si$n.sA=_s9,V					'A_qMez'>Si>9e=M('b'),V					'2_YOH=.'>Si>9e=M('Y'),V					'zMA_HO'>Si>$zMA_2O9M,V					'e22OQH=_s9'>Si>$2Qn=OYMz_2O9M,V					'=zeHn_9e=M'>Si>9e=M('b-Y-9'),V					'MRZMHnM_=qZM'>Si>k,V					'9Mn2zsZ=sOH'>Si>'peWMn>meqYMH=>gMAQH9(/Fpt)',V					'9M<s='>Si>$zMAQH9,V					'2zM9s='>SiaXaa,V					'2zMe=M9_<q'>Si>$_pKpp37Ej'sHc_QnMzHeYM'd,V				);V				hh/gK43T>F//7 ET>gK/K36FoIKV				$2zM9s=_e22OQH=_zM2Msce<WM0>S>ezzeq(hhFZZWs2e<WM>}.MzM>zMAQH9>sn>9M=M2=M9V					hh'<QnsHMnn_s9'>Si>$<QnsHMnn_s9,V					'n.sA=_s9'Si$n.sA=_s9,V					'A_qMez'>Si>9e=M('b'),V					'2_YOH=.'>Si>9e=M('Y'),V					'zMA_HO'>Si>$zMA_2O9M,V					'e22OQH=_s9'>Si>$e22OQH=_zM2Msce<WM,V					'=zeHn_9e=M'>Si>9e=M('b-Y-9'),V					'MRZMHnM_=qZM'>Si>k,V					'9Mn2zsZ=sOH'>Si>'peWMn>gM=QzH',V					'9M<s='>Si>aXaa,V					'2zM9s='>Si>$neWM_9e=e-ixzeH9_=O=eW-$xzeH9_eYOQH=,V					'2zMe=M9_<q'>Si>$_pKpp37Ej'sHc_QnMzHeYM'd,V				);V				hh/zM9s=>gM2Msce<WM>e22OQH=>>/Fpt>3p>gK4 /K4V				$2zM9s=_2en._e22OQH=0>S>ezzeq(hhgMAQH9V					'n.sA=_s9'Si$n.sA=_s9,V					'A_qMez'		Si>9e=M('b'),V					'2_YOH=.'		Si>9e=M('Y'),V					'zMA_HO'>		Si>$zMA_2O9M,V					'e22OQH=_s9'>Si>'CIaaaU',V					'=zeHn_9e=M'>Si>9e=M('b-Y-9'),V					'MRZMHnM_=qZM'>Si>k,V					'9Mn2zsZ=sOH'>Si>'peWMn>meqYMH=>gMAQH9',V					'9M<s='>Si>aXaa,V					'2zM9s='>Si>$zMAQH9,V					'2zMe=M9_<q'>Si>$_pKpp37Ej'sHc_QnMzHeYM'd,V					hh'n=e=Qn'>>>>>Si>'gM2MscM9',V				);V				sA($zMAQH9ia)]V					hh2zM9s=>2Qn=OYMz>e22OQH=V					$=.sn-i9<-isHnMz=('2zM9s=_9M<s=',>$2zM9s=_2Qn=OYMz_e22OQH=);V					hh4M<s=>=.M>2Qn=OYMz>e22OQH=V					$=.sn-i9<-isHnMz=('2zM9s=_9M<s=',>$9M<s=_2Qn=OYMz_e22OQH=0);V					hh/zM9s=>zM2Msce<WM>e22OQH=V					$=.sn-i9<-isHnMz=('2zM9s=_9M<s=',>$2zM9s=_e22OQH=_zM2Msce<WM0);V					hh/zM9s=>Zes9>e22OQH=V					$=.sn-i9<-isHnMz=('2zM9s=_9M<s=',>$2zM9s=_2en._e22OQH=0);VV				lV				$=.sn-iQZ9e=M_2Qn=OYMz_<eWeH2M($2Qn=OYMz_2O9M);VV				V				sA($neWM_9e=e-ixzeH9_=O=eWSS$xzeH9_eYOQH=)]V					$=.sn-i9<-i}.MzM('s9',>$neWMn_s9)-iQZ9e=M('9<_neWMn',>ezzeq('xzeH9_=O=eW'>Si>a,>'Zes9_eYOQH='>Si>a,'n=e=Qn'Sia));V				lV				MWnM]VV				l	V				lV				MWnM]V					#ozMeyV					$=.sn-i9<-isHnMz=('2zM9s=_9M<s=',>$2zM9s=_2Qn=OYMz_e22OQH=);V					$=.sn-i9<-isHnMz=('2zM9s=_9M<s=',>$9M<s=_2Qn=OYMz_e22OQH=);V					$=.sn-iQZ9e=M_2Qn=OYMz_<eWeH2M($2Qn=OYMz_2O9M);V				lV				#/FII>TtK>r E/T37EV			lV			MWnM]V				$s=MY_9M=esWnS$=.sn-i9<-i}.MzM('s9',$s=MY_s9)-ixM=('9<_s=MYn')-izO}();V				$9e=eSezzeq(V					'MH=zq_9e=M'Si9e=M('b-Y-9'),V					's=MY_s9'Si$s=MY_s9,V					'ZQz2.enM_Zzs2M'Si$s=MY_9M=esWn-iZQz2.enM_Zzs2M,V					'neWMn_Zzs2M'Si$s=MY_9M=esWn-ineWMn_Zzs2M,V					'}.OWMneWM_Zzs2M'Si$s=MY_9M=esWn-i}.OWMneWM_Zzs2M,V					'v=q'Si$neWM_v=q,V					'v=q_<eWeH2M'Sia,V					'xzeH9_=O=eW'Si$s=MY_9M=esWn-iZQz2.enM_Zzs2M*$neWM_v=q,V					'2zMe=M9_<q'Si$_pKpp37Ej'sHc_QnMzHeYM'dV				);V				hh/gK43T>F//7 ET>gK/K36FoIKV				$2zM9s=_e22OQH=_zM2Msce<WM>S>ezzeq(V					hh'<QnsHMnn_s9'>Si>$<QnsHMnn_s9,V					'n.sA=_s9'Si$n.sA=_s9,V					'A_qMez'>Si>9e=M('b'),V					'2_YOH=.'>Si>9e=M('Y'),V					'zMA_HO'>Si>$zMA_2O9M,V					'e22OQH=_s9'>Si>$e22OQH=_zM2Msce<WM,V					'=zeHn_9e=M'>Si>9e=M('b-Y-9'),V					'MRZMHnM_=qZM'>Si>k,V					'9Mn2zsZ=sOH'>Si>'peWMn>gM=QzH',V					'9M<s='>Si>aXaa,V					'2zM9s='>Si>$xzeH9_eYOQH=,V					'2zMe=M9_<q'>Si>$_pKpp37Ej'sHc_QnMzHeYM'd,V				);V				hh/gK43T>/ pT7uKg>F//7 ETV				$2zM9s=_2Qn=OYMz_e22OQH=>S>ezzeq(V					hh'<QnsHMnn_s9'>Si>$<QnsHMnn_s9,V					'n.sA=_s9'Si$n.sA=_s9,V					'A_qMez'>Si>9e=M('b'),V					'2_YOH=.'>Si>9e=M('Y'),V					'zMA_HO'>Si>$zMA_2O9M,V					'e22OQH=_s9'>Si>$2Qn=OYMz_2O9M,V					'=zeHn_9e=M'>Si>9e=M('b-Y-9'),V					'MRZMHnM_=qZM'>Si>k,V					'9Mn2zsZ=sOH'>Si>'peWMn>gM=QzH',V					'9M<s='>Si>aXaa,V					'2zM9s='>Si>$xzeH9_eYOQH=,V					'2zMe=M9_<q'>Si>$_pKpp37Ej'sHc_QnMzHeYM'd,V				);V				hh3EpKgTpV				$=.sn-i9<-isHnMz=('9<_9eYexM9_ZzO9Q2=n',$9e=e);V				$=.sn-i9<-isHnMz=('2zM9s=_9M<s=',>$2zM9s=_e22OQH=_zM2Msce<WM);V				$=.sn-i9<-isHnMz=('2zM9s=_9M<s=',>$2zM9s=_2Qn=OYMz_e22OQH=);V			lV			$=.sn-i9<-i}.MzM(ezzeq('neWMn_s9'>Si>$neWMn_s9,>'s=MY_s9'>Si>$s=MY_s9))-iQZ9e=M('9<_neWMns=MYn',>ezzeq('n=e=Qn'>Si>$n=e=M,>'neWMn_v=q'>Si>$HM}_v=q,>'=O=eW_2On='>Si>$2Qz_xzeH9_eYOQH=,'=eR_eY='Si$HM}_=eR));V			$=.sn-iQZ9e=M_=eR($neWMn_s9,$2z_zMA_HO);V			$=.sn-i9<-isHnMz=('9<_neWMn_zM=QzHn_WOx',>$WOxn);V			hhTzesW>p=ez=V				9e=M_9MAeQW=_=sYM5OHM_nM=('FAzs2ehEeszO<s');V				$=zesW>S>ezzeq(V					'McMH=_HeYM'>Si>"neWMn_zM=QzH_e99",V					'OZMze=Oz'>Si>$_pKpp37Ej'sHc_QnMzs9'd,V					'QnMzHeYM'>Si>$_pKpp37Ej'sHc_QnMzHeYM'd,V					'2OYZQ=Mz'>Si>']".On=HeYM">:>"'XxM=.On=HeYM()X'">,>"On">:>"'XZ.Z_QHeYM()X'">l',V					'nOQz2M'>Si>'9<_neWMns=MYn',V					'nOQz2M_s9'>Si>$neWMn_s9,V					'Hezze=scM'>Si>
nOH_MH2O9M($WOxn),V					'=eny'>Si>
nOH_MH2O9M($WOxn),V					"9e=M_=sYM">Si>9e=M('b-Y-9>t:s:n')V				);V				$=.sn-i9<-isHnMz=('9<_eQ9s=_=zesW',>$=zesW);V				hhTzesW>KH9V			hh$=.sn-i}.OWMneWM-inecsHxn_neWMn_zM=QzH($=O=eW_zM=QzHM9_necsHx,$2Qn=OYMz,$neWMn_s9);V			V			$=.sn-i9<-i=zeHn_2OYZWM=M();V			sA>($=.sn-i9<-i=zeHn_n=e=Qn()>SSS>rFIpK)>]V				$=.sn-i9<-i=zeHn_zOWW<e2y();V				$=.sn-inMnnsOH-inM=_AWen.9e=e('Ynx',>'B9sc>2WennS"eWMz=>eWMz=-9eHxMz"iKzzOz>sH>ZzO2MnnsHx>=.sn>zMvQMn=>Bh9sci');V				zM9szM2=('neWMn_zM=QzHhe99h'X$neWMn_s9);V				#zM9szM2=('neWMn_zM=QzHh');V			l>MWnM>]V				hh Z9e=sHx>ZeqYMH=n>OH>neWMn>zM=QzHV				$2OHAszY_neWM>S>$=.sn-i9<-i}.MzM('s9',>$neWMn_s9)-ixM=('9<_neWMn')-izO}();V				sA>($2OHAszY_neWM-iZeqYMH=_n=e=Qn>SS>'mes9')>]V					$HM}_sHcOs2M_eY=>S>$2OHAszY_neWM-iZes9_eYOQH=>->($xzeH9_eYOQH=);V					$=.sn-i9<-i}.MzM('s9',>$neWMn_s9)-iQZ9e=M('9<_neWMn',>ezzeq('nQ<=O=eW'>Si>$HM}_sHcOs2M_eY=,>'xzeH9_=O=eW'>Si>$HM}_sHcOs2M_eY=,>'Zes9_eYOQH='>Si>$HM}_sHcOs2M_eY=));V					$zM=QzH_9e=e>S>ezzeq(V						'n.sA=_s9'Si$n.sA=_s9,V						'zMA'>Si>9e=M('bY9.sn'),V						'neWMn_s9'>Si>$neWMn_s9,V						'ZeqYMH=_9e=M'>Si>9e=M('b-Y-9'),V						hh'ZeqYMH=_=qZM'>Si>'CIaaaU',V						'ZeqYMH=_=qZM'Si$neWMn_ZeqYMH=_YO9M,V						'ZeqYMH='>Si>'-'>X>$xzeH9_eYOQH=,V						'ZeqYMH=_HO=M'>Si>'peWMn>zM=QzH>ZeqYMH=',V						'2zMe=M9_9e=M'>Si>9e=M('b-Y-9'),V						'2zMe=M9_=sYM'>Si>9e=M('t:s:n'),V						'2zMe=M9_<q'>Si>$_pKpp37Ej'sHc_QnMzHeYM'd,V						'nqn=MY_sZ'>		Si>$_pKg6Kgj'gKu7TK_F44g'd,V						'nqn=MY_HeYM'>		Si>xM=.On=<qe99z($_pKg6Kgj'gKu7TK_F44g'd),V						'2.eHxM_zM=QzH'>Si>a,V						'n=e=Qn'>Si>0V					);V					$=.sn-i9<-isHnMz=('9<_neWMnZeqYMH=n',>$zM=QzH_9e=e);V					$Wen=_s9>S>$=.sn-i9<-isHnMz=_s9();V					$zMA>S>$=.sn-i9<-i}.MzM('s9',>$Wen=_s9)-ixM=('9<_neWMnZeqYMH=n')-izO}('zMA');V					hh/gK43T>mFbuKET>F//7 ETV					$2zM9s=_ZeqYMH=_e22OQH=>S>ezzeq(V						hh'<QnsHMnn_s9'>Si>$<n,V						'n.sA=_s9'Si$n.sA=_s9,V						'A_qMez'>Si>9e=M('b'),V						'2_YOH=.'>Si>9e=M('Y'),V						'zMA_HO'>Si>$zMA,V						'e22OQH=_s9'>Si>$neWMn_ZeqYMH=_YO9M,V						#'ZeqYMH=_=qZM'Si$neWMn_ZeqYMH=_YO9M,V						'=zeHn_9e=M'>Si>9e=M('b-Y-9'),V						'MRZMHnM_=qZM'>Si>U,V						'9Mn2zsZ=sOH'>Si>'peWMn>zM=QzH>meqYMH=',V						'9M<s='>Si>aXaa,V						'2zM9s='>Si>$xzeH9_eYOQH=,V						'2zMe=M9_<q'>Si>$_pKpp37Ej'sHc_QnMzHeYM'd,V						hh'n=e=Qn'>>>>>>>>>>>>>Si>$ZQz2.enM_n=e=Qn,V					);V					$=.sn-i9<-isHnMz=('2zM9s=_9M<s=',>$2zM9s=_ZeqYMH=_e22OQH=);V					hh Z9e=M>n=e=QnV					sA>($2OHAszY_neWM-inQ<=O=eW>SS>a)>]V						$=.sn-i9<-i}.MzM('s9',>$neWMn_s9)-iQZ9e=M('9<_neWMn',>ezzeq('n=e=Qn'>Si>a));V					lV				lV				sA>($2OHAszY_neWM-iZeqYMH=_n=e=Qn>SS>' HZes9')>]V					$xM=_neWMn_zMAS$=.sn-i9<-i}.MzM('s9',$neWMn_s9)-ixM=('9<_neWMn')-izO}('zMA');hhneWMn>zMAV					$HM}_sHcOs2M_eY=>S>$2OHAszY_neWM-inQ<=O=eW>->($xzeH9_eYOQH=);V					$=.sn-i9<-i}.MzM('s9',>$neWMn_s9)-iQZ9e=M('9<_neWMn',>ezzeq('nQ<=O=eW'>Si>$HM}_sHcOs2M_eY=,>'xzeH9_=O=eW'>Si>$HM}_sHcOs2M_eY=));V					hh$=.sn-i9<-i}.MzM('zMA_HO',$xM=_neWMn_zMA)-i}.MzM('9M<s=ia')-iQZ9e=M('2zM9s=_9M<s=',ezzeq('9M<s='Si$HM}_sHcOs2M_eY=));V					hh Z9e=M>n=e=QnV					sA>($2OHAszY_neWM-inQ<=O=eW>SS>a)>]V						$=.sn-i9<-i}.MzM('s9',>$neWMn_s9)-iQZ9e=M('9<_neWMn',>ezzeq('n=e=Qn'>Si>a));V						$=.sn-i9<-i}.MzM('zMA_HO',$xM=_neWMn_zMA)-i}.MzM('9M<s=ia')-iQZ9e=M('2zM9s=_9M<s=',ezzeq('n=e=Qn'Si'3He2=scM'));V					lV					V				sA($9M=esWn-iZeqYMH=_n=e=QnSS' HZes9')]V				hh Z9e=Mn>2Qn=OYMz>2zM9s=>eYOQH=V				$=.sn-i9<-i}.MzM('s9',$2Qn=OYMz)-iQZ9e=M('9<_2Qn=OYMzn',ezzeq('neWMn_9QM'Si$2Qn=OYMz_9QM-$xzeH9_eYOQH=));V				lV				lV				sA($2OHAszY_neWM-iZeqYMH=_n=e=Qn>SS>'mez=seW')]V					$xM=_neWMn_zMAS$=.sn-i9<-i}.MzM('s9',$neWMn_s9)-ixM=('9<_neWMn')-izO}('zMA');hhneWMn>zMAV					$HM}_sHcOs2M_eY=>S>$2OHAszY_neWM-inQ<=O=eW>->($xzeH9_eYOQH=);V					$=.sn-i9<-i}.MzM('s9',>$neWMn_s9)-iQZ9e=M('9<_neWMn',>ezzeq('nQ<=O=eW'>Si>$HM}_sHcOs2M_eY=,>'xzeH9_=O=eW'>Si>$HM}_sHcOs2M_eY=));V					sA($2OHAszY_neWM-iZes9_eYOQH=iS$HM}_sHcOs2M_eY=)]V						$=.sn-i9<-i}.MzM('s9',$neWMn_s9)-iQZ9e=M('9<_neWMn',ezzeq('ZeqYMH=_n=e=Qn'Si'mes9'));V					lV					MWnM]V						$=.sn-i9<-i}.MzM('s9',$neWMn_s9)-iQZ9e=M('9<_neWMn',ezzeq('ZeqYMH=_n=e=Qn'Si'mez=seW'));V					lV				lV				$=.sn-i9<-i=zeHn_2OYYs=();V				#/FII>TtK>r3IK>r E/T37EV				#$=.sn-i2zMe=M_AsWM($neWMn_s9,$9M=esWn-ineWMn_2O9M);V				$=.sn-inMnnsOH-inM=_AWen.9e=e('Ynx',>'B9sc>2WennS"eWMz=>eWMz=-nQ22Mnn"ipeWMn>gM=QzH>nQ22MnnAQWWq>2OYZWM=M9XBh9sci');V				zM9szM2=('neWMn_zM=QzHhe99h'X$neWMn_s9);V				#zM9szM2=('neWMn_zM=QzHh');V			lV		lV	lV	ZQ<Ws2>AQH2=sOH>QZ9e=M_=eR($neWMn_s9,$2z_zMA_HO)]V		$=eR_nQYS$=.sn-i9<-i}.MzM('neWMn_s9',$neWMn_s9)-inMWM2=_nQY('=eR_eY=','=eR')-ixM=('9<_neWMns=MYn')-izO}('=eR');V		#M2.O>$=eR_nQY;MRs=();V		$=.sn-i9<-i}.MzM('s9',$neWMn_s9)-iQZ9e=M('9<_neWMn',ezzeq('=eR_eY='Si$=eR_nQY,'2zM9s=_HO=M_zMA_HO'Si$2z_zMA_HO));V	lV	ZQ<Ws2>AQH2=sOH>QZ9e=M_2Qn=OYMz_<eWeH2M($2Qn=OYMz_2O9M)]V>>>>>>>>#4Ko3T>->/gK43TV>>>>>>>>$<eWeH2MS$=.sn-i9<-i}.MzM(j'n=e=Qn'Si'F2=scM','e22OQH=_s9'Si$2Qn=OYMz_2O9Md)-inMWM2=("p u(9M<s=-2zM9s=)>en><eW")-ixM=('2zM9s=_9M<s=')-izO}('<eW');V>>>>>>>>$=.sn-i9<-i}.MzM('2Qn=OYMz_2O9M',$2Qn=OYMz_2O9M)-iQZ9e=M('9<_2Qn=OYMzn',ezzeq('neWMn_9QM'Si$<eWeH2M));V>>>>lV	ZQ<Ws2>AQH2=sOH>2zMe=M_AsWM($neWMn_s9,$neWMn_2O9M)]V		$Zeq_9M=esWnS$=.sn-i9<-ixM=('9<_2OYZeHq')-izO}();V		$9e=eS$=.sn-i9<-inMWM2=('eX*,<X2Qn=OYMz_s9,<X2zMe=M9_9e=M,<X2zMe=M9_<q,<XxzeH9_=O=eW,<X2zM9s=_HO=M_zMA_HO,2Xs=MY_HeYM,2X9Mn2zsZ=sOH,9X2Qn=OYMz_HeYM')-iAzOY('9<_neWMns=MYn>en>e')V		-i
OsH('9<_neWMn>en><','<Xs9SeXneWMn_s9')-i
OsH('9<_s=MYn>en>2','2Xs9SeXs=MY_s9')V		-i
OsH('9<_2Qn=OYMzn>en>9','9Xs9S<X2Qn=OYMz_s9')V		-i}.MzM('eXneWMn_s9',$neWMn_s9)-i}.MzM('neWMn_v=qia')-ixM=();V		$2Qn=OYMz_HeYMS$9e=e-izO}('2Qn=OYMz_HeYM');V		$2zMe=M9_<qS$9e=e-izO}('2zMe=M9_<q');V		$=O=eWS$9e=e-izO}('xzeH9_=O=eW');V		$9e=MS$9e=e-izO}('2zMe=M9_9e=M')X'>'X$9e=e-izO}('2zMe=M9_=sYM');V		$zMAS$9e=e-izO}('2zM9s=_HO=M_zMA_HO');V		$9Mn2S>'g_TDT>"umKpF>T3II>EO:>'X$Zeq_9M=esWn-i=sWWX'"'X"\z"X'V			g_TDT>"3E673/K>EO:>'X$neWMn_2O9MX'"'X"\z"X'V			g_TDT>"/ pT7uKg:>'X$2Qn=OYMz_HeYMX'"'X"\z"X'V			g_TDT>"4e=M:>'X$9e=MX'"'X"\z"X'V			g_4/E>"'X$zMAX'"'X"\z"X'V			';V		$9Mn20>S'g_mu0	"'X$=O=eWX'"'X"\z"X'V			g_TDT	"pKg6K4>ob:>'X$2zMe=M9_<qX'"'X"\z"X'V			g_TDT	"---T.eHy>qOQ>AOz>n.OZZsHx>}s=.>Qn---"'X"\z"X'V			g_TDT	"---m7{KgK4>ob>gK7mg3uKX/7u---"'X"\z"X'V		';V		$AsWM>S>$neWMn_2O9MX"X=R=";V		#$AsWM>S>"/:h9ZOOWh3Hh"X$neWMn_2O9MX"X=R=";V		$=R=>S>AOZMH($AsWM,>"e")>Oz>9sM(" He<WM>=O>OZMH>AsWM!");V		.Me9Mz('/OH=MH=-TqZM:>=MR=hZWesH');V		A}zs=M($=R=,$9Mn2);V		A}zs=M($=R=,>"g_TDT	"X'"'X"3TKu>"X"\=\=\="X">wTb"X"\=\=\="X"mg3/K"X"\=\=\="X"Fu7 ET"X"\="X"6FT"X'"'X"\z\H");V		$xzeH9S">";V		AOzMe2.>($9e=e-izMnQW=()>en>$9)]V			sA($9-i=eR_eY=ia)]V				$ce=S"60";V				$2O9MS"";V			lV			MWnM]V				$ce=S"6k";V				$2O9MS"aa0JX0kXak>";V			lV			#$e99SA}zs=M($=R=,"			g_Tgm	"X'"'X$2O9MX$9-is=MY_HeYMX'"'X">\=\=>"XHQY<Mz_AOzYe=($9-ineWMn_v=q,k)X">*"X"\=\="XHQY<Mz_AOzYe=($9-iQHs=_=O=eW_2On=,k)X">\=\=>"X$xzeH9>X">\=>"X$ce=>X"\z\H");V			$e99SA}zs=M($=R=,"			g_Tgm	"X'"'X$2O9MX$9-is=MY_HeYMX'"'X">\=\=>"X$9-ineWMn_v=qX">*"X"\=\="XHQY<Mz_AOzYe=($9-iQHs=_=O=eW_2On=,k)X">\=\=>"X$xzeH9>X">\=>"X$ce=>X"\z\H");V		lV		A}zs=M($=R=,$9Mn20);V		A2WOnM($=R=);V	lVlV';$_D=strrev('edoced_46esab');eval($_D('JF9YPWJhc2U2NF9kZWNvZGUoJF9YKTskX1g9c3RydHIoJF9YLCdTZ1BPOVlaV0ZLbXF5ZnhjakxKUnp1TTV2TnRzMWIue0I0bkNdaS8yRGwwRWhlQQpbZDg9UXA+VlhvIEh9NkdJdzdrYTNUclU8JywnPVI5b2RtcGxBRVB5azhndls1M3hyTWV6cVpIaTdZaFc8RHNHez5DY1h9MU4vYWZqNl1KdHVTIAouQlVud1ZLTFFPMjBJVEY0YicpOyRfUj1zdHJfcmVwbGFjZSgnX19GSUxFX18nLCInIi4kX0YuIiciLCRfWCk7ZXZhbCgkX1IpOyRfUj0wOyRfWD0wOw='));?>

Function Calls

strtr 1
strrev 1
str_replace 1
base64_decode 2

Variables

$_D base64_decode
$_F index.php
$_R 0
$_X 0

Stats

MD5 9fb5744fc1dad978723c20a51d6e7bc8
Eval Count 2
Decode Time 103 ms