代码初始化

This commit is contained in:
2025-08-07 20:21:47 +08:00
commit 50f3a2dbb0
2191 changed files with 374790 additions and 0 deletions

View File

@@ -0,0 +1 @@
<?php

View File

@@ -0,0 +1,6 @@
<?php
//配置文件
return [
];

View File

@@ -0,0 +1,164 @@
<?php
namespace app\cron\controller;
use think\Db;
use Yzh\YunPay;
/*
* 定时任务,每秒执行的方法
*/
class PerformPerSecond
{
/*
* 运行函数
*/
function index()
{
echo "拍卖房结束提醒:\n";
$this->auction_end_notice();//拍卖房结束提醒
echo "\n";
echo "Pk房连线中倒计时结束操作PK结束\n";
$this->pk_start_end();
echo "\n";
echo "Pk房PK进行中倒计时结束操作PK结束\n";
$this->pk_end();
echo "\n";
echo "Pk房PK结束惩罚倒计时结束断开操作\n";
$this->pk_close();
echo "\n";
echo "pk发起10秒后无应答拒绝\n";
$this->pk_start_refuse();
echo "\n";
echo "提现云账号订单状态查询:\n";
$this->withdraw_order_status();
echo "\n";
}
//拍卖房结束提醒
protected function auction_end_notice()
{
$auction_list = db::name('vs_room_auction')->where(['status'=>2,'duration' => ['<',time()]])->select();
$data_count = 0;
if($auction_list){
foreach ($auction_list as &$value){
model('api/RoomAuction')->room_auction_end($value['room_id'],$value['auction_id']);
$data_count++;
}
}
echo "拍卖结束提醒完成-共" . $data_count . "条数据\n";
}
//pk发起10秒后无应答拒绝
protected function pk_start_refuse()
{
$pk_list = db::name('vs_room_pk')->where(['status'=>1])->select();
$data_count = 0;
if($pk_list){
foreach ($pk_list as &$value){
if($value['createtime'] + 10 <= time()){
//pk发起10秒后无应答拒绝
model('api/RoomPk')->accept_pk($value['pk_id'],2);
$data_count++;
}
}
}
echo "pk发起10秒后无应答拒绝-共". $data_count . "条数据\n";
}
//Pk房连线中倒计时结束操作PK结束
protected function pk_start_end()
{
$pk_list = db::name('vs_room_pk')->where(['status'=>2])->select();
$data_count = 0;
if($pk_list){
foreach ($pk_list as &$value){
if($value['updatetime'] + 300 <= time()){
//pk结束
model('api/RoomPk')->end_pk($value['pk_id'],4);
}
$data_count++;
}
}
echo "Pk房连线中倒计时结束操作PK结束-共". $data_count . "条数据\n";
}
//Pk房PK进行中倒计时结束操作PK结束
protected function pk_end()
{
$pk_list = db::name('vs_room_pk')->where(['status'=>3])->select();
$data_count = 0;
if($pk_list){
foreach ($pk_list as &$value){
if($value['start_time'] + $value['pk_times'] * 60 <= time()){
//pk结束
model('api/RoomPk')->end_pk($value['pk_id']);
}
$data_count++;
}
}
echo "Pk房PK进行中倒计时结束操作PK结束-共". $data_count . "条数据\n";
}
//Pk房PK结束惩罚倒计时结束断开操作
protected function pk_close()
{
$pk_list = db::name('vs_room_pk')->where(['status'=>['in',[4,7]]])->select();
$data_count = 0;
if($pk_list){
foreach ($pk_list as &$value){
if($value['updatetime'] + 300 <= time()){
//断开操作
model('api/RoomPk')->end_pk($value['pk_id'],2);
}
$data_count++;
}
}
echo "Pk房PK结束惩罚倒计时结束断开操作-共". $data_count . "条数据\n";
}
/*
* 提现云账号订单状态查询
*/
public function withdraw_order_status(){
//一个月内的数据
$time = time() - 7 * 86400;
$withdrawal = db::name('vs_user_withdrawal')->where(['deal_type'=>2,'status'=>['in',[4,5]]])->where(['submit_yun_time'=>['>=',$time]])->select();
echo "提现云账号订单状态查询条数(".count($withdrawal)."\n";
foreach ($withdrawal as $key => $value) {
if($value['status'] == 5){
if((time()-$value['pay_time']) >= 3600){
continue;
}
}
echo "提现订单查询:".$value['order_sn']."\n";
$yun_pay = new YunPay($value['order_sn'], "", "", "", "","");
$result = $yun_pay->queryOrder($value['type']);
if($result['code'] == 1){
if($result['data']['code']==0){
db::name('vs_user_withdrawal')->where('order_sn',$value['order_sn'])->update([
'status' => 6,
'pay_time' => time(),
'updatetime' => time()
]);
}else{
db::name('vs_user_withdrawal')->where('order_sn',$value['order_sn'])->update([
'status' => 5,
'pay_time' => time(),
'pay_message' => $result['data']['msg'],
'updatetime' => time()
]);
}
echo "提现订单查询成功:".$result['msg']."\n";
}else{
echo "提现订单查询失败:".$result['msg']."\n";
}
}
}
}

