diff options
author | Cash Costello <cash.costello@gmail.com> | 2012-06-26 17:01:23 -0700 |
---|---|---|
committer | Cash Costello <cash.costello@gmail.com> | 2012-06-26 17:01:23 -0700 |
commit | 264d3643f2c76bedf875e3c586055d9f5ee14132 (patch) | |
tree | ee3f3c09cad0e22ff54db8dbc62026d1c6d2d800 /mod/notifications/start.php | |
parent | 91d3da6284490c32c595bb94f112fe30982bdb6c (diff) | |
parent | 4d8c3b75e36c45d5dd8b9d56338f7b303ea0a4fa (diff) | |
download | elgg-264d3643f2c76bedf875e3c586055d9f5ee14132.tar.gz elgg-264d3643f2c76bedf875e3c586055d9f5ee14132.tar.bz2 |
Merge pull request #280 from mrclay/4138-notifications
Fixes #4138: Admin can edit any users' notifications
Diffstat (limited to 'mod/notifications/start.php')
-rw-r--r-- | mod/notifications/start.php | 22 |
1 files changed, 19 insertions, 3 deletions
diff --git a/mod/notifications/start.php b/mod/notifications/start.php index 761f17e40..d5d418f0f 100644 --- a/mod/notifications/start.php +++ b/mod/notifications/start.php @@ -40,13 +40,25 @@ function notifications_plugin_init() { */ function notifications_page_handler($page) { + gatekeeper(); + $current_user = elgg_get_logged_in_user_entity(); + // default to personal notifications if (!isset($page[0])) { $page[0] = 'personal'; } + if (!isset($page[1])) { + forward("notifications/{$page[0]}/{$current_user->username}"); + } + + $user = get_user_by_username($page[1]); + if (($user->guid != $current_user->guid) && !$current_user->isAdmin()) { + forward(); + } $base = elgg_get_plugins_path() . 'notifications'; + // note: $user passed in switch ($page[0]) { case 'group': require "$base/groups.php"; @@ -66,12 +78,16 @@ function notifications_page_handler($page) { */ function notifications_plugin_pagesetup() { if (elgg_get_context() == "settings" && elgg_get_logged_in_user_guid()) { - $user = elgg_get_logged_in_user_entity(); + + $user = elgg_get_page_owner_entity(); + if (!$user) { + $user = elgg_get_logged_in_user_entity(); + } $params = array( 'name' => '2_a_user_notify', 'text' => elgg_echo('notifications:subscriptions:changesettings'), - 'href' => "notifications/personal", + 'href' => "notifications/personal/{$user->username}", ); elgg_register_menu_item('page', $params); @@ -79,7 +95,7 @@ function notifications_plugin_pagesetup() { $params = array( 'name' => '2_group_notify', 'text' => elgg_echo('notifications:subscriptions:changesettings:groups'), - 'href' => "notifications/group", + 'href' => "notifications/group/{$user->username}", ); elgg_register_menu_item('page', $params); } |