server test version

This commit is contained in:
2025-01-03 02:11:09 +03:00
parent 093b04c2c9
commit 74efe9e01e
101 changed files with 2871 additions and 117 deletions

View File

@ -0,0 +1,67 @@
<?php
namespace kernel\app_modules\card;
use kernel\helpers\Debug;
use kernel\Module;
use kernel\modules\menu\service\MenuService;
use kernel\services\ConsoleService;
use kernel\services\MigrationService;
class CardModule extends Module
{
public MenuService $menuService;
public ConsoleService $consoleService;
public MigrationService $migrationService;
public function __construct()
{
$this->menuService = new MenuService();
$this->consoleService = new ConsoleService();
$this->migrationService = new MigrationService();
}
/**
* @throws \Exception
*/
public function init(): void
{
$this->migrationService->runAtPath("{KERNEL_APP_MODULES}/card/migrations");
$this->consoleService->runComposerRequire("dragon-code/card-number");
$this->consoleService->runComposerRequire("endroid/qr-code");
$this->menuService->createItem([
"label" => "Card",
"url" => "/admin/card",
"slug" => "card",
]);
$this->menuService->createItem([
"label" => "Список карт",
"url" => "/admin/card",
"slug" => "card_list",
"parent_slug" => "card"
]);
$this->menuService->createItem([
"label" => "Шаблоны карт",
"url" => "/admin/card_template",
"slug" => "card_template",
"parent_slug" => "card"
]);
}
/**
* @throws \Exception
*/
public function deactivate(): void
{
$this->menuService->removeItemBySlug("card");
$this->menuService->removeItemBySlug("card_list");
$this->menuService->removeItemBySlug("card_template");
$this->migrationService->rollbackAtPath("{KERNEL_APP_MODULES}/card/migrations");
$this->consoleService->runComposerRemove("dragon-code/card-number");
$this->consoleService->runComposerRemove("endroid/qr-code");
}
}

View File

@ -0,0 +1,101 @@
<?php
namespace kernel\app_modules\card\controllers;
use Exception;
use JetBrains\PhpStorm\NoReturn;
use kernel\AdminController;
use kernel\app_modules\card\models\forms\CreateCardForm;
use kernel\app_modules\card\models\Card;
use kernel\app_modules\card\services\CardService;
use kernel\Flash;
use kernel\helpers\Debug;
class CardController extends AdminController
{
private CardService $cardService;
protected function init(): void
{
parent::init();
$this->cgView->viewPath = KERNEL_APP_MODULES_DIR . "/card/views/";
$this->cardService = new CardService();
}
public function actionCreate(): void
{
$this->cgView->render("form.php");
}
#[NoReturn] public function actionAdd(): void
{
$cardForm = new CreateCardForm();
$cardForm->load($_REQUEST);
if ($cardForm->validate()){
$card = $this->cardService->create($cardForm);
if ($card){
$this->redirect("/admin/card/" . $card->id);
}
}
Flash::setMessage("error", $cardForm->getErrorsStr());
$this->redirect("/admin/card/create");
}
public function actionIndex($page_number = 1): void
{
$this->cgView->render("index.php", ['page_number' => $page_number]);
}
/**
* @throws Exception
*/
public function actionView($id): void
{
$card = Card::find($id);
if (!$card){
throw new Exception(message: "The card not found");
}
$this->cgView->render("view.php", ['card' => $card]);
}
/**
* @throws Exception
*/
public function actionUpdate($id): void
{
$model = Card::find($id);
if (!$model){
throw new Exception(message: "The card not found");
}
$this->cgView->render("form.php", ['model' => $model]);
}
/**
* @throws Exception
*/
public function actionEdit($id): void
{
$card = Card::find($id);
if (!$card){
throw new Exception(message: "The card not found");
}
$cardForm = new CreateCardForm();
$cardService = new CardService();
$cardForm->load($_REQUEST);
if ($cardForm->validate()) {
$card = $cardService->update($cardForm, $card);
if ($card) {
$this->redirect("/admin/card/" . $card->id);
}
}
$this->redirect("/admin/card/update/" . $id);
}
#[NoReturn] public function actionDelete($id): void
{
$card = Card::find($id)->first();
$card->delete();
$this->redirect("/admin/card/");
}
}

View File

@ -0,0 +1,25 @@
<?php
namespace kernel\app_modules\card\controllers;
use kernel\app_modules\card\models\Card;
use kernel\RestController;
class CardRestController extends RestController
{
public function __construct()
{
$this->model = new Card();
}
protected function expand(): array
{
return ["cardFile"];
}
protected function filters(): array
{
return ['pin', 'user_id', 'payment_type', 'bank_id', 'info', 'program', 'username', 'status'];
}
}

View File

@ -0,0 +1,125 @@
<?php
namespace kernel\app_modules\card\controllers;
use Exception;
use JetBrains\PhpStorm\NoReturn;
use kernel\AdminController;
use kernel\app_modules\card\models\Card;
use kernel\app_modules\card\models\CardTemplate;
use kernel\app_modules\card\models\forms\CreateCardForm;
use kernel\app_modules\card\models\forms\CreateCardTemplateForm;
use kernel\app_modules\card\services\CardService;
use kernel\app_modules\card\services\CardTemplateService;
use kernel\FileUpload;
use kernel\Flash;
use kernel\helpers\Debug;
class CardTemplateController extends AdminController
{
private CardService $cardService;
private CardTemplateService $cardTemplateService;
protected function init(): void
{
parent::init();
$this->cgView->viewPath = KERNEL_APP_MODULES_DIR . "/card/views/card_template/";
$this->cardService = new CardService();
$this->cardTemplateService = new CardTemplateService();
}
public function actionCreate(): void
{
$this->cgView->render("form.php");
}
#[NoReturn] public function actionAdd(): void
{
$cardForm = new CreateCardTemplateForm();
$cardForm->load($_REQUEST);
if (isset($_FILES['path']) && $_FILES['path']['error'] === UPLOAD_ERR_OK) {
$file = new FileUpload($_FILES['path'], ['jpg', 'jpeg', 'png']);
$file->upload();
$cardForm->setItem('path', $file->getUploadFile());
}
if ($cardForm->validate()){
$cardTemplate = $this->cardTemplateService->create($cardForm);
if ($cardTemplate){
$this->redirect("/admin/card_template/" . $cardTemplate->id);
}
}
Flash::setMessage("error", $cardForm->getErrorsStr());
$this->redirect("/admin/card_template/create");
}
public function actionIndex($page_number = 1): void
{
$this->cgView->render("index.php", ['page_number' => $page_number]);
}
/**
* @throws Exception
*/
public function actionView($id): void
{
$card = CardTemplate::find($id);
if (!$card){
throw new Exception(message: "The card template not found");
}
$this->cgView->render("view.php", ['card' => $card]);
}
/**
* @throws Exception
*/
public function actionUpdate($id): void
{
$model = CardTemplate::find($id);
if (!$model){
throw new Exception(message: "The card template not found");
}
$this->cgView->render("form.php", ['model' => $model]);
}
/**
* @throws Exception
*/
public function actionEdit($id): void
{
$cardTemplate = CardTemplate::find($id);
if (!$cardTemplate){
throw new Exception(message: "The card not found");
}
$cardTemplateForm = new CreateCardTemplateForm();
$cardTemplateForm->load($_REQUEST);
if (isset($_FILES['path']) && $_FILES['path']['error'] === UPLOAD_ERR_OK) {
$file = new FileUpload($_FILES['path'], ['jpg', 'jpeg', 'png']);
$file->upload();
$cardTemplateForm->setItem('path', $file->getUploadFile());
}
if ($cardTemplateForm->validateForUpdate()) {
$card = $this->cardTemplateService->update($cardTemplateForm, $cardTemplate);
if ($card) {
$this->redirect("/admin/card_template/" . $card->id);
}
}
Flash::setMessage("error", $cardTemplateForm->getErrorsStr());
$this->redirect("/admin/card_template/update/" . $id);
}
#[NoReturn] public function actionDelete($id): void
{
$card = CardTemplate::find($id)->first();
$card->delete();
$this->redirect("/admin/card_template/");
}
}

