nextcloud/lib/private/OCS/ApiHelper.php

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

81 lines
2.4 KiB
PHP
Raw Normal View History

<?php
declare(strict_types=1);
2015-10-05 14:54:56 -04:00
/**
* SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
* SPDX-FileCopyrightText: 2016 ownCloud, Inc.
* SPDX-License-Identifier: AGPL-3.0-only
2015-10-05 14:54:56 -04:00
*/
namespace OC\OCS;
use OC\AppFramework\OCS\V1Response;
use OC\AppFramework\OCS\V2Response;
use OCP\AppFramework\Http\DataResponse;
use OCP\AppFramework\OCSController;
use OCP\IRequest;
use OCP\Server;
class ApiHelper {
2012-07-28 17:50:40 -04:00
/**
* Respond to a call
* @psalm-taint-escape html
* @param int $overrideHttpStatusCode force the HTTP status code, only used for the special case of maintenance mode which return 503 even for v1
*/
public static function respond(int $statusCode, string $statusMessage, array $headers = [], ?int $overrideHttpStatusCode = null): void {
$request = Server::get(IRequest::class);
$format = $request->getParam('format', 'xml');
if (self::isV2($request)) {
$response = new V2Response(new DataResponse([], $statusCode, $headers), $format, $statusMessage);
} else {
$response = new V1Response(new DataResponse([], $statusCode, $headers), $format, $statusMessage);
}
2016-02-15 09:38:37 -05:00
// Send 401 headers if unauthorised
if ($response->getOCSStatus() === OCSController::RESPOND_UNAUTHORISED) {
2016-02-15 09:38:37 -05:00
// If request comes from JS return dummy auth request
if ($request->getHeader('X-Requested-With') === 'XMLHttpRequest') {
header('WWW-Authenticate: DummyBasic realm="Authorisation Required"');
} else {
header('WWW-Authenticate: Basic realm="Authorisation Required"');
}
http_response_code(401);
}
foreach ($response->getHeaders() as $name => $value) {
header($name . ': ' . $value);
}
http_response_code($overrideHttpStatusCode ?? $response->getStatus());
2015-08-03 15:03:11 -04:00
self::setContentType($format);
$body = $response->render();
2015-08-03 15:03:11 -04:00
echo $body;
2012-07-28 17:50:40 -04:00
}
2012-08-01 13:48:51 -04:00
2014-03-11 19:35:19 -04:00
/**
* Based on the requested format the response content type is set
*/
public static function setContentType(?string $format = null): void {
$format ??= Server::get(IRequest::class)->getParam('format', 'xml');
2014-03-11 19:35:19 -04:00
if ($format === 'xml') {
header('Content-type: text/xml; charset=UTF-8');
return;
}
if ($format === 'json') {
header('Content-Type: application/json; charset=utf-8');
return;
}
header('Content-Type: application/octet-stream; charset=utf-8');
}
protected static function isV2(IRequest $request): bool {
$script = $request->getScriptName();
2014-03-11 19:35:19 -04:00
return str_ends_with($script, '/ocs/v2.php');
}
2012-07-30 15:03:41 -04:00
}