| 
									
										
										
										
											2009-11-12 19:42:18 -08:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * StatusNet, the distributed open-source microblogging tool | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Widget to show a list of OAuth applications | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * PHP version 5 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * LICENCE: 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-11-16 16:58:49 -08:00
										 |  |  |  * @category  Application | 
					
						
							| 
									
										
										
										
											2009-11-12 19:42:18 -08:00
										 |  |  |  * @package   StatusNet | 
					
						
							|  |  |  |  * @author    Zach Copley <zach@status.net> | 
					
						
							| 
									
										
										
										
											2010-10-19 20:54:53 -07:00
										 |  |  |  * @copyright 2008-2010 StatusNet, Inc. | 
					
						
							| 
									
										
										
										
											2009-11-12 19:42:18 -08:00
										 |  |  |  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 | 
					
						
							|  |  |  |  * @link      http://status.net/ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if (!defined('STATUSNET') && !defined('LACONICA')) { | 
					
						
							|  |  |  |     exit(1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | require_once INSTALLDIR . '/lib/widget.php'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | define('APPS_PER_PAGE', 20); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Widget to show a list of OAuth applications | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2009-11-16 16:58:49 -08:00
										 |  |  |  * @category Application | 
					
						
							| 
									
										
										
										
											2009-11-12 19:42:18 -08:00
										 |  |  |  * @package  StatusNet | 
					
						
							|  |  |  |  * @author   Zach Copley <zach@status.net> | 
					
						
							|  |  |  |  * @license  http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 | 
					
						
							|  |  |  |  * @link     http://status.net/ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class ApplicationList extends Widget | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     /** Current application, application query */ | 
					
						
							|  |  |  |     var $application = null; | 
					
						
							| 
									
										
										
										
											2009-11-16 16:58:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-12 19:42:18 -08:00
										 |  |  |     /** Owner of this list */ | 
					
						
							|  |  |  |     var $owner = null; | 
					
						
							| 
									
										
										
										
											2009-11-16 16:58:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-12 19:42:18 -08:00
										 |  |  |     /** Action object using us. */ | 
					
						
							|  |  |  |     var $action = null; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-19 20:54:53 -07:00
										 |  |  |     function __construct($application, $owner=null, $action=null) | 
					
						
							| 
									
										
										
										
											2009-11-12 19:42:18 -08:00
										 |  |  |     { | 
					
						
							|  |  |  |         parent::__construct($action); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->application = $application; | 
					
						
							|  |  |  |         $this->owner       = $owner; | 
					
						
							|  |  |  |         $this->action      = $action; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function show() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2010-01-12 01:29:09 +00:00
										 |  |  |         $this->out->elementStart('ul', 'applications'); | 
					
						
							| 
									
										
										
										
											2009-11-12 19:42:18 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $cnt = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         while ($this->application->fetch()) { | 
					
						
							|  |  |  |             $cnt++; | 
					
						
							|  |  |  |             if($cnt > APPS_PER_PAGE) { | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             $this->showapplication(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->out->elementEnd('ul'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $cnt; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function showApplication() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $user = common_current_user(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-19 20:54:53 -07:00
										 |  |  |         $this->out->elementStart( | 
					
						
							|  |  |  |             'li', | 
					
						
							|  |  |  |             array( | 
					
						
							|  |  |  |                 'class' => 'application', | 
					
						
							|  |  |  |                 'id'    => 'oauthclient-' . $this->application->id | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  |         ); | 
					
						
							| 
									
										
										
										
											2009-11-16 16:58:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-12 01:44:15 +00:00
										 |  |  |         $this->out->elementStart('span', 'vcard author'); | 
					
						
							| 
									
										
										
										
											2010-10-19 20:54:53 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $this->out->elementStart( | 
					
						
							|  |  |  |             'a', | 
					
						
							|  |  |  |             array( | 
					
						
							|  |  |  |                 'href' => common_local_url( | 
					
						
							|  |  |  |                     'showapplication', | 
					
						
							|  |  |  |                     array('id' => $this->application->id)), | 
					
						
							|  |  |  |                     'class' => 'url' | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  |         ); | 
					
						
							| 
									
										
										
										
											2009-11-16 16:58:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-12 01:41:38 +00:00
										 |  |  |         if (!empty($this->application->icon)) { | 
					
						
							| 
									
										
										
										
											2010-10-19 20:54:53 -07:00
										 |  |  |             $this->out->element( | 
					
						
							|  |  |  |                 'img', | 
					
						
							|  |  |  |                 array( | 
					
						
							|  |  |  |                     'src' => $this->application->icon, | 
					
						
							|  |  |  |                     'class' => 'photo avatar' | 
					
						
							|  |  |  |                 ) | 
					
						
							|  |  |  |             ); | 
					
						
							| 
									
										
										
										
											2010-01-12 01:41:38 +00:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-12 01:52:59 +00:00
										 |  |  |         $this->out->element('span', 'fn', $this->application->name); | 
					
						
							| 
									
										
										
										
											2010-01-12 01:41:38 +00:00
										 |  |  |         $this->out->elementEnd('a'); | 
					
						
							| 
									
										
										
										
											2010-01-12 01:44:15 +00:00
										 |  |  |         $this->out->elementEnd('span'); | 
					
						
							| 
									
										
										
										
											2010-01-12 01:41:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-12 01:29:09 +00:00
										 |  |  |         $this->out->raw(' by '); | 
					
						
							| 
									
										
										
										
											2010-01-11 14:11:43 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-19 20:54:53 -07:00
										 |  |  |         $this->out->element( | 
					
						
							|  |  |  |             'a', | 
					
						
							|  |  |  |             array( | 
					
						
							|  |  |  |                 'href' => $this->application->homepage, | 
					
						
							|  |  |  |                 'class' => 'url' | 
					
						
							|  |  |  |             ), | 
					
						
							|  |  |  |             $this->application->organization | 
					
						
							|  |  |  |         ); | 
					
						
							| 
									
										
										
										
											2010-01-11 14:11:43 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-12 01:52:59 +00:00
										 |  |  |         $this->out->element('p', 'note', $this->application->description); | 
					
						
							| 
									
										
										
										
											2010-01-12 01:36:08 +00:00
										 |  |  |         $this->out->elementEnd('li'); | 
					
						
							| 
									
										
										
										
											2010-01-11 14:11:43 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-19 20:54:53 -07:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-01-11 14:11:43 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-19 20:54:53 -07:00
										 |  |  |     /* Override this in subclasses. */ | 
					
						
							|  |  |  |     function showOwnerControls() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Widget to show a list of connected OAuth clients | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category Application | 
					
						
							|  |  |  |  * @package  StatusNet | 
					
						
							|  |  |  |  * @author   Zach Copley <zach@status.net> | 
					
						
							|  |  |  |  * @license  http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 | 
					
						
							|  |  |  |  * @link     http://status.net/ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class ConnectedAppsList extends Widget | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     /** Current connected application query */ | 
					
						
							|  |  |  |     var $connection = null; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Owner of this list */ | 
					
						
							|  |  |  |     var $owner = null; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Action object using us. */ | 
					
						
							|  |  |  |     var $action = null; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function __construct($connection, $owner=null, $action=null) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct($action); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         common_debug("ConnectedAppsList constructor"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->connection = $connection; | 
					
						
							|  |  |  |         $this->owner       = $owner; | 
					
						
							|  |  |  |         $this->action      = $action; | 
					
						
							| 
									
										
										
										
											2009-11-12 19:42:18 -08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Override this in subclasses. */ | 
					
						
							|  |  |  |     function showOwnerControls() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-10-19 20:54:53 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     function show() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->out->elementStart('ul', 'applications'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $cnt = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         while ($this->connection->fetch()) { | 
					
						
							|  |  |  |             $cnt++; | 
					
						
							|  |  |  |             if($cnt > APPS_PER_PAGE) { | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             $this->showConnection(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->out->elementEnd('ul'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $cnt; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function showConnection() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $app = Oauth_application::staticGet('id', $this->connection->application_id); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->out->elementStart( | 
					
						
							|  |  |  |             'li', | 
					
						
							|  |  |  |             array( | 
					
						
							|  |  |  |                 'class' => 'application', | 
					
						
							|  |  |  |                 'id'    => 'oauthclient-' . $app->id | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->out->elementStart('span', 'vcard author'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->out->elementStart( | 
					
						
							|  |  |  |             'a', | 
					
						
							|  |  |  |             array( | 
					
						
							|  |  |  |                 'href' => $app->source_url, | 
					
						
							|  |  |  |                 'class' => 'url' | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!empty($app->icon)) { | 
					
						
							|  |  |  |             $this->out->element( | 
					
						
							|  |  |  |                 'img', | 
					
						
							|  |  |  |                 array( | 
					
						
							|  |  |  |                     'src' => $app->icon, | 
					
						
							|  |  |  |                     'class' => 'photo avatar' | 
					
						
							|  |  |  |                 ) | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if ($app->name != 'anonymous') { | 
					
						
							|  |  |  |             $this->out->element('span', 'fn', $app->name); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->out->elementEnd('a'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($app->name == 'anonymous') { | 
					
						
							| 
									
										
										
										
											2011-04-01 19:46:40 +02:00
										 |  |  |             // TRANS: Name for an anonymous application in application list.
 | 
					
						
							|  |  |  |             $this->out->element('span', 'fn', _('Unknown application')); | 
					
						
							| 
									
										
										
										
											2010-10-19 20:54:53 -07:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->out->elementEnd('span'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($app->name != 'anonymous') { | 
					
						
							| 
									
										
										
										
											2010-10-20 20:01:12 +02:00
										 |  |  |             // @todo FIXME: i18n trouble.
 | 
					
						
							| 
									
										
										
										
											2011-04-01 19:46:40 +02:00
										 |  |  |             // TRANS: Message has a leading space and a trailing space. Used in application list.
 | 
					
						
							|  |  |  |             // TRANS: Before this message the application name is put, behind it the organisation that manages it.
 | 
					
						
							| 
									
										
										
										
											2010-10-19 20:54:53 -07:00
										 |  |  |             $this->out->raw(_(' by ')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $this->out->element( | 
					
						
							|  |  |  |                 'a', | 
					
						
							|  |  |  |                 array( | 
					
						
							|  |  |  |                     'href' => $app->homepage, | 
					
						
							|  |  |  |                     'class' => 'url' | 
					
						
							|  |  |  |                 ), | 
					
						
							|  |  |  |                 $app->organization | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // TRANS: Application access type
 | 
					
						
							|  |  |  |         $readWriteText = _('read-write'); | 
					
						
							|  |  |  |         // TRANS: Application access type
 | 
					
						
							|  |  |  |         $readOnlyText = _('read-only'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $access = ($this->connection->access_type & Oauth_application::$writeAccess) | 
					
						
							|  |  |  |             ? $readWriteText : $readOnlyText; | 
					
						
							|  |  |  |         $modifiedDate = common_date_string($this->connection->modified); | 
					
						
							|  |  |  |         // TRANS: Used in application list. %1$s is a modified date, %2$s is access type ("read-write" or "read-only")
 | 
					
						
							|  |  |  |         $txt = sprintf(_('Approved %1$s - "%2$s" access.'), $modifiedDate, $access); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-01 19:46:40 +02:00
										 |  |  |         // @todo FIXME: i18n trouble.
 | 
					
						
							| 
									
										
										
										
											2010-10-19 20:54:53 -07:00
										 |  |  |         $this->out->raw(" - $txt"); | 
					
						
							|  |  |  |         if (!empty($app->description)) { | 
					
						
							|  |  |  |             $this->out->element( | 
					
						
							|  |  |  |                 'p', array('class' => 'application_description'), | 
					
						
							|  |  |  |                 $app->description | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $this->out->element( | 
					
						
							|  |  |  |             'p', array( | 
					
						
							|  |  |  |             'class' => 'access_token'), | 
					
						
							| 
									
										
										
										
											2010-10-20 19:34:27 +02:00
										 |  |  |             // TRANS: Access token in the application list.
 | 
					
						
							|  |  |  |             // TRANS: %s are the first 7 characters of the access token.
 | 
					
						
							|  |  |  |             sprintf(_('Access token starting with: %s'), substr($this->connection->token, 0, 7)) | 
					
						
							| 
									
										
										
										
											2010-10-19 20:54:53 -07:00
										 |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->out->elementStart( | 
					
						
							|  |  |  |             'form', | 
					
						
							|  |  |  |             array( | 
					
						
							|  |  |  |                 'id' => 'form_revoke_app', | 
					
						
							|  |  |  |                 'class' => 'form_revoke_app', | 
					
						
							|  |  |  |                 'method' => 'POST', | 
					
						
							|  |  |  |                 'action' => common_local_url('oauthconnectionssettings') | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |         $this->out->elementStart('fieldset'); | 
					
						
							|  |  |  |         $this->out->hidden('oauth_token', $this->connection->token); | 
					
						
							|  |  |  |         $this->out->hidden('token', common_session_token()); | 
					
						
							| 
									
										
										
										
											2011-04-01 19:46:40 +02:00
										 |  |  |         // TRANS: Button label in application list to revoke access to user data.
 | 
					
						
							| 
									
										
										
										
											2010-10-20 19:34:27 +02:00
										 |  |  |         $this->out->submit('revoke', _m('BUTTON','Revoke')); | 
					
						
							| 
									
										
										
										
											2010-10-19 20:54:53 -07:00
										 |  |  |         $this->out->elementEnd('fieldset'); | 
					
						
							|  |  |  |         $this->out->elementEnd('form'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->out->elementEnd('li'); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-11-12 19:42:18 -08:00
										 |  |  | } |