forked from GNUsocial/gnu-social
3a7261f70a
Lots of the Memcached_DataObject classes stopped working when upgraded to Managed_DataObject because they lacked schemaDef(). I have _hopefully_ made it so that all the references to the table uses each class' schemaDef, rather than the more manual ColumnDef stuff. Not all plugins have been tested thoroughly yet. NOTE: This is applied with getKV calls instead of staticGet, as it was important for PHP Strict Standards compliance to avoid calling the non- static functions statically. (unfortunately DB and DB_DataObject still do this within themselves...)
105 lines
4.2 KiB
PHP
105 lines
4.2 KiB
PHP
<?php
|
|
/**
|
|
* GNU Social
|
|
* Copyright (C) 2010, Free Software Foundation, Inc.
|
|
*
|
|
* PHP version 5
|
|
*
|
|
* LICENCE:
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Affero General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
* @category Widget
|
|
* @package GNU Social
|
|
* @author Ian Denhardt <ian@zenhack.net>
|
|
* @author Sean Corbett <sean@gnu.org>
|
|
* @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 Managed_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(255) -- Title for this album
|
|
public $album_description; // text -- A description of the album
|
|
public $created; // datetime() not_null
|
|
public $modified; // timestamp() not_null default_CURRENT_TIMESTAMP
|
|
|
|
/* TODO: Primary key on both album_id, profile_id / foriegn key on profile_id */
|
|
public static function schemaDef()
|
|
{
|
|
return array(
|
|
'fields' => array(
|
|
'album_id' => array('type' => 'int', 'not null' => true, 'description' => 'Unique identifier for the album'),
|
|
'profile_id' => array('type' => 'int', 'not null' => true, 'description' => 'Profile ID for the owner of the album'),
|
|
'album_name' => array('type' => 'varchar', 'not null' => true, 'length' => 255, 'description' => 'Title for this album'),
|
|
'album_description' => array('type' => 'text', 'not null' => true, 'description' => 'A description for this album'),
|
|
'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('user_id'),
|
|
'foreign keys' => array(
|
|
'gnusocialphotoalbum_profile_id_fkey' => array('profile', array('profile_id' => 'id')),
|
|
),
|
|
'indexes' => array(
|
|
'gnusocialphotoalbum_album_name_idx' => array('album_name'),
|
|
),
|
|
);
|
|
}
|
|
|
|
function getPageLink()
|
|
{
|
|
$profile = Profile::getKV('id', $this->profile_id);
|
|
return '/' . $profile->nickname . '/photos/' . $this->album_id;
|
|
}
|
|
|
|
function getThumbUri()
|
|
{
|
|
$photo = GNUsocialPhoto::getKV('album_id', $this->album_id);
|
|
if (empty($photo))
|
|
return '/theme/default/default-avatar-profile.png'; //For now...
|
|
return $photo->thumb_uri;
|
|
}
|
|
|
|
static function newAlbum($profile_id, $album_name, $album_description)
|
|
{
|
|
//TODO: Should use foreign key instead...
|
|
if (!Profile::getKV('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_description = $album_description;
|
|
|
|
$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;
|
|
}
|
|
|
|
}
|