| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 |
- <?php
- namespace app\api\controller\auction;
- use app\models\auction\Auction;
- use app\models\auction\AuctionBooking;
- use app\models\auction\AuctionOrder;
- use app\models\auction\AuctionPay;
- use app\models\auction\AuctionSection;
- use app\models\user\User;
- use app\models\user\UserBill;
- use app\Request;
- use Monolog\Handler\Curl\Util;
- use think\facade\Cache;
- use crmeb\services\{
- CacheService,
- ExpressService,
- SystemConfigService
- };
- use crmeb\services\UtilService;
- use crmeb\repositories\OrderRepository;
- use think\facade\Db;
- use think\facade\Validate;
- class AuctionController
- {
- /**
- * 场馆列表
- * @param Request $request
- * @return mixed
- */
- public function list(Request $request)
- {
- $data = UtilService::getMore([
- [['page', 'd'], 0],
- [['limit', 'd'], 0],
- ['advance'],
- ], $request);
- $auctionModel = new \app\models\auction\Auction();
- return app('json')->successful($auctionModel->list($data, $request->uid()));
- }
- /**
- * 预约场馆
- * @param Request $request
- * @return mixed
- * @throws \think\db\exception\DataNotFoundException
- * @throws \think\db\exception\DbException
- * @throws \think\db\exception\ModelNotFoundException
- */
- public function subscribe(Request $request)
- {
- $data = UtilService::postMore([
- ['id']
- ]);
- if (!$data['id']) return app('json')->fail('数据传入错误');
- $auctionModel = new Auction();
- $auction = $auctionModel->find($data['id']);
- if (!$auction)return app('json')->fail('没有此数据');
- if (strtotime($auction['radd_time']) < time() or (strtotime($auction['radd_time'])-1800) < time()) return app('json')->fail('预约时间已过');
- if (AuctionBooking::where([['uid', '=', $request->uid()], ['auction_id' , '=', $auction['id']], ['frequency', '=', $auction['frequency']]])->find()){
- return app('json')->fail('当前场馆已预约');
- }
- $userModel = new User();
- $user = $userModel->find($request->uid());
- if($auction['lowest'] > $user['now_money'] or $auction['minimum'] > $user['aid_val']) return app('json')->fail('未达到预约门槛');
- if ($user['aid_val'] < $auction['advert']) return app('json')->fail('广告值不够');
- $user['aid_val'] = $user['aid_val'] - $auction['advert'];// 扣除广告值
- User::rollbackTrans();
- $res = $user->save();
- if ($res){
- AuctionBooking::booking($user['uid'], $auction);
- UserBill::expend('预约场馆', $user['uid'], 'aid_val','sub_aid_val', $auction['advert'], 0, $user['aid_val'], '预约冻结广告值'); // 写入记录
- User::commitTrans();
- return app('json')->successful('预约成功');
- }else{
- User::rollbackTrans();
- return app('json')->fail('预约失败');
- }
- }
- /**
- * 进入场馆
- * @param Request $request
- * @return void
- */
- public function advance(Request $request)
- {
- $data = UtilService::getMore([
- ['id']
- ]);
- $auction = Auction::find($data['id']);
- if (!$auction) return app('json')->fail('场次不存在');
- $booking = AuctionBooking::where([['auction_id', '=',$auction['id']], ['frequency', '=', $auction['frequency']]])->find();
- $user = $request->user();
- $time = $user['add_time'] + (3600*48);
- if (!$booking){
- return app('json')->fail('未预约');
- }
- if (time() < $time or $user['is_real'] == 1){
- // 注册四十八小时或者团长提前入场
- if (strtotime($auction['radd_time']) - 180 > time()){
- return app('json')->fail('未到进入时间');
- }else if (strtotime($auction['rend_time']) < time()){
- return app('json')->fail('进场时间已过');
- }
- }else{
- if (strtotime($auction['radd_time']) > time()){
- return app('json')->fail('未到进场时间');
- }else if (strtotime($auction['rend_time']) < time()){
- return app('json')->fail('进场时间已过');
- }
- }
- return app('json')->successful('可进入');
- }
- public function section(Request $request)
- {
- $data = UtilService::getMore([
- ['id']
- ]);
- $auction = Auction::find($data['id']);
- if (!$auction) return app('json')->fail('场次不存在');
- $list = AuctionSection::where('auction_id', $data['id'])->order('id DESC')->select();
- $list = empty($list) ? [] : $list->toArray();
- return app('json')->successful($list);
- }
- }
|