| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Make another user an admin of a group | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * PHP version 5 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category Action | 
					
						
							| 
									
										
										
										
											2009-08-25 18:12:20 -04:00
										 |  |  |  * @package  StatusNet | 
					
						
							| 
									
										
										
										
											2009-08-25 18:19:04 -04:00
										 |  |  |  * @author   Evan Prodromou <evan@status.net> | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  |  * @license  http://www.fsf.org/licensing/licenses/agpl.html AGPLv3 | 
					
						
							| 
									
										
										
										
											2009-08-25 18:16:46 -04:00
										 |  |  |  * @link     http://status.net/ | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2009-08-25 18:14:12 -04:00
										 |  |  |  * StatusNet - the distributed open-source microblogging tool | 
					
						
							| 
									
										
										
										
											2009-08-25 18:12:20 -04:00
										 |  |  |  * Copyright (C) 2008, 2009, StatusNet, Inc. | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU Affero General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU Affero General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-26 10:41:36 -04:00
										 |  |  | if (!defined('STATUSNET') && !defined('LACONICA')) { | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  |     exit(1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Make another user an admin of a group | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category Action | 
					
						
							| 
									
										
										
										
											2009-08-25 18:12:20 -04:00
										 |  |  |  * @package  StatusNet | 
					
						
							| 
									
										
										
										
											2009-08-25 18:19:04 -04:00
										 |  |  |  * @author   Evan Prodromou <evan@status.net> | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  |  * @license  http://www.fsf.org/licensing/licenses/agpl.html AGPLv3 | 
					
						
							| 
									
										
										
										
											2009-08-25 18:16:46 -04:00
										 |  |  |  * @link     http://status.net/ | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-08 19:06:55 -07:00
										 |  |  | class MakeadminAction extends RedirectingAction | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  | { | 
					
						
							|  |  |  |     var $profile = null; | 
					
						
							|  |  |  |     var $group = null; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Take arguments for running | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param array $args $_REQUEST args | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean success flag | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function prepare($args) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::prepare($args); | 
					
						
							|  |  |  |         if (!common_logged_in()) { | 
					
						
							| 
									
										
										
										
											2011-03-05 00:12:38 +01:00
										 |  |  |             // TRANS: Client error displayed when trying to access the "make admin" page while not logged in.
 | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  |             $this->clientError(_('Not logged in.')); | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $token = $this->trimmed('token'); | 
					
						
							|  |  |  |         if (empty($token) || $token != common_session_token()) { | 
					
						
							| 
									
										
										
										
											2011-04-03 23:47:46 +02:00
										 |  |  |             // TRANS: Client error displayed when the session token does not match or is not given.
 | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  |             $this->clientError(_('There was a problem with your session token. Try again, please.')); | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $id = $this->trimmed('profileid'); | 
					
						
							|  |  |  |         if (empty($id)) { | 
					
						
							| 
									
										
										
										
											2011-03-05 00:12:38 +01:00
										 |  |  |             // TRANS: Client error displayed when not providing a profile ID on the Make Admin page.
 | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  |             $this->clientError(_('No profile specified.')); | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->profile = Profile::staticGet('id', $id); | 
					
						
							|  |  |  |         if (empty($this->profile)) { | 
					
						
							| 
									
										
										
										
											2011-03-05 00:12:38 +01:00
										 |  |  |             // TRANS: Client error displayed when specifying an invalid profile ID on the Make Admin page.
 | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  |             $this->clientError(_('No profile with that ID.')); | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $group_id = $this->trimmed('groupid'); | 
					
						
							|  |  |  |         if (empty($group_id)) { | 
					
						
							| 
									
										
										
										
											2011-03-05 00:12:38 +01:00
										 |  |  |             // TRANS: Client error displayed when not providing a group ID on the Make Admin page.
 | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  |             $this->clientError(_('No group specified.')); | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->group = User_group::staticGet('id', $group_id); | 
					
						
							|  |  |  |         if (empty($this->group)) { | 
					
						
							| 
									
										
										
										
											2011-03-05 00:12:38 +01:00
										 |  |  |             // TRANS: Client error displayed when providing an invalid group ID on the Make Admin page.
 | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  |             $this->clientError(_('No such group.')); | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $user = common_current_user(); | 
					
						
							| 
									
										
										
										
											2010-02-06 11:36:59 +01:00
										 |  |  |         if (!$user->isAdmin($this->group) && | 
					
						
							|  |  |  |             !$user->hasRight(Right::MAKEGROUPADMIN)) { | 
					
						
							| 
									
										
										
										
											2011-03-05 00:12:38 +01:00
										 |  |  |             // TRANS: Client error displayed when trying to make another user admin on the Make Admin page while not an admin.
 | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  |             $this->clientError(_('Only an admin can make another user an admin.'), 401); | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if ($this->profile->isAdmin($this->group)) { | 
					
						
							| 
									
										
										
										
											2011-03-05 00:12:38 +01:00
										 |  |  |             // TRANS: Client error displayed when trying to make another user admin on the Make Admin page who already is admin.
 | 
					
						
							|  |  |  |             // TRANS: %1$s is the user that is already admin, %2$s is the group user is already admin for.
 | 
					
						
							| 
									
										
										
										
											2010-01-10 01:45:58 +01:00
										 |  |  |             $this->clientError(sprintf(_('%1$s is already an admin for group "%2$s".'), | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  |                                        $this->profile->getBestName(), | 
					
						
							|  |  |  |                                        $this->group->getBestName()), | 
					
						
							|  |  |  |                                401); | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Handle request | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param array $args $_REQUEST args; handled in prepare() | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return void | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function handle($args) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::handle($args); | 
					
						
							|  |  |  |         if ($_SERVER['REQUEST_METHOD'] == 'POST') { | 
					
						
							|  |  |  |             $this->makeAdmin(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Make user an admin | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return void | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function makeAdmin() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $member = Group_member::pkeyGet(array('group_id' => $this->group->id, | 
					
						
							|  |  |  |                                               'profile_id' => $this->profile->id)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (empty($member)) { | 
					
						
							| 
									
										
										
										
											2011-03-05 00:12:38 +01:00
										 |  |  |             // TRANS: Server error displayed when trying to make another user admin on the Make Admin page fails
 | 
					
						
							|  |  |  |             // TRANS: because the group membership record could not be gotten.
 | 
					
						
							|  |  |  |             // TRANS: %1$s is the to be admin user, %2$s is the group user should be admin for.
 | 
					
						
							| 
									
										
										
										
											2010-01-10 12:26:24 +01:00
										 |  |  |             $this->serverError(_('Can\'t get membership record for %1$s in group %2$s.'), | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  |                                $this->profile->getBestName(), | 
					
						
							|  |  |  |                                $this->group->getBestName()); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $orig = clone($member); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $member->is_admin = 1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $result = $member->update($orig); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!$result) { | 
					
						
							|  |  |  |             common_log_db_error($member, 'UPDATE', __FILE__); | 
					
						
							| 
									
										
										
										
											2011-03-05 00:12:38 +01:00
										 |  |  |             // TRANS: Server error displayed when trying to make another user admin on the Make Admin page fails
 | 
					
						
							|  |  |  |             // TRANS: because the group adminship record coud not be saved properly.
 | 
					
						
							|  |  |  |             // TRANS: %1$s is the to be admin user, %2$s is the group user is already admin for.
 | 
					
						
							| 
									
										
										
										
											2010-01-10 12:26:24 +01:00
										 |  |  |             $this->serverError(_('Can\'t make %1$s an admin for group %2$s.'), | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  |                                $this->profile->getBestName(), | 
					
						
							|  |  |  |                                $this->group->getBestName()); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-15 15:33:54 -07:00
										 |  |  |         $this->returnToPrevious(); | 
					
						
							| 
									
										
										
										
											2010-04-08 19:06:55 -07:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-08 19:06:55 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * If we reached this form without returnto arguments, default to | 
					
						
							|  |  |  |      * the top of the group's member list. | 
					
						
							|  |  |  |      *  | 
					
						
							|  |  |  |      * @return string URL | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     function defaultReturnTo() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return common_local_url('groupmembers', | 
					
						
							|  |  |  |                                 array('nickname' => $this->group->nickname)); | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-04-08 19:06:55 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-15 05:44:36 -07:00
										 |  |  | } |