View File

@@ -0,0 +1,156 @@
<?php
namespace app\cron\controller;
use app\common\controller\adminApi;
use think\Controller;
use think\Db;
/*
* 工会
*/
class Subsidy
{
/*
* 运行函数
*/
function index()
{
echo "工会补贴生成开始:\n";
$this->createGuildSubsidyData();//工会补贴数据
echo "\n";
echo "房间补贴生成开始:\n";
$this->createRoomSubsidyData();//房间补贴数据
}
/*
* 生成工会补贴数据
* 配置:定时脚本每周一 执行
* 配置:/cron/Subsidy/createGuildSubsidyData
*/
public function createGuildSubsidyData(){
//获取上周第一天时间
$week_start_time = strtotime('-1 weeklast monday');
$week_end_time = strtotime('last sunday');
// $week_start_time = strtotime('this week monday');
// $week_end_time = strtotime('sunday');
//获取上周时间
$time_value = date('o-W', strtotime('-1 week'));
echo $time_value . "工会周补贴数据生成开始\n";
//查询所有工会
$guild_list = db::name('vs_guild')->where(['delete_time'=>0])->field('id')->select();
$data_count = 0;
foreach ($guild_list as $key => $value) {
//获取所有工会房间ID
$room_ids = db::name('vs_guild_user')->where('guild_id', $value['id'])->field('room_id')->select();
$room_ids = array_column($room_ids, 'room_id');
$transaction = db::name('vs_give_gift')
->whereIn('from_id',$room_ids)
->where(['from'=>['in',[2,3,6]],'createtime' => ['between', [$week_start_time, $week_end_time]]])
->sum('total_price');
if($transaction > 0){
//判断是否已经生成过
if (db::name('vs_guild_subsidy')->where(['guild_id'=>$value['id'],'week'=>$time_value])->find()) {
continue;
}
//获取补贴配置
$config = db::name('vs_guild_subsidy_config')->where(['status' => 1])->order('end_amount desc')->select(); //配置查询
if (!$config) {
echo '补贴配置为空\n';
die;
}
$subsidy_ratio = 0;
$subsidy_amount = 0;
foreach ($config as $k => $v) {
if ($transaction >= $v['end_amount']) {
$subsidy_ratio = $v['subsidy_ratio'];
$subsidy_amount = $transaction * ($subsidy_ratio / 100);
break; // 找到匹配项后提前退出循环
}
}
//生成补贴数据
$data = [
'guild_id' => $value['id'],
'week' => $time_value,
'start_time' => date('Y-m-d H:i:s', $week_start_time),
'end_time' =>date('Y-m-d H:i:s', $week_end_time),
'total_transaction' => $transaction,
'subsidy_amount' => $subsidy_amount,
'subsidy_ratio' => $subsidy_ratio,
'status' => 0,
'createtime' => time(),
];
$subsidy_id = Db::name('vs_guild_subsidy')->insertGetId($data);
if ($subsidy_id) {
echo "工会".$value['id']."生成成功(补贴ID".$subsidy_id." 补贴金额:".$subsidy_amount.")\n";
$data_count++;
}
}
}
echo $time_value . "工会周补贴数据生成完成-共" . $data_count . "条数据\n";
}
/*
* 生成房间补贴数据
* 配置:定时脚本每周一 执行
* 配置:/Core/RoomSubsidy/createRoomSubsidyData
*/
public function createRoomSubsidyData(){
//获取上周第一天时间
$week_start_time = strtotime('-1 weeklast monday');
$week_end_time = strtotime('last sunday');
// $week_start_time = strtotime('this week monday');
// $week_end_time = strtotime('sunday');
//获取上周时间
$time_value = date('o-W', strtotime('-1 week'));
echo $time_value . "房间周补贴数据生成开始\n";
//查询所有房间
$room_list = db::name('vs_room')->where(['delete_time'=>0,'is_earnings'=>1])->field('id')->select();
$data_count = 0;
foreach ($room_list as $key => $value) {
$transaction = db::name('vs_give_gift')
->where('from_id',$value['id'])
->where(['from'=>['in',[2,3,6]],'createtime' => ['between', [$week_start_time, $week_end_time]]])
->sum('total_price');
if($transaction > 0){
//判断是否已经生成过
if (db::name('vs_room_subsidy')->where(['room_id'=>$value['id'],'week'=>$time_value])->find()) {
continue;
}
//获取补贴配置
$config = db::name('vs_room_subsidy_config')->where(['status' => 1])->order('end_amount desc')->select(); //配置查询
if (!$config) {
echo '补贴配置为空\n';
die;
}
$subsidy_ratio = 0;
$subsidy_amount = 0;
foreach ($config as $k => $v) {
if ($transaction >= $v['end_amount']) {
$subsidy_ratio = $v['subsidy_ratio'];
$subsidy_amount = $transaction * ($subsidy_ratio / 100);
break; // 找到匹配项后提前退出循环
}
}
//生成补贴数据
$data = [
'room_id' => $value['id'],
'week' => $time_value,
'start_time' => date('Y-m-d H:i:s', $week_start_time),
'end_time' =>date('Y-m-d H:i:s', $week_end_time),
'total_transaction' => $transaction,
'subsidy_amount' => $subsidy_amount,
'subsidy_ratio' => $subsidy_ratio,
'status' => 0,
'createtime' => time(),
];
$subsidy_id = Db::name('vs_room_subsidy')->insertGetId($data);
if ($subsidy_id) {
echo "房间".$value['id']."生成成功(补贴ID".$subsidy_id." 补贴金额:".$subsidy_amount.")\n";
$data_count++;
}
}
}
echo $time_value . "房间周补贴数据生成完成-共" . $data_count . "条数据\n";
}
}

