aboutsummaryrefslogtreecommitdiff
path: root/actions/addtocalendar.php
diff options
context:
space:
mode:
Diffstat (limited to 'actions/addtocalendar.php')
-rw-r--r--actions/addtocalendar.php36
1 files changed, 36 insertions, 0 deletions
diff --git a/actions/addtocalendar.php b/actions/addtocalendar.php
new file mode 100644
index 000000000..cb83aab88
--- /dev/null
+++ b/actions/addtocalendar.php
@@ -0,0 +1,36 @@
+<?php
+
+// this action allows an admin or event owner to approve a calendar request
+
+// Load configuration
+global $CONFIG;
+
+gatekeeper();
+
+$user_guid = get_input('user_guid', get_loggedin_userid());
+$event_id = get_input('event_id');
+
+$user = get_entity($user_guid);
+$event = get_entity($event_id);
+
+// If join request made
+if (event_calendar_personal_can_manage($event,$user_guid)
+ && check_entity_relationship($user_guid, 'event_calendar_request', $event_id)) {
+ if (event_calendar_add_personal_event($event_id,$user_guid)) {
+ remove_entity_relationship($user_guid, 'event_calendar_request', $event_id);
+ notify_user($user_guid, $CONFIG->site->guid, elgg_echo('event_calendar:add_users_notify:subject'),
+ sprintf(
+ elgg_echo('event_calendar:add_users_notify:body'),
+ $user->name,
+ $event->title,
+ $event->getURL()
+ )
+ );
+ system_message(elgg_echo('event_calendar:request_approved'));
+
+ }
+} else {
+ register_error(elgg_echo('event_calendar:review_requests_error'));
+}
+
+forward($_SERVER['HTTP_REFERER']);