1
0
mirror of https://github.com/owncloudarchive/contacts.git synced 2025-01-25 14:52:17 +01:00
OwncloudContactsOfficial/lib/jsonresponse.php

84 lines
1.9 KiB
PHP
Raw Permalink Normal View History

<?php
/**
* @author Thomas Tanghus, Bart Visscher
* Copyright (c) 2013 Thomas Tanghus (thomas@tanghus.net)
* This file is licensed under the Affero General Public License version 3 or
* later.
* See the COPYING-README file.
*/
namespace OCA\Contacts;
2013-09-17 18:46:59 +02:00
use OCP\AppFramework\Http\JSONResponse as OriginalResponse,
2013-10-23 12:56:30 +02:00
OCP\AppFramework\Http;
/**
* A renderer for JSON calls
*/
class JSONResponse extends OriginalResponse {
2013-10-17 02:10:34 +02:00
public function __construct($params = array(), $statusCode = Http::STATUS_OK) {
2013-09-10 07:16:32 +02:00
parent::__construct(array(), $statusCode);
2013-10-17 02:10:34 +02:00
$this->data = $params;
}
2013-09-17 18:46:59 +02:00
/**
* Sets values in the data json array
* @param array|object $params an array or object which will be transformed
* to JSON
*/
2013-09-27 16:38:22 +02:00
public function setParams(array $params) {
$this->setData($params);
return $this;
2013-09-17 18:46:59 +02:00
}
2013-10-17 02:10:34 +02:00
public function setData($data) {
2013-09-27 16:38:22 +02:00
$this->data = $data;
return $this;
}
public function setStatus($status) {
parent::setStatus($status);
return $this;
}
2013-09-17 18:46:59 +02:00
/**
* in case we want to render an error message, also logs into the owncloud log
* @param string $message the error message
*/
public function setErrorMessage($message){
$this->error = true;
2013-09-27 16:38:22 +02:00
$this->data = $message;
return $this;
}
function bailOut($msg, $tracelevel = 1, $debuglevel = \OCP\Util::ERROR) {
2013-09-03 14:00:11 +02:00
if($msg instanceof \Exception) {
$msg = $msg->getMessage();
$this->setStatus($msg->getCode());
}
$this->setErrorMessage($msg);
2013-10-17 02:10:34 +02:00
return $this->debug($msg, $tracelevel, $debuglevel);
}
function debug($msg, $tracelevel = 0, $debuglevel = \OCP\Util::DEBUG) {
if(!is_numeric($tracelevel)) {
2013-09-27 16:38:22 +02:00
return $this;
}
if(PHP_VERSION >= "5.4") {
$call = debug_backtrace(false, $tracelevel + 1);
} else {
$call = debug_backtrace(false);
}
$call = $call[$tracelevel];
if($debuglevel !== false) {
\OCP\Util::writeLog('contacts',
$call['file'].'. Line: '.$call['line'].': '.$msg,
$debuglevel);
}
2013-09-27 16:38:22 +02:00
return $this;
}
}