| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110 |
- <?php
- namespace App\Http\Controllers\admin;
- use App\Http\Controllers\Controller;
- use App\Models\YuebaoItem;
- use App\Models\YuebaoLog;
- use Exception;
- use App\Constants\HttpStatus;
- class YueBao extends Controller
- {
- /**
- * 余额宝持仓列表
- */
- public function item()
- {
- try {
- $params = request()->validate([
- 'page' => ['nullable', 'integer', 'min:1'],
- 'limit' => ['nullable', 'integer', 'min:1'],
- 'id' => ['nullable', 'integer', 'min:1'],
- 'user_id' => ['nullable'],
- 'start_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:end_time'],
- 'end_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:start_time'],
- ]);
- $page = request()->input('page', 1);
- $limit = request()->input('limit', 15);
- $query = new YuebaoItem();
- if (!empty($params['id'])) {
- $query = $query->where('id', $params['id']);
- }
- if (!empty($params['user_id'])) {
- $query = $query->where('user_id', $params['user_id']);
- }
- if (!empty($params['start_time'])) {
- $startTime = strtotime($params['start_time'] . " 00:00:00");
- $query = $query->where('create_time', '>=', $startTime);
- }
- if (!empty($params['end_time'])) {
- $endTime = strtotime($params['end_time'] . " 23:59:59");
- $query = $query->where('create_time', '<=', $endTime);
- }
- $count = $query->count();
- $list = $query
- ->forPage($page, $limit)
- ->orderByDesc('create_time')
- ->get();
- } catch (Exception $e) {
- return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage());
- }
- return $this->success(['total' => $count, 'data' => $list]);
- }
- /**
- * 余额宝日志列表
- */
- public function log()
- {
- try {
- $params = request()->validate([
- 'page' => ['nullable', 'integer', 'min:1'],
- 'limit' => ['nullable', 'integer', 'min:1'],
- 'id' => ['nullable', 'integer', 'min:1'],
- 'item_id' => ['nullable', 'integer', 'min:1'],
- 'user_id' => ['nullable'],
- 'type' => ['nullable', 'integer'],
- 'start_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:end_time'],
- 'end_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:start_time'],
- ]);
- $page = request()->input('page', 1);
- $limit = request()->input('limit', 15);
- $query = new YuebaoLog();
- if (!empty($params['id'])) {
- $query = $query->where('id', $params['id']);
- }
- if (!empty($params['item_id'])) {
- $query = $query->where('item_id', $params['item_id']);
- }
- if (!empty($params['user_id'])) {
- $query = $query->where('user_id', $params['user_id']);
- }
- if (!empty($params['type'])) {
- $query = $query->where('type', $params['type']);
- }
- if (!empty($params['start_time'])) {
- $startTime = strtotime($params['start_time'] . " 00:00:00");
- $query = $query->where('create_time', '>=', $startTime);
- }
- if (!empty($params['end_time'])) {
- $endTime = strtotime($params['end_time'] . " 23:59:59");
- $query = $query->where('create_time', '<=', $endTime);
- }
- $count = $query->count();
- $list = $query
- ->forPage($page, $limit)
- ->orderByDesc('create_time')
- ->get();
- } catch (Exception $e) {
- return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage());
- }
- return $this->success(['total' => $count, 'data' => $list]);
- }
- }
|