View File

@ -0,0 +1,61 @@
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
public string $migration;
/**
* Run the migrations.
*/
public function up(): void
{
\kernel\App::$db->schema->create('card_template', function (Blueprint $table) {
$table->increments('id')->from(105545);
$table->string('path')->nullable(false);
$table->string('title')->nullable(false);
$table->integer('status')->default(1);
$table->timestamps();
});
\kernel\App::$db->schema->create('card_file', function (Blueprint $table) {
$table->increments('id');
$table->string('file')->nullable(false);
$table->integer('card_id')->nullable(false);
$table->integer('status')->default(1);
$table->timestamps();
});
\kernel\App::$db->schema->create('card', function (Blueprint $table) {
$table->increments('id')->from(105545);
$table->integer('user_id')->nullable(false);
$table->integer('balance')->nullable(false)->default(0);
$table->integer('payment_type')->nullable(false);
$table->integer('bank_id')->nullable(false);
$table->integer('info')->nullable(false);
$table->integer('program')->nullable(false);
$table->integer('cvc')->nullable(false);
$table->integer('pin')->nullable(false);
$table->string('username')->nullable();
$table->integer('card_template_id')->nullable();
$table->integer('card_file_id')->nullable();
$table->integer('status')->default(1);
$table->timestamps();
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
\kernel\App::$db->schema->dropIfExists('card');
\kernel\App::$db->schema->dropIfExists('card_template');
\kernel\App::$db->schema->dropIfExists('card_file');
}
};

View File

@ -0,0 +1,85 @@
<?php
namespace kernel\app_modules\card\models;
use Illuminate\Database\Eloquent\Model;
use kernel\modules\user\models\User;
// Добавить @property
/**
* @property int $id
* @property int $status
* @property int $balance
* @property int $user_id
* @property int $payment_type
* @property int $bank_id
* @property int $info
* @property int $program
* @property int $cvc
* @property int $pin
* @property int $card_template_id
* @property int $card_file_id
* @property string $username
*/
class Card extends Model
{
const DISABLE_STATUS = 0;
const ACTIVE_STATUS = 1;
protected $table = 'card';
protected $fillable = ['user_id', 'payment_type', 'balance', 'bank_id', 'info', 'program', 'cvc', 'pin', 'username', 'card_template_id', 'card_file_id', 'status'];
public static function labels(): array
{
// Заполнить массив
// Пример: [
// 'label' => 'Заголовок',
// 'entity' => 'Сущность',
// 'slug' => 'Slug',
// 'status' => 'Статус',
// ]
return [
'user_id' => 'ID пользователя',
'payment_type' => 'Платежная система',
'balance' => 'Баланс',
'bank_id' => 'ID банка',
'info' => 'Информация о банке',
'program' => 'Программа',
'cvc' => 'CVC',
'pin' => 'PIN',
'username' => 'Username',
'card_template_id' => 'Шаблон',
'card_file_id' => 'Карта',
'status' => 'Статус',
];
}
/**
* @return string[]
*/
public static function getStatus(): array
{
return [
self::DISABLE_STATUS => "Не активный",
self::ACTIVE_STATUS => "Активный",
];
}
public function cardTemplate(): \Illuminate\Database\Eloquent\Relations\BelongsTo
{
return $this->belongsTo(CardTemplate::class);
}
public function cardFile(): \Illuminate\Database\Eloquent\Relations\BelongsTo
{
return $this->belongsTo(CardFile::class);
}
// public function user(): \Illuminate\Database\Eloquent\Relations\BelongsTo
// {
// return $this->belongsTo(User::class);
// }
}

View File

@ -0,0 +1,51 @@
<?php
namespace kernel\app_modules\card\models;
use Illuminate\Database\Eloquent\Model;
/**
* @property int $id;
* @property string $file;
* @property int $card_id;
* @property int $status;
*/
class CardFile extends Model
{
const DISABLE_STATUS = 0;
const ACTIVE_STATUS = 1;
protected $table = 'card_file';
protected $fillable = ['file', 'card_id', 'status'];
public static function labels(): array
{
// Заполнить массив
// Пример: [
// 'label' => 'Заголовок',
// 'entity' => 'Сущность',
// 'slug' => 'Slug',
// 'status' => 'Статус',
// ]
return [
'file' => 'Файл карты',
'card_id' => 'Карта',
'status' => 'Статус',
];
}
/**
* @return string[]
*/
public static function getStatus(): array
{
return [
self::DISABLE_STATUS => "Не активный",
self::ACTIVE_STATUS => "Активный",
];
}
}

View File

@ -0,0 +1,50 @@
<?php
namespace kernel\app_modules\card\models;
use Illuminate\Database\Eloquent\Model;
/**
* @property string $path
* @property string $title
* @property int $status
*/
class CardTemplate extends Model
{
const DISABLE_STATUS = 0;
const ACTIVE_STATUS = 1;
protected $table = 'card_template';
protected $fillable = ['path', 'title', 'status'];
public static function labels(): array
{
// Заполнить массив
// Пример: [
// 'label' => 'Заголовок',
// 'entity' => 'Сущность',
// 'slug' => 'Slug',
// 'status' => 'Статус',
// ]
return [
'path' => 'Шаблон',
'title' => 'Название',
'status' => 'Статус',
];
}
/**
* @return string[]
*/
public static function getStatus(): array
{
return [
self::DISABLE_STATUS => "Не активный",
self::ACTIVE_STATUS => "Активный",
];
}
}

View File

@ -0,0 +1,36 @@
<?php
namespace kernel\app_modules\card\models\forms;
use kernel\FormModel;
class CreateCardForm extends FormModel
{
public function rules(): array
{
// Заполнить массив правил
// Пример:
// return [
// 'label' => 'required|min-str-len:5|max-str-len:30',
// 'entity' => 'required',
// 'slug' => '',
// 'status' => ''
// ];
return [
'user_id' => 'required|alpha-numeric',
'payment_type' => 'required|alpha-numeric',
'balance' => 'alpha-numeric',
'bank_id' => 'required|alpha-numeric',
'info' => 'required|alpha-numeric',
'program' => 'required|alpha-numeric',
'cvc' => 'required|alpha-numeric',
'pin' => 'required|alpha-numeric',
'username' => 'required|min-str-len:5|max-str-len:20',
'card_template_id' => 'required|alpha-numeric',
'card_file_id' => 'alpha-numeric',
'status' => '',
];
}
}

View File

@ -0,0 +1,38 @@
<?php
namespace kernel\app_modules\card\models\forms;
use kernel\FormModel;
class CreateCardTemplateForm extends FormModel
{
public function rules(): array
{
// Заполнить массив правил
// Пример:
// return [
// 'label' => 'required|min-str-len:5|max-str-len:30',
// 'entity' => 'required',
// 'slug' => '',
// 'status' => ''
// ];
return [
'path' => 'required|min-str-len:4',
'title' => 'required',
'status' => ''
];
}
public function rulesForUpdate(): array
{
return [
'path' => '',
'title' => 'required',
'status' => ''
];
}
}

View File

@ -0,0 +1,41 @@
<?php
use kernel\App;
use kernel\CgRouteCollector;
use Phroute\Phroute\RouteCollector;
App::$collector->group(["prefix" => "admin"], function (CgRouteCollector $router) {
App::$collector->group(["before" => "auth"], function (RouteCollector $router) {
App::$collector->group(["prefix" => "card"], function (CGRouteCollector $router) {
App::$collector->get('/', [\app\modules\card\controllers\CardController::class, 'actionIndex']);
App::$collector->get('/page/{page_number}', [\app\modules\card\controllers\CardController::class, 'actionIndex']);
App::$collector->get('/create', [\app\modules\card\controllers\CardController::class, 'actionCreate']);
App::$collector->post("/", [\app\modules\card\controllers\CardController::class, 'actionAdd']);
App::$collector->get('/{id}', [\app\modules\card\controllers\CardController::class, 'actionView']);
App::$collector->any('/update/{id}', [\app\modules\card\controllers\CardController::class, 'actionUpdate']);
App::$collector->any("/edit/{id}", [\app\modules\card\controllers\CardController::class, 'actionEdit']);
App::$collector->get('/delete/{id}', [\app\modules\card\controllers\CardController::class, 'actionDelete']);
});
});
});
App::$collector->group(["prefix" => "admin"], function (CgRouteCollector $router) {
App::$collector->group(["before" => "auth"], function (RouteCollector $router) {
App::$collector->group(["prefix" => "card_template"], function (CGRouteCollector $router) {
App::$collector->get('/', [\kernel\app_modules\card\controllers\CardTemplateController::class, 'actionIndex']);
App::$collector->get('/page/{page_number}', [\kernel\app_modules\card\controllers\CardTemplateController::class, 'actionIndex']);
App::$collector->get('/create', [\kernel\app_modules\card\controllers\CardTemplateController::class, 'actionCreate']);
App::$collector->post("/", [\kernel\app_modules\card\controllers\CardTemplateController::class, 'actionAdd']);
App::$collector->get('/{id}', [\kernel\app_modules\card\controllers\CardTemplateController::class, 'actionView']);
App::$collector->any('/update/{id}', [\kernel\app_modules\card\controllers\CardTemplateController::class, 'actionUpdate']);
App::$collector->any("/edit/{id}", [\kernel\app_modules\card\controllers\CardTemplateController::class, 'actionEdit']);
App::$collector->get('/delete/{id}', [\kernel\app_modules\card\controllers\CardTemplateController::class, 'actionDelete']);
});
});
});
App::$collector->group(["prefix" => "api"], function (CgRouteCollector $router){
App::$collector->group(['before' => 'bearer'], function (CgRouteCollector $router){
$router->rest("card", [\kernel\app_modules\card\controllers\CardRestController::class]);
});
});

View File

@ -0,0 +1,113 @@
<?php
namespace kernel\app_modules\card\services;
use DragonCode\CardNumber\CardNumber;
use DragonCode\CardNumber\Factories\BankFactory;
use DragonCode\CardNumber\Formatters\BankFormatter;
use kernel\app_modules\card\models\Card;
use kernel\app_modules\card\models\CardFile;
use kernel\FormModel;
use kernel\helpers\ImageGD;
use Endroid\QrCode\Color\Color;
use Endroid\QrCode\Encoding\Encoding;
use Endroid\QrCode\ErrorCorrectionLevel;
use Endroid\QrCode\QrCode;
use Endroid\QrCode\RoundBlockSizeMode;
use Endroid\QrCode\Writer\PngWriter;
class CardFileService
{
public function create(Card $card): false|CardFile
{
$cardFile = self::createCardPNG($card);
$model = new CardFile();
// Пример заполнения:
$model->file = $cardFile;
$model->status = CardFile::ACTIVE_STATUS;
$model->card_id = $card->id;
// $model->slug = Slug::createSlug($form_model->getItem('title'), Card::class); // Генерация уникального slug
if ($model->save()) {
return $model;
}
return false;
}
public function update(FormModel $form_model, CardFile $cardTemplate): false|CardFile
{
// Пример обновления:
$cardTemplate->file = $form_model->getItem('file');
$cardTemplate->card_id = $form_model->getItem('card_id');
$cardTemplate->status = $form_model->getItem('status');
if ($cardTemplate->save()) {
return $cardTemplate;
}
return false;
}
public static function createCardPNG(Card $card): false|string
{
if ($card->cardTemplate) {
$formatter = BankFormatter::create();
$customer = BankFactory::create()->paymentType($card->payment_type)->bank($card->bank_id, $card->info, $card->program)->client($card->id);
$cardNumber = CardNumber::generate($customer, $formatter);
//Card
$newFileName = md5(time() . $card->id) . '.png';
$uploadDir = "/resources/cards/";
$uploadDirUri = $uploadDir . mb_substr($newFileName, 0, 2) . '/' . mb_substr($newFileName, 2, 2) . '/';
$oldMask = umask(0);
mkdir(ROOT_DIR . $uploadDirUri, 0775, true);
umask($oldMask);
$uploadFileDir = ROOT_DIR . $uploadDirUri;
$img = ROOT_DIR . "/" . $card->cardTemplate->path; // Ссылка на файл
$font = RESOURCES_DIR . "/tmp/arialmt.ttf"; // Ссылка на шрифт
$qr = self::createQr($card->id);
$qrImg = new ImageGD($qr->getDataUri());
$img = new ImageGD($img);
$pngFilePath = RESOURCES_DIR . "/tmp/" . $card->id . ".png";
$pngFileUrl = "/resources/tmp/" . $card->id . ".png";
$img->addText(font_size: 14, degree: 0, x: 15, y: 25, color: "#000000", font: $font, text: "KO coin");
$img->addText(font_size: 14, degree: 0, x: 15, y: 45, color: "#000000", font: $font, text: "BGroup\ITGuild");
$img->addText(font_size: 14, degree: 0, x: 15, y: 65, color: "#000000", font: $font, text: $card->cardTemplate->title . " card");
$img->addText(font_size: 18, degree: 0, x: 15, y: 180, color: "#000000", font: $font, text: $cardNumber);
$img->addText(font_size: 12, degree: 0, x: 15, y: 200, color: "#000000", font: $font, text: $card->username);
$img->addImg($qrImg->getImg(), 200, 15, 0, 0, 124, 124, 100);
$img->save($uploadFileDir . $newFileName);
return $uploadDirUri . $newFileName;
}
return false;
}
public static function createQr(string|int $text): \Endroid\QrCode\Writer\Result\ResultInterface
{
$writer = new PngWriter();
$qrCode = new QrCode(
data: $text,
encoding: new Encoding('UTF-8'),
errorCorrectionLevel: ErrorCorrectionLevel::Low,
size: 120,
margin: 2,
roundBlockSizeMode: RoundBlockSizeMode::Margin,
foregroundColor: new Color(0, 0, 0),
backgroundColor: new Color(255, 255, 255)
);
return $writer->write($qrCode);
}
}

View File

@ -0,0 +1,108 @@
<?php
namespace kernel\app_modules\card\services;
use DragonCode\CardNumber\CardNumber;
use DragonCode\CardNumber\Factories\BankFactory;
use DragonCode\CardNumber\Formatters\BankFormatter;
use kernel\helpers\Debug;
use kernel\app_modules\card\models\Card;
use kernel\FormModel;
use kernel\helpers\ImageGD;
class CardService
{
protected CardFileService $cardFileService;
public function __construct()
{
$this->cardFileService = new CardFileService();
}
public function create(FormModel $form_model): false|Card
{
$model = new Card();
// Пример заполнения:
$model->user_id = $form_model->getItem('user_id');
$model->payment_type = $form_model->getItem('payment_type') ?? 2;
$model->bank_id = $form_model->getItem('bank_id') ?? 232;
$model->info = $form_model->getItem('info') ?? 42;
$model->program = $form_model->getItem('program') ?? 74;
$model->balance = $form_model->getItem('balance') ?? 0;
$model->cvc = $form_model->getItem('cvc');
$model->pin = $form_model->getItem('pin');
$model->username = $form_model->getItem('username');
$model->card_template_id = $form_model->getItem('card_template_id');
$model->status = $form_model->getItem('status');
if ($model->save()) {
$cardFile = $this->cardFileService->create($model);
if ($cardFile) {
$model->card_file_id = $cardFile->id;
$model->save();
}
return $model;
}
return false;
}
public function update(FormModel $form_model, Card $card): false|Card
{
// Пример обновления:
$card->user_id = $form_model->getItem('user_id');
$card->payment_type = $form_model->getItem('payment_type');
$card->bank_id = $form_model->getItem('bank_id');
$card->info = $form_model->getItem('info');
$card->program = $form_model->getItem('program');
$card->balance = $form_model->getItem('balance');
$card->cvc = $form_model->getItem('cvc');
$card->pin = $form_model->getItem('pin');
$card->username = $form_model->getItem('username');
$card->status = $form_model->getItem('status');
if ($card->card_template_id !== (int)$form_model->getItem('card_template_id')) {
$card->card_template_id = $form_model->getItem('card_template_id');
$cardFile = $this->cardFileService->create($card);
if ($cardFile) {
$card->card_file_id = $cardFile->id;
}
}
if ($card->save()) {
return $card;
}
return false;
}
public static function createCardPNG(Card $card): false|string
{
if ($card->cardTemplate) {
$formatter = BankFormatter::create();
$customer = BankFactory::create()->paymentType($card->payment_type)->bank($card->bank_id, $card->info, $card->program)->client($card->id);
$cardNumber = CardNumber::generate($customer, $formatter);
//Card
$img = ROOT_DIR . "/" . $card->cardTemplate->path; // Ссылка на файл
$font = RESOURCES_DIR . "/tmp/arialmt.ttf"; // Ссылка на шрифт
$img = new ImageGD($img);
$pngFilePath = RESOURCES_DIR . "/tmp/" . $card->id . ".png";
$pngFileUrl = "/resources/tmp/" . $card->id . ".png";
$img->addText(font_size: 14, degree: 0, x: 15, y: 25, color: "#000000", font: $font, text: "KO coin");
$img->addText(font_size: 14, degree: 0, x: 15, y: 45, color: "#000000", font: $font, text: "BGroup\ITGuild");
$img->addText(font_size: 18, degree: 0, x: 15, y: 180, color: "#000000", font: $font, text: $cardNumber);
$img->addText(font_size: 12, degree: 0, x: 15, y: 200, color: "#000000", font: $font, text: $card->username);
$img->save($pngFilePath);
return $pngFileUrl;
}
return false;
}
}

View File

@ -0,0 +1,55 @@
<?php
namespace kernel\app_modules\card\services;
use kernel\app_modules\card\models\Card;
use kernel\app_modules\card\models\CardTemplate;
use kernel\FormModel;
class CardTemplateService
{
public function create(FormModel $form_model): false|CardTemplate
{
$model = new CardTemplate();
// Пример заполнения:
$model->path = $form_model->getItem('path');
$model->status = $form_model->getItem('status');
$model->title = $form_model->getItem('title');
// $model->slug = Slug::createSlug($form_model->getItem('title'), Card::class); // Генерация уникального slug
if ($model->save()) {
return $model;
}
return false;
}
public function update(FormModel $form_model, CardTemplate $cardTemplate): false|CardTemplate
{
// Пример обновления:
$cardTemplate->title = $form_model->getItem('title');
$cardTemplate->path = $form_model->getItem('path') ?? $cardTemplate->path;
$cardTemplate->status = $form_model->getItem('status');
if ($cardTemplate->save()) {
return $cardTemplate;
}
return false;
}
public static function getTemplatesList(): array
{
$arr = [];
foreach (CardTemplate::all()->toArray() as $cardTemplate){
$arr[$cardTemplate['id']] = $cardTemplate['title'];
}
if (!empty($arr)) {
return $arr;
}
return [];
}
}

View File

@ -0,0 +1,63 @@
<?php
/**
* @var \kernel\app_modules\card\models\CardTemplate $model
*/
use kernel\app_modules\card\models\Card;
$form = new \itguild\forms\ActiveForm();
$form->beginForm(isset($model) ? "/admin/card_template/edit/" . $model->id : "/admin/card_template", 'multipart/form-data');
// Пример формы:
$form->field(\itguild\forms\inputs\TextInput::class, 'title', [
'class' => "form-control",
'placeholder' => 'Название',
'value' => $model->title ?? ''
])
->setLabel("Заголовок")
->render();
$form->field(\itguild\forms\inputs\File::class, 'path', [
'class' => "form-control",
'placeholder' => 'Путь к файлу',
'value' => $model->path ?? ''
])
->setLabel(\kernel\app_modules\card\models\CardTemplate::labels()['path'])
->render();
$form->field(class: \itguild\forms\inputs\Select::class, name: "status", params: [
'class' => "form-control",
'value' => $model->status ?? ''
])
->setLabel("Статус")
->setOptions(\kernel\app_modules\card\models\CardTemplate::getStatus())
->render();
?>
<div class="row">
<div class="col-sm-2">
<?php
$form->field(\itguild\forms\inputs\Button::class, name: "btn-submit", params: [
'class' => "btn btn-primary ",
'value' => 'Отправить',
'typeInput' => 'submit'
])
->render();
?>
</div>
<div class="col-sm-2">
<?php
$form->field(\itguild\forms\inputs\Button::class, name: "btn-reset", params: [
'class' => "btn btn-warning",
'value' => 'Сбросить',
'typeInput' => 'reset'
])
->render();
?>
</div>
</div>
<?php
$form->endForm();

View File

@ -0,0 +1,81 @@
<?php
/**
* @var \Illuminate\Database\Eloquent\Collection $card
* @var int $page_number
* @var \kernel\CgView $view
*/
use kernel\app_modules\card\models\Card;
use Itguild\EloquentTable\EloquentDataProvider;
use Itguild\EloquentTable\ListEloquentTable;
use kernel\widgets\IconBtn\IconBtnCreateWidget;
use kernel\widgets\IconBtn\IconBtnDeleteWidget;
use kernel\widgets\IconBtn\IconBtnEditWidget;
use kernel\widgets\IconBtn\IconBtnViewWidget;
$view->setTitle("Список шаблонов card");
$view->setMeta([
'description' => 'Список шаблонов card системы'
]);
//Для использования таблицы с моделью, необходимо создать таблицу в базе данных
$table = new ListEloquentTable(new EloquentDataProvider(\kernel\app_modules\card\models\CardTemplate::class, [
'currentPage' => $page_number,
'perPage' => 8,
'params' => ["class" => "table table-bordered", "border" => "2"],
'baseUrl' => "/admin/card_template"
]));
//$table = new \Itguild\Tables\ListJsonTable(json_encode(
// [
// 'meta' => [
// 'total' => 0,
// 'totalWithFilters' => 0,
// 'columns' => [
// 'title',
// 'slug',
// 'status',
// ],
// 'perPage' => 5,
// 'currentPage' => 1,
// 'baseUrl' => '/admin/some',
// 'params' => [
// 'class' => 'table table-bordered',
// 'border' => 2
// ]
// ],
// 'filters' => [],
// 'data' => [],
// ]
//));
$table->beforePrint(function () {
return IconBtnCreateWidget::create(['url' => '/admin/card_template/create'])->run();
});
$table->columns([
'status' => [
'value' => function ($data) {
return \kernel\app_modules\card\models\CardTemplate::getStatus()[$data];
}
],
'path' => [
'value' => function ($data) {
return \kernel\helpers\Html::img($data, ['width' => '200px']);
}
]
]);
$table->addAction(function($row) {
return IconBtnViewWidget::create(['url' => '/admin/card_template/' . $row['id']])->run();
});
$table->addAction(function($row) {
return IconBtnEditWidget::create(['url' => '/admin/card_template/update/' . $row['id']])->run();
});
$table->addAction(function($row) {
return IconBtnDeleteWidget::create(['url' => '/admin/card_template/delete/' . $row['id']])->run();
});
$table->create();
$table->render();

View File

@ -0,0 +1,34 @@
<?php
/**
* @var \Illuminate\Database\Eloquent\Collection $card
*/
use Itguild\EloquentTable\ViewEloquentTable;
use Itguild\EloquentTable\ViewJsonTableEloquentModel;
use kernel\widgets\IconBtn\IconBtnDeleteWidget;
use kernel\widgets\IconBtn\IconBtnEditWidget;
use kernel\widgets\IconBtn\IconBtnListWidget;
$table = new ViewEloquentTable(new ViewJsonTableEloquentModel($card, [
'params' => ["class" => "table table-bordered", "border" => "2"],
'baseUrl' => "/admin/card_template",
]));
$table->rows([
'status' => [
'value' => function ($data) {
return \kernel\app_modules\card\models\CardTemplate::getStatus()[$data];
}
]
]);
$table->beforePrint(function () use ($card) {
$btn = IconBtnListWidget::create(['url' => '/admin/card_template'])->run();
$btn .= IconBtnEditWidget::create(['url' => '/admin/card_template/update/' . $card->id])->run();
$btn .= IconBtnDeleteWidget::create(['url' => '/admin/card_template/delete/' . $card->id])->run();
return $btn;
});
$table->create();
$table->render();

View File

@ -0,0 +1,125 @@
<?php
/**
* @var Card $model
*/
use kernel\app_modules\card\models\Card;
$form = new \itguild\forms\ActiveForm();
$form->beginForm(isset($model) ? "/admin/card/edit/" . $model->id : "/admin/card", 'multipart/form-data');
// Пример формы:
$form->field(class: \itguild\forms\inputs\Select::class, name: "user_id", params: [
'class' => "form-control",
'value' => $model->user_id ?? ''
])
->setLabel("Пользователи")
->setOptions(\kernel\modules\user\service\UserService::createUsernameArr())
->render();
$form->field(\itguild\forms\inputs\TextInput::class, 'username', [
'class' => "form-control",
'placeholder' => 'Username',
'value' => $model->username ?? ''
])
->setLabel("Username")
->render();
$form->field(\itguild\forms\inputs\TextInput::class, 'balance', [
'class' => "form-control",
'placeholder' => 'Баланс',
'value' => $model->balance ?? ''
])
->setLabel("Баланс")
->render();
$form->field(\itguild\forms\inputs\TextInput::class, 'payment_type', [
'class' => "form-control",
'placeholder' => 'Тип оплаты',
'value' => $model->payment_type ?? ''
])
->setLabel("Тип оплаты")
->render();
$form->field(\itguild\forms\inputs\TextInput::class, 'bank_id', [
'class' => "form-control",
'placeholder' => 'ID банка',
'value' => $model->bank_id ?? ''
])
->setLabel("ID банка")
->render();
$form->field(\itguild\forms\inputs\TextInput::class, 'info', [
'class' => "form-control",
'placeholder' => 'Информация',
'value' => $model->info ?? ''
])
->setLabel("Информация")
->render();
$form->field(\itguild\forms\inputs\TextInput::class, 'program', [
'class' => "form-control",
'placeholder' => 'Программа',
'value' => $model->program ?? ''
])
->setLabel("Программа")
->render();
$form->field(\itguild\forms\inputs\TextInput::class, 'cvc', [
'class' => "form-control",
'placeholder' => 'CVC',
'value' => $model->cvc ?? ''
])
->setLabel("CVC")
->render();
$form->field(\itguild\forms\inputs\TextInput::class, 'pin', [
'class' => "form-control",
'placeholder' => 'PIN',
'value' => $model->pin ?? ''
])
->setLabel("PIN")
->render();
$form->field(class: \itguild\forms\inputs\Select::class, name: "card_template_id", params: [
'class' => "form-control",
'value' => $model->card_template_id ?? ''
])
->setLabel("Шаблон")
->setOptions(\kernel\app_modules\card\services\CardTemplateService::getTemplatesList())
->render();
$form->field(class: \itguild\forms\inputs\Select::class, name: "status", params: [
'class' => "form-control",
'value' => $model->status ?? ''
])
->setLabel("Статус")
->setOptions(Card::getStatus())
->render();
?>
<div class="row">
<div class="col-sm-2">
<?php
$form->field(\itguild\forms\inputs\Button::class, name: "btn-submit", params: [
'class' => "btn btn-primary ",
'value' => 'Отправить',
'typeInput' => 'submit'
])
->render();
?>
</div>
<div class="col-sm-2">
<?php
$form->field(\itguild\forms\inputs\Button::class, name: "btn-reset", params: [
'class' => "btn btn-warning",
'value' => 'Сбросить',
'typeInput' => 'reset'
])
->render();
?>
</div>
</div>
<?php
$form->endForm();

View File

@ -0,0 +1,92 @@
<?php
/**
* @var \Illuminate\Database\Eloquent\Collection $card
* @var int $page_number
* @var \kernel\CgView $view
*/
use kernel\app_modules\card\models\Card;
use Itguild\EloquentTable\EloquentDataProvider;
use Itguild\EloquentTable\ListEloquentTable;
use kernel\modules\user\models\User;
use kernel\widgets\IconBtn\IconBtnCreateWidget;
use kernel\widgets\IconBtn\IconBtnDeleteWidget;
use kernel\widgets\IconBtn\IconBtnEditWidget;
use kernel\widgets\IconBtn\IconBtnViewWidget;
$view->setTitle("Список card");
$view->setMeta([
'description' => 'Список card системы'
]);
//Для использования таблицы с моделью, необходимо создать таблицу в базе данных
$table = new ListEloquentTable(new EloquentDataProvider(Card::class, [
'currentPage' => $page_number,
'perPage' => 8,
'params' => ["class" => "table table-bordered", "border" => "2"],
'baseUrl' => "/admin/card"
]));
$table->columns([
'user_id' => [
'value' => function ($data) {
return User::find($data)->username ?? '';
}
],
'card_template_id' => [
'value' => function ($data) {
return \kernel\app_modules\card\models\CardTemplate::find($data)->title;
}
],
'card_file_id' => [
'value' => function ($data) {
$file = \kernel\app_modules\card\models\CardFile::find($data)->file;
return $file ? \kernel\helpers\Html::img($file) : "";
}
],
'status' => [
'value' => function ($data) {
return Card::getStatus()[$data];
}
]
]);
//$table = new \Itguild\Tables\ListJsonTable(json_encode(
// [
// 'meta' => [
// 'total' => 0,
// 'totalWithFilters' => 0,
// 'columns' => [
// 'title',
// 'slug',
// 'status',
// ],
// 'perPage' => 5,
// 'currentPage' => 1,
// 'baseUrl' => '/admin/some',
// 'params' => [
// 'class' => 'table table-bordered',
// 'border' => 2
// ]
// ],
// 'filters' => [],
// 'data' => [],
// ]
//));
$table->beforePrint(function () {
return IconBtnCreateWidget::create(['url' => '/admin/card/create'])->run();
});
$table->addAction(function($row) {
return IconBtnViewWidget::create(['url' => '/admin/card/' . $row['id']])->run();
});
$table->addAction(function($row) {
return IconBtnEditWidget::create(['url' => '/admin/card/update/' . $row['id']])->run();
});
$table->addAction(function($row) {
return IconBtnDeleteWidget::create(['url' => '/admin/card/delete/' . $row['id']])->run();
});
$table->create();
$table->render();

View File

@ -0,0 +1,71 @@
<?php
/**
* @var \Illuminate\Database\Eloquent\Collection $card
*/
use Endroid\QrCode\Color\Color;
use Endroid\QrCode\Encoding\Encoding;
use Endroid\QrCode\ErrorCorrectionLevel;
use Endroid\QrCode\QrCode;
use Endroid\QrCode\RoundBlockSizeMode;
use Endroid\QrCode\Writer\PngWriter;
use Itguild\EloquentTable\ViewEloquentTable;
use Itguild\EloquentTable\ViewJsonTableEloquentModel;
use kernel\widgets\IconBtn\IconBtnDeleteWidget;
use kernel\widgets\IconBtn\IconBtnEditWidget;
use kernel\widgets\IconBtn\IconBtnListWidget;
$table = new ViewEloquentTable(new ViewJsonTableEloquentModel($card, [
'params' => ["class" => "table table-bordered", "border" => "2"],
'baseUrl' => "/admin/card",
]));
$table->beforePrint(function () use ($card) {
$btn = IconBtnListWidget::create(['url' => '/admin/card'])->run();
$btn .= IconBtnEditWidget::create(['url' => '/admin/card/update/' . $card->id])->run();
$btn .= IconBtnDeleteWidget::create(['url' => '/admin/card/delete/' . $card->id])->run();
return $btn;
});
$table->rows([
'card_file_id' => function ($data) {
$file = \kernel\app_modules\card\models\CardFile::find($data)->file;
return $file ? \kernel\helpers\Html::img($file) : "";
},
'status' => function ($data) {
return \kernel\app_modules\card\models\Card::getStatus()[$data];
}
]);
$table->create();
$table->render();
//$writer = new PngWriter();
//
//// Create QR code
//$qrCode = new QrCode(
// data: $card->id,
// encoding: new Encoding('UTF-8'),
// errorCorrectionLevel: ErrorCorrectionLevel::Low,
// size: 120,
// margin: 2,
// roundBlockSizeMode: RoundBlockSizeMode::Margin,
// foregroundColor: new Color(0, 0, 0),
// backgroundColor: new Color(255, 255, 255)
//);
//
//
//$result = $writer->write($qrCode);
//echo "<img src='".$result->getDataUri()."'>";
//
//$path = $card->cardFile->file;
//$mainImg = new \kernel\helpers\ImageGD(ROOT_DIR . $path);
//$qrImg = new \kernel\helpers\ImageGD($result->getDataUri());
//$mainImg->addImg($qrImg->getImg(), 200, 15, 0, 0, 124, 124, 100);
//$mainImg->save(RESOURCES_DIR . "/tmp/with_qr.png");
//$cardFile = \kernel\app_modules\card\services\CardService::createCardPNG($card);
//echo \kernel\helpers\Html::img("/resources/tmp/card_tpl.png");
//if ($cardFile) {
// echo \kernel\helpers\Html::img($cardFile);
//}

View File

@ -0,0 +1,39 @@
<?php
namespace kernel\app_modules\tgbot;
use kernel\Module;
use kernel\modules\menu\service\MenuService;
use kernel\services\MigrationService;
class TgbotModule extends Module
{
public MenuService $menuService;
public MigrationService $migrationService;
public function __construct()
{
$this->menuService = new MenuService();
$this->migrationService = new MigrationService();
}
/**
* @throws \Exception
*/
public function init(): void
{
$this->migrationService->runAtPath("{KERNEL_APP_MODULES}/tgbot/migrations");
$this->menuService->createItem([
"label" => "TG bot",
"url" => "/admin/tg-bot",
"slug" => "tg-bot",
]);
}
public function deactivate()
{
$this->menuService->removeItemBySlug("tg-bot");
$this->migrationService->rollbackAtPath("{KERNEL_APP_MODULES}/tgbot/migrations");
}
}

View File

@ -0,0 +1,91 @@
<?php
namespace kernel\app_modules\tgbot\controllers;
use app\modules\tgbot\models\Tgbot;
use JetBrains\PhpStorm\NoReturn;
use kernel\app_modules\card\models\forms\CreateCardForm;
use kernel\app_modules\card\services\CardService;
use kernel\helpers\Debug;
use kernel\modules\user\models\forms\CreateUserForm;
use kernel\modules\user\service\UserService;
use kernel\Request;
use kernel\RestController;
use kernel\services\TokenService;
class TgBotRestController extends RestController
{
public function __construct()
{
$this->model = new Tgbot();
}
#[NoReturn] public function actionStore(): void
{
$request = new Request();
$data = $request->post();
$tgBot = $this->model->where("bot_id", $data['bot_id'])->where("dialog_id", $data['dialog_id'])->first();
if (!$tgBot){
foreach ($this->model->getFillable() as $item){
$this->model->{$item} = $data[$item] ?? null;
}
$userService = new UserService();
$userForm = new CreateUserForm();
$username = $data['username'];
$userForm->load([
'username' => $username,
'password' => TokenService::random_bytes(20),
'email' => $username . "@hookahdnr.ru"
]);
$user = $userService->create($userForm);
if ($user) {
$this->model->user_id = $user->id;
}
$this->model->save();
$this->renderApi($this->model->toArray());
}
$this->renderApi($tgBot->toArray());
}
#[NoReturn] public function actionCreateCard(): void
{
$cardService = new CardService();
$request = new Request();
$data = $request->post();
$form = new CreateCardForm();
$form->load($data);
$form->setItem('payment_type', 2);
$form->setItem('bank_id', 323);
$form->setItem('info', 42);
$form->setItem('program', 74);
$form->setItem('cvc', 101);
$form->setItem('pin', 1111);
$form->setItem('status', 1);
if ($form->validate()){
$model = $cardService->create($form);
$this->renderApi($model->load(['cardFile'])->toArray());
}
$this->renderApi([]);
}
#[NoReturn] public function actionGetByDialog(int $dialog_id, int $bot_id): void
{
$model = \kernel\app_modules\tgbot\models\Tgbot::where(['dialog_id' => $dialog_id, 'bot_id' => $bot_id])->first();
if ($model) {
$this->renderApi($model->toArray());
}
$this->renderApi([]);
}
}

View File

@ -0,0 +1,111 @@
<?php
namespace kernel\app_modules\tgbot\controllers;
use app\modules\tgbot\models\forms\CreateTgBotForm;
use app\modules\tgbot\models\Tgbot;
use app\modules\tgbot\services\TgBotService;
use Exception;
use JetBrains\PhpStorm\NoReturn;
use kernel\AdminController;
use kernel\helpers\Debug;
use kernel\modules\user\models\forms\CreateUserForm;
use kernel\modules\user\service\UserService;
use kernel\services\TokenService;
class TgbotController extends AdminController
{
protected TgBotService $botService;
protected function init(): void
{
parent::init();
$this->cgView->viewPath = KERNEL_APP_MODULES_DIR . "/tgbot/views/tgbot/";
$this->botService = new TgBotService();
}
public function actionCreate(): void
{
$this->cgView->render("form.php");
}
public function actionIndex($page_number = 1): void
{
$this->cgView->render("index.php", ['page_number' => $page_number]);
}
#[NoReturn] public function actionAdd(): void
{
$tgForm = new CreateTgBotForm();
$tgForm->load($_REQUEST);
if ($tgForm->validate()) {
$tg = $this->botService->create($tgForm);
if ($tg) {
$this->redirect("/admin/tg-bot/view/" . $tg->id);
}
}
$this->redirect("/admin/tg-bot/create");
}
/**
* @throws Exception
*/
public function actionUpdate($id): void
{
$model = Tgbot::find($id);
if (!$model) {
throw new Exception(message: "The dialog not found");
}
$this->cgView->render("form.php", ['model' => $model]);
}
/**
* @throws Exception
*/
public function actionEdit($id): void
{
$tg = Tgbot::find($id);
if (!$tg) {
throw new Exception(message: "The tag not found");
}
$tgForm = new CreateTgBotForm();
$tgService = new TgBotService();
$tgForm->load($_REQUEST);
if ($tgForm->validate()) {
$tg = $tgService->update($tgForm, $tg);
if ($tg) {
$this->redirect("/admin/tg-bot/view/" . $tg->id);
}
}
$this->redirect("/admin/tg-bot/update/" . $id);
}
/**
* @throws Exception
*/
public function actionView($id): void
{
$tg = Tgbot::find($id);
if (!$tg) {
throw new Exception(message: "The dialog not found");
}
$this->cgView->render("view.php", ['tg' => $tg]);
}
/**
* @throws Exception
*/
#[NoReturn] public function actionDelete(int $id): void
{
$post = Tgbot::find($id)->first();
if (!$post){
throw new Exception(message: "The tg client not found");
}
$post->delete();
$this->redirect("/admin/tg-bot/");
}
}

View File

@ -0,0 +1,35 @@
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
public string $migration;
/**
* Run the migrations.
*/
public function up(): void
{
\kernel\App::$db->schema->create('tgbot', function (Blueprint $table) {
$table->increments('id');
$table->bigInteger('bot_id')->nullable(false);
$table->bigInteger('dialog_id')->nullable(false);
$table->integer('user_id')->nullable();
$table->string('username', 255)->nullable(false);
$table->string('first_name', 255)->nullable();
$table->string('last_name', 255)->nullable();
$table->integer('status')->nullable()->default(1);
$table->timestamps();
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
\kernel\App::$db->schema->dropIfExists('tgbot');
}
};

View File

@ -0,0 +1,51 @@
<?php
namespace kernel\app_modules\tgbot\models;
use Illuminate\Database\Eloquent\Model;
/**
* @property integer $id
* @property integer $bot_id
* @property integer $dialog_id
* @property integer $user_id
* @property string $username
* @property string $first_name
* @property string $last_name
* @property integer $status
*/
class Tgbot extends Model
{
const DISABLE_STATUS = 0;
const ACTIVE_STATUS = 1;
protected $table = 'tgbot';
protected $fillable = ['bot_id', 'dialog_id', 'user_id', 'username', 'first_name', 'last_name', 'status'];
public static function labels(): array
{
return [
'bot_id' => 'Bot ID',
'dialog_id' => 'Dialog ID',
'user_id' => 'User ID',
'username' => 'Username',
'first_name' => 'First name',
'last_name' => 'Last name',
'status' => 'Статус',
];
}
/**
* @return string[]
*/
public static function getStatus(): array
{
return [
self::DISABLE_STATUS => "Не активный",
self::ACTIVE_STATUS => "Активный",
];
}
}

View File

@ -0,0 +1,30 @@
<?php
namespace kernel\app_modules\tgbot\models\forms;
use kernel\FormModel;
/**
* @property integer $bot_id
* @property integer $dialog_id
* @property string $username
* @property string $first_name
* @property string $last_name
* @property integer $status
*/
class CreateTgBotForm extends FormModel
{
public function rules(): array
{
return [
'bot_id' => 'required',
'dialog_id' => 'required',
'username' => 'required',
'first_name' => '',
'last_name' => '',
'status' => ''
];
}
}

View File

@ -0,0 +1,33 @@
<?php
use kernel\App;
use kernel\CgRouteCollector;
use Phroute\Phroute\RouteCollector;
App::$collector->group(["prefix" => "admin"], function (CgRouteCollector $router) {
App::$collector->group(["before" => "auth"], function (RouteCollector $router) {
App::$collector->group(["prefix" => "tg-bot"], function (CGRouteCollector $router) {
App::$collector->get('/', [\app\modules\tgbot\controllers\TgbotController::class, 'actionIndex']);
App::$collector->get('/page/{page_number}', [\app\modules\tag\controllers\TagController::class, 'actionIndex']);
App::$collector->get('/create', [\app\modules\tgbot\controllers\TgbotController::class, 'actionCreate']);
App::$collector->post("/", [\app\modules\tgbot\controllers\TgbotController::class, 'actionAdd']);
App::$collector->get('/view/{id}', [\app\modules\tgbot\controllers\TgbotController::class, 'actionView']);
App::$collector->any('/update/{id}', [\app\modules\tgbot\controllers\TgbotController::class, 'actionUpdate']);
App::$collector->any("/edit/{id}", [\app\modules\tgbot\controllers\TgbotController::class, 'actionEdit']);
App::$collector->get('/delete/{id}', [\app\modules\tgbot\controllers\TgbotController::class, 'actionDelete']);
});
App::$collector->group(["prefix" => "settings"], function (CGRouteCollector $router) {
App::$collector->get('/tag', [\app\modules\tag\controllers\TagController::class, 'actionSettings']);
App::$collector->post('/tag/update', [\app\modules\tag\controllers\TagController::class, 'actionSaveSettings']);
});
});
});
App::$collector->group(["prefix" => "api"], function (CgRouteCollector $router){
App::$collector->group(['before' => 'bearer'], function (CgRouteCollector $router){
$router->rest("tg-bot", [\app\modules\tgbot\controllers\TgBotRestController::class]);
$router->post('/tg-bot/create-card', [\app\modules\tgbot\controllers\TgBotRestController::class, 'actionCreateCard']);
$router->get('/tg-bot/get-by-dialog/{dialog_id}/{bot_id}', [\app\modules\tgbot\controllers\TgBotRestController::class, 'actionGetByDialog']);
});
});

View File

@ -0,0 +1,48 @@
<?php
namespace kernel\app_modules\tgbot\services;
use app\modules\tgbot\models\Tgbot;
use kernel\app_modules\tag\models\Tag;
use kernel\FormModel;
use kernel\helpers\Debug;
use kernel\helpers\Slug;
use kernel\services\ModuleService;
class TgBotService
{
public function create(FormModel $form_model): false|Tgbot
{
$model = new Tgbot();
$model->bot_id = $form_model->getItem('bot_id');
$model->dialog_id = $form_model->getItem('dialog_id');
$model->user_id = $form_model->getItem('user_id');
$model->username = $form_model->getItem('username');
$model->first_name = $form_model->getItem('first_name');
$model->last_name = $form_model->getItem('last_name');
$model->status = $form_model->getItem('status');
if ($model->save()){
return $model;
}
return false;
}
public function update(FormModel $form_model, Tgbot $model): false|Tgbot
{
$model->bot_id = $form_model->getItem('bot_id');
$model->dialog_id = $form_model->getItem('dialog_id');
$model->user_id = $form_model->getItem('user_id');
$model->username = $form_model->getItem('username');
$model->first_name = $form_model->getItem('first_name');
$model->last_name = $form_model->getItem('last_name');
$model->status = $form_model->getItem('status');
if ($model->save()){
return $model;
}
return false;
}
}

View File

@ -0,0 +1,83 @@
<?php
/**
* @var Tgbot $model
*/
use app\modules\tgbot\models\Tgbot;
$form = new \itguild\forms\ActiveForm();
$form->beginForm(isset($model) ? "/admin/tg-bot/edit/" . $model->id : "/admin/tg-bot");
$form->field(class: \itguild\forms\inputs\TextInput::class, name: "bot_id", params: [
'class' => "form-control",
'placeholder' => 'Bot ID',
'value' => $model->bot_id ?? ''
])
->setLabel("Bot ID")
->render();
$form->field(class: \itguild\forms\inputs\TextInput::class, name: "dialog_id", params: [
'class' => "form-control",
'placeholder' => 'Dialog ID',
'value' => $model->dialog_id ?? ''
])
->setLabel("Dialog ID")
->render();
$form->field(class: \itguild\forms\inputs\TextInput::class, name: "username", params: [
'class' => "form-control",
'placeholder' => 'Username',
'value' => $model->username ?? ''
])
->setLabel("Username")
->render();
$form->field(class: \itguild\forms\inputs\TextInput::class, name: "first_name", params: [
'class' => "form-control",
'placeholder' => 'First name',
'value' => $model->first_name ?? ''
])
->setLabel("First name")
->render();
$form->field(class: \itguild\forms\inputs\TextInput::class, name: "last_name", params: [
'class' => "form-control",
'placeholder' => 'Last name',
'value' => $model->last_name ?? ''
])
->setLabel("Last name")
->render();
$form->field(\itguild\forms\inputs\Select::class, 'status', [
'class' => "form-control",
'value' => $model->status ?? ''
])
->setLabel("Статус")
->setOptions(Tgbot::getStatus())
->render();
?>
<div class="row">
<div class="col-sm-2">
<?php
$form->field(\itguild\forms\inputs\Button::class, name: "btn-submit", params: [
'class' => "btn btn-primary ",
'value' => 'Отправить',
'typeInput' => 'submit'
])
->render();
?>
</div>
<div class="col-sm-2">
<?php
$form->field(\itguild\forms\inputs\Button::class, name: "btn-reset", params: [
'class' => "btn btn-warning",
'value' => 'Сбросить',
'typeInput' => 'reset'
])
->render();
?>
</div>
</div>
<?php
$form->endForm();

View File

@ -0,0 +1,59 @@
<?php
/**
* @var int $page_number
* @var \kernel\CgView $view
*/
use Itguild\EloquentTable\EloquentDataProvider;
use Itguild\EloquentTable\ListEloquentTable;
use kernel\app_modules\tag\models\Tag;
use kernel\IGTabel\btn\PrimaryBtn;
use kernel\models\Menu;
use kernel\modules\menu\table\columns\MenuDeleteActionColumn;
use kernel\modules\menu\table\columns\MenuEditActionColumn;
use kernel\modules\menu\table\columns\MenuViewActionColumn;
$view->setTitle("Список существующих диалогов");
$table = new ListEloquentTable(new EloquentDataProvider(\app\modules\tgbot\models\Tgbot::class, [
'currentPage' => $page_number,
'perPage' => 8,
'params' => ["class" => "table table-bordered", "border" => "2"],
'baseUrl' => "/admin/tg-bot",
'searchPrefix' => "",
'searchParams' => (new \kernel\Request())->get(),
]));
$table->beforePrint(function () {
return PrimaryBtn::create("Создать", "/admin/tg-bot/create")->fetch();
});
$table->columns([
"status" => [
"value" => function ($cell) {
return \app\modules\tgbot\models\Tgbot::getStatus()[$cell];
}
],
"username" => [
"filter" => [
"class" => \Itguild\Tables\Filter\InputTextFilter::class
]
],
"bot_id" => [
"filter" => [
"class" => \Itguild\Tables\Filter\InputTextFilter::class
]
],
"dialog_id" => [
"filter" => [
"class" => \Itguild\Tables\Filter\InputTextFilter::class
]
]
]);
$table->addAction(\kernel\IGTabel\action_column\ViewActionColumn::class);
$table->addAction(\kernel\IGTabel\action_column\DeleteActionColumn::class);
$table->addAction(\kernel\IGTabel\action_column\EditActionColumn::class);
$table->create();
$table->render();

View File

@ -0,0 +1,30 @@
<?php
/**
* @var \Illuminate\Database\Eloquent\Collection $tg
*/
use kernel\modules\user\models\User;
use Itguild\EloquentTable\ViewEloquentTable;
use Itguild\EloquentTable\ViewJsonTableEloquentModel;
use kernel\IGTabel\btn\DangerBtn;
use kernel\IGTabel\btn\PrimaryBtn;
use kernel\IGTabel\btn\SuccessBtn;
$table = new ViewEloquentTable(new ViewJsonTableEloquentModel($tg, [
'params' => ["class" => "table table-bordered", "border" => "2"],
'baseUrl' => "/admin/tg-bot",
]));
$table->beforePrint(function () use ($tg) {
$btn = PrimaryBtn::create("Список", "/admin/tg-bot")->fetch();
$btn .= SuccessBtn::create("Редактировать", "/admin/tg-bot/update/" . $tg->id)->fetch();
$btn .= DangerBtn::create("Удалить", "/admin/tg-bot/delete/" . $tg->id)->fetch();
return $btn;
});
$table->rows([
'status' => (function ($data) {
return \app\modules\tgbot\models\Tgbot::getStatus()[$data];
})
]);
$table->create();
$table->render();