1a9a8ea730
The parent class for our database objects, Managed_DataObject, has a dynamically assigned class in staticGet which objects get put into, leaving us with less code to do the same thing. We will probably have to move away from the DB_DataObject 'staticGet' call as it is nowadays deprecated.
81 lines
2.7 KiB
PHP
81 lines
2.7 KiB
PHP
<?php
|
|
/**
|
|
* Table Definition for consumer
|
|
*/
|
|
require_once INSTALLDIR.'/classes/Memcached_DataObject.php';
|
|
|
|
class Consumer extends Managed_DataObject
|
|
{
|
|
###START_AUTOCODE
|
|
/* the code below is auto generated do not remove the above tag */
|
|
|
|
public $__table = 'consumer'; // table name
|
|
public $consumer_key; // varchar(255) primary_key not_null
|
|
public $consumer_secret; // varchar(255) not_null
|
|
public $seed; // char(32) not_null
|
|
public $created; // datetime not_null
|
|
public $modified; // timestamp not_null default_CURRENT_TIMESTAMP
|
|
|
|
/* the code above is auto generated do not remove the tag below */
|
|
###END_AUTOCODE
|
|
|
|
public static function schemaDef()
|
|
{
|
|
return array(
|
|
'description' => 'OAuth consumer record',
|
|
'fields' => array(
|
|
'consumer_key' => array('type' => 'varchar', 'length' => 255, 'not null' => true, 'description' => 'unique identifier, root URL'),
|
|
'consumer_secret' => array('type' => 'varchar', 'length' => 255, 'not null' => true, 'description' => 'secret value'),
|
|
'seed' => array('type' => 'char', 'length' => 32, 'not null' => true, 'description' => 'seed for new tokens by this consumer'),
|
|
|
|
'created' => array('type' => 'datetime', 'not null' => true, 'description' => 'date this record was created'),
|
|
'modified' => array('type' => 'timestamp', 'not null' => true, 'description' => 'date this record was modified'),
|
|
),
|
|
'primary key' => array('consumer_key'),
|
|
);
|
|
}
|
|
|
|
static function generateNew()
|
|
{
|
|
$cons = new Consumer();
|
|
$rand = common_good_rand(16);
|
|
|
|
$cons->seed = $rand;
|
|
$cons->consumer_key = md5(time() + $rand);
|
|
$cons->consumer_secret = md5(md5(time() + time() + $rand));
|
|
$cons->created = common_sql_now();
|
|
|
|
return $cons;
|
|
}
|
|
|
|
/**
|
|
* Delete a Consumer and related tokens and nonces
|
|
*
|
|
* XXX: Should this happen in an OAuthDataStore instead?
|
|
*
|
|
*/
|
|
function delete()
|
|
{
|
|
// XXX: Is there any reason NOT to do this kind of cleanup?
|
|
|
|
$this->_deleteTokens();
|
|
$this->_deleteNonces();
|
|
|
|
parent::delete();
|
|
}
|
|
|
|
function _deleteTokens()
|
|
{
|
|
$token = new Token();
|
|
$token->consumer_key = $this->consumer_key;
|
|
$token->delete();
|
|
}
|
|
|
|
function _deleteNonces()
|
|
{
|
|
$nonce = new Nonce();
|
|
$nonce->consumer_key = $this->consumer_key;
|
|
$nonce->delete();
|
|
}
|
|
}
|