| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262 | <?phpnamespace App\Services;use App\Services\BaseService;use App\Models\Wallet;use Illuminate\Support\Facades\DB;use Illuminate\Support\Collection;use Illuminate\Support\Facades\Cache;use App\Services\CoinService;use App\Services\UserService;use App\Helpers\TronHelper;use Illuminate\Support\Facades\Log;use App\Services\BalanceLogService;/** * 用户虚拟币钱包*/class WalletService extends BaseService {    /**     * @description: 模型     * @return {string}     */        public static function model() :string    {        return Wallet::class;    }    /**     * @description: 枚举     * @return {*}     */        public static function enum() :string    {        return '';    }    /**     * @description: 获取查询条件     * @param {array} $search 查询内容     * @return {array}     */        public static function getWhere(array $search = []) :array    {        $where = [];        if(isset($search['coin']) && !empty($search['coin'])){            $where[] = ['coin', '=', $search['coin']];        }        if(isset($search['net']) && !empty($search['net'])){            $where[] = ['net', '=', $search['net']];        }        if(isset($search['address']) && !empty($search['address'])){            $where[] = ['address', '=', $search['address']];        }        if(isset($search['id']) && !empty($search['id'])){            $where[] = ['id', '=', $search['id']];        }        if(isset($search['member_id']) && !empty($search['member_id'])){            $where[] = ['member_id', '=', $search['member_id']];        }        return $where;    }     /**     * @description: 查询单条数据     * @param array $search     * @return \App\Models\Coin|null     */    public static function findOne(array $search): ?Wallet    {        return self::model()::where(self::getWhere($search))->first();    }    /**     * @description: 查询所有数据     * @param array $search     * @return \Illuminate\Database\Eloquent\Collection     */    public static function findAll(array $search = [])    {        return self::model()::where(self::getWhere($search))->get();    }    /**     * @description: 分页查询     * @param array $search     * @return \Illuminate\Contracts\Pagination\LengthAwarePaginator     */    public static function paginate(array $search = [])    {        $limit = isset($search['limit'])?$search['limit']:15;        $paginator = self::model()::where(self::getWhere($search))->paginate($limit);        return ['total' => $paginator->total(), 'data' => $paginator->items()];    }    /**     * @description: 为用户创建虚拟钱包     * @param {int} $memberId 用户ID     * @return {*}     */        public static function createVirtualWallets(int $memberId)    {        $coins = CoinService::findAll(['coin' => 'USDT']);        $users = UserService::findOne(['member_id' => $memberId]);        $walletsData = $coins->map(function($coin) use ($memberId,$users) {            switch($coin->coin){                case 'USDT':                    $trons = TronHelper::createAddress($memberId);                    break;                default:                    $trons = [];            }            return [                'user_id' => $users['id'],                'member_id' => $memberId,                'coin' => $coin->coin,                'net' => $coin->net,                'address' => $trons['address']??'',                'private_key' => $trons['private_key']??'',                'available_balance' => 0,                'frozen_balance' => 0            ];        })->toArray();                // 批量创建钱包以提高性能        self::model()::insert($walletsData);        return self::findAll(['member_id' => $memberId]);                    }    /**     * @description: 获取用户的钱包     * @param {int} $memberId      * @return {*}     */        public static function getUserWallet(int $memberId)    {        $wallets = self::findAll(['member_id' => $memberId]);        if($wallets->isEmpty()){            $wallets = self::createVirtualWallets($memberId);        }        $wallets->map(function($wallet) {                    $wallet->available_balance = removeZero($wallet->available_balance);                    $wallet->frozen_balance = removeZero($wallet->frozen_balance);                    // $wallet->total_balance = $wallet->available_balance + $wallet->frozen_balance;                    return $wallet;                });        return $wallets;    }    /**     * @description: 获取用户充值钱包地址     * @param {*} $memberId     * @return {*}     */        public static function getRechargeImageAddress($memberId)    {        self::getUserWallet($memberId);        $info = self::findOne(['member_id' => $memberId]);        $path = self::rechargeQrCodeExists($info->address);        if(empty($path)){            $path = self::createRechargeQrCode($info->address);        }        // $host = config('app.url'); // 通常在 .env 中配置 APP_URL        return [            'coin' => $info->coin,            'net' => $info->net,            'address' => $info->address,            'path' => $path,            'full_path' => asset($path)        ];    }    /**     * @description: 获取平台充值钱包地址     * @param {*} $address     * @return {*}     */        public static function getPlatformImageAddress($address)    {         $path = self::rechargeQrCodeExists($address);        if(empty($path)){            $path = self::createRechargeQrCode($address);        }        // $host = config('app.url'); // 通常在 .env 中配置 APP_URL        return [            'coin' => 'USDT',            'net' => 'TRC20',            'address' => $address,            'path' => $path,            'full_path' => asset($path)        ];    }    /**     * @description: 更新余额     * @param {*} $memberId     * @param {*} $amount     * @return {*}     */        public static function updateBalance($memberId , $amount)    {        $data = [];        $self = self::findOne(['member_id' => $memberId]);        $data['before_balance'] = $self->available_balance; // 操作前余额        $self->available_balance += $amount;        $data['after_balance'] = $self->available_balance;        $self->save();        return $data;    }        /**     * @description: 获取用户余额     * @param {int} $memberId 用户ID     * @return {*}     */    public static function getBalance($memberId)    {        $selfInfo = self::findOne(['member_id' => $memberId]);        $userInfo = UserService::findOne(['member_id' => $memberId]);        $balance = number_format($selfInfo->available_balance, 2, '.', '');        $text = '';        $text .= "用户ID:{$memberId} \n";        $text .= "用户名:{$userInfo->first_name} \n";        $text .= "当前余额:{$balance} \n";        $keyboard = [            [                ['text' => '➕充值', 'callback_data' => "topup@@topup"],                ['text' => '🧾充值账单', 'callback_data' => "topup@@bill"],            ],            [                ['text' => '➕ 提现', 'callback_data' => "withdraw@@apply"],                ['text' => '🧾 提现账单', 'callback_data' => "withdraw@@bill"]            ]        ];        return [            'chat_id' => $memberId,            'text' => $text,            'reply_markup' => json_encode(['inline_keyboard' => $keyboard]),            'protect_content' => true        ];    }    }
 |