summaryrefslogtreecommitdiffstats
path: root/web
diff options
context:
space:
mode:
Diffstat (limited to 'web')
-rw-r--r--web/lib/aurjson.class.php49
1 files changed, 48 insertions, 1 deletions
diff --git a/web/lib/aurjson.class.php b/web/lib/aurjson.class.php
index 8ead253..4e4d5dc 100644
--- a/web/lib/aurjson.class.php
+++ b/web/lib/aurjson.class.php
@@ -14,7 +14,7 @@ class AurJSON {
private $version = 1;
private static $exposed_methods = array(
'search', 'info', 'multiinfo', 'msearch', 'suggest',
- 'suggest-pkgbase'
+ 'suggest-pkgbase', 'get-comment-form'
);
private static $exposed_fields = array(
'name', 'name-desc'
@@ -477,5 +477,52 @@ class AurJSON {
return json_encode($result_array);
}
+
+ /**
+ * Get the HTML markup of the comment form.
+ *
+ * @param array $http_data Query parameters.
+ *
+ * @return string The JSON formatted response data.
+ */
+ private function get_comment_form($http_data) {
+ if (!isset($http_data['base_id']) || !isset($http_data['pkgbase_name'])) {
+ $output = array(
+ 'success' => 0,
+ 'error' => __('Package base ID or package base name missing.')
+ );
+ return json_encode($output);
+ }
+
+ $comment_id = intval($http_data['arg']);
+ $base_id = intval($http_data['base_id']);
+ $pkgbase_name = $http_data['pkgbase_name'];
+
+ list($user_id, $comment) = comment_by_id($comment_id);
+
+ if (!has_credential(CRED_COMMENT_EDIT, array($user_id))) {
+ $output = array(
+ 'success' => 0,
+ 'error' => __('You do not have the right to edit this comment.')
+ );
+ return json_encode($output);
+ } elseif (is_null($comment)) {
+ $output = array(
+ 'success' => 0,
+ 'error' => __('Comment does not exist.')
+ );
+ return json_encode($output);
+ }
+
+ ob_start();
+ include('pkg_comment_form.php');
+ $html = ob_get_clean();
+ $output = array(
+ 'success' => 1,
+ 'form' => $html
+ );
+
+ return json_encode($output);
+ }
}