. * * @category Application * @package StatusNet * @author Zach Copley * @copyright 2008-2009 StatusNet, Inc. * @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 * * @category Application * @package StatusNet * @author Zach Copley * @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; /** Owner of this list */ var $owner = null; /** Action object using us. */ var $action = null; function __construct($application, $owner=null, $action=null, $connections = false) { parent::__construct($action); $this->application = $application; $this->owner = $owner; $this->action = $action; $this->connections = $connections; } function show() { $this->out->elementStart('ul', 'applications'); $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(); $this->out->elementStart('li', array('class' => 'application', 'id' => 'oauthclient-' . $this->application->id)); $this->out->elementStart('span', 'vcard author'); if (!$this->connections) { $this->out->elementStart('a', array('href' => common_local_url('showapplication', array('id' => $this->application->id)), 'class' => 'url')); } else { $this->out->elementStart('a', array('href' => $this->application->source_url, 'class' => 'url')); } if (!empty($this->application->icon)) { $this->out->element('img', array('src' => $this->application->icon, 'class' => 'photo avatar')); } $this->out->element('span', 'fn', $this->application->name); $this->out->elementEnd('a'); $this->out->elementEnd('span'); $this->out->raw(' by '); $this->out->element('a', array('href' => $this->application->homepage, 'class' => 'url'), $this->application->organization); $this->out->element('p', 'note', $this->application->description); $this->out->elementEnd('li'); if ($this->connections) { $appUser = Oauth_application_user::getByKeys($this->owner, $this->application); if (empty($appUser)) { common_debug("empty appUser!"); } $this->out->elementStart('li'); // TRANS: Application access type $readWriteText = _('read-write'); // TRANS: Application access type $readOnlyText = _('read-only'); $access = ($this->application->access_type & Oauth_application::$writeAccess) ? $readWriteText : $readOnlyText; $modifiedDate = common_date_string($appUser->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); $this->out->raw($txt); $this->out->elementEnd('li'); $this->out->elementStart('li', 'entity_revoke'); $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('id', $this->application->id); $this->out->hidden('token', common_session_token()); // TRANS: Button label $this->out->submit('revoke', _m('BUTTON','Revoke')); $this->out->elementEnd('fieldset'); $this->out->elementEnd('form'); $this->out->elementEnd('li'); } } /* Override this in subclasses. */ function showOwnerControls() { return; } }