Flutterwave calling from back office

This commit is contained in:
ChiefSoft works
2022-05-09 05:42:10 +00:00
parent 5f40e637ea
commit 6804ebc879
3 changed files with 140 additions and 31 deletions
+41 -24
View File
@@ -92,16 +92,17 @@ class Bkotransaction extends Bko_Controller {
switch ($proc) {
case 'PROCESS':
$mysql = "SELECT m.id,mp.confirmation, m.added,me.firstname||' '||me.lastname||'<br>'||me.email AS Sender,"
. "sr.firstname||' '||sr.lastname||'<br>ACC:'||sr.account_no||'-'||be.name AS recipient, m.initiatingamount*0.01 AS Amount,m.fee*0.01 AS Fee, "
. "'<input type=submit id=\"accs'||m.id||'\" onclick=\"return smoneyDetail('||m.id||')\" name=\"manage\" class=\"btn btn-info btn-sm\" value=\"Detail\">' As Detail, "
. "'<input type=submit id=\"acc'||m.id||'\" onclick=\"return smoneyProcess('||m.id||')\" name=\"manage\" class=\"btn btn-info btn-sm\" value=\"Process\">' As Process "
. "FROM money_transfer m "
. "LEFT JOIN members me ON me.id=m.member_id "
. "LEFT JOIN sendmoney_recipient sr ON sr.id=m.recipientid "
. "LEFT JOIN members_payments mp ON mp.what_sendmoney = m.id "
. "LEFT JOIN bank_entity_codes be ON be.code=sr.bank_code WHERE m.id=" . $sendmoney_id;
$mysql = "SELECT m.id,mp.confirmation, m.added,me.firstname||' '||me.lastname||'<br>'||me.email AS Sender,"
. "sr.firstname||' '||sr.lastname||'<br>ACC:'||sr.account_no||'-'||be.name AS recipient, m.initiatingamount*0.01 AS Amount,m.fee*0.01 AS Fee, "
. "'<input type=submit id=\"accs'||m.id||'\" onclick=\"return smoneyDetail('||m.id||')\" name=\"manage\" class=\"btn btn-info btn-sm\" value=\"Detail\">' As Detail, "
. "'<input type=submit id=\"acc'||m.id||'\" onclick=\"return smoneyProcess('||m.id||')\" name=\"manage\" class=\"btn btn-info btn-sm\" value=\"Process\">' As Process "
. "FROM money_transfer m "
. "LEFT JOIN members me ON me.id=m.member_id "
. "LEFT JOIN sendmoney_recipient sr ON sr.id=m.recipientid "
. "LEFT JOIN members_payments mp ON mp.what_sendmoney = m.id "
. "LEFT JOIN bank_entity_codes be ON be.code=sr.bank_code WHERE m.id=" . $sendmoney_id;
$query = $this->db->query($mysql);
$row = $query->row_array();
@@ -116,23 +117,39 @@ class Bkotransaction extends Bko_Controller {
break;
case 'TRANSMIT':
/*
$mysql = "SELECT m.id,mp.confirmation, m.added,"
. "'Transfer from '||me.firstname||' '||me.lastname||'<br>'||me.email AS narration,"
. "sr.firstname,sr.lastname,sr.account_no,be.code AS bank_code, m.initiatingamount*0.01 AS Amount,m.fee*0.01 AS Fee "
. "FROM money_transfer m "
. "LEFT JOIN members me ON me.id=m.member_id "
. "LEFT JOIN sendmoney_recipient sr ON sr.id=m.recipientid "
. "LEFT JOIN members_payments mp ON mp.what_sendmoney = m.id "
. "LEFT JOIN bank_entity_codes be ON be.code=sr.bank_code WHERE m.id=" . $sendmoney_id;
$query = $this->db->query($mysql);
$row = $query->row_array();
/*
This is te place to call the Fluuerwve API for testing
*/
$data["trans_code"] = $this->input->get('tcode');
$data["trans_tref"] = $this->input->get('tref');
$data["sendmoney_id"] = $sendmoney_id;
$data['action'] = WRENCHBOARD_SMONEY_BKOPROC;
$data['action_mode'] = SMONEY_PROCC_INTERSWITCH;
$this->load->model('backend_model');
$out = array();
$this->backend_model->wrenchboard_api($data, $out); //THis calls he backend - dont worry about it for now.
echo $out['status'];
$this->load->helper('FlutterWave');
$out = flutterwave_api($row);
if (is_array($out) && $out['result'] > 0) {
$data["trans_code"] = $this->input->get('tcode');
$data["trans_tref"] = $this->input->get('tref');
$data["sendmoney_id"] = $sendmoney_id;
$data['action'] = WRENCHBOARD_SMONEY_BKOPROC;
$data['action_mode'] = SMONEY_PROCC_INTERSWITCH;
$this->load->model('backend_model');
$out = array();
$this->backend_model->wrenchboard_api($data, $out); //THis calls he backend - dont worry about it for now.
echo $out['status'];
} else {
if (is_array($out) && array_key_exists('status',$out)) {
echo $out['status'];
} else {
var_dump($out); // Unexpected failure
}
}
break;
}
}
@@ -0,0 +1,92 @@
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
if ( ! function_exists('flutterwave_api'))
{
function flutterwave_api($in)
{
$out = array();
$out['status'] = 'Unhandled error';
$out['result'] = -1;
$ch = curl_init();
/* Example :
OrderedMap {
"account_bank": "044",
"account_number": "0690000040",
"amount": 5500,
"narration": "Akhlm Pstmn Trnsfr xx007",
"currency": "NGN",
"reference": "akhlm-pstmnpyt-rfxx007_PMCKDU_1",
"debit_currency": "NGN"
}
*/
$reference = str_replace('.','-',$in['id'].'.'.microtime());
$out['my_reference'] = $reference;
// Setup request to send json via POST.
$payload = json_encode(array(
"account_bank" => $in['bank_code'],
"account_number" => $in['account_no'],
"amount" => $in['amount'],
"narration" => $in['narration'],
"currency" => "NGN",
"reference" => $reference,
"debit_currency" => "NGN"
));
curl_setopt($ch, CURLOPT_URL,"http://10.20.30.32:9086/create");
// curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $payload);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type:application/json'));
// Receive server response ...
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$result = curl_exec($ch);
curl_close ($ch);
$data = json_decode($result, true);
// Further processing ...
if ($data!=null && is_array($data)) {
if (array_key_exists('status',$data) && $data['status']=='success') {
$out['result'] = 0; // OK
$out['status'] = 'Transfer successful';
if (array_key_exists('message',$data) && $data['message']!='') {
$out['status'].= ': '.$data['message'];
}
} else {
$out['result'] = -3;
$out['status'] = 'failure';
if (array_key_exists('status',$data) && $data['status']!='') {
$out['status'] = $data['status'];
}
if (array_key_exists('message',$data) && $data['message']!='') {
$out['status'].= ': '.$data['message'];
}
if (array_key_exists('details',$data) && $data['details']!='') {
$out['status'].= ': '.$data['details'];
}
if (array_key_exists('data',$data) && is_array($data['data'])
&& array_key_exists('message',$data['data']) && $data['data']['message']!='') {
$out['status'].= ': '.$data['data']['message'];
}
if (array_key_exists('data',$data) && is_array($data['data'])
&& array_key_exists('data',$data['data']) && is_array($data['data']['data'])
&& array_key_exists('complete_message',$data['data']['data']) && $data['data']['data']['complete_message']!='') {
$out['status'].= ': '.$data['data']['data']['complete_message'];
}
}
} else {
$out['result'] = -2;
$out['stauts'] = 'Invalid service response: ' . $result;
}
// Cannot POST /api/create
$out['response'] = $result;
return $out;
}
}
@@ -106,15 +106,15 @@ return false;
return false;
}
function smoneyProcessComplete(link_id) {
function smoneyProcessComplete(link_id) {
if(confirm("Are you sure you want to transmit this transaction ?")) {
// do something
} else {
return false;
}
if(confirm("Are you sure you want to transmit this transaction ?")) {
// do something
} else {
return false;
}
var f = document.getElementById('sendmoneyProcessPage'+link_id);
var f = document.getElementById('sendmoneyProcessPage'+link_id);
$('#btump'+link_id).html('Processing...');
$('#acmp'+link_id).prop('disabled', true);