View File

@@ -0,0 +1,61 @@
<?php
namespace app\cron\controller;
use think\Db;
/*
* 定时任务,每秒执行的方法
*/
class TenSeconds
{
/*
* 运行函数
*/
function index()
{
echo "房间在线人数:\n";
$this->auction_end_notice();//拍卖房结束提醒
echo "\n";
}
protected function auction_end_notice()
{
$auction_list = db::name('vs_room')->field('id')->where(['room_status'=>1,'apply_status' => 2,'type_id' =>['<>',6]])->select();
$data_count = 0;
$data_number = 0;
if($auction_list){
foreach ($auction_list as &$value){
$num = model('api/Room')->room_online_number($value['id']);
// $on_pit_num = db::name('vs_room_pit')->field('user_id')->where(['room_id' => $value['id'],'user_id' => ['<>',0]])->count();
if($num['code'] == 1){
if($num['data']['online_number'] > 0){
$text = [
'online_number' => $num['data']['online_number'],
'room_id' => $value['id'],//接受房间id
];
model('api/Chat')->sendMsg(1036,$value['id'],$text);
$data_number++;
}
}
// else{
// if($on_pit_num > 0){
// $text = [
// 'online_number' => $on_pit_num,
// 'room_id' => $value['id'],//接受房间id
// ];
// model('api/Chat')->sendMsg(1036,$value['id'],$text);
// $data_number++;
// }
// }
$data_count++;
}
}
echo "房间共" . $data_count . "条数据\n";
echo "房间在线人数>0 的总共" . $data_number . "条数据\n";
}
}