2020-04-15 23:08:09 +00:00
|
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
|
|
2020-04-17 15:26:12 +00:00
|
|
|
|
use App\Models\AgentPlus;
|
2020-04-15 23:08:09 +00:00
|
|
|
|
use App\Models\CodeGenerer;
|
|
|
|
|
use App\Models\ConfigWallet;
|
|
|
|
|
use App\Models\NetworksAgent;
|
|
|
|
|
use App\Models\Wallet;
|
|
|
|
|
use App\Models\WalletAgent;
|
|
|
|
|
use App\Models\WalletTransaction;
|
|
|
|
|
use App\Traits\ApiResponser;
|
|
|
|
|
use Illuminate\Http\Request;
|
|
|
|
|
use Illuminate\Http\Response;
|
|
|
|
|
|
|
|
|
|
class TransactionController extends Controller
|
|
|
|
|
{
|
|
|
|
|
use ApiResponser;
|
|
|
|
|
/**
|
|
|
|
|
* Create a new controller instance.
|
|
|
|
|
*
|
|
|
|
|
* @return void
|
|
|
|
|
*/
|
|
|
|
|
public function __construct()
|
|
|
|
|
{
|
|
|
|
|
//
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function add(Request $request)
|
|
|
|
|
{
|
|
|
|
|
$transaction = new WalletTransaction ;
|
|
|
|
|
$this->validate($request,$transaction->rules());
|
|
|
|
|
|
|
|
|
|
$walletAgent = Wallet::findOrFail($request->get('id_wallet'));
|
|
|
|
|
$network_agent = NetworksAgent::findOrFail( $walletAgent->id_networkAgent);
|
|
|
|
|
// Configuratrion du wallet
|
|
|
|
|
$config = ConfigWallet::where('id_network',$network_agent->network_id)->firstOrFail();
|
|
|
|
|
|
|
|
|
|
// Recuperation des wallets hyperviseur et superviseur
|
|
|
|
|
$codeGenerer = CodeGenerer::findOrFail($network_agent->codeGenerer_id);
|
2020-04-17 15:26:12 +00:00
|
|
|
|
$superviseur = AgentPlus::where('code_membre',$codeGenerer->code_parrain)->firstOrFail();
|
|
|
|
|
$hyperviseur = AgentPlus::where('code_membre',$superviseur->code_parrain)->firstOrFail();
|
2020-04-15 23:08:09 +00:00
|
|
|
|
|
|
|
|
|
$wallet_agent_sup = WalletAgent::where('agent_id', $superviseur->id)->firstOrFail();
|
|
|
|
|
$wallet_agent_hyp = WalletAgent::where('agent_id', $hyperviseur->id)->firstOrFail();
|
2020-04-17 15:26:12 +00:00
|
|
|
|
$walletSuperviseur = Wallet::findOrFail($wallet_agent_sup->wallet_id);
|
|
|
|
|
$walletHyperviseur = Wallet::findOrFail($wallet_agent_hyp->wallet_id);
|
2020-04-15 23:08:09 +00:00
|
|
|
|
|
2020-04-17 15:26:12 +00:00
|
|
|
|
$data = $request->all();
|
2020-04-24 10:37:13 +00:00
|
|
|
|
$data['expiration_date'] = \DateTime::createFromFormat('m/y',$request->expiration_date);
|
2020-04-17 15:26:12 +00:00
|
|
|
|
$transaction->fill($data);
|
2020-04-15 23:08:09 +00:00
|
|
|
|
|
|
|
|
|
$client = new \GuzzleHttp\Client();
|
|
|
|
|
// Procedure de depot d'argent
|
|
|
|
|
if($transaction->type == 'credit')
|
|
|
|
|
{
|
2020-04-17 15:26:12 +00:00
|
|
|
|
$frais = $transaction->montant * $config->taux_com_client_depot / 100 ;
|
|
|
|
|
|
2020-04-21 14:07:57 +00:00
|
|
|
|
// Verification faites au niveau du frontend
|
|
|
|
|
// if($walletAgent->balance_princ >= ($transaction->montant + $frais + $config->frais_min_banque_depot)){
|
2020-04-17 15:26:12 +00:00
|
|
|
|
|
|
|
|
|
$response = $client->post('https://ilink-app.com/mobilebackendtest/interacted/MembersAction.php');
|
|
|
|
|
$code = $response->getStatusCode();
|
|
|
|
|
if($code == 200){
|
|
|
|
|
//Requete vers la banque
|
|
|
|
|
// 1 ---> Emmètre via API sécurisé SSL une requête de débit de notre
|
|
|
|
|
//compte marchand la valeur égale au $montantDepot( montant de la
|
|
|
|
|
//transaction – la frais calculé en % - frais minimum fixe du
|
|
|
|
|
//dépôt client) et créditer sa carte visa de cette valeur
|
2020-04-29 15:24:10 +00:00
|
|
|
|
$montantDepot = $transaction->montant - $frais - $config->frais_min_banque_depot;
|
2020-04-17 15:26:12 +00:00
|
|
|
|
|
2020-05-12 11:27:02 +00:00
|
|
|
|
$banqueCommission = floatval(($frais + $config->frais_min_banque_depot) * $config->part_banque_depot / 100);
|
2020-04-21 14:07:57 +00:00
|
|
|
|
$transaction->commission_banque = $banqueCommission;
|
2020-04-17 15:26:12 +00:00
|
|
|
|
// 2---> Emmètre via API sécurisé SSL une requête de débit de notre
|
|
|
|
|
//compte marchand du (Part de la banque partenaire en %
|
|
|
|
|
//pour le dépôtqui s’applique sur les frais minimum) et créditer
|
|
|
|
|
//le compte des opérations défini avec notre banque
|
|
|
|
|
//partenaire
|
|
|
|
|
|
2020-05-07 10:46:16 +00:00
|
|
|
|
$walletAgent->balance_princ -= $transaction->montant;
|
2020-04-17 15:26:12 +00:00
|
|
|
|
|
2020-05-12 11:27:02 +00:00
|
|
|
|
$agentCommission = floatval(($frais + $config->frais_min_banque_depot) * $config->taux_com_ag_depot / 100);
|
|
|
|
|
$superviseurCommission = floatval(($frais + $config->frais_min_banque_depot) * $config->taux_com_sup_depot / 100);
|
2020-04-17 15:26:12 +00:00
|
|
|
|
$hyperviseurCommission = $frais + $config->frais_min_banque_depot - $superviseurCommission - $agentCommission - $banqueCommission;
|
|
|
|
|
|
|
|
|
|
$walletAgent->balance_com += $agentCommission;
|
|
|
|
|
$walletSuperviseur->balance_com += $superviseurCommission;
|
|
|
|
|
$walletHyperviseur->balance_com += $hyperviseurCommission;
|
2020-04-24 10:37:13 +00:00
|
|
|
|
|
|
|
|
|
$transaction->id_wallet_sup = $walletSuperviseur->id;
|
|
|
|
|
$transaction->commission_sup = $superviseurCommission;
|
|
|
|
|
$transaction->id_wallet_hyp = $walletHyperviseur->id;
|
|
|
|
|
$transaction->commission_hyp = $hyperviseurCommission;
|
|
|
|
|
$transaction->commission_ag = $agentCommission;
|
2020-04-17 15:26:12 +00:00
|
|
|
|
}
|
|
|
|
|
|
2020-04-21 14:07:57 +00:00
|
|
|
|
// }else{
|
|
|
|
|
// return $this->errorResponse('Solde agent inferieur au montant de depot + frais + frais minimun de depot de la banque', Response::HTTP_BAD_REQUEST);
|
|
|
|
|
// }
|
2020-04-15 23:08:09 +00:00
|
|
|
|
|
|
|
|
|
// Procedure de retrait d'argent
|
|
|
|
|
}elseif ($transaction->type == 'debit')
|
|
|
|
|
{
|
2020-05-12 18:05:56 +00:00
|
|
|
|
// 12-05-20: Modif de Mr Manga : Le montant de la transaction c'est le montant de retrait sans les frais
|
2020-05-22 17:11:23 +00:00
|
|
|
|
//Bloquer le retrait
|
2020-05-22 17:08:13 +00:00
|
|
|
|
return $this->errorResponse(trans('errors.service_unavailable'),Response::HTTP_SERVICE_UNAVAILABLE);
|
2020-05-22 16:59:02 +00:00
|
|
|
|
// $frais = $transaction->montant * $config->taux_com_client_retrait / 100;
|
|
|
|
|
//
|
|
|
|
|
// $response = $client->post('https://ilink-app.com/mobilebackendtest/interacted/MembersAction.php');
|
|
|
|
|
// $code = $response->getStatusCode();
|
|
|
|
|
// if($code == 200) {
|
|
|
|
|
// //Requete vers la banque
|
|
|
|
|
// // 1 ---> Emmètre via API sécurisé SSL une requête de retrait du
|
|
|
|
|
// //(montant de la transaction + frais de transaction) pour débiter
|
|
|
|
|
// //sa carte et créditer notre compte marchand
|
|
|
|
|
// $montantRetrait = $transaction->montant + $frais;
|
|
|
|
|
//
|
|
|
|
|
// $banqueCommission = floatval($transaction->montant * $config->part_banque_retrait / 100);
|
|
|
|
|
// $transaction->commission_banque = $banqueCommission;
|
|
|
|
|
// // 2---> Emmètre via API sécurisé SSL une requête de débit de notre
|
|
|
|
|
// //compte marchand du (montant de la transaction multiplié
|
|
|
|
|
// //par la Part de la banque partenaire en % ) et créditer le
|
|
|
|
|
// //compte des opérations défini avec notre banque partenaire
|
|
|
|
|
//
|
|
|
|
|
// $walletAgent->balance_princ += $transaction->montant;
|
|
|
|
|
//
|
|
|
|
|
// $agentCommission=floatval($transaction->montant*$config->taux_com_ag_retrait / 100);
|
|
|
|
|
// $superviseurCommission=floatval($transaction->montant*$config->taux_com_sup_retrait / 100);
|
|
|
|
|
// $hyperviseurCommission = $frais - $superviseurCommission - $agentCommission - $banqueCommission;
|
|
|
|
|
//
|
|
|
|
|
//// dd(array($hyperviseurCommission ,$superviseurCommission));
|
|
|
|
|
// $walletAgent->balance_com += $agentCommission;
|
|
|
|
|
// $walletSuperviseur->balance_com += $superviseurCommission;
|
|
|
|
|
// $walletHyperviseur->balance_com += $hyperviseurCommission;
|
|
|
|
|
//
|
|
|
|
|
// $transaction->id_wallet_sup = $walletSuperviseur->id;
|
|
|
|
|
// $transaction->commission_sup = $superviseurCommission;
|
|
|
|
|
// $transaction->id_wallet_hyp = $walletHyperviseur->id;
|
|
|
|
|
// $transaction->commission_hyp = $hyperviseurCommission;
|
|
|
|
|
// $transaction->commission_ag = $agentCommission;
|
|
|
|
|
// }
|
2020-04-17 15:26:12 +00:00
|
|
|
|
|
2020-04-15 23:08:09 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$transaction->date = new \DateTime();
|
|
|
|
|
$transaction->statut = 1;
|
|
|
|
|
$walletAgent->save();
|
|
|
|
|
$walletSuperviseur->save();
|
|
|
|
|
$walletHyperviseur->save();
|
|
|
|
|
$transaction->save();
|
2020-04-21 14:07:57 +00:00
|
|
|
|
return $this->successResponse($walletAgent);
|
2020-04-15 23:08:09 +00:00
|
|
|
|
}
|
2020-04-25 11:41:40 +00:00
|
|
|
|
|
|
|
|
|
public function lastTransactions($id_wallet){
|
|
|
|
|
$transactions = WalletTransaction::where('id_wallet',$id_wallet)->orderBy('date','desc')->limit(10)
|
|
|
|
|
->get(['id', 'montant' ,'numCarte' ,'commission_ag', 'type' ,'date']);
|
|
|
|
|
return $this->successResponse($transactions);
|
|
|
|
|
}
|
2020-05-02 14:43:28 +00:00
|
|
|
|
|
|
|
|
|
public function calculateCommission(Request $request)
|
|
|
|
|
{
|
|
|
|
|
$rules = [
|
|
|
|
|
'id_wallet' => 'required|integer|min:1',
|
|
|
|
|
'montant'=> 'required|numeric|min:0|not_in:0',
|
|
|
|
|
'type' =>'required|in:credit,debit',
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
$this->validate($request,$rules);
|
|
|
|
|
|
|
|
|
|
$walletAgent = Wallet::findOrFail($request->get('id_wallet'));
|
|
|
|
|
$network_agent = NetworksAgent::findOrFail( $walletAgent->id_networkAgent);
|
|
|
|
|
// Configuratrion du wallet
|
|
|
|
|
$config = ConfigWallet::where('id_network',$network_agent->network_id)->firstOrFail();
|
|
|
|
|
$commission = null;
|
|
|
|
|
if($request->type == 'credit') {
|
2020-05-12 18:09:28 +00:00
|
|
|
|
//Depot
|
2020-05-02 14:43:28 +00:00
|
|
|
|
$commission = ( $request->montant * $config->taux_com_client_depot / 100 ) + $config->frais_min_banque_depot;
|
2020-05-12 18:09:28 +00:00
|
|
|
|
$data['montant_calcule'] = $request->montant - $commission;
|
2020-05-02 14:43:28 +00:00
|
|
|
|
}elseif ($request->type == 'debit'){
|
2020-05-12 18:09:28 +00:00
|
|
|
|
// Retrait
|
2020-05-02 14:43:28 +00:00
|
|
|
|
$commission = $request->montant * $config->taux_com_client_retrait / 100 ;
|
2020-05-12 18:09:28 +00:00
|
|
|
|
$data['montant_calcule'] = $request->montant + $commission;
|
2020-05-02 14:43:28 +00:00
|
|
|
|
}
|
2020-05-12 18:09:28 +00:00
|
|
|
|
|
2020-05-02 14:43:28 +00:00
|
|
|
|
$data['commission'] = $commission ;
|
|
|
|
|
return $this->successResponse($data);
|
|
|
|
|
}
|
2020-04-15 23:08:09 +00:00
|
|
|
|
}
|