AzuraCast/src/Controller/Api/IndexController.php

66 lines
1.7 KiB
PHP
Raw Normal View History

<?php
2021-07-19 05:53:45 +00:00
declare(strict_types=1);
namespace App\Controller\Api;
use App\Entity;
use App\Http\Response;
use App\Http\ServerRequest;
2020-07-08 07:03:50 +00:00
use OpenApi\Annotations as OA;
use Psr\Http\Message\ResponseInterface;
class IndexController
{
/**
* Public index for API.
*
* @param ServerRequest $request
* @param Response $response
*/
public function indexAction(ServerRequest $request, Response $response): ResponseInterface
{
return $response->withRedirect('/static/api/index.html');
}
/**
2018-09-18 14:09:48 +00:00
* @OA\Get(path="/status",
* tags={"Miscellaneous"},
* description="Returns an affirmative response if the API is active.",
* parameters={},
2018-09-18 14:09:48 +00:00
* @OA\Response(
* response=200,
* description="Success",
* @OA\JsonContent(ref="#/components/schemas/Api_SystemStatus")
* )
* )
*
* @param ServerRequest $request
* @param Response $response
*/
public function statusAction(ServerRequest $request, Response $response): ResponseInterface
{
return $response->withJson(new Entity\Api\SystemStatus());
}
/**
2018-09-18 14:09:48 +00:00
* @OA\Get(path="/time",
* tags={"Miscellaneous"},
* description="Returns the time (with formatting) in GMT and the user's local time zone, if logged in.",
* parameters={},
2018-09-18 14:09:48 +00:00
* @OA\Response(
* response=200,
* description="Success",
* @OA\JsonContent(ref="#/components/schemas/Api_Time")
* )
* )
*
* @param ServerRequest $request
* @param Response $response
*/
public function timeAction(ServerRequest $request, Response $response): ResponseInterface
{
return $response->withJson(new Entity\Api\Time());
}
}