summaryrefslogtreecommitdiffstats
path: root/lib/json.php
diff options
context:
space:
mode:
authorBartek Przybylski <bart.p.pl@gmail.com>2011-09-25 22:32:16 +0200
committerBartek Przybylski <bart.p.pl@gmail.com>2011-09-25 22:32:16 +0200
commit63e6863222b92d7fc2e6ca5ccb3ab79688594348 (patch)
tree1d3b342b6eec3d4a0ec379cba4986dd43ba7216c /lib/json.php
parentbc43851d74e8fceea1c914e98a8cd571b84610d5 (diff)
parent17e631bc5e327514596ce8761fe7f93d414a8717 (diff)
downloadnextcloud-server-63e6863222b92d7fc2e6ca5ccb3ab79688594348.tar.gz
nextcloud-server-63e6863222b92d7fc2e6ca5ccb3ab79688594348.zip
Merge branch 'master' of git://gitorious.org/owncloud/owncloud
Diffstat (limited to 'lib/json.php')
-rw-r--r--lib/json.php68
1 files changed, 68 insertions, 0 deletions
diff --git a/lib/json.php b/lib/json.php
new file mode 100644
index 00000000000..47d5e82fbb0
--- /dev/null
+++ b/lib/json.php
@@ -0,0 +1,68 @@
+<?php
+/**
+ * Copyright (c) 2011 Bart Visscher <bartv@thisnet.nl>
+ * This file is licensed under the Affero General Public License version 3 or
+ * later.
+ * See the COPYING-README file.
+ */
+
+class OC_JSON{
+ static protected $send_content_type_header = false;
+ /**
+ * set Content-Type header to jsonrequest
+ */
+ public static function setContentTypeHeader($type='application/jsonrequest'){
+ if (!self::$send_content_type_header){
+ // We send json data
+ header( 'Content-Type: '.$type );
+ self::$send_content_type_header = true;
+ }
+ }
+
+ /**
+ * Check if the user is logged in, send json error msg if not
+ */
+ public static function checkLoggedIn(){
+ if( !OC_User::isLoggedIn()){
+ $l = new OC_L10N('core');
+ self::error(array( 'data' => array( 'message' => $l->t('Authentication error') )));
+ exit();
+ }
+ }
+
+ /**
+ * Check if the user is a admin, send json error msg if not
+ */
+ public static function checkAdminUser(){
+ self::checkLoggedIn();
+ if( !OC_Group::inGroup( OC_User::getUser(), 'admin' )){
+ $l = new OC_L10N('core');
+ self::error(array( 'data' => array( 'message' => $l->t('Authentication error') )));
+ exit();
+ }
+ }
+
+ /**
+ * Send json error msg
+ */
+ public static function error($data = array()){
+ $data['status'] = 'error';
+ self::encodedPrint($data);
+ }
+
+ /**
+ * Send json success msg
+ */
+ public static function success($data = array()){
+ $data['status'] = 'success';
+ self::encodedPrint($data);
+ }
+
+ /**
+ * Encode and print $data in json format
+ */
+ public static function encodedPrint($data){
+ self::setContentTypeHeader();
+ echo json_encode($data);
+ }
+}