mirror of
https://github.com/lkddi/nexusphp.git
synced 2026-04-15 13:32:41 +08:00
API: torrents upload/list
This commit is contained in:
@@ -4,25 +4,34 @@ namespace App\Http\Controllers;
|
||||
|
||||
use App\Exceptions\InsufficientPermissionException;
|
||||
use App\Models\Setting;
|
||||
use App\Utils\ApiQueryBuilder;
|
||||
use Illuminate\Foundation\Auth\Access\AuthorizesRequests;
|
||||
use Illuminate\Foundation\Bus\DispatchesJobs;
|
||||
use Illuminate\Foundation\Validation\ValidatesRequests;
|
||||
use Illuminate\Http\Resources\Json\AnonymousResourceCollection;
|
||||
use Illuminate\Http\Resources\Json\JsonResource;
|
||||
use Illuminate\Http\Resources\MissingValue;
|
||||
use Illuminate\Routing\Controller as BaseController;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
use Illuminate\Support\Str;
|
||||
|
||||
|
||||
/**
|
||||
* @OA\Info(
|
||||
* title="NexusPHP API",
|
||||
* version="1.0"
|
||||
* )
|
||||
*/
|
||||
class Controller extends BaseController
|
||||
{
|
||||
use AuthorizesRequests, DispatchesJobs, ValidatesRequests;
|
||||
|
||||
public function success($data, $msg = null)
|
||||
protected ?array $extraFields = null;
|
||||
protected ?array $extraSettingNames = null;
|
||||
|
||||
/**
|
||||
* 返回成功信息,这里是旧方法,大部分情况下 $data 已经是 JsonResource
|
||||
* 但很多地方有使用,历史原因保留不动,尽量使用 successJsonResource
|
||||
*
|
||||
* @param $data
|
||||
* @param $msg
|
||||
* @return array
|
||||
*/
|
||||
public function success($data, $msg = null): array
|
||||
{
|
||||
if (is_null($msg)) {
|
||||
$backtrace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 2);
|
||||
@@ -32,6 +41,34 @@ class Controller extends BaseController
|
||||
return success($msg, $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* 返回成功信息,对于不是 JsonResource 的数据,进行包装。返回的数据在 data.data 中
|
||||
*
|
||||
* @param $data
|
||||
* @param $msg
|
||||
* @return array
|
||||
*/
|
||||
public function successJsonResource($data, $msg = null): array
|
||||
{
|
||||
if (is_null($msg)) {
|
||||
$backtrace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 2);
|
||||
$caller = $backtrace[1];
|
||||
$msg = $this->getReturnMsg($caller);
|
||||
}
|
||||
if ($data instanceof JsonResource) {
|
||||
return $this->success($data, $msg);
|
||||
}
|
||||
$resource = new JsonResource($data);
|
||||
return $this->success($resource, $msg);
|
||||
}
|
||||
|
||||
/**
|
||||
* 返回失败信息,目前对于失败信息不需要包装
|
||||
*
|
||||
* @param $data
|
||||
* @param $msg
|
||||
* @return array
|
||||
*/
|
||||
public function fail($data, $msg = null)
|
||||
{
|
||||
if (is_null($msg)) {
|
||||
@@ -78,6 +115,31 @@ class Controller extends BaseController
|
||||
return [$perPage, ['*'], 'page', $page];
|
||||
}
|
||||
|
||||
protected function hasExtraField($field): bool
|
||||
{
|
||||
if ($this->extraFields === null) {
|
||||
$extraFieldsStr = request()->input("extra_fields", '');
|
||||
$this->extraFields = explode(',', $extraFieldsStr);
|
||||
}
|
||||
do_log(sprintf("field: %s, extraFields: %s", $field, json_encode($this->extraFields)));
|
||||
return in_array($field, $this->extraFields);
|
||||
}
|
||||
|
||||
protected function appendExtraSettings(array &$additional, array $names): void
|
||||
{
|
||||
if ($this->extraSettingNames === null) {
|
||||
$extraSettingStr = request()->input("extra_settings", '');
|
||||
$this->extraSettingNames = explode(',', $extraSettingStr);
|
||||
}
|
||||
$results = [];
|
||||
foreach ($names as $name) {
|
||||
if (in_array($name, $this->extraSettingNames)) {
|
||||
$results[$name] = get_setting($name);
|
||||
}
|
||||
}
|
||||
if (!empty($results)) {
|
||||
$additional['extra_settings'] = $results;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -27,14 +27,12 @@ class TokenController extends Controller
|
||||
$user = Auth::user();
|
||||
$count = $user->tokens()->count();
|
||||
if ($count >= 5) {
|
||||
throw new NexusException("Token limit exceeded");
|
||||
throw new NexusException(nexus_trans("token.maximum_allow_number_reached"));
|
||||
}
|
||||
$newAccessToken = $user->createToken($request->name, $request->permissions);
|
||||
PersonalAccessTokenPlain::query()->create([
|
||||
'access_token_id' => $newAccessToken->accessToken->getKey(),
|
||||
'plain_text_token' => $newAccessToken->plainTextToken,
|
||||
]);
|
||||
return $this->success(true);
|
||||
$tokenText = $newAccessToken->plainTextToken;
|
||||
$msg = nexus_trans("token.create_success_tip", ['token' => $tokenText]);
|
||||
return $this->successJsonResource(['token' => $tokenText], $msg);
|
||||
} catch (\Exception $exception) {
|
||||
return $this->fail(false, $exception->getMessage());
|
||||
}
|
||||
@@ -47,11 +45,7 @@ class TokenController extends Controller
|
||||
'id' => 'required|integer',
|
||||
]);
|
||||
$user = Auth::user();
|
||||
$token = $user->tokens()->where("id", $request->id)->first();
|
||||
if ($token) {
|
||||
PersonalAccessTokenPlain::query()->where("access_token_id", $token->id)->delete();
|
||||
$token->delete();
|
||||
}
|
||||
$user->tokens()->where("id", $request->id)->delete();
|
||||
return $this->success(true);
|
||||
} catch (\Exception $exception) {
|
||||
return $this->fail(false, $exception->getMessage());
|
||||
|
||||
@@ -6,6 +6,7 @@ use App\Models\PluginStore;
|
||||
use App\Repositories\ToolRepository;
|
||||
use App\Repositories\UploadRepository;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Http\Resources\Json\JsonResource;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
use Symfony\Component\Process\Process;
|
||||
use Symfony\Component\HttpFoundation\StreamedResponse;
|
||||
@@ -31,9 +32,9 @@ class ToolController extends Controller
|
||||
|
||||
public function test(Request $request)
|
||||
{
|
||||
$rep = new UploadRepository();
|
||||
$result = $rep->listSections();
|
||||
return $result;
|
||||
$result = ['id' => 1];
|
||||
$resource = new JsonResource($result);
|
||||
return $this->success($resource);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -11,7 +11,10 @@ use App\Models\TorrentDenyReason;
|
||||
use App\Models\TorrentOperationLog;
|
||||
use App\Models\User;
|
||||
use App\Repositories\TorrentRepository;
|
||||
use App\Repositories\UploadRepository;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Http\Resources\Json\AnonymousResourceCollection;
|
||||
use Illuminate\Http\Resources\Json\JsonResource;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
|
||||
class TorrentController extends Controller
|
||||
@@ -23,17 +26,10 @@ class TorrentController extends Controller
|
||||
$this->repository = $repository;
|
||||
}
|
||||
|
||||
public function index(Request $request)
|
||||
public function index(Request $request, string $section = null)
|
||||
{
|
||||
$params = $request->all();
|
||||
$params['visible'] = Torrent::VISIBLE_YES;
|
||||
$params['category_mode'] = Setting::get('main.browsecat');
|
||||
$result = $this->repository->getList($params, Auth::user());
|
||||
$result = $this->repository->getList($request, Auth::user(), $section);
|
||||
$resource = TorrentResource::collection($result);
|
||||
// $resource->additional([
|
||||
// 'page_title' => nexus_trans('torrent.index.page_title'),
|
||||
// ]);
|
||||
|
||||
return $this->success($resource);
|
||||
}
|
||||
|
||||
@@ -41,18 +37,21 @@ class TorrentController extends Controller
|
||||
* Store a newly created resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return \Illuminate\Http\Response
|
||||
* @return array
|
||||
*/
|
||||
public function store(Request $request)
|
||||
{
|
||||
//
|
||||
$uploadRep = new UploadRepository();
|
||||
$newTorrent = $uploadRep->upload($request);
|
||||
$resource = new JsonResource(["id" => $newTorrent->id]);
|
||||
return $this->success($resource);
|
||||
}
|
||||
|
||||
/**
|
||||
* Display the specified resource.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
* @return array
|
||||
*/
|
||||
public function show($id)
|
||||
{
|
||||
@@ -60,17 +59,15 @@ class TorrentController extends Controller
|
||||
* @var User
|
||||
*/
|
||||
$user = Auth::user();
|
||||
$result = $this->repository->getDetail($id, $user);
|
||||
$isBookmarked = $user->bookmarks()->where('torrentid', $id)->exists();
|
||||
|
||||
$resource = new TorrentResource($result);
|
||||
$resource->additional([
|
||||
// 'page_title' => nexus_trans('torrent.show.page_title'),
|
||||
// 'field_labels' => Torrent::getFieldLabels(),
|
||||
'is_bookmarked' => (int)$isBookmarked,
|
||||
'bonus_reward_values' => Torrent::BONUS_REWARD_VALUES,
|
||||
]);
|
||||
|
||||
$torrent = $this->repository->getDetail($id, $user);
|
||||
$resource = new TorrentResource($torrent);
|
||||
$additional = [];
|
||||
if ($this->hasExtraField('bonus_reward_values')) {
|
||||
$additional['bonus_reward_values'] = Torrent::BONUS_REWARD_VALUES;
|
||||
}
|
||||
$extraSettingsNames = ['torrent.claim_torrent_user_counts_up_limit'];
|
||||
$this->appendExtraSettings($additional, $extraSettingsNames);
|
||||
$resource->additional($additional);
|
||||
return $this->success($resource);
|
||||
}
|
||||
|
||||
|
||||
@@ -3,6 +3,7 @@
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Http\Resources\SearchBoxResource;
|
||||
use App\Http\Resources\TorrentResource;
|
||||
use App\Repositories\SearchBoxRepository;
|
||||
use App\Repositories\UploadRepository;
|
||||
use Illuminate\Http\Request;
|
||||
@@ -26,10 +27,4 @@ class UploadController extends Controller
|
||||
return $this->success($resource);
|
||||
}
|
||||
|
||||
public function upload(Request $request)
|
||||
{
|
||||
$user = $request->user();
|
||||
return $this->success("OK");
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -15,6 +15,7 @@ use App\Repositories\UserRepository;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Http\Resources\Json\JsonResource;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
use League\OAuth2\Server\Grant\AuthCodeGrant;
|
||||
|
||||
class UserController extends Controller
|
||||
{
|
||||
@@ -64,10 +65,15 @@ class UserController extends Controller
|
||||
* @param int $id
|
||||
* @return array
|
||||
*/
|
||||
public function show($id)
|
||||
public function show($id = null)
|
||||
{
|
||||
$result = $this->repository->getDetail($id);
|
||||
return $this->success($result);
|
||||
$currentUser = Auth::user();
|
||||
if ($id === null) {
|
||||
$id = $currentUser->id;
|
||||
}
|
||||
$result = $this->repository->getDetail($id, $currentUser);
|
||||
$resource = new UserResource($result);
|
||||
return $this->success($resource);
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
Reference in New Issue
Block a user