mirror of
https://github.com/lkddi/nexusphp.git
synced 2026-04-24 03:57:22 +08:00
api peer list
This commit is contained in:
@@ -5,10 +5,17 @@ namespace App\Http\Controllers;
|
||||
use App\Http\Resources\PeerResource;
|
||||
use App\Models\Peer;
|
||||
use App\Models\Torrent;
|
||||
use App\Repositories\TorrentRepository;
|
||||
use Illuminate\Http\Request;
|
||||
|
||||
class PeerController extends Controller
|
||||
{
|
||||
private $repository;
|
||||
|
||||
public function __construct(TorrentRepository $repository)
|
||||
{
|
||||
$this->repository = $repository;
|
||||
}
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
*
|
||||
@@ -17,22 +24,22 @@ class PeerController extends Controller
|
||||
*/
|
||||
public function index(Request $request)
|
||||
{
|
||||
$torrentId = $request->torrent_id;
|
||||
$peers = Peer::query()->where('torrent', $torrentId)->with(['user', 'relative_torrent'])->get()->groupBy('seeder');
|
||||
$seederResource = [];
|
||||
$leecherResource = [];
|
||||
if ($peers->has(Peer::SEEDER_YES)) {
|
||||
$seederResource = PeerResource::collection($peers->get(Peer::SEEDER_YES));
|
||||
}
|
||||
if ($peers->has(Peer::SEEDER_NO)) {
|
||||
$leecherResource = PeerResource::collection($peers->get(Peer::SEEDER_NO));
|
||||
}
|
||||
$request->validate([
|
||||
'torrent_id' => 'required',
|
||||
]);
|
||||
|
||||
$response = [
|
||||
'seeder_list' => $seederResource,
|
||||
'leecher_list' => $leecherResource,
|
||||
'seeder_list' => [],
|
||||
'leecher_list' => [],
|
||||
'card_titles' => Peer::$cardTitles,
|
||||
];
|
||||
$result = $this->repository->listPeers($request->torrent_id);
|
||||
if ($result['seeder_list']->isNotEmpty()) {
|
||||
$response['seeder_list'] = PeerResource::collection($result['seeder_list']);
|
||||
}
|
||||
if ($result['leecher_list']->isNotEmpty()) {
|
||||
$response['leecher_list'] = PeerResource::collection($result['leecher_list']);
|
||||
}
|
||||
|
||||
return $this->success($response);
|
||||
|
||||
|
||||
@@ -14,69 +14,19 @@ class PeerResource extends JsonResource
|
||||
*/
|
||||
public function toArray($request)
|
||||
{
|
||||
$seconds = $this->started->diff($this->last_action)->s;
|
||||
if ($this->uploaded == 0) {
|
||||
$uploadSpeed = mksize(0) . '/s';
|
||||
} else {
|
||||
$uploadSpeed = mksize(($this->uploaded - $this->uploadoffset) / $seconds) . '/s';
|
||||
}
|
||||
$nowTimestamp = time();
|
||||
return [
|
||||
'id' => $this->id,
|
||||
'connectable_text' => $this->connectableText,
|
||||
|
||||
'upload_text' => sprintf('%s@%s', mksize($this->uploaded), $uploadSpeed),
|
||||
|
||||
'download_text' => sprintf('%s@%s', mksize($this->downloaded), $this->getUploadSpeed($this->resource)),
|
||||
|
||||
'share_ratio' => $this->getShareRatio($this->resource),
|
||||
'download_progress' => $this->getDownloadProgress($this->resource),
|
||||
'connect_time_total' => mkprettytime($nowTimestamp - $this->started->timestamp),
|
||||
'last_action_human' => mkprettytime($nowTimestamp - $this->last_action->timestamp),
|
||||
'agent_human' => htmlspecialchars(get_agent($this->peer_id, $this->agent)),
|
||||
'upload_text' => $this->upload_text,
|
||||
'download_text' => $this->download_text,
|
||||
'share_ratio' => $this->share_ratio,
|
||||
'download_progress' => $this->download_progress,
|
||||
'connect_time_total' => $this->connect_time_total,
|
||||
'last_action_human' => $this->last_action_human,
|
||||
'agent_human' => $this->agent_human,
|
||||
'user' => new UserResource($this->whenLoaded('user')),
|
||||
|
||||
];
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 获得上传速度
|
||||
*
|
||||
* @see viewpeerlist.php
|
||||
*
|
||||
* @param $peer
|
||||
* @return string
|
||||
*/
|
||||
protected function getUploadSpeed($peer)
|
||||
{
|
||||
$diff = $peer->downloaded - $peer->downloadoffset;
|
||||
if ($peer->isSeeder()) {
|
||||
$seconds = $peer->finishedat - $peer->started->getTimestamp();
|
||||
} else {
|
||||
$seconds = $this->started->diff($this->last_action)->s;
|
||||
}
|
||||
|
||||
return mksize($diff / $seconds) . '/s';
|
||||
}
|
||||
|
||||
protected function getShareRatio($peer)
|
||||
{
|
||||
if ($peer->downloaded) {
|
||||
$ratio = floor(($peer->uploaded / $peer->downloaded) * 1000) / 1000;
|
||||
} elseif ($peer->uploaded) {
|
||||
//@todo 读语言文件
|
||||
$ratio = '无限';
|
||||
} else {
|
||||
$ratio = '---';
|
||||
}
|
||||
|
||||
return $ratio;
|
||||
}
|
||||
|
||||
protected function getDownloadProgress($peer)
|
||||
{
|
||||
return sprintf("%.2f%%", 100 * (1 - ($peer->to_go / $peer->relative_torrent->size)));
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user