mirror of
https://codeberg.org/demostf/api.git
synced 2026-06-03 09:54:17 +02:00
ordering for profile and uploads
This commit is contained in:
parent
202d11fcc9
commit
750de60257
2 changed files with 8 additions and 6 deletions
|
|
@ -120,12 +120,14 @@ class DemoController extends BaseController {
|
||||||
$page = (int) $this->query('page', '1');
|
$page = (int) $this->query('page', '1');
|
||||||
$where = $this->getFilter();
|
$where = $this->getFilter();
|
||||||
$where['players'][] = $steamId;
|
$where['players'][] = $steamId;
|
||||||
$this->json($this->demoListProvider->listProfile((int) $page, $where));
|
$order = 'ASC' === $this->query('order', 'DESC') ? 'ASC' : 'DESC';
|
||||||
|
$this->json($this->demoListProvider->listProfile((int) $page, $where, $order));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function listUploads(string $steamId): void {
|
public function listUploads(string $steamId): void {
|
||||||
$page = (int) $this->query('page', '1');
|
$page = (int) $this->query('page', '1');
|
||||||
$this->json($this->demoListProvider->listUploads($steamId, (int) $page, $this->getFilter()));
|
$order = 'ASC' === $this->query('order', 'DESC') ? 'ASC' : 'DESC';
|
||||||
|
$this->json($this->demoListProvider->listUploads($steamId, (int) $page, $this->getFilter(), $order));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function chat(string $demoId): void {
|
public function chat(string $demoId): void {
|
||||||
|
|
|
||||||
|
|
@ -17,7 +17,7 @@ class DemoListProvider extends BaseProvider {
|
||||||
*
|
*
|
||||||
* @return Demo[]
|
* @return Demo[]
|
||||||
*/
|
*/
|
||||||
public function listUploads(string $steamId, int $page, array $where = []) {
|
public function listUploads(string $steamId, int $page, array $where = [], string $order = 'DESC') {
|
||||||
$query = $this->getQueryBuilder();
|
$query = $this->getQueryBuilder();
|
||||||
$query->select('id')
|
$query->select('id')
|
||||||
->from('users')
|
->from('users')
|
||||||
|
|
@ -29,7 +29,7 @@ class DemoListProvider extends BaseProvider {
|
||||||
|
|
||||||
$where['uploader'] = $userId;
|
$where['uploader'] = $userId;
|
||||||
|
|
||||||
return $this->listDemos($page, $where);
|
return $this->listDemos($page, $where, $order);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -39,7 +39,7 @@ class DemoListProvider extends BaseProvider {
|
||||||
*
|
*
|
||||||
* @return Demo[]
|
* @return Demo[]
|
||||||
*/
|
*/
|
||||||
public function listProfile(int $page, array $where = []): array {
|
public function listProfile(int $page, array $where = [], string $order = 'DESC'): array {
|
||||||
$query = $this->getQueryBuilder();
|
$query = $this->getQueryBuilder();
|
||||||
$query->select('id')
|
$query->select('id')
|
||||||
->from('users')
|
->from('users')
|
||||||
|
|
@ -66,7 +66,7 @@ class DemoListProvider extends BaseProvider {
|
||||||
$query->where($query->expr()->eq('user_id',
|
$query->where($query->expr()->eq('user_id',
|
||||||
$query->createNamedParameter($userIds[0], PDO::PARAM_INT)));
|
$query->createNamedParameter($userIds[0], PDO::PARAM_INT)));
|
||||||
}
|
}
|
||||||
$query->orderBy('demo_id', 'desc')
|
$query->orderBy('demo_id', $order)
|
||||||
->setMaxResults(50)
|
->setMaxResults(50)
|
||||||
->setFirstResult(((int) $page - 1) * 50);
|
->setFirstResult(((int) $page - 1) * 50);
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue