aboutsummaryrefslogtreecommitdiffstats
path: root/include/api_zot.php
diff options
context:
space:
mode:
authorzotlabs <mike@macgirvin.com>2016-11-14 20:50:55 -0800
committerzotlabs <mike@macgirvin.com>2016-11-14 20:50:55 -0800
commite0a83b4b94d50a69d787ba7484683941238596ab (patch)
tree498ea31f6e1f90eb203ed1ae622d7a915f0478f5 /include/api_zot.php
parentb9728a96ce22f90e40ff5d5c3a4f5bf413dcbde6 (diff)
downloadvolse-hubzilla-e0a83b4b94d50a69d787ba7484683941238596ab.tar.gz
volse-hubzilla-e0a83b4b94d50a69d787ba7484683941238596ab.tar.bz2
volse-hubzilla-e0a83b4b94d50a69d787ba7484683941238596ab.zip
API: add GET /api/z/1.0/perm_allowed
Diffstat (limited to 'include/api_zot.php')
-rw-r--r--include/api_zot.php24
1 files changed, 24 insertions, 0 deletions
diff --git a/include/api_zot.php b/include/api_zot.php
index 107b73796..49a3f1077 100644
--- a/include/api_zot.php
+++ b/include/api_zot.php
@@ -35,6 +35,7 @@
api_register_func('api/z/1.0/abook','api_zot_abook_xchan',true);
api_register_func('api/z/1.0/abconfig','api_zot_abconfig',true);
+ api_register_func('api/z/1.0/perm_allowed','api_zot_perm_allowed',true);
return;
}
@@ -305,6 +306,29 @@
}
+ function api_zot_perm_allowed($type) {
+ if(api_user() === false)
+ return false;
+
+ $perm = ((array_key_exists('perm',$_REQUEST)) ? $_REQUEST['perm'] : '');
+ // possibly should return all perms
+ if(! $perm)
+ return false;
+
+ if(array_key_exists('abook_id',$_REQUEST) && intval($_REQUEST['abook_id'])) {
+ $r = q("select abook_xchan as xchan_hash from abook where abook_id = %d and abook_channel = %d limit 1",
+ intval($_REQUEST['abook_id']),
+ intval(api_user())
+ );
+ }
+ else {
+ $r = xchan_fetch($_REQUEST);
+ }
+ if($r)
+ $x = [ [ 'perm' => $perm, 'allowed' => perm_is_allowed(api_user(), $r[0]['xchan_hash'], $perm)] ];
+
+ json_return_and_die($x);
+ }
function red_item_new($type) {