123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210 |
- <?php
- defined('GNUSOCIAL') || die();
- class Oauth_application extends Managed_DataObject
- {
-
-
- public $__table = 'oauth_application';
- public $id;
- public $owner;
- public $consumer_key;
- public $name;
- public $description;
- public $icon;
- public $source_url;
- public $organization;
- public $homepage;
- public $callback_url;
- public $type;
- public $access_type;
- public $created;
- public $modified;
-
-
-
- public static $readAccess = 1;
- public static $writeAccess = 2;
- public static $browser = 1;
- public static $desktop = 2;
- public function getConsumer()
- {
- return Consumer::getKV('consumer_key', $this->consumer_key);
- }
- public static function maxDesc()
- {
-
-
-
-
-
-
- $max = 191;
- $desclimit = intval(common_config('application', 'desclimit'));
- if ($desclimit > 0 && $desclimit < $max) {
- return $desclimit;
- } else {
- return $max;
- }
- }
- public static function descriptionTooLong($desc)
- {
- $desclimit = self::maxDesc();
- return ($desclimit > 0 && !empty($desc) && (mb_strlen($desc) > $desclimit));
- }
- public function setAccessFlags($read, $write)
- {
- if ($read) {
- $this->access_type |= self::$readAccess;
- } else {
- $this->access_type &= ~self::$readAccess;
- }
- if ($write) {
- $this->access_type |= self::$writeAccess;
- } else {
- $this->access_type &= ~self::$writeAccess;
- }
- }
- public function setOriginal($filename)
- {
- $imagefile = new ImageFile(null, Avatar::path($filename));
-
-
- $orig = clone($this);
- $this->icon = Avatar::url($filename);
- common_debug(common_log_objstring($this));
- return $this->update($orig);
- }
- public static function getByConsumerKey($key)
- {
- if (empty($key)) {
- return null;
- }
- $app = new Oauth_application();
- $app->consumer_key = $key;
- $app->limit(1);
- $result = $app->find(true);
- return empty($result) ? null : $app;
- }
-
- public function uploadLogo()
- {
- if ($_FILES['app_icon']['error'] == UPLOAD_ERR_OK) {
- try {
- $imagefile = ImageFile::fromUpload('app_icon');
- } catch (Exception $e) {
- common_debug("damn that sucks");
- $this->showForm($e->getMessage());
- return;
- }
- $filename = Avatar::filename(
- $this->id,
- image_type_to_extension($imagefile->type),
- null,
- 'oauth-app-icon-' . common_timestamp()
- );
- $filepath = Avatar::path($filename);
- move_uploaded_file($imagefile->filepath, $filepath);
- $this->setOriginal($filename);
- }
- }
- public function delete($useWhere = false)
- {
- $this->deleteAppUsers();
- $consumer = $this->getConsumer();
- $consumer->delete();
- return parent::delete($useWhere);
- }
- private function deleteAppUsers()
- {
- $oauser = new Oauth_application_user();
- $oauser->application_id = $this->id;
- $oauser->delete();
- }
- public static function schemaDef()
- {
- return array(
- 'description' => 'OAuth application registration record',
- 'fields' => array(
- 'id' => array('type' => 'serial', 'not null' => true, 'description' => 'unique identifier'),
- 'owner' => array('type' => 'int', 'not null' => true, 'description' => 'owner of the application'),
- 'consumer_key' => array('type' => 'varchar', 'length' => 191, 'not null' => true, 'description' => 'application consumer key'),
- 'name' => array('type' => 'varchar', 'length' => 191, 'not null' => true, 'description' => 'name of the application'),
- 'description' => array('type' => 'varchar', 'length' => 191, 'description' => 'description of the application'),
- 'icon' => array('type' => 'varchar', 'length' => 191, 'not null' => true, 'default' => '/theme/base/default-avatar-stream.png', 'description' => 'application icon'),
- 'source_url' => array('type' => 'varchar', 'length' => 191, 'description' => 'application homepage - used for source link'),
- 'organization' => array('type' => 'varchar', 'length' => 191, 'description' => 'name of the organization running the application'),
- 'homepage' => array('type' => 'varchar', 'length' => 191, 'description' => 'homepage for the organization'),
- 'callback_url' => array('type' => 'varchar', 'length' => 191, 'description' => 'url to redirect to after authentication'),
- 'type' => array('type' => 'int', 'size' => 'tiny', 'default' => 0, 'description' => 'type of app, 1 = browser, 2 = desktop'),
- 'access_type' => array('type' => 'int', 'size' => 'tiny', 'default' => 0, 'description' => 'default access type, bit 1 = read, bit 2 = write'),
- 'created' => array('type' => 'datetime', 'description' => 'date this record was created'),
- 'modified' => array('type' => 'timestamp', 'not null' => true, 'description' => 'date this record was modified'),
- ),
- 'primary key' => array('id'),
- 'unique keys' => array(
- 'oauth_application_name_key' => array('name'),
- ),
- 'foreign keys' => array(
- 'oauth_application_owner_fkey' => array('profile', array('owner' => 'id')),
- 'oauth_application_consumer_key_fkey' => array('consumer', array('consumer_key' => 'consumer_key')),
- ),
- 'indexes' => array(
- 'oauth_application_owner_idx' => array('owner'),
- 'oauth_application_consumer_key_idx' => array('consumer_key'),
- ),
- );
- }
- }
|