| 
									
										
										
										
											2008-05-07 13:15:42 -04:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2008-05-20 15:14:12 -04:00
										 |  |  | /* | 
					
						
							| 
									
										
										
										
											2009-08-25 18:14:12 -04:00
										 |  |  |  * StatusNet - the distributed open-source microblogging tool | 
					
						
							| 
									
										
										
										
											2009-08-25 18:12:20 -04:00
										 |  |  |  * Copyright (C) 2008, 2009, StatusNet, Inc. | 
					
						
							| 
									
										
										
										
											2008-05-20 15:14:12 -04:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-05-14 15:26:48 -04:00
										 |  |  |  * 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. | 
					
						
							| 
									
										
										
										
											2008-05-20 15:14:12 -04:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-05-14 15:26:48 -04:00
										 |  |  |  * 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. | 
					
						
							| 
									
										
										
										
											2008-05-20 15:14:12 -04:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-05-14 15:26:48 -04:00
										 |  |  |  * 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/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-26 10:41:36 -04:00
										 |  |  | if (!defined('STATUSNET') && !defined('LACONICA')) { exit(1); } | 
					
						
							| 
									
										
										
										
											2008-05-14 15:26:48 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-07 13:15:42 -04:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Table Definition for profile | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-09-26 12:18:24 -04:00
										 |  |  | require_once INSTALLDIR.'/classes/Memcached_DataObject.php'; | 
					
						
							| 
									
										
										
										
											2008-05-07 13:15:42 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-10 12:47:22 -05:00
										 |  |  | class Profile extends Memcached_DataObject | 
					
						
							| 
									
										
										
										
											2008-05-07 13:15:42 -04:00
										 |  |  | { | 
					
						
							|  |  |  |     ###START_AUTOCODE
 | 
					
						
							|  |  |  |     /* the code below is auto generated do not remove the above tag */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public $__table = 'profile';                         // table name
 | 
					
						
							|  |  |  |     public $id;                              // int(4)  primary_key not_null
 | 
					
						
							| 
									
										
										
										
											2008-07-10 00:51:26 -04:00
										 |  |  |     public $nickname;                        // varchar(64)  multiple_key not_null
 | 
					
						
							|  |  |  |     public $fullname;                        // varchar(255)  multiple_key
 | 
					
						
							| 
									
										
										
										
											2008-12-10 12:47:22 -05:00
										 |  |  |     public $profileurl;                      // varchar(255)
 | 
					
						
							| 
									
										
										
										
											2008-07-10 00:51:26 -04:00
										 |  |  |     public $homepage;                        // varchar(255)  multiple_key
 | 
					
						
							| 
									
										
										
										
											2009-08-20 17:09:04 -04:00
										 |  |  |     public $bio;                             // text()  multiple_key
 | 
					
						
							| 
									
										
										
										
											2008-07-10 00:51:26 -04:00
										 |  |  |     public $location;                        // varchar(255)  multiple_key
 | 
					
						
							| 
									
										
										
										
											2009-09-15 18:28:44 -04:00
										 |  |  |     public $lat;                             // decimal(10,7)
 | 
					
						
							|  |  |  |     public $lon;                             // decimal(10,7)
 | 
					
						
							|  |  |  |     public $location_id;                     // int(4)
 | 
					
						
							|  |  |  |     public $location_ns;                     // int(4)
 | 
					
						
							| 
									
										
										
										
											2008-05-07 13:15:42 -04:00
										 |  |  |     public $created;                         // datetime()   not_null
 | 
					
						
							|  |  |  |     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Static get */ | 
					
						
							| 
									
										
										
										
											2009-09-15 18:28:44 -04:00
										 |  |  |     function staticGet($k,$v=NULL) { | 
					
						
							|  |  |  |         return Memcached_DataObject::staticGet('Profile',$k,$v); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-05-07 13:15:42 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* the code above is auto generated do not remove the tag below */ | 
					
						
							|  |  |  |     ###END_AUTOCODE
 | 
					
						
							| 
									
										
										
										
											2008-05-20 15:14:12 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-15 05:16:37 -04:00
										 |  |  |     function getUser() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return User::staticGet('id', $this->id); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function getAvatar($width, $height=null) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         if (is_null($height)) { | 
					
						
							|  |  |  |             $height = $width; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return Avatar::pkeyGet(array('profile_id' => $this->id, | 
					
						
							|  |  |  |                                      'width' => $width, | 
					
						
							|  |  |  |                                      'height' => $height)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function getOriginalAvatar() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         $avatar = DB_DataObject::factory('avatar'); | 
					
						
							|  |  |  |         $avatar->profile_id = $this->id; | 
					
						
							|  |  |  |         $avatar->original = true; | 
					
						
							|  |  |  |         if ($avatar->find(true)) { | 
					
						
							|  |  |  |             return $avatar; | 
					
						
							|  |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:21:29 -05:00
										 |  |  |             return null; | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-04 19:32:15 -05:00
										 |  |  |     function setOriginal($filename) | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-02-06 03:13:08 -05:00
										 |  |  |         $imagefile = new ImageFile($this->id, Avatar::path($filename)); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $avatar = new Avatar(); | 
					
						
							|  |  |  |         $avatar->profile_id = $this->id; | 
					
						
							| 
									
										
										
										
											2009-02-04 19:32:15 -05:00
										 |  |  |         $avatar->width = $imagefile->width; | 
					
						
							|  |  |  |         $avatar->height = $imagefile->height; | 
					
						
							|  |  |  |         $avatar->mediatype = image_type_to_mime_type($imagefile->type); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         $avatar->filename = $filename; | 
					
						
							|  |  |  |         $avatar->original = true; | 
					
						
							| 
									
										
										
										
											2009-02-06 03:13:08 -05:00
										 |  |  |         $avatar->url = Avatar::url($filename); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         $avatar->created = DB_DataObject_Cast::dateTime(); # current time
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # XXX: start a transaction here
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-04 19:32:15 -05:00
										 |  |  |         if (!$this->delete_avatars() || !$avatar->insert()) { | 
					
						
							| 
									
										
										
										
											2009-02-06 03:13:08 -05:00
										 |  |  |             @unlink(Avatar::path($filename)); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:21:29 -05:00
										 |  |  |             return null; | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         foreach (array(AVATAR_PROFILE_SIZE, AVATAR_STREAM_SIZE, AVATAR_MINI_SIZE) as $size) { | 
					
						
							| 
									
										
										
										
											2009-11-08 23:32:15 +01:00
										 |  |  |             # We do not do a scaled one if original is our scaled size
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |             if (!($avatar->width == $size && $avatar->height == $size)) { | 
					
						
							| 
									
										
										
										
											2009-02-06 03:13:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-04 19:32:15 -05:00
										 |  |  |                 $scaled_filename = $imagefile->resize($size); | 
					
						
							| 
									
										
										
										
											2009-02-06 03:13:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-04 19:32:15 -05:00
										 |  |  |                 //$scaled = DB_DataObject::factory('avatar');
 | 
					
						
							|  |  |  |                 $scaled = new Avatar(); | 
					
						
							|  |  |  |                 $scaled->profile_id = $this->id; | 
					
						
							|  |  |  |                 $scaled->width = $size; | 
					
						
							|  |  |  |                 $scaled->height = $size; | 
					
						
							|  |  |  |                 $scaled->original = false; | 
					
						
							|  |  |  |                 $scaled->mediatype = image_type_to_mime_type($imagefile->type); | 
					
						
							|  |  |  |                 $scaled->filename = $scaled_filename; | 
					
						
							| 
									
										
										
										
											2009-02-06 03:13:08 -05:00
										 |  |  |                 $scaled->url = Avatar::url($scaled_filename); | 
					
						
							| 
									
										
										
										
											2009-02-04 19:32:15 -05:00
										 |  |  |                 $scaled->created = DB_DataObject_Cast::dateTime(); # current time
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 if (!$scaled->insert()) { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:21:29 -05:00
										 |  |  |                     return null; | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $avatar; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-21 13:57:18 -05:00
										 |  |  |     function delete_avatars($original=true) | 
					
						
							| 
									
										
										
										
											2008-12-25 09:46:01 -05:00
										 |  |  |     { | 
					
						
							|  |  |  |         $avatar = new Avatar(); | 
					
						
							|  |  |  |         $avatar->profile_id = $this->id; | 
					
						
							|  |  |  |         $avatar->find(); | 
					
						
							|  |  |  |         while ($avatar->fetch()) { | 
					
						
							|  |  |  |             if ($avatar->original) { | 
					
						
							|  |  |  |                 if ($original == false) { | 
					
						
							|  |  |  |                     continue; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             $avatar->delete(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function getBestName() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         return ($this->fullname) ? $this->fullname : $this->nickname; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-07-07 01:43:58 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     # Get latest notice on or before date; default now
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function getCurrentNotice($dt=null) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         $notice = new Notice(); | 
					
						
							|  |  |  |         $notice->profile_id = $this->id; | 
					
						
							|  |  |  |         if ($dt) { | 
					
						
							|  |  |  |             $notice->whereAdd('created < "' . $dt . '"'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $notice->orderBy('created DESC, notice.id DESC'); | 
					
						
							|  |  |  |         $notice->limit(1); | 
					
						
							|  |  |  |         if ($notice->find(true)) { | 
					
						
							|  |  |  |             return $notice; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2008-12-23 14:21:29 -05:00
										 |  |  |         return null; | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-17 15:04:57 -07:00
										 |  |  |     function getTaggedNotices($tag, $offset=0, $limit=NOTICES_PER_PAGE, $since_id=0, $max_id=0, $since=null) | 
					
						
							| 
									
										
										
										
											2009-05-18 17:18:57 -04:00
										 |  |  |     { | 
					
						
							|  |  |  |         $ids = Notice::stream(array($this, '_streamTaggedDirect'), | 
					
						
							| 
									
										
										
										
											2009-06-17 15:04:57 -07:00
										 |  |  |                               array($tag), | 
					
						
							|  |  |  |                               'profile:notice_ids_tagged:' . $this->id . ':' . $tag, | 
					
						
							|  |  |  |                               $offset, $limit, $since_id, $max_id, $since); | 
					
						
							| 
									
										
										
										
											2009-05-18 17:18:57 -04:00
										 |  |  |         return Notice::getStreamByIds($ids); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-17 15:04:57 -07:00
										 |  |  |     function getNotices($offset=0, $limit=NOTICES_PER_PAGE, $since_id=0, $max_id=0, $since=null) | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-11-08 23:32:15 +01:00
										 |  |  |         // XXX: I'm not sure this is going to be any faster. It probably is not.
 | 
					
						
							| 
									
										
										
										
											2009-05-01 11:27:57 -07:00
										 |  |  |         $ids = Notice::stream(array($this, '_streamDirect'), | 
					
						
							|  |  |  |                               array(), | 
					
						
							|  |  |  |                               'profile:notice_ids:' . $this->id, | 
					
						
							| 
									
										
										
										
											2009-06-08 11:55:32 -07:00
										 |  |  |                               $offset, $limit, $since_id, $max_id, $since); | 
					
						
							| 
									
										
										
										
											2009-05-01 11:27:57 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return Notice::getStreamByIds($ids); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-17 15:04:57 -07:00
										 |  |  |     function _streamTaggedDirect($tag, $offset, $limit, $since_id, $max_id, $since) | 
					
						
							| 
									
										
										
										
											2009-05-18 17:18:57 -04:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-06-17 15:04:57 -07:00
										 |  |  |         // XXX It would be nice to do this without a join
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-18 17:18:57 -04:00
										 |  |  |         $notice = new Notice(); | 
					
						
							| 
									
										
										
										
											2009-06-17 15:04:57 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $query = | 
					
						
							|  |  |  |           "select id from notice join notice_tag on id=notice_id where tag='". | 
					
						
							|  |  |  |           $notice->escape($tag) . | 
					
						
							|  |  |  |           "' and profile_id=" . $notice->escape($this->id); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-18 17:18:57 -04:00
										 |  |  |         if ($since_id != 0) { | 
					
						
							|  |  |  |             $query .= " and id > $since_id"; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-17 15:04:57 -07:00
										 |  |  |         if ($max_id != 0) { | 
					
						
							|  |  |  |             $query .= " and id < $max_id"; | 
					
						
							| 
									
										
										
										
											2009-05-18 17:18:57 -04:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!is_null($since)) { | 
					
						
							|  |  |  |             $query .= " and created > '" . date('Y-m-d H:i:s', $since) . "'"; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $query .= ' order by id DESC'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!is_null($offset)) { | 
					
						
							| 
									
										
										
										
											2009-07-23 15:07:28 +12:00
										 |  |  |             $query .= " LIMIT $limit OFFSET $offset"; | 
					
						
							| 
									
										
										
										
											2009-05-18 17:18:57 -04:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-06-17 15:04:57 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-18 17:18:57 -04:00
										 |  |  |         $notice->query($query); | 
					
						
							| 
									
										
										
										
											2009-06-17 15:04:57 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-18 17:18:57 -04:00
										 |  |  |         $ids = array(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         while ($notice->fetch()) { | 
					
						
							|  |  |  |             $ids[] = $notice->id; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $ids; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-17 15:04:57 -07:00
										 |  |  |     function _streamDirect($offset, $limit, $since_id, $max_id, $since = null) | 
					
						
							| 
									
										
										
										
											2009-05-01 11:27:57 -07:00
										 |  |  |     { | 
					
						
							|  |  |  |         $notice = new Notice(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $notice->profile_id = $this->id; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $notice->selectAdd(); | 
					
						
							|  |  |  |         $notice->selectAdd('id'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($since_id != 0) { | 
					
						
							|  |  |  |             $notice->whereAdd('id > ' . $since_id); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-29 16:54:24 -07:00
										 |  |  |         if ($max_id != 0) { | 
					
						
							|  |  |  |             $notice->whereAdd('id <= ' . $max_id); | 
					
						
							| 
									
										
										
										
											2009-05-01 11:27:57 -07:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!is_null($since)) { | 
					
						
							|  |  |  |             $notice->whereAdd('created > \'' . date('Y-m-d H:i:s', $since) . '\''); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $notice->orderBy('id DESC'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!is_null($offset)) { | 
					
						
							|  |  |  |             $notice->limit($offset, $limit); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $ids = array(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($notice->find()) { | 
					
						
							|  |  |  |             while ($notice->fetch()) { | 
					
						
							|  |  |  |                 $ids[] = $notice->id; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $ids; | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-01-21 13:57:18 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     function isMember($group) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $mem = new Group_member(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $mem->group_id = $group->id; | 
					
						
							|  |  |  |         $mem->profile_id = $this->id; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($mem->find()) { | 
					
						
							|  |  |  |             return true; | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function isAdmin($group) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $mem = new Group_member(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $mem->group_id = $group->id; | 
					
						
							|  |  |  |         $mem->profile_id = $this->id; | 
					
						
							|  |  |  |         $mem->is_admin = 1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($mem->find()) { | 
					
						
							|  |  |  |             return true; | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-06 03:13:08 -05:00
										 |  |  |     function avatarUrl($size=AVATAR_PROFILE_SIZE) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $avatar = $this->getAvatar($size); | 
					
						
							|  |  |  |         if ($avatar) { | 
					
						
							|  |  |  |             return $avatar->displayUrl(); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             return Avatar::defaultImage($size); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-06-25 23:00:46 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     function getSubscriptions($offset=0, $limit=null) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $qry = | 
					
						
							|  |  |  |           'SELECT profile.* ' . | 
					
						
							|  |  |  |           'FROM profile JOIN subscription ' . | 
					
						
							|  |  |  |           'ON profile.id = subscription.subscribed ' . | 
					
						
							|  |  |  |           'WHERE subscription.subscriber = %d ' . | 
					
						
							|  |  |  |           'AND subscription.subscribed != subscription.subscriber ' . | 
					
						
							|  |  |  |           'ORDER BY subscription.created DESC '; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (common_config('db','type') == 'pgsql') { | 
					
						
							|  |  |  |             $qry .= ' LIMIT ' . $limit . ' OFFSET ' . $offset; | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             $qry .= ' LIMIT ' . $offset . ', ' . $limit; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $profile = new Profile(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $profile->query(sprintf($qry, $this->id)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $profile; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function getSubscribers($offset=0, $limit=null) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $qry = | 
					
						
							|  |  |  |           'SELECT profile.* ' . | 
					
						
							|  |  |  |           'FROM profile JOIN subscription ' . | 
					
						
							|  |  |  |           'ON profile.id = subscription.subscriber ' . | 
					
						
							|  |  |  |           'WHERE subscription.subscribed = %d ' . | 
					
						
							|  |  |  |           'AND subscription.subscribed != subscription.subscriber ' . | 
					
						
							|  |  |  |           'ORDER BY subscription.created DESC '; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($offset) { | 
					
						
							|  |  |  |             if (common_config('db','type') == 'pgsql') { | 
					
						
							|  |  |  |                 $qry .= ' LIMIT ' . $limit . ' OFFSET ' . $offset; | 
					
						
							|  |  |  |             } else { | 
					
						
							|  |  |  |                 $qry .= ' LIMIT ' . $offset . ', ' . $limit; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $profile = new Profile(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $cnt = $profile->query(sprintf($qry, $this->id)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $profile; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-07-09 17:28:38 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     function subscriptionCount() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $c = common_memcache(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!empty($c)) { | 
					
						
							|  |  |  |             $cnt = $c->get(common_cache_key('profile:subscription_count:'.$this->id)); | 
					
						
							|  |  |  |             if (is_integer($cnt)) { | 
					
						
							|  |  |  |                 return (int) $cnt; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $sub = new Subscription(); | 
					
						
							|  |  |  |         $sub->subscriber = $this->id; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $cnt = (int) $sub->count('distinct subscribed'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $cnt = ($cnt > 0) ? $cnt - 1 : $cnt; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!empty($c)) { | 
					
						
							|  |  |  |             $c->set(common_cache_key('profile:subscription_count:'.$this->id), $cnt); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $cnt; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function subscriberCount() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $c = common_memcache(); | 
					
						
							|  |  |  |         if (!empty($c)) { | 
					
						
							|  |  |  |             $cnt = $c->get(common_cache_key('profile:subscriber_count:'.$this->id)); | 
					
						
							|  |  |  |             if (is_integer($cnt)) { | 
					
						
							|  |  |  |                 return (int) $cnt; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $sub = new Subscription(); | 
					
						
							|  |  |  |         $sub->subscribed = $this->id; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $cnt = (int) $sub->count('distinct subscriber'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $cnt = ($cnt > 0) ? $cnt - 1 : $cnt; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!empty($c)) { | 
					
						
							|  |  |  |             $c->set(common_cache_key('profile:subscriber_count:'.$this->id), $cnt); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $cnt; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function faveCount() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $c = common_memcache(); | 
					
						
							|  |  |  |         if (!empty($c)) { | 
					
						
							|  |  |  |             $cnt = $c->get(common_cache_key('profile:fave_count:'.$this->id)); | 
					
						
							|  |  |  |             if (is_integer($cnt)) { | 
					
						
							|  |  |  |                 return (int) $cnt; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $faves = new Fave(); | 
					
						
							|  |  |  |         $faves->user_id = $this->id; | 
					
						
							|  |  |  |         $cnt = (int) $faves->count('distinct notice_id'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!empty($c)) { | 
					
						
							|  |  |  |             $c->set(common_cache_key('profile:fave_count:'.$this->id), $cnt); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $cnt; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function noticeCount() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $c = common_memcache(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!empty($c)) { | 
					
						
							|  |  |  |             $cnt = $c->get(common_cache_key('profile:notice_count:'.$this->id)); | 
					
						
							|  |  |  |             if (is_integer($cnt)) { | 
					
						
							|  |  |  |                 return (int) $cnt; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $notices = new Notice(); | 
					
						
							|  |  |  |         $notices->profile_id = $this->id; | 
					
						
							|  |  |  |         $cnt = (int) $notices->count('distinct id'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!empty($c)) { | 
					
						
							|  |  |  |             $c->set(common_cache_key('profile:notice_count:'.$this->id), $cnt); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $cnt; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function blowSubscriberCount() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $c = common_memcache(); | 
					
						
							|  |  |  |         if (!empty($c)) { | 
					
						
							|  |  |  |             $c->delete(common_cache_key('profile:subscriber_count:'.$this->id)); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function blowSubscriptionCount() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $c = common_memcache(); | 
					
						
							|  |  |  |         if (!empty($c)) { | 
					
						
							|  |  |  |             $c->delete(common_cache_key('profile:subscription_count:'.$this->id)); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function blowFaveCount() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $c = common_memcache(); | 
					
						
							|  |  |  |         if (!empty($c)) { | 
					
						
							|  |  |  |             $c->delete(common_cache_key('profile:fave_count:'.$this->id)); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function blowNoticeCount() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $c = common_memcache(); | 
					
						
							|  |  |  |         if (!empty($c)) { | 
					
						
							|  |  |  |             $c->delete(common_cache_key('profile:notice_count:'.$this->id)); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-08-21 07:40:46 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     static function maxBio() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-08-21 07:48:14 -04:00
										 |  |  |         $biolimit = common_config('profile', 'biolimit'); | 
					
						
							| 
									
										
										
										
											2009-08-21 07:40:46 -04:00
										 |  |  |         // null => use global limit (distinct from 0!)
 | 
					
						
							|  |  |  |         if (is_null($biolimit)) { | 
					
						
							|  |  |  |             $biolimit = common_config('site', 'textlimit'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $biolimit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static function bioTooLong($bio) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $biolimit = self::maxBio(); | 
					
						
							|  |  |  |         return ($biolimit > 0 && !empty($bio) && (mb_strlen($bio) > $biolimit)); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-10-04 03:07:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-26 13:06:38 -06:00
										 |  |  |     function delete() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->_deleteNotices(); | 
					
						
							|  |  |  |         $this->_deleteSubscriptions(); | 
					
						
							|  |  |  |         $this->_deleteMessages(); | 
					
						
							|  |  |  |         $this->_deleteTags(); | 
					
						
							|  |  |  |         $this->_deleteBlocks(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $related = array('Avatar', | 
					
						
							|  |  |  |                          'Reply', | 
					
						
							|  |  |  |                          'Group_member', | 
					
						
							|  |  |  |                          ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         foreach ($related as $cls) { | 
					
						
							|  |  |  |             $inst = new $cls(); | 
					
						
							|  |  |  |             $inst->profile_id = $this->id; | 
					
						
							|  |  |  |             $inst->delete(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         parent::delete(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function _deleteNotices() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $notice = new Notice(); | 
					
						
							|  |  |  |         $notice->profile_id = $this->id; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($notice->find()) { | 
					
						
							|  |  |  |             while ($notice->fetch()) { | 
					
						
							|  |  |  |                 $other = clone($notice); | 
					
						
							|  |  |  |                 $other->delete(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function _deleteSubscriptions() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $sub = new Subscription(); | 
					
						
							|  |  |  |         $sub->subscriber = $this->id; | 
					
						
							|  |  |  |         $sub->delete(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $subd = new Subscription(); | 
					
						
							|  |  |  |         $subd->subscribed = $this->id; | 
					
						
							|  |  |  |         $subd->delete(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function _deleteMessages() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $msg = new Message(); | 
					
						
							|  |  |  |         $msg->from_profile = $this->id; | 
					
						
							|  |  |  |         $msg->delete(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $msg = new Message(); | 
					
						
							|  |  |  |         $msg->to_profile = $this->id; | 
					
						
							|  |  |  |         $msg->delete(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function _deleteTags() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $tag = new Profile_tag(); | 
					
						
							|  |  |  |         $tag->tagged = $this->id; | 
					
						
							| 
									
										
										
										
											2009-10-02 15:42:34 -04:00
										 |  |  |         $tag->delete(); | 
					
						
							| 
									
										
										
										
											2009-07-26 13:06:38 -06:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function _deleteBlocks() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $block = new Profile_block(); | 
					
						
							|  |  |  |         $block->blocked = $this->id; | 
					
						
							|  |  |  |         $block->delete(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $block = new Group_block(); | 
					
						
							|  |  |  |         $block->blocked = $this->id; | 
					
						
							|  |  |  |         $block->delete(); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-10-29 14:43:25 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // XXX: identical to Notice::getLocation.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function getLocation() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $location = null; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!empty($this->location_id) && !empty($this->location_ns)) { | 
					
						
							|  |  |  |             $location = Location::fromId($this->location_id, $this->location_ns); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (is_null($location)) { // no ID, or Location::fromId() failed
 | 
					
						
							|  |  |  |             if (!empty($this->lat) && !empty($this->lon)) { | 
					
						
							|  |  |  |                 $location = Location::fromLatLon($this->lat, $this->lon); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (is_null($location)) { // still haven't found it!
 | 
					
						
							|  |  |  |             if (!empty($this->location)) { | 
					
						
							|  |  |  |                 $location = Location::fromName($this->location); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $location; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-05-07 13:15:42 -04:00
										 |  |  | } |