Compare commits

...

4 Commits

Author SHA1 Message Date
6157902274 test 2025-10-27 21:36:49 +05:00
8f1e941d09 Card Requisite 2025-10-27 21:10:13 +05:00
acadd8c9a4 sms use bank 2025-10-27 21:02:26 +05:00
79c4bb0c24 wip 2025-10-27 20:43:34 +05:00
9 changed files with 278 additions and 28 deletions

View File

@@ -7,12 +7,14 @@ use App\Filament\Clusters\Cards\CardsCluster;
use App\Modules\AppHelpers\Repositories\DateHelper;
use App\Modules\Card\Models\Card;
use App\Modules\CardBalance\Repositories\CardBalanceRepository;
use App\Modules\CardTransaction\Repositories\CardTransactionRepository;
use BackedEnum;
use Filament\Actions\Action;
use Filament\Actions\BulkActionGroup;
use Filament\Actions\DeleteAction;
use Filament\Actions\DeleteBulkAction;
use Filament\Actions\EditAction;
use Filament\Forms\Components\DatePicker;
use Filament\Forms\Components\Hidden;
use Filament\Forms\Components\Select;
use Filament\Forms\Components\TextInput;
@@ -127,6 +129,26 @@ class CardResource extends Resource
->modalContent(fn (Card $record): View => CardBalanceRepository::make()->showCardBalance($record))
->modalFooterActions([]),
Action::make('card_transaction')
->label(__('Card transaction'))
->icon('heroicon-m-arrows-right-left')
->requiresConfirmation()
->modalIcon('heroicon-m-arrows-right-left')
->schema([
DatePicker::make('start_date')
->label(__('Start date'))
->native(false)
->required()
->beforeOrEqual('today'),
DatePicker::make('end_date')
->label(__('End date'))
->native(false)
->required()
->beforeOrEqual('today'),
])
->action(fn (array $data, Card $record) => CardTransactionRepository::make()->downloadCardTransaction($data, $record)),
EditAction::make()
->label(''),
DeleteAction::make()

View File

@@ -24,11 +24,9 @@ class CardBalanceRepository
card_expire_date: $record->month.'/'.substr($record->year, 2),
);
if ($data->errCode != 0) {
return view('module.card-balance::client-not-found', compact('data'));
}
return view('module.card-balance::card-balance-modal', compact('data'));
return $data->errCode != 0
? view('module.card-balance::client-not-found', compact('data'))
: view('module.card-balance::card-balance-modal', compact('data'));
}
/**
@@ -69,7 +67,7 @@ class CardBalanceRepository
curl_close($curl);
/** @var object */
$safeResponse = Str::isJson($response)
$safeResponse = Str::isJson($response)
? json_decode($response)
: emptyClass(errCode: 1, message: 'Connection issue to VP');

View File

@@ -0,0 +1,64 @@
<?php
namespace App\Modules\CardRequisite;
use App\Modules\Makeable;
use App\Modules\ModuleContract;
class CardRequisiteModule implements ModuleContract
{
use Makeable;
/**
* Module is enabled
*/
protected bool $enabled = true;
/**
* Check if is module enabled
*/
public function isEnabled(): bool
{
return $this->enabled;
}
/**
* Disable module
*/
public function disable(): void
{
$this->enabled = false;
}
/**
* Enable module
*/
public function enable(): void
{
$this->enabled = true;
}
/**
* Check if module has a filament resource
*/
public function hasFilamentResource(): bool
{
return false;
}
/**
* Get module composer requirements
*/
public function getComposerRequirements(): array
{
return [];
}
/**
* Get module composer suggestions
*/
public function getComposerSuggestions(): array
{
return [];
}
}

View File

@@ -0,0 +1,10 @@
<?php
namespace App\Modules\CardRequisite\Repositories;
use App\Modules\Makeable;
class CardRequisiteRepository
{
use Makeable;
}

View File

@@ -0,0 +1,64 @@
<?php
namespace App\Modules\CardTransaction;
use App\Modules\Makeable;
use App\Modules\ModuleContract;
class CardTransactionModule implements ModuleContract
{
use Makeable;
/**
* Module is enabled
*/
protected bool $enabled = true;
/**
* Check if is module enabled
*/
public function isEnabled(): bool
{
return $this->enabled;
}
/**
* Disable module
*/
public function disable(): void
{
$this->enabled = false;
}
/**
* Enable module
*/
public function enable(): void
{
$this->enabled = true;
}
/**
* Check if module has a filament resource
*/
public function hasFilamentResource(): bool
{
return false;
}
/**
* Get module composer requirements
*/
public function getComposerRequirements(): array
{
return [];
}
/**
* Get module composer suggestions
*/
public function getComposerSuggestions(): array
{
return [];
}
}

View File

