. * * @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(false, false, 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(); //TODO: Should autoincrement.. $album->profile_id = $profile_id; $album->album_name = $album_name; if ($album->insert() == false){ common_log_db_error($album, 'INSERT', __FILE__); throw new ServerException(_m('Error creating new album.')); } } }