3 * Laconica - a distributed open-source microblogging tool
4 * Copyright (C) 2008, Controlez-Vous, Inc.
6 * This program is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU Affero General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU Affero General Public License for more details.
16 * You should have received a copy of the GNU Affero General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
20 if (!defined('LACONICA')) { exit(1); }
22 * Table Definition for user
24 require_once 'DB/DataObject.php';
25 require_once 'Validate.php';
27 class User extends DB_DataObject
30 /* the code below is auto generated do not remove the above tag */
32 public $__table = 'user'; // table name
33 public $id; // int(4) primary_key not_null
34 public $nickname; // varchar(64) unique_key
35 public $password; // varchar(255)
36 public $email; // varchar(255) unique_key
37 public $emailnotifysub; // tinyint(1) default_1
38 public $jabber; // varchar(255) unique_key
39 public $jabbernotify; // tinyint(1)
40 public $jabberreplies; // tinyint(1)
41 public $updatefrompresence; // tinyint(1)
42 public $sms; // varchar(64) unique_key
43 public $carrier; // int(4)
44 public $smsnotify; // tinyint(1)
45 public $uri; // varchar(255) unique_key
46 public $created; // datetime() not_null
47 public $modified; // timestamp() not_null default_CURRENT_TIMESTAMP
50 function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('User',$k,$v); }
52 /* the code above is auto generated do not remove the tag below */
55 function getProfile() {
56 $profile = DB_DataObject::factory('profile');
57 $profile->id = $this->id;
58 if ($profile->find()) {
65 function isSubscribed($other) {
66 assert(!is_null($other));
67 $sub = DB_DataObject::factory('subscription');
68 $sub->subscriber = $this->id;
69 $sub->subscribed = $other->id;
73 # 'update' won't write key columns, so we have to do it ourselves.
75 function updateKeys(&$orig) {
77 foreach (array('nickname', 'email', 'jabber', 'sms', 'carrier') as $k) {
78 if (strcmp($this->$k, $orig->$k) != 0) {
79 $parts[] = $k . ' = ' . $this->_quote($this->$k);
82 if (count($parts) == 0) {
86 $toupdate = implode(', ', $parts);
87 $qry = 'UPDATE ' . $this->tableName() . ' SET ' . $toupdate .
88 ' WHERE id = ' . $this->id;
89 return $this->query($qry);
92 function allowed_nickname($nickname) {
93 # XXX: should already be validated for size, content, etc.
94 static $blacklist = array('rss', 'xrds', 'doc', 'main',
95 'settings', 'notice', 'user',
97 $merged = array_merge($blacklist, common_config('nickname', 'blacklist'));
98 return !in_array($nickname, $merged);
101 function getCurrentNotice($dt=NULL) {
102 $profile = $this->getProfile();
106 return $profile->getCurrentNotice($dt);