@@ -0,0 +1,87 @@
<?php
namespace App\Modules\CardTransaction\Repositories;
use App\Modules\Card\Models\Card;
use App\Modules\Makeable;
use Illuminate\Support\Carbon;
use Illuminate\Support\Str;
class CardTransactionRepository
{
use Makeable;
/**
* Download card transaction
*
* @param array{start_date: string, end_date: string} $data
*/
public function downloadCardTransaction(array $data, Card $record)
{
$start_date = Carbon::create($data['start_date']);
$end_date = Carbon::create($data['end_date']);
$response = $this->fetchApi(
passport_serie: user()->getOption('passport_serie') ?? 'I',
passport_id: user()->getOption('passport_id') ?? '909090',
card_number_masked: Str::mask($record->number, '*', 6, 6),
card_expire_date: $record->month.'/'.substr($record->year, 2),
start_date: $start_date->format('d.m.Y'),
end_date: $end_date->format('d.m.Y'),
);
info([
'response' => $response,
'type' => gettype($response),
]);
// /** @var ResponseTypes\AzatApiClientInfoAllResponse */
// $data = Str::isJson($response)
// ? json_decode($response)
// : emptyClass(errCode: 1, message: 'Connection issue to VP');
// if ($data->errCode != 0) {
// return ActionResponse::danger($data->message);
// }
// $url = $this->doFiles($model, $data);
}
/**
* Fetch from internal API
*
*
* @return string
*/
public function fetchApi(
string $passport_serie,
string $passport_id,
string $card_number_masked,
string $card_expire_date,
string $start_date,
string $end_date
) {
$curl = curl_init();
curl_setopt_array($curl, [
CURLOPT_URL => 'http://10.3.158.102:9999/api/clientinfo/all',
CURLOPT_RETURNTRANSFER => true,
CURLOPT_ENCODING => '',
CURLOPT_MAXREDIRS => 10,
CURLOPT_TIMEOUT => 0,
CURLOPT_FOLLOWLOCATION => true,
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
CURLOPT_CUSTOMREQUEST => 'POST',
CURLOPT_POSTFIELDS => sprintf('{ "idSeria": "%s", "idNo": "%s", "clientType": "recipient", "cardMaskNumber": "%s", "expDate": "%s", "fromDate" : "%s", "toDate" : "%s" }', $passport_serie, $passport_id, $card_number_masked, $card_expire_date, $start_date, $end_date),
CURLOPT_HTTPHEADER => [
'Authorization: Basic dGJ1c2VyOlFBWndzeDEyMw==',
'Content-Type: application/json',
],
]);
$response = curl_exec($curl);
curl_close($curl);
return $response;
}
}

View File

@@ -3,8 +3,8 @@
namespace App\Modules\Sms\Repositories;
use Exception;
use Illuminate\Http\Client\PendingRequest;
use Illuminate\Support\Facades\Http;
use GuzzleHttp\Client;
use GuzzleHttp\Psr7\Request as GuzzleRequest;
use Illuminate\Support\Facades\Log;
class SmsRepository
@@ -18,23 +18,31 @@ class SmsRepository
return true;
}
$response = Http::retry(
times: 3,
sleepMilliseconds: 50,
throw: false,
when: function (Exception $exception, PendingRequest $request) {
Log::error('Exception: ', [
'message' => $exception->getMessage(),
'line' => $exception->getLine(),
]);
$client = new Client;
$headers = [
'Content-Type' => 'application/json;charset=utf-8;',
'Charset' => 'UTF-8',
];
$body = 'JSON={
"SendRequest": {
"TerminalID": "Online_PANEL",
"Version": "1",
"Lang": "EN",
"MobilePhone": "993'.$phone.'",
"Text": "'.$message.'"
}
}';
// 10.3.158.103
$request = new GuzzleRequest('POST', 'http://10.3.158.28:8080/kpsmsroute/online.request', $headers, $body);
return true;
})
->post(config()->string('module.sms.url'), [
'phone' => '+993'.$phone,
'code' => $message,
]);
try {
$res = $client->sendAsync($request)->wait();
return $response->body();
return $res->getBody();
} catch (Exception $e) {
Log::error($e);
return null;
}
}
}

View File

@@ -3,9 +3,6 @@
namespace App\Providers;
use AbdulmajeedJamaan\FilamentTranslatableTabs\TranslatableTabs;
use Filament\Notifications\Livewire\Notifications;
use Filament\Support\Enums\Alignment;
use Filament\Support\Enums\VerticalAlignment;
use Illuminate\Contracts\Foundation\Application;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Support\ServiceProvider;

View File

@@ -2,7 +2,7 @@
return [
'confirmation' => 'Muny etmek isleýärsiňizmi?',
'confirmation' => 'Dowam etmek üçin Tassykla düwmesine basyň',
'actions' => [