| 
									
										
										
										
											2008-11-20 15:55:06 -05:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Table Definition for profile_tag | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-11-20 16:49:45 -05:00
										 |  |  | require_once INSTALLDIR.'/classes/Memcached_DataObject.php'; | 
					
						
							| 
									
										
										
										
											2008-11-20 15:55:06 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | class Profile_tag extends Memcached_DataObject | 
					
						
							| 
									
										
										
										
											2008-11-20 15:55:06 -05:00
										 |  |  | { | 
					
						
							|  |  |  |     ###START_AUTOCODE
 | 
					
						
							|  |  |  |     /* the code below is auto generated do not remove the above tag */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public $__table = 'profile_tag';                     // table name
 | 
					
						
							|  |  |  |     public $tagger;                          // int(4)  primary_key not_null
 | 
					
						
							|  |  |  |     public $tagged;                          // int(4)  primary_key not_null
 | 
					
						
							|  |  |  |     public $tag;                             // varchar(64)  primary_key not_null
 | 
					
						
							|  |  |  |     public $modified;                        // timestamp()   not_null default_CURRENT_TIMESTAMP
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Static get */ | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  |     function staticGet($k,$v=null) | 
					
						
							|  |  |  |     { return Memcached_DataObject::staticGet('Profile_tag',$k,$v); } | 
					
						
							| 
									
										
										
										
											2008-11-20 15:55:06 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* the code above is auto generated do not remove the tag below */ | 
					
						
							|  |  |  |     ###END_AUTOCODE
 | 
					
						
							| 
									
										
										
										
											2008-11-20 16:48:21 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |     function pkeyGet($kv) { | 
					
						
							|  |  |  |         return Memcached_DataObject::pkeyGet('Profile_tag', $kv); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function links() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return array('tagger,tag' => 'profile_list:tagger,tag'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function getMeta() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return Profile_list::pkeyGet(array('tagger' => $this->tagger, 'tag' => $this->tag)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static function getTags($tagger, $tagged, $auth_user=null) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $profile_list = new Profile_list(); | 
					
						
							|  |  |  |         $include_priv = 1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!($auth_user instanceof User || | 
					
						
							|  |  |  |             $auth_user instanceof Profile) || | 
					
						
							|  |  |  |             ($auth_user->id !== $tagger)) { | 
					
						
							| 
									
										
										
										
											2008-11-20 16:48:21 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |             $profile_list->private = false; | 
					
						
							|  |  |  |             $include_priv = 0; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $key = sprintf('profile_tag:tagger_tagged_privacy:%d-%d-%d', $tagger, $tagged, $include_priv); | 
					
						
							|  |  |  |         $tags = Profile_list::getCached($key); | 
					
						
							|  |  |  |         if ($tags !== false) { | 
					
						
							|  |  |  |             return $tags; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         $profile_tag = new Profile_tag(); | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |         $profile_list->tagger = $tagger; | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         $profile_tag->tagged = $tagged; | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |         $profile_list->selectAdd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // only fetch id, tag, mainpage and
 | 
					
						
							|  |  |  |         // private hoping this will be faster
 | 
					
						
							|  |  |  |         $profile_list->selectAdd('profile_list.id, ' . | 
					
						
							|  |  |  |                                  'profile_list.tag, ' . | 
					
						
							|  |  |  |                                  'profile_list.mainpage, ' . | 
					
						
							|  |  |  |                                  'profile_list.private'); | 
					
						
							|  |  |  |         $profile_list->joinAdd($profile_tag); | 
					
						
							|  |  |  |         $profile_list->find(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Profile_list::setCache($key, $profile_list); | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |         return $profile_list; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static function getTagsArray($tagger, $tagged, $auth_user_id=null) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $ptag = new Profile_tag(); | 
					
						
							|  |  |  |         $ptag->tagger = $tagger; | 
					
						
							|  |  |  |         $ptag->tagged = $tagged; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($tagger != $auth_user_id) { | 
					
						
							|  |  |  |             $list = new Profile_list(); | 
					
						
							|  |  |  |             $list->private = false; | 
					
						
							|  |  |  |             $ptag->joinAdd($list); | 
					
						
							|  |  |  |             $ptag->selectAdd(); | 
					
						
							|  |  |  |             $ptag->selectAdd('profile_tag.tag'); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |         $tags = array(); | 
					
						
							|  |  |  |         $ptag->find(); | 
					
						
							|  |  |  |         while ($ptag->fetch()) { | 
					
						
							|  |  |  |             $tags[] = $ptag->tag; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $ptag->free(); | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         return $tags; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |     static function setTags($tagger, $tagged, $newtags, $privacy=array()) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  |         $newtags = array_unique($newtags); | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |         $oldtags = self::getTagsArray($tagger, $tagged, $tagger); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $ptag = new Profile_tag(); | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-30 15:43:13 +05:30
										 |  |  |         // Delete stuff that's in old and not in new
 | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         $to_delete = array_diff($oldtags, $newtags); | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-22 11:54:23 -04:00
										 |  |  |         // Insert stuff that's in new and not in old
 | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         $to_insert = array_diff($newtags, $oldtags); | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |         foreach ($to_delete as $deltag) { | 
					
						
							|  |  |  |             self::unTag($tagger, $tagged, $deltag); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |         foreach ($to_insert as $instag) { | 
					
						
							|  |  |  |             $private = isset($privacy[$instag]) ? $privacy[$instag] : false; | 
					
						
							|  |  |  |             self::setTag($tagger, $tagged, $instag, null, $private); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # set a single tag
 | 
					
						
							|  |  |  |     static function setTag($tagger, $tagged, $tag, $desc=null, $private=false) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $ptag = Profile_tag::pkeyGet(array('tagger' => $tagger, | 
					
						
							|  |  |  |                                            'tagged' => $tagged, | 
					
						
							|  |  |  |                                            'tag' => $tag)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # if tag already exists, return it
 | 
					
						
							|  |  |  |         if(!empty($ptag)) { | 
					
						
							|  |  |  |             return $ptag; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $tagger_profile = Profile::staticGet('id', $tagger); | 
					
						
							|  |  |  |         $tagged_profile = Profile::staticGet('id', $tagged); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (Event::handle('StartTagProfile', array($tagger_profile, $tagged_profile, $tag))) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (!$tagger_profile->canTag($tagged_profile)) { | 
					
						
							|  |  |  |                 throw new ClientException(_('You cannot tag this user.')); | 
					
						
							|  |  |  |                 return false; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $tags = new Profile_list(); | 
					
						
							|  |  |  |             $tags->tagger = $tagger; | 
					
						
							|  |  |  |             $count = (int) $tags->count('distinct tag'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if ($count >= common_config('peopletag', 'maxtags')) { | 
					
						
							|  |  |  |                 throw new ClientException(sprintf(_('You already have created %d or more tags ' . | 
					
						
							|  |  |  |                                                     'which is the maximum allowed number of tags. ' . | 
					
						
							|  |  |  |                                                     'Try using or deleting some existing tags.'), | 
					
						
							|  |  |  |                                                     common_config('peopletag', 'maxtags'))); | 
					
						
							|  |  |  |                 return false; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $plist = new Profile_list(); | 
					
						
							|  |  |  |             $plist->query('BEGIN'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $profile_list = Profile_list::ensureTag($tagger, $tag, $desc, $private); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if ($profile_list->taggedCount() >= common_config('peopletag', 'maxpeople')) { | 
					
						
							|  |  |  |                 throw new ClientException(sprintf(_('You already have %d or more people tagged %s ' . | 
					
						
							|  |  |  |                                                     'which is the maximum allowed number.' . | 
					
						
							|  |  |  |                                                     'Try untagging others with the same tag first.'), | 
					
						
							|  |  |  |                                                     common_config('peopletag', 'maxpeople'), $tag)); | 
					
						
							|  |  |  |                 return false; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $newtag = new Profile_tag(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $newtag->tagger = $tagger; | 
					
						
							|  |  |  |             $newtag->tagged = $tagged; | 
					
						
							|  |  |  |             $newtag->tag = $tag; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $result = $newtag->insert(); | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |             if (!$result) { | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |                 common_log_db_error($newtag, 'INSERT', __FILE__); | 
					
						
							|  |  |  |                 return false; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             try { | 
					
						
							|  |  |  |                 $plist->query('COMMIT'); | 
					
						
							|  |  |  |                 Event::handle('EndTagProfile', array($newtag)); | 
					
						
							|  |  |  |             } catch (Exception $e) { | 
					
						
							|  |  |  |                 $newtag->delete(); | 
					
						
							|  |  |  |                 $profile_list->delete(); | 
					
						
							|  |  |  |                 throw $e; | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                 return false; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |             $profile_list->taggedCount(true); | 
					
						
							|  |  |  |             self::blowCaches($tagger, $tagged); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |         return $newtag; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static function unTag($tagger, $tagged, $tag) { | 
					
						
							|  |  |  |         $ptag = Profile_tag::pkeyGet(array('tagger' => $tagger, | 
					
						
							|  |  |  |                                            'tagged' => $tagged, | 
					
						
							|  |  |  |                                            'tag'    => $tag)); | 
					
						
							|  |  |  |         if (!$ptag) { | 
					
						
							|  |  |  |             return true; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (Event::handle('StartUntagProfile', array($ptag))) { | 
					
						
							|  |  |  |             $orig = clone($ptag); | 
					
						
							|  |  |  |             $result = $ptag->delete(); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |             if (!$result) { | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |                 common_log_db_error($this, 'DELETE', __FILE__); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |                 return false; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |             Event::handle('EndUntagProfile', array($orig)); | 
					
						
							|  |  |  |             if ($result) { | 
					
						
							|  |  |  |                 $profile_list = Profile_list::pkeyGet(array('tag' => $tag, 'tagger' => $tagger)); | 
					
						
							|  |  |  |                 $profile_list->taggedCount(true); | 
					
						
							|  |  |  |                 self::blowCaches($tagger, $tagged); | 
					
						
							|  |  |  |                 return true; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             return false; | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // @fixme: move this to Profile_list?
 | 
					
						
							|  |  |  |     static function cleanup($profile_list) { | 
					
						
							|  |  |  |         $ptag = new Profile_tag(); | 
					
						
							|  |  |  |         $ptag->tagger = $profile_list->tagger; | 
					
						
							|  |  |  |         $ptag->tag = $profile_list->tag; | 
					
						
							|  |  |  |         $ptag->find(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         while($ptag->fetch()) { | 
					
						
							|  |  |  |             if (Event::handle('StartUntagProfile', array($ptag))) { | 
					
						
							|  |  |  |                 $orig = clone($ptag); | 
					
						
							|  |  |  |                 $result = $ptag->delete(); | 
					
						
							|  |  |  |                 if (!$result) { | 
					
						
							|  |  |  |                     common_log_db_error($this, 'DELETE', __FILE__); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 Event::handle('EndUntagProfile', array($orig)); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |     // move a tag!
 | 
					
						
							|  |  |  |     static function moveTag($orig, $new) { | 
					
						
							|  |  |  |         $tags = new Profile_tag(); | 
					
						
							|  |  |  |         $qry = 'UPDATE profile_tag SET ' . | 
					
						
							|  |  |  |                'tag = "%s", tagger = "%s" ' . | 
					
						
							|  |  |  |                'WHERE tag = "%s" ' . | 
					
						
							|  |  |  |                'AND tagger = "%s"'; | 
					
						
							|  |  |  |         $result = $tags->query(sprintf($qry, $new->tag, $new->tagger, | 
					
						
							|  |  |  |                                              $orig->tag, $orig->tagger)); | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |         if (!$result) { | 
					
						
							|  |  |  |             common_log_db_error($tags, 'UPDATE', __FILE__); | 
					
						
							|  |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |     static function blowCaches($tagger, $tagged) { | 
					
						
							|  |  |  |         foreach (array(0, 1) as $perm) { | 
					
						
							|  |  |  |             self::blow(sprintf('profile_tag:tagger_tagged_privacy:%d-%d-%d', $tagger, $tagged, $perm)); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2011-03-06 23:28:03 +05:30
										 |  |  |         return true; | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-02-28 15:17:49 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-22 11:54:23 -04:00
										 |  |  |     // Return profiles with a given tag
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     static function getTagged($tagger, $tag) { | 
					
						
							|  |  |  |         $profile = new Profile(); | 
					
						
							|  |  |  |         $profile->query('SELECT profile.* ' . | 
					
						
							|  |  |  |                         'FROM profile JOIN profile_tag ' . | 
					
						
							|  |  |  |                         'ON profile.id = profile_tag.tagged ' . | 
					
						
							|  |  |  |                         'WHERE profile_tag.tagger = ' . $tagger . ' ' . | 
					
						
							|  |  |  |                         'AND profile_tag.tag = "' . $tag . '" '); | 
					
						
							|  |  |  |         $tagged = array(); | 
					
						
							|  |  |  |         while ($profile->fetch()) { | 
					
						
							|  |  |  |             $tagged[] = clone($profile); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2011-03-30 15:43:13 +05:30
										 |  |  |         return true; | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-11-20 15:55:06 -05:00
										 |  |  | } |