. * * @category Widget * @package GNU Social * @author Ian Denhardt * @author Sean Corbett * @copyright 2010 Free Software Foundation, Inc. * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0 */ if (!defined('STATUSNET')) { exit(1); } require_once INSTALLDIR . '/classes/Memcached_DataObject.php'; class GNUsocialPhotoAlbum extends Memcached_DataObject { public $__table = 'GNUsocialPhotoAlbum'; public $album_id; // int(11) -- Unique identifier for the album public $profile_id; // int(11) -- Profile ID for the owner of the album public $album_name; // varchar(256) -- Title for this album function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('GNUsocialPhotoAlbum',$k,$v); } /* TODO: Primary key on both album_id, profile_id / foriegn key on profile_id */ function table() { return array('album_id' => DB_DATAOBJECT_INT + DB_DATAOBJECT_NOTNULL, 'profile_id' => DB_DATAOBJECT_INT + DB_DATAOBJECT_NOTNULL, 'album_name' => DB_DATAOBJECT_STR + DB_DATAOBJECT_NOTNULL); } function keys() { return array_keys($this->keyTypes()); } /* Using album_id as the primary key for now.. */ function keyTypes() { return array('album_id' => 'K'); } function sequenceKey() { return array('album_id', true, false); } static function newAlbum($profile_id, $album_name) { //TODO: Should use foreign key instead... if (!Profile::staticGet('id', $profile_id)){ //Is this a bit extreme? throw new ServerException(_m('No such user exists with id ' . $profile_id . ', couldn\'t create album.')); } $album = new GNUsocialPhotoAlbum(); $album->profile_id = $profile_id; $album->album_name = $album_name; $album->album_id = $album->insert(); if (!$album->album_id){ common_log_db_error($album, 'INSERT', __FILE__); throw new ServerException(_m('Error creating new album.')); } common_log(LOG_INFO, 'album_id : ' . $album->album_id); return $album; } }