Database stuff. New table "thread". Changing "left join" to "inner join", removing "limit 1" at update and delete.
This commit is contained in:
		
					parent
					
						
							
								2b5345323f
							
						
					
				
			
			
				commit
				
					
						6b8585d48d
					
				
			
		
					 33 changed files with 487 additions and 444 deletions
				
			
		
							
								
								
									
										10
									
								
								boot.php
									
										
									
									
									
								
							
							
						
						
									
										10
									
								
								boot.php
									
										
									
									
									
								
							|  | @ -14,7 +14,7 @@ require_once('include/features.php'); | ||||||
| define ( 'FRIENDICA_PLATFORM',     'Friendica'); | define ( 'FRIENDICA_PLATFORM',     'Friendica'); | ||||||
| define ( 'FRIENDICA_VERSION',      '3.2.1748' ); | define ( 'FRIENDICA_VERSION',      '3.2.1748' ); | ||||||
| define ( 'DFRN_PROTOCOL_VERSION',  '2.23'    ); | define ( 'DFRN_PROTOCOL_VERSION',  '2.23'    ); | ||||||
| define ( 'DB_UPDATE_VERSION',      1169      ); | define ( 'DB_UPDATE_VERSION',      1170      ); | ||||||
| define ( 'EOL',                    "<br />\r\n"     ); | define ( 'EOL',                    "<br />\r\n"     ); | ||||||
| define ( 'ATOM_TIME',              'Y-m-d\TH:i:s\Z' ); | define ( 'ATOM_TIME',              'Y-m-d\TH:i:s\Z' ); | ||||||
| 
 | 
 | ||||||
|  | @ -739,7 +739,7 @@ if(! class_exists('App')) { | ||||||
| 			if($this->cached_profile_picdate[$common_filename]){ | 			if($this->cached_profile_picdate[$common_filename]){ | ||||||
| 				$this->cached_profile_image[$avatar_image] = $avatar_image . $this->cached_profile_picdate[$common_filename]; | 				$this->cached_profile_image[$avatar_image] = $avatar_image . $this->cached_profile_picdate[$common_filename]; | ||||||
| 			} else { | 			} else { | ||||||
| 				$r = q("SELECT `contact`.`avatar-date` AS picdate FROM `contact` WHERE `contact`.`thumb` like \"%%/%s\"", | 				$r = q("SELECT `contact`.`avatar-date` AS picdate FROM `contact` WHERE `contact`.`thumb` like '%%/%s'", | ||||||
| 					$common_filename); | 					$common_filename); | ||||||
| 				if(! count($r)){ | 				if(! count($r)){ | ||||||
| 					$this->cached_profile_image[$avatar_image] = $avatar_image; | 					$this->cached_profile_image[$avatar_image] = $avatar_image; | ||||||
|  | @ -1328,7 +1328,7 @@ if(! function_exists('profile_load')) { | ||||||
| 		if($profile) { | 		if($profile) { | ||||||
| 			$profile_int = intval($profile); | 			$profile_int = intval($profile); | ||||||
| 			$r = q("SELECT `profile`.`uid` AS `profile_uid`, `profile`.* , `contact`.`avatar-date` AS picdate, `user`.* FROM `profile`
 | 			$r = q("SELECT `profile`.`uid` AS `profile_uid`, `profile`.* , `contact`.`avatar-date` AS picdate, `user`.* FROM `profile`
 | ||||||
| 					left join `contact` on `contact`.`uid` = `profile`.`uid` LEFT JOIN `user` ON `profile`.`uid` = `user`.`uid` | 					INNER JOIN `contact` on `contact`.`uid` = `profile`.`uid` INNER JOIN `user` ON `profile`.`uid` = `user`.`uid` | ||||||
| 					WHERE `user`.`nickname` = '%s' AND `profile`.`id` = %d and `contact`.`self` = 1 LIMIT 1",
 | 					WHERE `user`.`nickname` = '%s' AND `profile`.`id` = %d and `contact`.`self` = 1 LIMIT 1",
 | ||||||
| 					dbesc($nickname), | 					dbesc($nickname), | ||||||
| 					intval($profile_int) | 					intval($profile_int) | ||||||
|  | @ -1336,7 +1336,7 @@ if(! function_exists('profile_load')) { | ||||||
| 		} | 		} | ||||||
| 		if((! $r) && (!  count($r))) { | 		if((! $r) && (!  count($r))) { | ||||||
| 			$r = q("SELECT `profile`.`uid` AS `profile_uid`, `profile`.* , `contact`.`avatar-date` AS picdate, `user`.* FROM `profile`
 | 			$r = q("SELECT `profile`.`uid` AS `profile_uid`, `profile`.* , `contact`.`avatar-date` AS picdate, `user`.* FROM `profile`
 | ||||||
| 					left join `contact` on `contact`.`uid` = `profile`.`uid` LEFT JOIN `user` ON `profile`.`uid` = `user`.`uid` | 					INNER JOIN `contact` on `contact`.`uid` = `profile`.`uid` INNER JOIN `user` ON `profile`.`uid` = `user`.`uid` | ||||||
| 					WHERE `user`.`nickname` = '%s' AND `profile`.`is-default` = 1 and `contact`.`self` = 1 LIMIT 1",
 | 					WHERE `user`.`nickname` = '%s' AND `profile`.`is-default` = 1 and `contact`.`self` = 1 LIMIT 1",
 | ||||||
| 					dbesc($nickname) | 					dbesc($nickname) | ||||||
| 			); | 			); | ||||||
|  | @ -1591,7 +1591,7 @@ if(! function_exists('get_birthdays')) { | ||||||
| 		$bd_short = t('F d'); | 		$bd_short = t('F d'); | ||||||
| 
 | 
 | ||||||
| 		$r = q("SELECT `event`.*, `event`.`id` AS `eid`, `contact`.* FROM `event`
 | 		$r = q("SELECT `event`.*, `event`.`id` AS `eid`, `contact`.* FROM `event`
 | ||||||
| 				LEFT JOIN `contact` ON `contact`.`id` = `event`.`cid` | 				INNER JOIN `contact` ON `contact`.`id` = `event`.`cid` | ||||||
| 				WHERE `event`.`uid` = %d AND `type` = 'birthday' AND `start` < '%s' AND `finish` > '%s' | 				WHERE `event`.`uid` = %d AND `type` = 'birthday' AND `start` < '%s' AND `finish` > '%s' | ||||||
| 				ORDER BY `start` ASC ",
 | 				ORDER BY `start` ASC ",
 | ||||||
| 				intval(local_user()), | 				intval(local_user()), | ||||||
|  |  | ||||||
							
								
								
									
										43
									
								
								database.sql
									
										
									
									
									
								
							
							
						
						
									
										43
									
								
								database.sql
									
										
									
									
									
								
							|  | @ -1192,3 +1192,46 @@ CREATE TABLE IF NOT EXISTS `unique_contacts` ( | ||||||
|   PRIMARY KEY (`id`), |   PRIMARY KEY (`id`), | ||||||
|   KEY `url` (`url`) |   KEY `url` (`url`) | ||||||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8; | ) ENGINE=MyISAM DEFAULT CHARSET=utf8; | ||||||
|  | 
 | ||||||
|  | -- -------------------------------------------------------- | ||||||
|  | 
 | ||||||
|  | -- | ||||||
|  | -- Table structure for table `thread` | ||||||
|  | -- | ||||||
|  | 
 | ||||||
|  | CREATE TABLE IF NOT EXISTS `thread` ( | ||||||
|  |   `iid` int(10) unsigned NOT NULL DEFAULT '0', | ||||||
|  |   `uid` int(10) unsigned NOT NULL DEFAULT '0', | ||||||
|  |   `contact-id` int(10) unsigned NOT NULL DEFAULT '0', | ||||||
|  |   `created` datetime NOT NULL DEFAULT '0000-00-00 00:00:00', | ||||||
|  |   `edited` datetime NOT NULL DEFAULT '0000-00-00 00:00:00', | ||||||
|  |   `commented` datetime NOT NULL DEFAULT '0000-00-00 00:00:00', | ||||||
|  |   `received` datetime NOT NULL DEFAULT '0000-00-00 00:00:00', | ||||||
|  |   `changed` datetime NOT NULL DEFAULT '0000-00-00 00:00:00', | ||||||
|  |   `wall` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  |   `private` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  |   `pubmail` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  |   `moderated` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  |   `visible` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  |   `spam` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  |   `starred` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  |   `bookmark` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  |   `unseen` tinyint(1) NOT NULL DEFAULT '1', | ||||||
|  |   `deleted` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  |   `origin` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  |   `forum_mode` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  |   `mention` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  |   `network` char(32) NOT NULL, | ||||||
|  |   PRIMARY KEY (`iid`), | ||||||
|  |   KEY `uid` (`uid`), | ||||||
|  |   KEY `contact-id` (`contact-id`), | ||||||
|  |   KEY `created` (`created`), | ||||||
|  |   KEY `edited` (`edited`), | ||||||
|  |   KEY `commented` (`commented`), | ||||||
|  |   KEY `received` (`received`), | ||||||
|  |   KEY `changed` (`changed`), | ||||||
|  |   KEY `network` (`network`), | ||||||
|  |   KEY `visible_deleted_moderated_private_wall_received` (`visible`,`deleted`,`moderated`,`private`,`wall`,`received`), | ||||||
|  |   KEY `uid_visible_deleted_moderated_created` (`uid`,`visible`,`deleted`,`moderated`,`created`), | ||||||
|  |   KEY `uid_visible_deleted_moderated_commented` (`uid`,`visible`,`deleted`,`moderated`,`commented`) | ||||||
|  | ) ENGINE=MyISAM DEFAULT CHARSET=utf8; | ||||||
|  |  | ||||||
|  | @ -842,13 +842,14 @@ | ||||||
| 
 | 
 | ||||||
| 		$lastwall = q("SELECT `item`.*
 | 		$lastwall = q("SELECT `item`.*
 | ||||||
| 				FROM `item`, `contact` | 				FROM `item`, `contact` | ||||||
| 				WHERE `item`.`contact-id` = %d | 				WHERE `item`.`uid` = %d AND `item`.`contact-id` = %d | ||||||
| 					AND ((`item`.`author-link` IN ('%s', '%s')) OR (`item`.`owner-link` IN ('%s', '%s'))) | 					AND ((`item`.`author-link` IN ('%s', '%s')) OR (`item`.`owner-link` IN ('%s', '%s'))) | ||||||
| 					AND `contact`.`id`=`item`.`contact-id` | 					AND `contact`.`id`=`item`.`contact-id` | ||||||
| 					AND `type`!='activity' | 					AND `type`!='activity' | ||||||
| 					AND `item`.`allow_cid`='' AND `item`.`allow_gid`='' AND `item`.`deny_cid`='' AND `item`.`deny_gid`='' | 					AND `item`.`allow_cid`='' AND `item`.`allow_gid`='' AND `item`.`deny_cid`='' AND `item`.`deny_gid`='' | ||||||
| 				ORDER BY `created` DESC | 				ORDER BY `created` DESC | ||||||
| 				LIMIT 1",
 | 				LIMIT 1",
 | ||||||
|  | 				intval(api_user()), | ||||||
| 				intval($user_info['cid']), | 				intval($user_info['cid']), | ||||||
| 				dbesc($user_info['url']), | 				dbesc($user_info['url']), | ||||||
| 				dbesc(normalise_link($user_info['url'])), | 				dbesc(normalise_link($user_info['url'])), | ||||||
|  | @ -1041,8 +1042,8 @@ | ||||||
|         	        `contact`.`network`, `contact`.`thumb`, `contact`.`self`, `contact`.`writable`, |         	        `contact`.`network`, `contact`.`thumb`, `contact`.`self`, `contact`.`writable`, | ||||||
|                 	`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid`, |                 	`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid`, | ||||||
|                 	`user`.`nickname`, `user`.`hidewall` |                 	`user`.`nickname`, `user`.`hidewall` | ||||||
|                 	FROM `item` LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` |                 	FROM `item` INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | ||||||
|                 	LEFT JOIN `user` ON `user`.`uid` = `item`.`uid` |                 	INNER JOIN `user` ON `user`.`uid` = `item`.`uid` | ||||||
|                 	WHERE `item`.`visible` = 1 AND `item`.`deleted` = 0 and `item`.`moderated` = 0 |                 	WHERE `item`.`visible` = 1 AND `item`.`deleted` = 0 and `item`.`moderated` = 0 | ||||||
|                 	AND `item`.`allow_cid` = ''  AND `item`.`allow_gid` = '' |                 	AND `item`.`allow_cid` = ''  AND `item`.`allow_gid` = '' | ||||||
|                 	AND `item`.`deny_cid`  = '' AND `item`.`deny_gid`  = '' |                 	AND `item`.`deny_cid`  = '' AND `item`.`deny_gid`  = '' | ||||||
|  |  | ||||||
|  | @ -18,6 +18,7 @@ class dba { | ||||||
| 
 | 
 | ||||||
| 	private $debug = 0; | 	private $debug = 0; | ||||||
| 	private $db; | 	private $db; | ||||||
|  | 	private $result; | ||||||
| 	public  $mysqli = true; | 	public  $mysqli = true; | ||||||
| 	public  $connected = false; | 	public  $connected = false; | ||||||
| 	public  $error = false; | 	public  $error = false; | ||||||
|  | @ -75,7 +76,7 @@ class dba { | ||||||
| 		return $this->db; | 		return $this->db; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	public function q($sql) { | 	public function q($sql, $onlyquery = false) { | ||||||
| 		global $a; | 		global $a; | ||||||
| 
 | 
 | ||||||
| 		if((! $this->db) || (! $this->connected)) | 		if((! $this->db) || (! $this->connected)) | ||||||
|  | @ -154,6 +155,11 @@ class dba { | ||||||
| 		if(($result === true) || ($result === false)) | 		if(($result === true) || ($result === false)) | ||||||
| 			return $result; | 			return $result; | ||||||
| 
 | 
 | ||||||
|  | 		if ($onlyquery) { | ||||||
|  | 			$this->result = $result; | ||||||
|  | 			return true; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
| 		$r = array(); | 		$r = array(); | ||||||
| 		if($this->mysqli) { | 		if($this->mysqli) { | ||||||
| 			if($result->num_rows) { | 			if($result->num_rows) { | ||||||
|  | @ -177,6 +183,30 @@ class dba { | ||||||
| 		return($r); | 		return($r); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	public function qfetch() { | ||||||
|  | 		$x = false; | ||||||
|  | 
 | ||||||
|  | 		if ($this->result) | ||||||
|  | 			if($this->mysqli) { | ||||||
|  | 				if($this->result->num_rows) | ||||||
|  | 					$x = $this->result->fetch_array(MYSQLI_ASSOC); | ||||||
|  | 			} else { | ||||||
|  | 				if(mysql_num_rows($this->result)) | ||||||
|  | 					$x = mysql_fetch_array($this->result, MYSQL_ASSOC); | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 		return($x); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	public function qclose() { | ||||||
|  | 		if ($this->result) | ||||||
|  | 			if($this->mysqli) { | ||||||
|  | 				$this->result->free_result(); | ||||||
|  | 			} else { | ||||||
|  | 				mysql_free_result($this->result); | ||||||
|  | 			} | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	public function dbg($dbg) { | 	public function dbg($dbg) { | ||||||
| 		$this->debug = $dbg; | 		$this->debug = $dbg; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | @ -157,7 +157,7 @@ function delivery_run(&$argv, &$argc){ | ||||||
| 		$r = q("SELECT `contact`.*, `user`.`pubkey` AS `upubkey`, `user`.`prvkey` AS `uprvkey`, 
 | 		$r = q("SELECT `contact`.*, `user`.`pubkey` AS `upubkey`, `user`.`prvkey` AS `uprvkey`, 
 | ||||||
| 			`user`.`timezone`, `user`.`nickname`, `user`.`sprvkey`, `user`.`spubkey`,  | 			`user`.`timezone`, `user`.`nickname`, `user`.`sprvkey`, `user`.`spubkey`,  | ||||||
| 			`user`.`page-flags`, `user`.`prvnets` | 			`user`.`page-flags`, `user`.`prvnets` | ||||||
| 			FROM `contact` LEFT JOIN `user` ON `user`.`uid` = `contact`.`uid`  | 			FROM `contact` INNER JOIN `user` ON `user`.`uid` = `contact`.`uid`  | ||||||
| 			WHERE `contact`.`uid` = %d AND `contact`.`self` = 1 LIMIT 1",
 | 			WHERE `contact`.`uid` = %d AND `contact`.`self` = 1 LIMIT 1",
 | ||||||
| 			intval($uid) | 			intval($uid) | ||||||
| 		); | 		); | ||||||
|  | @ -319,7 +319,7 @@ function delivery_run(&$argv, &$argc){ | ||||||
| 						`contact`.`name` as `senderName`, | 						`contact`.`name` as `senderName`, | ||||||
| 						`user`.*  | 						`user`.*  | ||||||
| 						FROM `contact`  | 						FROM `contact`  | ||||||
| 						LEFT JOIN `user` ON `contact`.`uid` = `user`.`uid`  | 						INNER JOIN `user` ON `contact`.`uid` = `user`.`uid`  | ||||||
| 						WHERE `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | 						WHERE `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
| 						AND `contact`.`network` = '%s' AND `user`.`nickname` = '%s' | 						AND `contact`.`network` = '%s' AND `user`.`nickname` = '%s' | ||||||
| 						$sql_extra | 						$sql_extra | ||||||
|  |  | ||||||
|  | @ -578,7 +578,7 @@ function diaspora_request($importer,$xml) { | ||||||
| 		// That makes us friends.
 | 		// That makes us friends.
 | ||||||
| 
 | 
 | ||||||
| 		if($contact['rel'] == CONTACT_IS_FOLLOWER && $importer['page-flags'] != PAGE_COMMUNITY) { | 		if($contact['rel'] == CONTACT_IS_FOLLOWER && $importer['page-flags'] != PAGE_COMMUNITY) { | ||||||
| 			q("UPDATE `contact` SET `rel` = %d, `writable` = 1 WHERE `id` = %d AND `uid` = %d LIMIT 1", | 			q("UPDATE `contact` SET `rel` = %d, `writable` = 1 WHERE `id` = %d AND `uid` = %d", | ||||||
| 				intval(CONTACT_IS_FRIEND), | 				intval(CONTACT_IS_FRIEND), | ||||||
| 				intval($contact['id']), | 				intval($contact['id']), | ||||||
| 				intval($importer['uid']) | 				intval($importer['uid']) | ||||||
|  | @ -733,7 +733,7 @@ function diaspora_request($importer,$xml) { | ||||||
| 			`avatar-date` = '%s',  | 			`avatar-date` = '%s',  | ||||||
| 			`blocked` = 0,  | 			`blocked` = 0,  | ||||||
| 			`pending` = 0 | 			`pending` = 0 | ||||||
| 			WHERE `id` = %d LIMIT 1 | 			WHERE `id` = %d | ||||||
| 			",
 | 			",
 | ||||||
| 			dbesc($photos[0]), | 			dbesc($photos[0]), | ||||||
| 			dbesc($photos[1]), | 			dbesc($photos[1]), | ||||||
|  | @ -759,7 +759,7 @@ function diaspora_post_allow($importer,$contact) { | ||||||
| 	// That makes us friends.
 | 	// That makes us friends.
 | ||||||
| 	// Normally this should have handled by getting a request - but this could get lost
 | 	// Normally this should have handled by getting a request - but this could get lost
 | ||||||
| 	if($contact['rel'] == CONTACT_IS_FOLLOWER && $importer['page-flags'] != PAGE_COMMUNITY) { | 	if($contact['rel'] == CONTACT_IS_FOLLOWER && $importer['page-flags'] != PAGE_COMMUNITY) { | ||||||
| 		q("UPDATE `contact` SET `rel` = %d, `writable` = 1 WHERE `id` = %d AND `uid` = %d LIMIT 1", | 		q("UPDATE `contact` SET `rel` = %d, `writable` = 1 WHERE `id` = %d AND `uid` = %d", | ||||||
| 			intval(CONTACT_IS_FRIEND), | 			intval(CONTACT_IS_FRIEND), | ||||||
| 			intval($contact['id']), | 			intval($contact['id']), | ||||||
| 			intval($importer['uid']) | 			intval($importer['uid']) | ||||||
|  | @ -895,7 +895,7 @@ function diaspora_post($importer,$xml,$msg) { | ||||||
| 	$message_id = item_store($datarray); | 	$message_id = item_store($datarray); | ||||||
| 
 | 
 | ||||||
| 	//if($message_id) {
 | 	//if($message_id) {
 | ||||||
| 	//	q("update item set plink = '%s' where id = %d limit 1",
 | 	//	q("update item set plink = '%s' where id = %d",
 | ||||||
| 	//		dbesc($a->get_baseurl() . '/display/' . $importer['nickname'] . '/' . $message_id),
 | 	//		dbesc($a->get_baseurl() . '/display/' . $importer['nickname'] . '/' . $message_id),
 | ||||||
| 	//		intval($message_id)
 | 	//		intval($message_id)
 | ||||||
| 	//	);
 | 	//	);
 | ||||||
|  | @ -1071,7 +1071,7 @@ function diaspora_reshare($importer,$xml,$msg) { | ||||||
| 	$message_id = item_store($datarray); | 	$message_id = item_store($datarray); | ||||||
| 
 | 
 | ||||||
| 	//if($message_id) {
 | 	//if($message_id) {
 | ||||||
| 	//	q("update item set plink = '%s' where id = %d limit 1",
 | 	//	q("update item set plink = '%s' where id = %d",
 | ||||||
| 	//		dbesc($a->get_baseurl() . '/display/' . $importer['nickname'] . '/' . $message_id),
 | 	//		dbesc($a->get_baseurl() . '/display/' . $importer['nickname'] . '/' . $message_id),
 | ||||||
| 	//		intval($message_id)
 | 	//		intval($message_id)
 | ||||||
| 	//	);
 | 	//	);
 | ||||||
|  | @ -1170,7 +1170,7 @@ function diaspora_asphoto($importer,$xml,$msg) { | ||||||
| 	$message_id = item_store($datarray); | 	$message_id = item_store($datarray); | ||||||
| 
 | 
 | ||||||
| 	//if($message_id) {
 | 	//if($message_id) {
 | ||||||
| 	//	q("update item set plink = '%s' where id = %d limit 1",
 | 	//	q("update item set plink = '%s' where id = %d",
 | ||||||
| 	//		dbesc($a->get_baseurl() . '/display/' . $importer['nickname'] . '/' . $message_id),
 | 	//		dbesc($a->get_baseurl() . '/display/' . $importer['nickname'] . '/' . $message_id),
 | ||||||
| 	//		intval($message_id)
 | 	//		intval($message_id)
 | ||||||
| 	//	);
 | 	//	);
 | ||||||
|  | @ -1350,7 +1350,7 @@ function diaspora_comment($importer,$xml,$msg) { | ||||||
| 	$message_id = item_store($datarray); | 	$message_id = item_store($datarray); | ||||||
| 
 | 
 | ||||||
| 	if($message_id) { | 	if($message_id) { | ||||||
| 		q("update item set plink = '%s' where id = %d limit 1", | 		q("update item set plink = '%s' where id = %d", | ||||||
| 			dbesc($a->get_baseurl() . '/display/' . $importer['nickname'] . '/' . $message_id), | 			dbesc($a->get_baseurl() . '/display/' . $importer['nickname'] . '/' . $message_id), | ||||||
| 			intval($message_id) | 			intval($message_id) | ||||||
| 		); | 		); | ||||||
|  | @ -1561,7 +1561,7 @@ function diaspora_conversation($importer,$xml,$msg) { | ||||||
| 			dbesc($msg_created_at) | 			dbesc($msg_created_at) | ||||||
| 		); | 		); | ||||||
| 
 | 
 | ||||||
| 		q("update conv set updated = '%s' where id = %d limit 1", | 		q("update conv set updated = '%s' where id = %d", | ||||||
| 			dbesc(datetime_convert()), | 			dbesc(datetime_convert()), | ||||||
| 			intval($conversation['id']) | 			intval($conversation['id']) | ||||||
| 		); | 		); | ||||||
|  | @ -1674,7 +1674,7 @@ function diaspora_message($importer,$xml,$msg) { | ||||||
| 		dbesc($msg_created_at) | 		dbesc($msg_created_at) | ||||||
| 	); | 	); | ||||||
| 
 | 
 | ||||||
| 	q("update conv set updated = '%s' where id = %d limit 1", | 	q("update conv set updated = '%s' where id = %d", | ||||||
| 		dbesc(datetime_convert()), | 		dbesc(datetime_convert()), | ||||||
| 		intval($conversation['id']) | 		intval($conversation['id']) | ||||||
| 	); | 	); | ||||||
|  | @ -1740,7 +1740,7 @@ function diaspora_photo($importer,$xml,$msg,$attempt=1) { | ||||||
| 	                                   array($remote_photo_name, 'scaled_full_' . $remote_photo_name)); | 	                                   array($remote_photo_name, 'scaled_full_' . $remote_photo_name)); | ||||||
| 
 | 
 | ||||||
| 	if(strpos($parent_item['body'],$link_text) === false) { | 	if(strpos($parent_item['body'],$link_text) === false) { | ||||||
| 		$r = q("update item set `body` = '%s', `visible` = 1 where `id` = %d and `uid` = %d limit 1", | 		$r = q("update item set `body` = '%s', `visible` = 1 where `id` = %d and `uid` = %d", | ||||||
| 			dbesc($link_text . $parent_item['body']), | 			dbesc($link_text . $parent_item['body']), | ||||||
| 			intval($parent_item['id']), | 			intval($parent_item['id']), | ||||||
| 			intval($parent_item['uid']) | 			intval($parent_item['uid']) | ||||||
|  | @ -1805,7 +1805,7 @@ function diaspora_like($importer,$xml,$msg) { | ||||||
| 		// It looks like "RelayableRetractions" are used for "unlike" instead
 | 		// It looks like "RelayableRetractions" are used for "unlike" instead
 | ||||||
| 		if($positive === 'false') { | 		if($positive === 'false') { | ||||||
| 			logger('diaspora_like: received a like with positive set to "false"...ignoring'); | 			logger('diaspora_like: received a like with positive set to "false"...ignoring'); | ||||||
| /*			q("UPDATE `item` SET `deleted` = 1 WHERE `id` = %d AND `uid` = %d LIMIT 1", | /*			q("UPDATE `item` SET `deleted` = 1 WHERE `id` = %d AND `uid` = %d", | ||||||
| 				intval($r[0]['id']), | 				intval($r[0]['id']), | ||||||
| 				intval($importer['uid']) | 				intval($importer['uid']) | ||||||
| 			);*/ | 			);*/ | ||||||
|  | @ -1942,7 +1942,7 @@ EOT; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 	if($message_id) { | 	if($message_id) { | ||||||
| 		q("update item set plink = '%s' where id = %d limit 1", | 		q("update item set plink = '%s' where id = %d", | ||||||
| 			dbesc($a->get_baseurl() . '/display/' . $importer['nickname'] . '/' . $message_id), | 			dbesc($a->get_baseurl() . '/display/' . $importer['nickname'] . '/' . $message_id), | ||||||
| 			intval($message_id) | 			intval($message_id) | ||||||
| 		); | 		); | ||||||
|  | @ -1989,7 +1989,7 @@ function diaspora_retraction($importer,$xml) { | ||||||
| 		); | 		); | ||||||
| 		if(count($r)) { | 		if(count($r)) { | ||||||
| 			if(link_compare($r[0]['author-link'],$contact['url'])) { | 			if(link_compare($r[0]['author-link'],$contact['url'])) { | ||||||
| 				q("update item set `deleted` = 1, `changed` = '%s' where `id` = %d limit 1", | 				q("update item set `deleted` = 1, `changed` = '%s' where `id` = %d", | ||||||
| 					dbesc(datetime_convert()), | 					dbesc(datetime_convert()), | ||||||
| 					intval($r[0]['id']) | 					intval($r[0]['id']) | ||||||
| 				); | 				); | ||||||
|  | @ -2060,7 +2060,7 @@ function diaspora_signed_retraction($importer,$xml,$msg) { | ||||||
| 		); | 		); | ||||||
| 		if(count($r)) { | 		if(count($r)) { | ||||||
| 			if(link_compare($r[0]['author-link'],$contact['url'])) { | 			if(link_compare($r[0]['author-link'],$contact['url'])) { | ||||||
| 				q("update item set `deleted` = 1, `edited` = '%s', `changed` = '%s', `body` = '' , `title` = '' where `id` = %d limit 1", | 				q("update item set `deleted` = 1, `edited` = '%s', `changed` = '%s', `body` = '' , `title` = '' where `id` = %d", | ||||||
| 					dbesc(datetime_convert()), | 					dbesc(datetime_convert()), | ||||||
| 					dbesc(datetime_convert()), | 					dbesc(datetime_convert()), | ||||||
| 					intval($r[0]['id']) | 					intval($r[0]['id']) | ||||||
|  | @ -2161,7 +2161,7 @@ function diaspora_profile($importer,$xml,$msg) { | ||||||
| 	// TODO: update name on item['author-name'] if the name changed. See consume_feed()
 | 	// TODO: update name on item['author-name'] if the name changed. See consume_feed()
 | ||||||
| 	// Not doing this currently because D* protocol is scheduled for revision soon. 
 | 	// Not doing this currently because D* protocol is scheduled for revision soon. 
 | ||||||
| 
 | 
 | ||||||
| 	$r = q("UPDATE `contact` SET `name` = '%s', `name-date` = '%s', `photo` = '%s', `thumb` = '%s', `micro` = '%s', `avatar-date` = '%s' , `bd` = '%s' WHERE `id` = %d AND `uid` = %d LIMIT 1", | 	$r = q("UPDATE `contact` SET `name` = '%s', `name-date` = '%s', `photo` = '%s', `thumb` = '%s', `micro` = '%s', `avatar-date` = '%s' , `bd` = '%s' WHERE `id` = %d AND `uid` = %d", | ||||||
| 		dbesc($name), | 		dbesc($name), | ||||||
| 		dbesc(datetime_convert()), | 		dbesc(datetime_convert()), | ||||||
| 		dbesc($images[0]), | 		dbesc($images[0]), | ||||||
|  |  | ||||||
|  | @ -262,7 +262,7 @@ function new_contact($uid,$url,$interactive = false) { | ||||||
| 		'$ostat_follow' => '' | 		'$ostat_follow' => '' | ||||||
| 	)); | 	)); | ||||||
| 
 | 
 | ||||||
| 	$r = q("SELECT `contact`.*, `user`.* FROM `contact` LEFT JOIN `user` ON `contact`.`uid` = `user`.`uid` 
 | 	$r = q("SELECT `contact`.*, `user`.* FROM `contact` INNER JOIN `user` ON `contact`.`uid` = `user`.`uid` 
 | ||||||
| 			WHERE `user`.`uid` = %d AND `contact`.`self` = 1 LIMIT 1",
 | 			WHERE `user`.`uid` = %d AND `contact`.`self` = 1 LIMIT 1",
 | ||||||
| 			intval($uid) | 			intval($uid) | ||||||
| 	); | 	); | ||||||
|  |  | ||||||
|  | @ -157,7 +157,7 @@ function group_get_members($gid) { | ||||||
| 	$ret = array(); | 	$ret = array(); | ||||||
| 	if(intval($gid)) { | 	if(intval($gid)) { | ||||||
| 		$r = q("SELECT `group_member`.`contact-id`, `contact`.* FROM `group_member` 
 | 		$r = q("SELECT `group_member`.`contact-id`, `contact`.* FROM `group_member` 
 | ||||||
| 			LEFT JOIN `contact` ON `contact`.`id` = `group_member`.`contact-id`  | 			INNER JOIN `contact` ON `contact`.`id` = `group_member`.`contact-id`  | ||||||
| 			WHERE `gid` = %d AND `group_member`.`uid` = %d ORDER BY `contact`.`name` ASC ",
 | 			WHERE `gid` = %d AND `group_member`.`uid` = %d ORDER BY `contact`.`name` ASC ",
 | ||||||
| 			intval($gid), | 			intval($gid), | ||||||
| 			intval(local_user()) | 			intval(local_user()) | ||||||
|  | @ -172,7 +172,7 @@ function group_public_members($gid) { | ||||||
| 	$ret = 0; | 	$ret = 0; | ||||||
| 	if(intval($gid)) { | 	if(intval($gid)) { | ||||||
| 		$r = q("SELECT `contact`.`id` AS `contact-id` FROM `group_member` 
 | 		$r = q("SELECT `contact`.`id` AS `contact-id` FROM `group_member` 
 | ||||||
| 			LEFT JOIN `contact` ON `contact`.`id` = `group_member`.`contact-id`  | 			INNER JOIN `contact` ON `contact`.`id` = `group_member`.`contact-id`  | ||||||
| 			WHERE `gid` = %d AND `group_member`.`uid` = %d  | 			WHERE `gid` = %d AND `group_member`.`uid` = %d  | ||||||
| 			AND  `contact`.`network` = '%s' AND `contact`.`notify` != '' ",
 | 			AND  `contact`.`network` = '%s' AND `contact`.`notify` != '' ",
 | ||||||
| 			intval($gid), | 			intval($gid), | ||||||
|  | @ -299,7 +299,7 @@ function expand_groups($a,$check_dead = false) { | ||||||
| 
 | 
 | ||||||
| function member_of($c) { | function member_of($c) { | ||||||
| 
 | 
 | ||||||
| 	$r = q("SELECT `group`.`name`, `group`.`id` FROM `group` LEFT JOIN `group_member` ON `group_member`.`gid` = `group`.`id` WHERE `group_member`.`contact-id` = %d AND `group`.`deleted` = 0 ORDER BY `group`.`name`  ASC ", | 	$r = q("SELECT `group`.`name`, `group`.`id` FROM `group` INNER JOIN `group_member` ON `group_member`.`gid` = `group`.`id` WHERE `group_member`.`contact-id` = %d AND `group`.`deleted` = 0 ORDER BY `group`.`name`  ASC ", | ||||||
| 		intval($c) | 		intval($c) | ||||||
| 	); | 	); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -9,6 +9,7 @@ require_once('include/tags.php'); | ||||||
| require_once('include/text.php'); | require_once('include/text.php'); | ||||||
| require_once('include/email.php'); | require_once('include/email.php'); | ||||||
| require_once('include/ostatus_conversation.php'); | require_once('include/ostatus_conversation.php'); | ||||||
|  | require_once('include/threads.php'); | ||||||
| 
 | 
 | ||||||
| function get_feed_for(&$a, $dfrn_id, $owner_nick, $last_update, $direction = 0) { | function get_feed_for(&$a, $dfrn_id, $owner_nick, $last_update, $direction = 0) { | ||||||
| 
 | 
 | ||||||
|  | @ -36,7 +37,7 @@ function get_feed_for(&$a, $dfrn_id, $owner_nick, $last_update, $direction = 0) | ||||||
| 	$sql_extra = " AND `allow_cid` = '' AND `allow_gid` = '' AND `deny_cid`  = '' AND `deny_gid`  = '' "; | 	$sql_extra = " AND `allow_cid` = '' AND `allow_gid` = '' AND `deny_cid`  = '' AND `deny_gid`  = '' "; | ||||||
| 
 | 
 | ||||||
| 	$r = q("SELECT `contact`.*, `user`.`uid` AS `user_uid`, `user`.`nickname`, `user`.`timezone`, `user`.`page-flags`
 | 	$r = q("SELECT `contact`.*, `user`.`uid` AS `user_uid`, `user`.`nickname`, `user`.`timezone`, `user`.`page-flags`
 | ||||||
| 		FROM `contact` LEFT JOIN `user` ON `user`.`uid` = `contact`.`uid` | 		FROM `contact` INNER JOIN `user` ON `user`.`uid` = `contact`.`uid` | ||||||
| 		WHERE `contact`.`self` = 1 AND `user`.`nickname` = '%s' LIMIT 1",
 | 		WHERE `contact`.`self` = 1 AND `user`.`nickname` = '%s' LIMIT 1",
 | ||||||
| 		dbesc($owner_nick) | 		dbesc($owner_nick) | ||||||
| 	); | 	); | ||||||
|  | @ -128,7 +129,7 @@ function get_feed_for(&$a, $dfrn_id, $owner_nick, $last_update, $direction = 0) | ||||||
| 		`contact`.`thumb`, `contact`.`dfrn-id`, `contact`.`self`, | 		`contact`.`thumb`, `contact`.`dfrn-id`, `contact`.`self`, | ||||||
| 		`contact`.`id` AS `contact-id`, `contact`.`uid` AS `contact-uid`, | 		`contact`.`id` AS `contact-id`, `contact`.`uid` AS `contact-uid`, | ||||||
| 		`sign`.`signed_text`, `sign`.`signature`, `sign`.`signer` | 		`sign`.`signed_text`, `sign`.`signature`, `sign`.`signer` | ||||||
| 		FROM `item` LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | 		FROM `item` INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` AND `contact`.`uid` = `item`.`uid` | ||||||
| 		LEFT JOIN `sign` ON `sign`.`iid` = `item`.`id` | 		LEFT JOIN `sign` ON `sign`.`iid` = `item`.`id` | ||||||
| 		WHERE `item`.`uid` = %d AND `item`.`visible` = 1 and `item`.`moderated` = 0 AND `item`.`parent` != 0 | 		WHERE `item`.`uid` = %d AND `item`.`visible` = 1 and `item`.`moderated` = 0 AND `item`.`parent` != 0 | ||||||
| 		AND `item`.`wall` = 1 AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | 		AND `item`.`wall` = 1 AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
|  | @ -1089,6 +1090,20 @@ function item_store($arr,$force_parent = false) { | ||||||
| 
 | 
 | ||||||
| 			if((intval($r[0]['forum_mode']) == 1) && (! $r[0]['private'])) | 			if((intval($r[0]['forum_mode']) == 1) && (! $r[0]['private'])) | ||||||
| 				$arr['private'] = 0; | 				$arr['private'] = 0; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 			// If its a post from myself then tag the thread as "mention"
 | ||||||
|  | 			logger("item_store: Checking if parent ".$parent_id." has to be tagged as mention for user ".$arr['uid'], LOGGER_DEBUG); | ||||||
|  | 			$u = q("select * from user where uid = %d limit 1", intval($arr['uid'])); | ||||||
|  | 			if(count($u)) { | ||||||
|  | 				$a = get_app(); | ||||||
|  | 				$self = normalise_link($a->get_baseurl() . '/profile/' . $u[0]['nickname']); | ||||||
|  | 				logger("item_store: 'myself' is ".$self." for parent ".$parent_id." checking against ".$arr['author-link']." and ".$arr['owner-link'], LOGGER_DEBUG); | ||||||
|  | 				if ((normalise_link($arr['author-link']) == $self) OR (normalise_link($arr['owner-link']) == $self)) { | ||||||
|  | 					q("UPDATE `thread` SET `mention` = 1 WHERE `iid` = %d", intval($parent_id)); | ||||||
|  | 					logger("item_store: tagged thread ".$parent_id." as mention for user ".$self, LOGGER_DEBUG); | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
| 		} | 		} | ||||||
| 		else { | 		else { | ||||||
| 
 | 
 | ||||||
|  | @ -1150,6 +1165,7 @@ function item_store($arr,$force_parent = false) { | ||||||
| 
 | 
 | ||||||
| 		// Only check for notifications on start posts
 | 		// Only check for notifications on start posts
 | ||||||
| 		if ($arr['parent-uri'] === $arr['uri']) { | 		if ($arr['parent-uri'] === $arr['uri']) { | ||||||
|  | 			add_thread($r[0]['id']); | ||||||
| 			logger('item_store: Check notification for contact '.$arr['contact-id'].' and post '.$current_post, LOGGER_DEBUG); | 			logger('item_store: Check notification for contact '.$arr['contact-id'].' and post '.$current_post, LOGGER_DEBUG); | ||||||
| 
 | 
 | ||||||
| 			// Send a notification for every new post?
 | 			// Send a notification for every new post?
 | ||||||
|  | @ -1246,6 +1262,7 @@ function item_store($arr,$force_parent = false) { | ||||||
| 		dbesc(datetime_convert()), | 		dbesc(datetime_convert()), | ||||||
| 		intval($parent_id) | 		intval($parent_id) | ||||||
| 	); | 	); | ||||||
|  | 	update_thread($parent_id); | ||||||
| 
 | 
 | ||||||
| 	if($dsprsig) { | 	if($dsprsig) { | ||||||
| 		q("insert into sign (`iid`,`signed_text`,`signature`,`signer`) values (%d,'%s','%s','%s') ", | 		q("insert into sign (`iid`,`signed_text`,`signature`,`signer`) values (%d,'%s','%s','%s') ", | ||||||
|  | @ -1448,6 +1465,7 @@ function tag_deliver($uid,$item_id) { | ||||||
| 		dbesc($u[0]['deny_gid']), | 		dbesc($u[0]['deny_gid']), | ||||||
| 		intval($item_id) | 		intval($item_id) | ||||||
| 	); | 	); | ||||||
|  | 	update_thread($item_id); | ||||||
| 
 | 
 | ||||||
| 	proc_run('php','include/notifier.php','tgroup',$item_id); | 	proc_run('php','include/notifier.php','tgroup',$item_id); | ||||||
| 
 | 
 | ||||||
|  | @ -1965,7 +1983,7 @@ function consume_feed($xml,$importer,&$contact, &$hub, $datedir = 0, $pass = 0) | ||||||
| 					$when = datetime_convert('UTC','UTC','now','Y-m-d H:i:s'); | 					$when = datetime_convert('UTC','UTC','now','Y-m-d H:i:s'); | ||||||
| 			} | 			} | ||||||
| 			if($deleted && is_array($contact)) { | 			if($deleted && is_array($contact)) { | ||||||
| 				$r = q("SELECT `item`.*, `contact`.`self` FROM `item` left join `contact` on `item`.`contact-id` = `contact`.`id` 
 | 				$r = q("SELECT `item`.*, `contact`.`self` FROM `item` INNER JOIN `contact` on `item`.`contact-id` = `contact`.`id` 
 | ||||||
| 					WHERE `uri` = '%s' AND `item`.`uid` = %d AND `contact-id` = %d AND NOT `item`.`file` LIKE '%%[%%' LIMIT 1",
 | 					WHERE `uri` = '%s' AND `item`.`uid` = %d AND `contact-id` = %d AND NOT `item`.`file` LIKE '%%[%%' LIMIT 1",
 | ||||||
| 					dbesc($uri), | 					dbesc($uri), | ||||||
| 					intval($importer['uid']), | 					intval($importer['uid']), | ||||||
|  | @ -2023,6 +2041,7 @@ function consume_feed($xml,$importer,&$contact, &$hub, $datedir = 0, $pass = 0) | ||||||
| 							intval($importer['uid']) | 							intval($importer['uid']) | ||||||
| 						); | 						); | ||||||
| 						create_tags_from_itemuri($item['uri'], $importer['uid']); | 						create_tags_from_itemuri($item['uri'], $importer['uid']); | ||||||
|  | 						update_thread_uri($item['uri'], $importer['uid']); | ||||||
| 					} | 					} | ||||||
| 					else { | 					else { | ||||||
| 						$r = q("UPDATE `item` SET `deleted` = 1, `edited` = '%s', `changed` = '%s',
 | 						$r = q("UPDATE `item` SET `deleted` = 1, `edited` = '%s', `changed` = '%s',
 | ||||||
|  | @ -2122,6 +2141,7 @@ function consume_feed($xml,$importer,&$contact, &$hub, $datedir = 0, $pass = 0) | ||||||
| 						intval($importer['uid']) | 						intval($importer['uid']) | ||||||
| 					); | 					); | ||||||
| 					$datarray['last-child'] = 1; | 					$datarray['last-child'] = 1; | ||||||
|  | 					update_thread_uri($parent_uri, $importer['uid']); | ||||||
| 				} | 				} | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @ -2148,6 +2168,7 @@ function consume_feed($xml,$importer,&$contact, &$hub, $datedir = 0, $pass = 0) | ||||||
| 							intval($importer['uid']) | 							intval($importer['uid']) | ||||||
| 						); | 						); | ||||||
| 						create_tags_from_itemuri($item_id, $importer['uid']); | 						create_tags_from_itemuri($item_id, $importer['uid']); | ||||||
|  | 						update_thread_uri($item_id, $importer['uid']); | ||||||
| 					} | 					} | ||||||
| 
 | 
 | ||||||
| 					// update last-child if it changes
 | 					// update last-child if it changes
 | ||||||
|  | @ -2165,6 +2186,7 @@ function consume_feed($xml,$importer,&$contact, &$hub, $datedir = 0, $pass = 0) | ||||||
| 							dbesc($item_id), | 							dbesc($item_id), | ||||||
| 							intval($importer['uid']) | 							intval($importer['uid']) | ||||||
| 						); | 						); | ||||||
|  | 						update_thread_uri($item_id, $importer['uid']); | ||||||
| 					} | 					} | ||||||
| 					continue; | 					continue; | ||||||
| 				} | 				} | ||||||
|  | @ -2306,6 +2328,7 @@ function consume_feed($xml,$importer,&$contact, &$hub, $datedir = 0, $pass = 0) | ||||||
| 							intval($importer['uid']) | 							intval($importer['uid']) | ||||||
| 						); | 						); | ||||||
| 						create_tags_from_itemuri($item_id, $importer['uid']); | 						create_tags_from_itemuri($item_id, $importer['uid']); | ||||||
|  | 						update_thread_uri($item_id, $importer['uid']); | ||||||
| 					} | 					} | ||||||
| 
 | 
 | ||||||
| 					// update last-child if it changes
 | 					// update last-child if it changes
 | ||||||
|  | @ -2318,6 +2341,7 @@ function consume_feed($xml,$importer,&$contact, &$hub, $datedir = 0, $pass = 0) | ||||||
| 							dbesc($item_id), | 							dbesc($item_id), | ||||||
| 							intval($importer['uid']) | 							intval($importer['uid']) | ||||||
| 						); | 						); | ||||||
|  | 						update_thread_uri($item_id, $importer['uid']); | ||||||
| 					} | 					} | ||||||
| 					continue; | 					continue; | ||||||
| 				} | 				} | ||||||
|  | @ -2601,7 +2625,7 @@ function local_delivery($importer,$data) { | ||||||
| 			'author-avatar' => array($old['photo'], $newloc['photo']), | 			'author-avatar' => array($old['photo'], $newloc['photo']), | ||||||
| 			); | 			); | ||||||
| 		foreach ($fields as $n=>$f){ | 		foreach ($fields as $n=>$f){ | ||||||
|             $x = q("UPDATE item SET `%s`='%s' WHERE `%s`='%s' AND uid=%d", | 			$x = q("UPDATE `item` SET `%s`='%s' WHERE `%s`='%s' AND uid=%d", | ||||||
| 					$n, dbesc($f[1]), | 					$n, dbesc($f[1]), | ||||||
| 					$n, dbesc($f[0]), | 					$n, dbesc($f[0]), | ||||||
| 					intval($importer['importer_uid'])); | 					intval($importer['importer_uid'])); | ||||||
|  | @ -2832,7 +2856,7 @@ function local_delivery($importer,$data) { | ||||||
| 					// POSSIBLE CLEANUP --> Why select so many fields when only forum_mode and wall are used?
 | 					// POSSIBLE CLEANUP --> Why select so many fields when only forum_mode and wall are used?
 | ||||||
| 					$r = q("select `item`.`id`, `item`.`uri`, `item`.`tag`, `item`.`forum_mode`,`item`.`origin`,`item`.`wall`, 
 | 					$r = q("select `item`.`id`, `item`.`uri`, `item`.`tag`, `item`.`forum_mode`,`item`.`origin`,`item`.`wall`, 
 | ||||||
| 						`contact`.`name`, `contact`.`url`, `contact`.`thumb` from `item`  | 						`contact`.`name`, `contact`.`url`, `contact`.`thumb` from `item`  | ||||||
| 						LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id`  | 						INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id`  | ||||||
| 						WHERE `item`.`uri` = '%s' AND (`item`.`parent-uri` = '%s' or `item`.`thr-parent` = '%s') | 						WHERE `item`.`uri` = '%s' AND (`item`.`parent-uri` = '%s' or `item`.`thr-parent` = '%s') | ||||||
| 						AND `item`.`uid` = %d  | 						AND `item`.`uid` = %d  | ||||||
| 						$sql_extra | 						$sql_extra | ||||||
|  | @ -2862,7 +2886,7 @@ function local_delivery($importer,$data) { | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
| 
 | 
 | ||||||
| 				$r = q("SELECT `item`.*, `contact`.`self` FROM `item` left join contact on `item`.`contact-id` = `contact`.`id`
 | 				$r = q("SELECT `item`.*, `contact`.`self` FROM `item` INNER JOIN contact on `item`.`contact-id` = `contact`.`id`
 | ||||||
| 					WHERE `uri` = '%s' AND `item`.`uid` = %d AND `contact-id` = %d AND NOT `item`.`file` LIKE '%%[%%' LIMIT 1",
 | 					WHERE `uri` = '%s' AND `item`.`uid` = %d AND `contact-id` = %d AND NOT `item`.`file` LIKE '%%[%%' LIMIT 1",
 | ||||||
| 					dbesc($uri), | 					dbesc($uri), | ||||||
| 					intval($importer['importer_uid']), | 					intval($importer['importer_uid']), | ||||||
|  | @ -2924,6 +2948,7 @@ function local_delivery($importer,$data) { | ||||||
| 							intval($importer['importer_uid']) | 							intval($importer['importer_uid']) | ||||||
| 						); | 						); | ||||||
| 						create_tags_from_itemuri($item['uri'], $importer['importer_uid']); | 						create_tags_from_itemuri($item['uri'], $importer['importer_uid']); | ||||||
|  | 						update_thread_uri($item['uri'], $importer['importer_uid']); | ||||||
| 					} | 					} | ||||||
| 					else { | 					else { | ||||||
| 						$r = q("UPDATE `item` SET `deleted` = 1, `edited` = '%s', `changed` = '%s',
 | 						$r = q("UPDATE `item` SET `deleted` = 1, `edited` = '%s', `changed` = '%s',
 | ||||||
|  | @ -2935,6 +2960,7 @@ function local_delivery($importer,$data) { | ||||||
| 							intval($importer['importer_uid']) | 							intval($importer['importer_uid']) | ||||||
| 						); | 						); | ||||||
| 						create_tags_from_itemuri($uri, $importer['importer_uid']); | 						create_tags_from_itemuri($uri, $importer['importer_uid']); | ||||||
|  | 						update_thread_uri($uri, $importer['importer_uid']); | ||||||
| 						if($item['last-child']) { | 						if($item['last-child']) { | ||||||
| 							// ensure that last-child is set in case the comment that had it just got wiped.
 | 							// ensure that last-child is set in case the comment that had it just got wiped.
 | ||||||
| 							q("UPDATE `item` SET `last-child` = 0, `changed` = '%s' WHERE `parent-uri` = '%s' AND `uid` = %d ", | 							q("UPDATE `item` SET `last-child` = 0, `changed` = '%s' WHERE `parent-uri` = '%s' AND `uid` = %d ", | ||||||
|  | @ -3003,7 +3029,7 @@ function local_delivery($importer,$data) { | ||||||
| 				// POSSIBLE CLEANUP --> Why select so many fields when only forum_mode and wall are used?
 | 				// POSSIBLE CLEANUP --> Why select so many fields when only forum_mode and wall are used?
 | ||||||
| 				$r = q("select `item`.`id`, `item`.`uri`, `item`.`tag`, `item`.`forum_mode`,`item`.`origin`,`item`.`wall`,
 | 				$r = q("select `item`.`id`, `item`.`uri`, `item`.`tag`, `item`.`forum_mode`,`item`.`origin`,`item`.`wall`,
 | ||||||
| 					`contact`.`name`, `contact`.`url`, `contact`.`thumb` from `item` | 					`contact`.`name`, `contact`.`url`, `contact`.`thumb` from `item` | ||||||
| 					LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | 					INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | ||||||
| 					WHERE `item`.`uri` = '%s' AND (`item`.`parent-uri` = '%s' or `item`.`thr-parent` = '%s') | 					WHERE `item`.`uri` = '%s' AND (`item`.`parent-uri` = '%s' or `item`.`thr-parent` = '%s') | ||||||
| 					AND `item`.`uid` = %d | 					AND `item`.`uid` = %d | ||||||
| 					$sql_extra | 					$sql_extra | ||||||
|  | @ -3430,6 +3456,7 @@ function local_delivery($importer,$data) { | ||||||
| 						intval($importer['importer_uid']) | 						intval($importer['importer_uid']) | ||||||
| 					); | 					); | ||||||
| 					create_tags_from_itemuri($item_id, $importer['importer_uid']); | 					create_tags_from_itemuri($item_id, $importer['importer_uid']); | ||||||
|  | 					update_thread_uri($item_id, $importer['importer_uid']); | ||||||
| 				} | 				} | ||||||
| 
 | 
 | ||||||
| 				// update last-child if it changes
 | 				// update last-child if it changes
 | ||||||
|  | @ -4154,6 +4181,7 @@ function drop_item($id,$interactive = true) { | ||||||
| 			intval($item['id']) | 			intval($item['id']) | ||||||
| 		); | 		); | ||||||
| 		create_tags_from_item($item['id']); | 		create_tags_from_item($item['id']); | ||||||
|  | 		delete_thread($item['id']); | ||||||
| 
 | 
 | ||||||
| 		// clean up categories and tags so they don't end up as orphans
 | 		// clean up categories and tags so they don't end up as orphans
 | ||||||
| 
 | 
 | ||||||
|  | @ -4248,6 +4276,7 @@ function drop_item($id,$interactive = true) { | ||||||
| 				intval($item['uid']) | 				intval($item['uid']) | ||||||
| 			); | 			); | ||||||
| 			create_tags_from_item($item['parent-uri'], $item['uid']); | 			create_tags_from_item($item['parent-uri'], $item['uid']); | ||||||
|  | 			delete_thread_uri($item['parent-uri'], $item['uid']); | ||||||
| 			// ignore the result
 | 			// ignore the result
 | ||||||
| 		} | 		} | ||||||
| 		else { | 		else { | ||||||
|  |  | ||||||
|  | @ -207,7 +207,7 @@ function notifier_run(&$argv, &$argc){ | ||||||
| 	$r = q("SELECT `contact`.*, `user`.`pubkey` AS `upubkey`, `user`.`prvkey` AS `uprvkey`, 
 | 	$r = q("SELECT `contact`.*, `user`.`pubkey` AS `upubkey`, `user`.`prvkey` AS `uprvkey`, 
 | ||||||
| 		`user`.`timezone`, `user`.`nickname`, `user`.`sprvkey`, `user`.`spubkey`,  | 		`user`.`timezone`, `user`.`nickname`, `user`.`sprvkey`, `user`.`spubkey`,  | ||||||
| 		`user`.`page-flags`, `user`.`prvnets` | 		`user`.`page-flags`, `user`.`prvnets` | ||||||
| 		FROM `contact` LEFT JOIN `user` ON `user`.`uid` = `contact`.`uid`  | 		FROM `contact` INNER JOIN `user` ON `user`.`uid` = `contact`.`uid`  | ||||||
| 		WHERE `contact`.`uid` = %d AND `contact`.`self` = 1 LIMIT 1",
 | 		WHERE `contact`.`uid` = %d AND `contact`.`self` = 1 LIMIT 1",
 | ||||||
| 		intval($uid) | 		intval($uid) | ||||||
| 	); | 	); | ||||||
|  | @ -643,7 +643,7 @@ function notifier_run(&$argv, &$argc){ | ||||||
| 							`contact`.`name` as `senderName`, | 							`contact`.`name` as `senderName`, | ||||||
| 							`user`.*  | 							`user`.*  | ||||||
| 							FROM `contact`  | 							FROM `contact`  | ||||||
| 							LEFT JOIN `user` ON `contact`.`uid` = `user`.`uid`  | 							INNER JOIN `user` ON `contact`.`uid` = `user`.`uid`  | ||||||
| 							WHERE `contact`.`blocked` = 0 AND `contact`.`archive` = 0 | 							WHERE `contact`.`blocked` = 0 AND `contact`.`archive` = 0 | ||||||
| 							AND `contact`.`pending` = 0 | 							AND `contact`.`pending` = 0 | ||||||
| 							AND `contact`.`network` = '%s' AND `user`.`nickname` = '%s' | 							AND `contact`.`network` = '%s' AND `user`.`nickname` = '%s' | ||||||
|  |  | ||||||
|  | @ -112,7 +112,7 @@ function onepoll_run(&$argv, &$argc){ | ||||||
| 
 | 
 | ||||||
| 	$importer_uid = $contact['uid']; | 	$importer_uid = $contact['uid']; | ||||||
| 
 | 
 | ||||||
| 	$r = q("SELECT `contact`.*, `user`.`page-flags` FROM `contact` LEFT JOIN `user` on `contact`.`uid` = `user`.`uid` WHERE `user`.`uid` = %d AND `contact`.`self` = 1 LIMIT 1", | 	$r = q("SELECT `contact`.*, `user`.`page-flags` FROM `contact` INNER JOIN `user` on `contact`.`uid` = `user`.`uid` WHERE `user`.`uid` = %d AND `contact`.`self` = 1 LIMIT 1", | ||||||
| 		intval($importer_uid) | 		intval($importer_uid) | ||||||
| 	); | 	); | ||||||
| 	if(! count($r)) | 	if(! count($r)) | ||||||
|  |  | ||||||
|  | @ -174,7 +174,7 @@ function poller_run(&$argv, &$argc){ | ||||||
| 		: ''  | 		: ''  | ||||||
| 	); | 	); | ||||||
| 
 | 
 | ||||||
| 	$contacts = q("SELECT `contact`.`id` FROM `contact` LEFT JOIN `user` ON `user`.`uid` = `contact`.`uid` 
 | 	$contacts = q("SELECT `contact`.`id` FROM `contact` INNER JOIN `user` ON `user`.`uid` = `contact`.`uid` 
 | ||||||
| 		WHERE ( `rel` = %d OR `rel` = %d ) AND `poll` != '' | 		WHERE ( `rel` = %d OR `rel` = %d ) AND `poll` != '' | ||||||
| 		AND NOT `network` IN ( '%s', '%s', '%s' ) | 		AND NOT `network` IN ( '%s', '%s', '%s' ) | ||||||
| 		$sql_extra  | 		$sql_extra  | ||||||
|  |  | ||||||
|  | @ -25,7 +25,7 @@ function profile_change() { | ||||||
| 		return; | 		return; | ||||||
| 
 | 
 | ||||||
| 	$r = q("SELECT `profile`.`uid` AS `profile_uid`, `profile`.* , `user`.* FROM `profile`
 | 	$r = q("SELECT `profile`.`uid` AS `profile_uid`, `profile`.* , `user`.* FROM `profile`
 | ||||||
| 		LEFT JOIN `user` ON `profile`.`uid` = `user`.`uid` | 		INNER JOIN `user` ON `profile`.`uid` = `user`.`uid` | ||||||
| 		WHERE `user`.`uid` = %d AND `profile`.`is-default` = 1 LIMIT 1",
 | 		WHERE `user`.`uid` = %d AND `profile`.`is-default` = 1 LIMIT 1",
 | ||||||
| 		intval(local_user()) | 		intval(local_user()) | ||||||
| 	); | 	); | ||||||
|  |  | ||||||
|  | @ -111,7 +111,7 @@ function queue_run(&$argv, &$argc){ | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	$r = q("SELECT `queue`.*, `contact`.`name`, `contact`.`uid` FROM `queue` 
 | 	$r = q("SELECT `queue`.*, `contact`.`name`, `contact`.`uid` FROM `queue` 
 | ||||||
| 		LEFT JOIN `contact` ON `queue`.`cid` = `contact`.`id`  | 		INNER JOIN `contact` ON `queue`.`cid` = `contact`.`id`  | ||||||
| 		WHERE `queue`.`created` < UTC_TIMESTAMP() - INTERVAL 3 DAY");
 | 		WHERE `queue`.`created` < UTC_TIMESTAMP() - INTERVAL 3 DAY");
 | ||||||
| 	if($r) { | 	if($r) { | ||||||
| 		foreach($r as $rr) { | 		foreach($r as $rr) { | ||||||
|  |  | ||||||
|  | @ -2,7 +2,7 @@ | ||||||
| 
 | 
 | ||||||
| function update_queue_time($id) { | function update_queue_time($id) { | ||||||
| 	logger('queue: requeue item ' . $id); | 	logger('queue: requeue item ' . $id); | ||||||
| 	q("UPDATE `queue` SET `last` = '%s' WHERE `id` = %d LIMIT 1", | 	q("UPDATE `queue` SET `last` = '%s' WHERE `id` = %d", | ||||||
| 		dbesc(datetime_convert()), | 		dbesc(datetime_convert()), | ||||||
| 		intval($id) | 		intval($id) | ||||||
| 	); | 	); | ||||||
|  | @ -10,7 +10,7 @@ function update_queue_time($id) { | ||||||
| 
 | 
 | ||||||
| function remove_queue_item($id) { | function remove_queue_item($id) { | ||||||
| 	logger('queue: remove queue item ' . $id); | 	logger('queue: remove queue item ' . $id); | ||||||
| 	q("DELETE FROM `queue` WHERE `id` = %d LIMIT 1", | 	q("DELETE FROM `queue` WHERE `id` = %d", | ||||||
| 		intval($id) | 		intval($id) | ||||||
| 	); | 	); | ||||||
| } | } | ||||||
|  | @ -44,7 +44,7 @@ function add_to_queue($cid,$network,$msg,$batch = false) { | ||||||
| 	if($batch_queue < 1) | 	if($batch_queue < 1) | ||||||
| 		$batch_queue = 1000; | 		$batch_queue = 1000; | ||||||
| 
 | 
 | ||||||
| 	$r = q("SELECT COUNT(*) AS `total` FROM `queue` left join `contact` ON `queue`.`cid` = `contact`.`id` 
 | 	$r = q("SELECT COUNT(*) AS `total` FROM `queue` INNER JOIN `contact` ON `queue`.`cid` = `contact`.`id` 
 | ||||||
| 		WHERE `queue`.`cid` = %d AND `contact`.`self` = 0 ",
 | 		WHERE `queue`.`cid` = %d AND `contact`.`self` = 0 ",
 | ||||||
| 		intval($cid) | 		intval($cid) | ||||||
| 	); | 	); | ||||||
|  |  | ||||||
|  | @ -56,7 +56,7 @@ function authenticate_success($user_record, $login_initial = false, $interactive | ||||||
| 		$a->identities = array(); | 		$a->identities = array(); | ||||||
| 
 | 
 | ||||||
| 	$r = q("select `user`.`uid`, `user`.`username`, `user`.`nickname` 
 | 	$r = q("select `user`.`uid`, `user`.`username`, `user`.`nickname` 
 | ||||||
| 		from manage left join user on manage.mid = user.uid where `user`.`account_removed` = 0 | 		from manage INNER JOIN user on manage.mid = user.uid where `user`.`account_removed` = 0 | ||||||
| 		and `manage`.`uid` = %d",
 | 		and `manage`.`uid` = %d",
 | ||||||
| 		intval($master_record['uid']) | 		intval($master_record['uid']) | ||||||
| 	); | 	); | ||||||
|  | @ -139,7 +139,7 @@ function can_write_wall(&$a,$owner) { | ||||||
| 				return false; | 				return false; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 			$r = q("SELECT `contact`.*, `user`.`page-flags` FROM `contact` LEFT JOIN `user` on `user`.`uid` = `contact`.`uid` 
 | 			$r = q("SELECT `contact`.*, `user`.`page-flags` FROM `contact` INNER JOIN `user` on `user`.`uid` = `contact`.`uid` 
 | ||||||
| 				WHERE `contact`.`uid` = %d AND `contact`.`id` = %d AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0  | 				WHERE `contact`.`uid` = %d AND `contact`.`id` = %d AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0  | ||||||
| 				AND `user`.`blockwall` = 0 AND `readonly` = 0  AND ( `contact`.`rel` IN ( %d , %d ) OR `user`.`page-flags` = %d ) LIMIT 1",
 | 				AND `user`.`blockwall` = 0 AND `readonly` = 0  AND ( `contact`.`rel` IN ( %d , %d ) OR `user`.`page-flags` = %d ) LIMIT 1",
 | ||||||
| 				intval($owner), | 				intval($owner), | ||||||
|  | @ -255,11 +255,11 @@ function item_permissions_sql($owner_id,$remote_verified = false,$groups = null) | ||||||
| 	 * default permissions - anonymous user | 	 * default permissions - anonymous user | ||||||
| 	 */ | 	 */ | ||||||
| 
 | 
 | ||||||
| 	$sql = " AND allow_cid = '' 
 | 	$sql = " AND `item`.allow_cid = ''
 | ||||||
| 			 AND allow_gid = ''  | 			 AND `item`.allow_gid = '' | ||||||
| 			 AND deny_cid  = ''  | 			 AND `item`.deny_cid  = '' | ||||||
| 			 AND deny_gid  = ''  | 			 AND `item`.deny_gid  = '' | ||||||
| 			 AND private = 0 | 			 AND `item`.private = 0 | ||||||
| 	";
 | 	";
 | ||||||
| 
 | 
 | ||||||
| 	/** | 	/** | ||||||
|  | @ -310,9 +310,9 @@ function item_permissions_sql($owner_id,$remote_verified = false,$groups = null) | ||||||
| 				dbesc($gs), | 				dbesc($gs), | ||||||
| 				dbesc($gs) | 				dbesc($gs) | ||||||
| */ | */ | ||||||
| 				" AND ( private = 0 OR ( private in (1,2) AND wall = 1
 | 				" AND ( `item`.private = 0 OR ( `item`.private in (1,2) AND wall = 1
 | ||||||
| 				  AND ( NOT (deny_cid REGEXP '<%d>' OR deny_gid REGEXP '%s') | 				  AND ( NOT (`item`.deny_cid REGEXP '<%d>' OR `item`.deny_gid REGEXP '%s') | ||||||
| 				  AND ( allow_cid REGEXP '<%d>' OR allow_gid REGEXP '%s' OR ( allow_cid = '' AND allow_gid = ''))))) | 				  AND ( `item`.allow_cid REGEXP '<%d>' OR `item`.allow_gid REGEXP '%s' OR ( allow_cid = '' AND allow_gid = ''))))) | ||||||
| 				",
 | 				",
 | ||||||
| 				intval($remote_user), | 				intval($remote_user), | ||||||
| 				dbesc($gs), | 				dbesc($gs), | ||||||
|  |  | ||||||
|  | @ -170,7 +170,7 @@ function poco_load($cid,$uid = 0,$zcid = 0,$url = null) { | ||||||
| function count_common_friends($uid,$cid) { | function count_common_friends($uid,$cid) { | ||||||
| 
 | 
 | ||||||
| 	$r = q("SELECT count(*) as `total`
 | 	$r = q("SELECT count(*) as `total`
 | ||||||
| 		FROM `glink` left join `gcontact` on `glink`.`gcid` = `gcontact`.`id` | 		FROM `glink` INNER JOIN `gcontact` on `glink`.`gcid` = `gcontact`.`id` | ||||||
| 		where `glink`.`cid` = %d and `glink`.`uid` = %d | 		where `glink`.`cid` = %d and `glink`.`uid` = %d | ||||||
| 		and `gcontact`.`nurl` in (select nurl from contact where uid = %d and self = 0 and blocked = 0 and hidden = 0 and id != %d ) ",
 | 		and `gcontact`.`nurl` in (select nurl from contact where uid = %d and self = 0 and blocked = 0 and hidden = 0 and id != %d ) ",
 | ||||||
| 		intval($cid), | 		intval($cid), | ||||||
|  | @ -195,7 +195,7 @@ function common_friends($uid,$cid,$start = 0,$limit=9999,$shuffle = false) { | ||||||
| 		$sql_extra = " order by `gcontact`.`name` asc ";  | 		$sql_extra = " order by `gcontact`.`name` asc ";  | ||||||
| 
 | 
 | ||||||
| 	$r = q("SELECT `gcontact`.* 
 | 	$r = q("SELECT `gcontact`.* 
 | ||||||
| 		FROM `glink` left join `gcontact` on `glink`.`gcid` = `gcontact`.`id` | 		FROM `glink` INNER JOIN `gcontact` on `glink`.`gcid` = `gcontact`.`id` | ||||||
| 		where `glink`.`cid` = %d and `glink`.`uid` = %d | 		where `glink`.`cid` = %d and `glink`.`uid` = %d | ||||||
| 		and `gcontact`.`nurl` in (select nurl from contact where uid = %d and self = 0 and blocked = 0 and hidden = 0 and id != %d )  | 		and `gcontact`.`nurl` in (select nurl from contact where uid = %d and self = 0 and blocked = 0 and hidden = 0 and id != %d )  | ||||||
| 		$sql_extra limit %d, %d",
 | 		$sql_extra limit %d, %d",
 | ||||||
|  | @ -215,7 +215,7 @@ function common_friends($uid,$cid,$start = 0,$limit=9999,$shuffle = false) { | ||||||
| function count_common_friends_zcid($uid,$zcid) { | function count_common_friends_zcid($uid,$zcid) { | ||||||
| 
 | 
 | ||||||
| 	$r = q("SELECT count(*) as `total` 
 | 	$r = q("SELECT count(*) as `total` 
 | ||||||
| 		FROM `glink` left join `gcontact` on `glink`.`gcid` = `gcontact`.`id` | 		FROM `glink` INNER JOIN `gcontact` on `glink`.`gcid` = `gcontact`.`id` | ||||||
| 		where `glink`.`zcid` = %d | 		where `glink`.`zcid` = %d | ||||||
| 		and `gcontact`.`nurl` in (select nurl from contact where uid = %d and self = 0 and blocked = 0 and hidden = 0 ) ",
 | 		and `gcontact`.`nurl` in (select nurl from contact where uid = %d and self = 0 and blocked = 0 and hidden = 0 ) ",
 | ||||||
| 		intval($zcid), | 		intval($zcid), | ||||||
|  | @ -236,7 +236,7 @@ function common_friends_zcid($uid,$zcid,$start = 0, $limit = 9999,$shuffle = fal | ||||||
| 		$sql_extra = " order by `gcontact`.`name` asc ";  | 		$sql_extra = " order by `gcontact`.`name` asc ";  | ||||||
| 
 | 
 | ||||||
| 	$r = q("SELECT `gcontact`.* 
 | 	$r = q("SELECT `gcontact`.* 
 | ||||||
| 		FROM `glink` left join `gcontact` on `glink`.`gcid` = `gcontact`.`id` | 		FROM `glink` INNER JOIN `gcontact` on `glink`.`gcid` = `gcontact`.`id` | ||||||
| 		where `glink`.`zcid` = %d | 		where `glink`.`zcid` = %d | ||||||
| 		and `gcontact`.`nurl` in (select nurl from contact where uid = %d and self = 0 and blocked = 0 and hidden = 0 )  | 		and `gcontact`.`nurl` in (select nurl from contact where uid = %d and self = 0 and blocked = 0 and hidden = 0 )  | ||||||
| 		$sql_extra limit %d, %d",
 | 		$sql_extra limit %d, %d",
 | ||||||
|  | @ -254,7 +254,7 @@ function common_friends_zcid($uid,$zcid,$start = 0, $limit = 9999,$shuffle = fal | ||||||
| function count_all_friends($uid,$cid) { | function count_all_friends($uid,$cid) { | ||||||
| 
 | 
 | ||||||
| 	$r = q("SELECT count(*) as `total`
 | 	$r = q("SELECT count(*) as `total`
 | ||||||
| 		FROM `glink` left join `gcontact` on `glink`.`gcid` = `gcontact`.`id` | 		FROM `glink` INNER JOIN `gcontact` on `glink`.`gcid` = `gcontact`.`id` | ||||||
| 		where `glink`.`cid` = %d and `glink`.`uid` = %d ",
 | 		where `glink`.`cid` = %d and `glink`.`uid` = %d ",
 | ||||||
| 		intval($cid), | 		intval($cid), | ||||||
| 		intval($uid) | 		intval($uid) | ||||||
|  | @ -270,7 +270,7 @@ function count_all_friends($uid,$cid) { | ||||||
| function all_friends($uid,$cid,$start = 0, $limit = 80) { | function all_friends($uid,$cid,$start = 0, $limit = 80) { | ||||||
| 
 | 
 | ||||||
| 	$r = q("SELECT `gcontact`.* 
 | 	$r = q("SELECT `gcontact`.* 
 | ||||||
| 		FROM `glink` left join `gcontact` on `glink`.`gcid` = `gcontact`.`id` | 		FROM `glink` INNER JOIN `gcontact` on `glink`.`gcid` = `gcontact`.`id` | ||||||
| 		where `glink`.`cid` = %d and `glink`.`uid` = %d  | 		where `glink`.`cid` = %d and `glink`.`uid` = %d  | ||||||
| 		order by `gcontact`.`name` asc LIMIT %d, %d ",
 | 		order by `gcontact`.`name` asc LIMIT %d, %d ",
 | ||||||
| 		intval($cid), | 		intval($cid), | ||||||
|  | @ -290,7 +290,7 @@ function suggestion_query($uid, $start = 0, $limit = 80) { | ||||||
| 		return array(); | 		return array(); | ||||||
| 
 | 
 | ||||||
| 	$r = q("SELECT count(glink.gcid) as `total`, gcontact.* from gcontact 
 | 	$r = q("SELECT count(glink.gcid) as `total`, gcontact.* from gcontact 
 | ||||||
| 		left join glink on glink.gcid = gcontact.id  | 		INNER JOIN glink on glink.gcid = gcontact.id  | ||||||
| 		where uid = %d and not gcontact.nurl in ( select nurl from contact where uid = %d ) | 		where uid = %d and not gcontact.nurl in ( select nurl from contact where uid = %d ) | ||||||
| 		and not gcontact.name in ( select name from contact where uid = %d ) | 		and not gcontact.name in ( select name from contact where uid = %d ) | ||||||
| 		and not gcontact.id in ( select gcid from gcign where uid = %d ) | 		and not gcontact.id in ( select gcid from gcign where uid = %d ) | ||||||
|  | @ -307,7 +307,7 @@ function suggestion_query($uid, $start = 0, $limit = 80) { | ||||||
| 		return $r; | 		return $r; | ||||||
| 
 | 
 | ||||||
| 	$r2 = q("SELECT gcontact.* from gcontact 
 | 	$r2 = q("SELECT gcontact.* from gcontact 
 | ||||||
| 		left join glink on glink.gcid = gcontact.id  | 		INNER JOIN glink on glink.gcid = gcontact.id  | ||||||
| 		where glink.uid = 0 and glink.cid = 0 and glink.zcid = 0 and not gcontact.nurl in ( select nurl from contact where uid = %d ) | 		where glink.uid = 0 and glink.cid = 0 and glink.zcid = 0 and not gcontact.nurl in ( select nurl from contact where uid = %d ) | ||||||
| 		and not gcontact.name in ( select name from contact where uid = %d ) | 		and not gcontact.name in ( select name from contact where uid = %d ) | ||||||
| 		and not gcontact.id in ( select gcid from gcign where uid = %d ) | 		and not gcontact.id in ( select gcid from gcign where uid = %d ) | ||||||
|  |  | ||||||
|  | @ -1,20 +1,4 @@ | ||||||
| <?php | <?php | ||||||
| /* |  | ||||||
| require_once("boot.php"); |  | ||||||
| if(@is_null($a)) { |  | ||||||
|         $a = new App; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| if(is_null($db)) { |  | ||||||
|         @include(".htconfig.php"); |  | ||||||
|         require_once("dba.php"); |  | ||||||
|         $db = new dba($db_host, $db_user, $db_pass, $db_data); |  | ||||||
|         unset($db_host, $db_user, $db_pass, $db_data); |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| $a->set_baseurl("https://pirati.ca"); |  | ||||||
| */ |  | ||||||
| 
 |  | ||||||
| function create_tags_from_item($itemid) { | function create_tags_from_item($itemid) { | ||||||
| 	global $a; | 	global $a; | ||||||
| 
 | 
 | ||||||
|  | @ -25,7 +9,7 @@ function create_tags_from_item($itemid) { | ||||||
| 
 | 
 | ||||||
| 	$searchpath = $a->get_baseurl()."/search?tag="; | 	$searchpath = $a->get_baseurl()."/search?tag="; | ||||||
| 
 | 
 | ||||||
| 	$messages = q("SELECT `guid`, `uid`, `id`, `edited`, `deleted`, `title`, `body`, `tag` FROM `item` WHERE `id` = %d LIMIT 1", intval($itemid)); | 	$messages = q("SELECT `guid`, `uid`, `id`, `edited`, `deleted`, `title`, `body`, `tag`, `parent` FROM `item` WHERE `id` = %d LIMIT 1", intval($itemid)); | ||||||
| 
 | 
 | ||||||
| 	if (!$messages) | 	if (!$messages) | ||||||
| 		return; | 		return; | ||||||
|  | @ -102,8 +86,11 @@ function create_tags_from_item($itemid) { | ||||||
| 		if ((substr($tag, 0, 1) == '@') AND (strpos($link, $profile_base_friendica) OR strpos($link, $profile_base_diaspora))) { | 		if ((substr($tag, 0, 1) == '@') AND (strpos($link, $profile_base_friendica) OR strpos($link, $profile_base_diaspora))) { | ||||||
| 			$users = q("SELECT `uid` FROM `contact` WHERE self AND (`url` = '%s' OR `nurl` = '%s')", $link, $link); | 			$users = q("SELECT `uid` FROM `contact` WHERE self AND (`url` = '%s' OR `nurl` = '%s')", $link, $link); | ||||||
| 			foreach ($users AS $user) { | 			foreach ($users AS $user) { | ||||||
| 				if ($user["uid"] == $message["uid"]) | 				if ($user["uid"] == $message["uid"]) { | ||||||
| 					q("UPDATE `item` SET `mention` = 1 WHERE `id` = %d", intval($itemid)); | 					q("UPDATE `item` SET `mention` = 1 WHERE `id` = %d", intval($itemid)); | ||||||
|  | 
 | ||||||
|  | 					q("UPDATE `thread` SET `mention` = 1 WHERE `iid` = %d", intval($message["parent"])); | ||||||
|  | 				} | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | @ -125,11 +112,4 @@ function update_items() { | ||||||
| 	foreach ($messages as $message) | 	foreach ($messages as $message) | ||||||
| 		create_tags_from_item($message["id"]); | 		create_tags_from_item($message["id"]); | ||||||
| } | } | ||||||
| 
 |  | ||||||
| //print_r($tags);
 |  | ||||||
| //print_r($hashtags);
 |  | ||||||
| //print_r($mentions);
 |  | ||||||
| //update_items();
 |  | ||||||
| //create_tags_from_item(265194);
 |  | ||||||
| //create_tags_from_itemuri("infoagent@diasp.org:cce94abd104c06e8", 2);
 |  | ||||||
| ?>
 | ?>
 | ||||||
|  |  | ||||||
|  | @ -233,7 +233,7 @@ function create_user($arr) { | ||||||
| 	); | 	); | ||||||
| 	if((count($r) > 1) && $newuid) { | 	if((count($r) > 1) && $newuid) { | ||||||
| 		$result['message'] .= t('Nickname is already registered. Please choose another.') . EOL; | 		$result['message'] .= t('Nickname is already registered. Please choose another.') . EOL; | ||||||
| 		q("DELETE FROM `user` WHERE `uid` = %d LIMIT 1", | 		q("DELETE FROM `user` WHERE `uid` = %d", | ||||||
| 			intval($newuid) | 			intval($newuid) | ||||||
| 		); | 		); | ||||||
| 		return $result; | 		return $result; | ||||||
|  |  | ||||||
|  | @ -46,12 +46,13 @@ function community_content(&$a, $update = 0) { | ||||||
| 
 | 
 | ||||||
| 	if( (! get_config('alt_pager', 'global')) && (! get_pconfig(local_user(),'system','alt_pager')) ) { | 	if( (! get_config('alt_pager', 'global')) && (! get_pconfig(local_user(),'system','alt_pager')) ) { | ||||||
| 		$r = q("SELECT COUNT(distinct(`item`.`uri`)) AS `total`
 | 		$r = q("SELECT COUNT(distinct(`item`.`uri`)) AS `total`
 | ||||||
| 			FROM `item` LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` LEFT JOIN `user` ON `user`.`uid` = `item`.`uid` | 			FROM `item` INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | ||||||
|  | 			AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
|  | 			INNER JOIN `user` ON `user`.`uid` = `item`.`uid` AND `user`.`hidewall` = 0 | ||||||
| 			WHERE `item`.`visible` = 1 AND `item`.`deleted` = 0 and `item`.`moderated` = 0 | 			WHERE `item`.`visible` = 1 AND `item`.`deleted` = 0 and `item`.`moderated` = 0 | ||||||
| 			AND `item`.`allow_cid` = ''  AND `item`.`allow_gid` = '' | 			AND `item`.`allow_cid` = ''  AND `item`.`allow_gid` = '' | ||||||
| 			AND `item`.`deny_cid`  = '' AND `item`.`deny_gid`  = '' | 			AND `item`.`deny_cid`  = '' AND `item`.`deny_gid`  = '' | ||||||
| 			AND `item`.`private` = 0 AND `item`.`wall` = 1 AND `user`.`hidewall` = 0  | 			AND `item`.`private` = 0 AND `item`.`wall` = 1" | ||||||
| 			AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0" |  | ||||||
| 		); | 		); | ||||||
| 
 | 
 | ||||||
| 		if(count($r)) | 		if(count($r)) | ||||||
|  | @ -70,22 +71,20 @@ function community_content(&$a, $update = 0) { | ||||||
| 		`contact`.`network`, `contact`.`thumb`, `contact`.`self`, `contact`.`writable`, | 		`contact`.`network`, `contact`.`thumb`, `contact`.`self`, `contact`.`writable`, | ||||||
| 		`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid`, | 		`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid`, | ||||||
| 		`user`.`nickname`, `user`.`hidewall` | 		`user`.`nickname`, `user`.`hidewall` | ||||||
| 		FROM `item` FORCE INDEX (`received`, `wall`) LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | 		FROM `thread` FORCE INDEX (`visible_deleted_moderated_private_wall_received`) | ||||||
| 		LEFT JOIN `user` ON `user`.`uid` = `item`.`uid` | 		INNER JOIN `user` ON `user`.`uid` = `thread`.`uid` AND `user`.`hidewall` = 0 | ||||||
| 		WHERE `item`.`visible` = 1 AND `item`.`deleted` = 0 and `item`.`moderated` = 0 | 		INNER JOIN `item` ON `item`.`id` = `thread`.`iid` | ||||||
| 		AND `item`.`allow_cid` = ''  AND `item`.`allow_gid` = '' | 		AND `item`.`allow_cid` = ''  AND `item`.`allow_gid` = '' | ||||||
| 		AND `item`.`deny_cid`  = '' AND `item`.`deny_gid`  = '' | 		AND `item`.`deny_cid`  = '' AND `item`.`deny_gid`  = '' | ||||||
| 		AND `item`.`private` = 0 AND `item`.`wall` = 1 AND `item`.`id` = `item`.`parent` | 		INNER JOIN `contact` ON `contact`.`id` = `thread`.`contact-id` | ||||||
| 		AND `user`.`hidewall` = 0 |  | ||||||
| 		AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 AND `contact`.`self` | 		AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 AND `contact`.`self` | ||||||
| 		ORDER BY `received` DESC LIMIT %d, %d ",
 | 		WHERE `thread`.`visible` = 1 AND `thread`.`deleted` = 0 and `thread`.`moderated` = 0 | ||||||
|  | 		AND `thread`.`private` = 0 AND `thread`.`wall` = 1 | ||||||
|  | 		ORDER BY `thread`.`received` DESC LIMIT %d, %d ",
 | ||||||
| 		intval($a->pager['start']), | 		intval($a->pager['start']), | ||||||
| 		intval($a->pager['itemspage']) | 		intval($a->pager['itemspage']) | ||||||
| 
 | 
 | ||||||
| 	); | 	); | ||||||
| //		group by `item`.`uri`
 |  | ||||||
| //		AND `item`.`private` = 0 AND `item`.`wall` = 1 AND `item`.`id` = `item`.`parent`
 |  | ||||||
| //		AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 AND `contact`.`self`
 |  | ||||||
| 
 | 
 | ||||||
| 	if(! count($r)) { | 	if(! count($r)) { | ||||||
| 		info( t('No results.') . EOL); | 		info( t('No results.') . EOL); | ||||||
|  |  | ||||||
|  | @ -164,7 +164,7 @@ function contacts_post(&$a) { | ||||||
| 	$info = fix_mce_lf(escape_tags(trim($_POST['info']))); | 	$info = fix_mce_lf(escape_tags(trim($_POST['info']))); | ||||||
| 
 | 
 | ||||||
| 	$r = q("UPDATE `contact` SET `profile-id` = %d, `priority` = %d , `info` = '%s',
 | 	$r = q("UPDATE `contact` SET `profile-id` = %d, `priority` = %d , `info` = '%s',
 | ||||||
| 		`hidden` = %d, `notify_new_posts` = %d, `fetch_further_information` = %d WHERE `id` = %d AND `uid` = %d LIMIT 1",
 | 		`hidden` = %d, `notify_new_posts` = %d, `fetch_further_information` = %d WHERE `id` = %d AND `uid` = %d",
 | ||||||
| 		intval($profile_id), | 		intval($profile_id), | ||||||
| 		intval($priority), | 		intval($priority), | ||||||
| 		dbesc($info), | 		dbesc($info), | ||||||
|  | @ -197,7 +197,7 @@ function _contact_update($contact_id) { | ||||||
| } | } | ||||||
| function _contact_block($contact_id, $orig_record) { | function _contact_block($contact_id, $orig_record) { | ||||||
| 	$blocked = (($orig_record['blocked']) ? 0 : 1); | 	$blocked = (($orig_record['blocked']) ? 0 : 1); | ||||||
| 	$r = q("UPDATE `contact` SET `blocked` = %d WHERE `id` = %d AND `uid` = %d LIMIT 1", | 	$r = q("UPDATE `contact` SET `blocked` = %d WHERE `id` = %d AND `uid` = %d", | ||||||
| 		intval($blocked), | 		intval($blocked), | ||||||
| 		intval($contact_id), | 		intval($contact_id), | ||||||
| 		intval(local_user()) | 		intval(local_user()) | ||||||
|  | @ -207,7 +207,7 @@ function _contact_block($contact_id, $orig_record) { | ||||||
| } | } | ||||||
| function _contact_ignore($contact_id, $orig_record) { | function _contact_ignore($contact_id, $orig_record) { | ||||||
| 	$readonly = (($orig_record['readonly']) ? 0 : 1); | 	$readonly = (($orig_record['readonly']) ? 0 : 1); | ||||||
| 	$r = q("UPDATE `contact` SET `readonly` = %d WHERE `id` = %d AND `uid` = %d LIMIT 1", | 	$r = q("UPDATE `contact` SET `readonly` = %d WHERE `id` = %d AND `uid` = %d", | ||||||
| 		intval($readonly), | 		intval($readonly), | ||||||
| 		intval($contact_id), | 		intval($contact_id), | ||||||
| 		intval(local_user()) | 		intval(local_user()) | ||||||
|  | @ -216,7 +216,7 @@ function _contact_ignore($contact_id, $orig_record) { | ||||||
| } | } | ||||||
| function _contact_archive($contact_id, $orig_record) { | function _contact_archive($contact_id, $orig_record) { | ||||||
| 	$archived = (($orig_record['archive']) ? 0 : 1); | 	$archived = (($orig_record['archive']) ? 0 : 1); | ||||||
| 	$r = q("UPDATE `contact` SET `archive` = %d WHERE `id` = %d AND `uid` = %d LIMIT 1", | 	$r = q("UPDATE `contact` SET `archive` = %d WHERE `id` = %d AND `uid` = %d", | ||||||
| 		intval($archived), | 		intval($archived), | ||||||
| 		intval($contact_id), | 		intval($contact_id), | ||||||
| 		intval(local_user()) | 		intval(local_user()) | ||||||
|  |  | ||||||
|  | @ -176,7 +176,7 @@ function content_content(&$a, $update = 0) { | ||||||
| 		if($tag) { | 		if($tag) { | ||||||
| 			//$sql_extra = sprintf(" AND `term`.`term` = '%s' AND `term`.`otype` = %d AND `term`.`type` = %d ",
 | 			//$sql_extra = sprintf(" AND `term`.`term` = '%s' AND `term`.`otype` = %d AND `term`.`type` = %d ",
 | ||||||
| 			//	dbesc(protect_sprintf($search)), intval(TERM_OBJ_POST), intval(TERM_HASHTAG));
 | 			//	dbesc(protect_sprintf($search)), intval(TERM_OBJ_POST), intval(TERM_HASHTAG));
 | ||||||
| 			//$sql_table = "`term` LEFT JOIN `item` ON `item`.`id` = `term`.`oid` AND `item`.`uid` = `term`.`uid` ";
 | 			//$sql_table = "`term` INNER JOIN `item` ON `item`.`id` = `term`.`oid` AND `item`.`uid` = `term`.`uid` ";
 | ||||||
| 
 | 
 | ||||||
| 			$sql_extra = ""; | 			$sql_extra = ""; | ||||||
| 			$sql_table = sprintf("`item` INNER JOIN (SELECT `oid` FROM `term` WHERE `term` = '%s' AND `otype` = %d AND `type` = %d AND `uid` = %d ORDER BY `tid` DESC) AS `term` ON `item`.`id` = `term`.`oid` ", | 			$sql_table = sprintf("`item` INNER JOIN (SELECT `oid` FROM `term` WHERE `term` = '%s' AND `otype` = %d AND `type` = %d AND `uid` = %d ORDER BY `tid` DESC) AS `term` ON `item`.`id` = `term`.`oid` ", | ||||||
|  | @ -216,7 +216,7 @@ function content_content(&$a, $update = 0) { | ||||||
| 			`contact`.`name`, `contact`.`photo`, `contact`.`url`, `contact`.`rel`, `contact`.`writable`, | 			`contact`.`name`, `contact`.`photo`, `contact`.`url`, `contact`.`rel`, `contact`.`writable`, | ||||||
| 			`contact`.`network`, `contact`.`thumb`, `contact`.`dfrn-id`, `contact`.`self`, | 			`contact`.`network`, `contact`.`thumb`, `contact`.`dfrn-id`, `contact`.`self`, | ||||||
| 			`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid` | 			`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid` | ||||||
| 			FROM $sql_table LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | 			FROM $sql_table INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | ||||||
| 			WHERE `item`.`uid` = %d AND `item`.`visible` = 1 | 			WHERE `item`.`uid` = %d AND `item`.`visible` = 1 | ||||||
| 			AND `item`.`deleted` = 0 and `item`.`moderated` = 0 | 			AND `item`.`deleted` = 0 and `item`.`moderated` = 0 | ||||||
| 			$simple_update | 			$simple_update | ||||||
|  | @ -240,7 +240,7 @@ function content_content(&$a, $update = 0) { | ||||||
| 		$start = dba_timer(); | 		$start = dba_timer(); | ||||||
| 
 | 
 | ||||||
| 		$r = q("SELECT `item`.`id` AS `item_id`, `contact`.`uid` AS `contact_uid`
 | 		$r = q("SELECT `item`.`id` AS `item_id`, `contact`.`uid` AS `contact_uid`
 | ||||||
| 			FROM $sql_table LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | 			FROM $sql_table INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | ||||||
| 			WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | 			WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | ||||||
| 			AND `item`.`moderated` = 0 AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | 			AND `item`.`moderated` = 0 AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
| 			AND `item`.`parent` = `item`.`id` | 			AND `item`.`parent` = `item`.`id` | ||||||
|  | @ -267,7 +267,7 @@ function content_content(&$a, $update = 0) { | ||||||
| 				`contact`.`name`, `contact`.`photo`, `contact`.`url`, `contact`.`alias`, `contact`.`rel`, `contact`.`writable`, | 				`contact`.`name`, `contact`.`photo`, `contact`.`url`, `contact`.`alias`, `contact`.`rel`, `contact`.`writable`, | ||||||
| 				`contact`.`network`, `contact`.`thumb`, `contact`.`dfrn-id`, `contact`.`self`, | 				`contact`.`network`, `contact`.`thumb`, `contact`.`dfrn-id`, `contact`.`self`, | ||||||
| 				`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid` | 				`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid` | ||||||
| 				FROM $sql_table LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | 				FROM $sql_table INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | ||||||
| 				WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | 				WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | ||||||
| 				AND `item`.`moderated` = 0 | 				AND `item`.`moderated` = 0 | ||||||
| 				AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | 				AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
|  |  | ||||||
|  | @ -138,10 +138,10 @@ function display_content(&$a, $update = 0) { | ||||||
| 		`contact`.`name`, `contact`.`photo`, `contact`.`url`, `contact`.`rel`, | 		`contact`.`name`, `contact`.`photo`, `contact`.`url`, `contact`.`rel`, | ||||||
| 		`contact`.`network`, `contact`.`thumb`, `contact`.`self`, `contact`.`writable`,  | 		`contact`.`network`, `contact`.`thumb`, `contact`.`self`, `contact`.`writable`,  | ||||||
| 		`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid` | 		`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid` | ||||||
| 		FROM `item` LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | 		FROM `item` INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | ||||||
|  | 		AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
| 		WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | 		WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | ||||||
| 		and `item`.`moderated` = 0 | 		and `item`.`moderated` = 0 | ||||||
| 		AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 |  | ||||||
| 		AND `item`.`parent` = ( SELECT `parent` FROM `item` FORCE INDEX (PRIMARY, `uri`) WHERE ( `id` = '%s' OR `uri` = '%s' ) | 		AND `item`.`parent` = ( SELECT `parent` FROM `item` FORCE INDEX (PRIMARY, `uri`) WHERE ( `id` = '%s' OR `uri` = '%s' ) | ||||||
| 		AND uid = %d ) | 		AND uid = %d ) | ||||||
| 		$sql_extra | 		$sql_extra | ||||||
|  | @ -167,10 +167,10 @@ function display_content(&$a, $update = 0) { | ||||||
| 				`contact`.`name`, `contact`.`photo`, `contact`.`url`, `contact`.`rel`, | 				`contact`.`name`, `contact`.`photo`, `contact`.`url`, `contact`.`rel`, | ||||||
| 				`contact`.`network`, `contact`.`thumb`, `contact`.`self`, `contact`.`writable`,  | 				`contact`.`network`, `contact`.`thumb`, `contact`.`self`, `contact`.`writable`,  | ||||||
| 				`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid` | 				`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid` | ||||||
| 				FROM `item` LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | 				FROM `item` INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | ||||||
|  | 				AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
| 				WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | 				WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | ||||||
| 				and `item`.`moderated` = 0 | 				and `item`.`moderated` = 0 | ||||||
| 				AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 |  | ||||||
| 				AND `item`.`parent` = ( SELECT `parent` FROM `item` FORCE INDEX (PRIMARY, `uri`) WHERE `uri` = '%s' AND uid = %d ) | 				AND `item`.`parent` = ( SELECT `parent` FROM `item` FORCE INDEX (PRIMARY, `uri`) WHERE `uri` = '%s' AND uid = %d ) | ||||||
| 				ORDER BY `parent` DESC, `gravity` ASC, `id` ASC ",
 | 				ORDER BY `parent` DESC, `gravity` ASC, `id` ASC ",
 | ||||||
| 				intval(local_user()), | 				intval(local_user()), | ||||||
|  |  | ||||||
							
								
								
									
										12
									
								
								mod/item.php
									
										
									
									
									
								
							
							
						
						
									
										12
									
								
								mod/item.php
									
										
									
									
									
								
							|  | @ -20,6 +20,7 @@ require_once('include/enotify.php'); | ||||||
| require_once('include/email.php'); | require_once('include/email.php'); | ||||||
| require_once('library/langdet/Text/LanguageDetect.php'); | require_once('library/langdet/Text/LanguageDetect.php'); | ||||||
| require_once('include/tags.php'); | require_once('include/tags.php'); | ||||||
|  | require_once('include/threads.php'); | ||||||
| 
 | 
 | ||||||
| function item_post(&$a) { | function item_post(&$a) { | ||||||
| 
 | 
 | ||||||
|  | @ -705,6 +706,7 @@ function item_post(&$a) { | ||||||
| 			intval($profile_uid) | 			intval($profile_uid) | ||||||
| 		); | 		); | ||||||
| 		create_tags_from_itemuri($post_id, $profile_uid); | 		create_tags_from_itemuri($post_id, $profile_uid); | ||||||
|  | 		update_thread_uri($post_id, $profile_uid); | ||||||
| 
 | 
 | ||||||
| 		// update filetags in pconfig
 | 		// update filetags in pconfig
 | ||||||
|                 file_tag_update_pconfig($uid,$categories_old,$categories_new,'category'); |                 file_tag_update_pconfig($uid,$categories_old,$categories_new,'category'); | ||||||
|  | @ -772,6 +774,7 @@ function item_post(&$a) { | ||||||
| 		$post_id = $r[0]['id']; | 		$post_id = $r[0]['id']; | ||||||
| 		logger('mod_item: saved item ' . $post_id); | 		logger('mod_item: saved item ' . $post_id); | ||||||
| 		create_tags_from_item($post_id); | 		create_tags_from_item($post_id); | ||||||
|  | 		add_thread($post_id); | ||||||
| 
 | 
 | ||||||
| 		// update filetags in pconfig
 | 		// update filetags in pconfig
 | ||||||
|                 file_tag_update_pconfig($uid,$categories_old,$categories_new,'category'); |                 file_tag_update_pconfig($uid,$categories_old,$categories_new,'category'); | ||||||
|  | @ -794,8 +797,9 @@ function item_post(&$a) { | ||||||
| 				dbesc(datetime_convert()), | 				dbesc(datetime_convert()), | ||||||
| 				intval($parent) | 				intval($parent) | ||||||
| 			); | 			); | ||||||
|  | 			update_thread($parent, true); | ||||||
| 
 | 
 | ||||||
| 			// Inherit ACL's from the parent item.
 | 			// Inherit ACLs from the parent item.
 | ||||||
| 
 | 
 | ||||||
| 			$r = q("UPDATE `item` SET `allow_cid` = '%s', `allow_gid` = '%s', `deny_cid` = '%s', `deny_gid` = '%s', `private` = %d
 | 			$r = q("UPDATE `item` SET `allow_cid` = '%s', `allow_gid` = '%s', `deny_cid` = '%s', `deny_gid` = '%s', `private` = %d
 | ||||||
| 				WHERE `id` = %d",
 | 				WHERE `id` = %d",
 | ||||||
|  | @ -832,8 +836,7 @@ function item_post(&$a) { | ||||||
| 			// Store the comment signature information in case we need to relay to Diaspora
 | 			// Store the comment signature information in case we need to relay to Diaspora
 | ||||||
| 			store_diaspora_comment_sig($datarray, $author, ($self ? $a->user['prvkey'] : false), $parent_item, $post_id); | 			store_diaspora_comment_sig($datarray, $author, ($self ? $a->user['prvkey'] : false), $parent_item, $post_id); | ||||||
| 
 | 
 | ||||||
| 		} | 		} else { | ||||||
| 		else { |  | ||||||
| 			$parent = $post_id; | 			$parent = $post_id; | ||||||
| 
 | 
 | ||||||
| 			if($contact_record != $author) { | 			if($contact_record != $author) { | ||||||
|  | @ -868,6 +871,7 @@ function item_post(&$a) { | ||||||
| 			dbesc(datetime_convert()), | 			dbesc(datetime_convert()), | ||||||
| 			intval($post_id) | 			intval($post_id) | ||||||
| 		); | 		); | ||||||
|  | 		update_thread($post_id); | ||||||
| 
 | 
 | ||||||
| 		// photo comments turn the corresponding item visible to the profile wall
 | 		// photo comments turn the corresponding item visible to the profile wall
 | ||||||
| 		// This way we don't see every picture in your new photo album posted to your wall at once.
 | 		// This way we don't see every picture in your new photo album posted to your wall at once.
 | ||||||
|  | @ -877,6 +881,7 @@ function item_post(&$a) { | ||||||
| 			$r = q("UPDATE `item` SET `visible` = 1 WHERE `id` = %d", | 			$r = q("UPDATE `item` SET `visible` = 1 WHERE `id` = %d", | ||||||
| 				intval($parent_item['id']) | 				intval($parent_item['id']) | ||||||
| 			); | 			); | ||||||
|  | 			update_thread($parent_item['id']); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	else { | 	else { | ||||||
|  | @ -893,6 +898,7 @@ function item_post(&$a) { | ||||||
| 		dbesc(datetime_convert()), | 		dbesc(datetime_convert()), | ||||||
| 		intval($parent) | 		intval($parent) | ||||||
| 	); | 	); | ||||||
|  | 	update_thread($parent); | ||||||
| 
 | 
 | ||||||
| 	$datarray['id']    = $post_id; | 	$datarray['id']    = $post_id; | ||||||
| 	$datarray['plink'] = $a->get_baseurl() . '/display/' . $user['nickname'] . '/' . $post_id; | 	$datarray['plink'] = $a->get_baseurl() . '/display/' . $user['nickname'] . '/' . $post_id; | ||||||
|  |  | ||||||
							
								
								
									
										234
									
								
								mod/network.php
									
										
									
									
									
								
							
							
						
						
									
										234
									
								
								mod/network.php
									
										
									
									
									
								
							|  | @ -1,5 +1,8 @@ | ||||||
| <?php | <?php | ||||||
| 
 | /* | ||||||
|  | To-Do: | ||||||
|  | - Community-Seite umstellen | ||||||
|  | */ | ||||||
| 
 | 
 | ||||||
| function network_init(&$a) { | function network_init(&$a) { | ||||||
| 	if(! local_user()) { | 	if(! local_user()) { | ||||||
|  | @ -93,52 +96,11 @@ function network_init(&$a) { | ||||||
| 			$net_args = array_merge($query_array, $net_args); | 			$net_args = array_merge($query_array, $net_args); | ||||||
| 			$net_queries = build_querystring($net_args); | 			$net_queries = build_querystring($net_args); | ||||||
| 
 | 
 | ||||||
|             // groups filter is in form of "network/nnn". Add it to $dest_url, if it's possible
 |  | ||||||
|             //if ($a->argc==2 && is_numeric($a->argv[1]) && strpos($net_baseurl, "/",1)===false){
 |  | ||||||
|             //    $net_baseurl .= "/".$a->argv[1];
 |  | ||||||
|             //}
 |  | ||||||
| 
 |  | ||||||
| 			$redir_url = ($net_queries ? $net_baseurl."?".$net_queries : $net_baseurl); | 			$redir_url = ($net_queries ? $net_baseurl."?".$net_queries : $net_baseurl); | ||||||
| 			goaway($a->get_baseurl() . $redir_url); | 			goaway($a->get_baseurl() . $redir_url); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| /*	$sel_tabs = network_query_get_sel_tab($a); |  | ||||||
| 	$last_sel_tabs = get_pconfig(local_user(), 'network.view','tab.selected'); |  | ||||||
| 	if (is_array($last_sel_tabs)){ |  | ||||||
| 		$tab_urls = array( |  | ||||||
| 			'/network?f=&order=comment',//all
 |  | ||||||
| 			'/network?f=&order=post',		//postord
 |  | ||||||
| 			'/network?f=&conv=1',			//conv
 |  | ||||||
| 			'/network/new',					//new
 |  | ||||||
| 			'/network?f=&star=1',			//starred
 |  | ||||||
| 			'/network?f=&bmark=1',			//bookmarked
 |  | ||||||
| 			'/network?f=&spam=1',			//spam
 |  | ||||||
| 		); |  | ||||||
| 
 |  | ||||||
| 		// redirect if current selected tab is 'no_active' and
 |  | ||||||
| 		// last selected tab is _not_ 'all_active'.
 |  | ||||||
| 		// and this isn't a date query
 |  | ||||||
| 
 |  | ||||||
| 		if ($sel_tabs[0] == 'active' && $last_sel_tabs[0]!='active' && (! $is_a_date_query)) { |  | ||||||
| 			$k = array_search('active', $last_sel_tabs); |  | ||||||
| 
 |  | ||||||
|             // merge tab querystring with request querystring
 |  | ||||||
|             $dest_qa = array(); |  | ||||||
|             list($dest_url,$dest_qs) = explode("?", $tab_urls[$k]); |  | ||||||
|             parse_str( $dest_qs, $dest_qa); |  | ||||||
|             $dest_qa = array_merge($query_array, $dest_qa); |  | ||||||
|             $dest_qs = build_querystring($dest_qa); |  | ||||||
| 
 |  | ||||||
|             // groups filter is in form of "network/nnn". Add it to $dest_url, if it's possible
 |  | ||||||
|             if ($a->argc==2 && is_numeric($a->argv[1]) && strpos($dest_url, "/",1)===false){ |  | ||||||
|                 $dest_url .= "/".$a->argv[1]; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
| 			goaway($a->get_baseurl() . $dest_url."?".$dest_qs); |  | ||||||
| 		} |  | ||||||
| 	}*/ |  | ||||||
| 
 |  | ||||||
| 	if(x($_GET['nets']) && $_GET['nets'] === 'all') | 	if(x($_GET['nets']) && $_GET['nets'] === 'all') | ||||||
| 		unset($_GET['nets']); | 		unset($_GET['nets']); | ||||||
| 
 | 
 | ||||||
|  | @ -383,7 +345,6 @@ function network_content(&$a, $update = 0) { | ||||||
| 	list($no_active, $all_active, $postord_active, $conv_active, $new_active, $starred_active, $bookmarked_active, $spam_active) = network_query_get_sel_tab($a); | 	list($no_active, $all_active, $postord_active, $conv_active, $new_active, $starred_active, $bookmarked_active, $spam_active) = network_query_get_sel_tab($a); | ||||||
| 	// if no tabs are selected, defaults to comments
 | 	// if no tabs are selected, defaults to comments
 | ||||||
| 	if ($no_active=='active') $all_active='active'; | 	if ($no_active=='active') $all_active='active'; | ||||||
| 	//echo "<pre>"; var_dump($no_active, $all_active, $postord_active, $conv_active, $new_active, $starred_active, $bookmarked_active, $spam_active); killme();
 |  | ||||||
| 
 | 
 | ||||||
| 	$cmd = (($datequery) ? '' : $a->cmd); | 	$cmd = (($datequery) ? '' : $a->cmd); | ||||||
| 	$len_naked_cmd = strlen(str_replace('/new','',$cmd)); | 	$len_naked_cmd = strlen(str_replace('/new','',$cmd)); | ||||||
|  | @ -402,38 +363,6 @@ function network_content(&$a, $update = 0) { | ||||||
| 			'sel'=>$postord_active, | 			'sel'=>$postord_active, | ||||||
| 			'title' => t('Sort by Post Date'), | 			'title' => t('Sort by Post Date'), | ||||||
| 		), | 		), | ||||||
| 
 |  | ||||||
| /*		array( |  | ||||||
| 			'label' => t('Personal'), |  | ||||||
| 			'url' => $a->get_baseurl(true) . '/' . str_replace('/new', '', $cmd) . ((x($_GET,'cid')) ? '/?f=&cid=' . $_GET['cid'] : '') . '&conv=1', |  | ||||||
| 			'sel' => $conv_active, |  | ||||||
| 			'title' => t('Posts that mention or involve you'), |  | ||||||
| 		),*/ |  | ||||||
| /*		array( |  | ||||||
| 			'label' => t('New'), |  | ||||||
| 			'url' => $a->get_baseurl(true) . '/' . str_replace('/new', '', $cmd) . ($len_naked_cmd ? '/' : '') . 'new' . ((x($_GET,'cid')) ? '/?f=&cid=' . $_GET['cid'] : ''), |  | ||||||
| 			'sel' => $new_active, |  | ||||||
| 			'title' => t('Activity Stream - by date'), |  | ||||||
| 		),*/ |  | ||||||
| /*		array( |  | ||||||
| 			'label' => t('Starred'), |  | ||||||
| 			'url'=>$a->get_baseurl(true) . '/' . str_replace('/new', '', $cmd) . ((x($_GET,'cid')) ? '/?f=&cid=' . $_GET['cid'] : '') . '&star=1', |  | ||||||
| 			'sel'=>$starred_active, |  | ||||||
| 			'title' => t('Favourite Posts'), |  | ||||||
| 		),*/ |  | ||||||
| /*		array( |  | ||||||
| 			'label' => t('Shared Links'), |  | ||||||
| 			'url'=>$a->get_baseurl(true) . '/' . str_replace('/new', '', $cmd) . ((x($_GET,'cid')) ? '/?f=&cid=' . $_GET['cid'] : '') . '&bmark=1', |  | ||||||
| 			'sel'=>$bookmarked_active, |  | ||||||
| 			'title'=> t('Interesting Links'), |  | ||||||
| 		),	*/ |  | ||||||
| //		array(
 |  | ||||||
| //			'label' => t('Spam'),
 |  | ||||||
| //			'url'=>$a->get_baseurl(true) . '/network?f=&spam=1'
 |  | ||||||
| //			'sel'=> $spam_active,
 |  | ||||||
| //			'title' => t('Posts flagged as SPAM'),
 |  | ||||||
| //		),
 |  | ||||||
| 
 |  | ||||||
| 	); | 	); | ||||||
| 
 | 
 | ||||||
| 	if(feature_enabled(local_user(),'personal_tab')) { | 	if(feature_enabled(local_user(),'personal_tab')) { | ||||||
|  | @ -472,17 +401,6 @@ function network_content(&$a, $update = 0) { | ||||||
| 		); | 		); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// Not yet implemented
 |  | ||||||
| 
 |  | ||||||
| /*	if(feature_enabled(local_user(),'spam_filter'))  { |  | ||||||
| 		$tabs[] = array( |  | ||||||
| 			'label' => t('Spam'), |  | ||||||
| 			'url'=>$a->get_baseurl(true) . '/network?f=&spam=1', |  | ||||||
| 			'sel'=> $spam_active, |  | ||||||
| 			'title' => t('Posts flagged as SPAM'), |  | ||||||
| 		); |  | ||||||
| 	}*/ |  | ||||||
| 
 |  | ||||||
| 	// save selected tab, but only if not in search or file mode
 | 	// save selected tab, but only if not in search or file mode
 | ||||||
| 	if(!x($_GET,'search') && !x($_GET,'file')) { | 	if(!x($_GET,'search') && !x($_GET,'file')) { | ||||||
| 		set_pconfig( local_user(), 'network.view','tab.selected',array($all_active, $postord_active, $conv_active, $new_active, $starred_active, $bookmarked_active, $spam_active) ); | 		set_pconfig( local_user(), 'network.view','tab.selected',array($all_active, $postord_active, $conv_active, $new_active, $starred_active, $bookmarked_active, $spam_active) ); | ||||||
|  | @ -533,6 +451,11 @@ function network_content(&$a, $update = 0) { | ||||||
| 	} | 	} | ||||||
| 	set_pconfig(local_user(), 'network.view', 'net.selected', ($nets ? $nets : 'all')); | 	set_pconfig(local_user(), 'network.view', 'net.selected', ($nets ? $nets : 'all')); | ||||||
| 
 | 
 | ||||||
|  | /*if ($update) { | ||||||
|  | print_r($_GET); | ||||||
|  | die("ss"); | ||||||
|  | }*/ | ||||||
|  | 
 | ||||||
| 	if(! $update) { | 	if(! $update) { | ||||||
| 		if($group) { | 		if($group) { | ||||||
| 			if(($t = group_public_members($group)) && (! get_pconfig(local_user(),'system','nowarn_insecure'))) { | 			if(($t = group_public_members($group)) && (! get_pconfig(local_user(),'system','nowarn_insecure'))) { | ||||||
|  | @ -569,17 +492,21 @@ function network_content(&$a, $update = 0) { | ||||||
| 	// that belongs to you, hence you can see all of it. We will filter by group if
 | 	// that belongs to you, hence you can see all of it. We will filter by group if
 | ||||||
| 	// desired.
 | 	// desired.
 | ||||||
| 
 | 
 | ||||||
|  | 	$sql_post_table = ""; | ||||||
| 	$sql_options  = (($star) ? " and starred = 1 " : ''); | 	$sql_options  = (($star) ? " and starred = 1 " : ''); | ||||||
| 	$sql_options .= (($bmark) ? " and bookmark = 1 " : ''); | 	$sql_options .= (($bmark) ? " and bookmark = 1 " : ''); | ||||||
|  | 	$sql_extra = $sql_options; | ||||||
|  | 	$sql_extra2 = ""; | ||||||
|  | 	$sql_extra3 = ""; | ||||||
|  | 	$sql_table = "`thread`"; | ||||||
|  | 	$sql_parent = "`iid`"; | ||||||
| 
 | 
 | ||||||
| 	//$sql_nets = (($nets) ? sprintf(" and `contact`.`network` = '%s' ", dbesc($nets)) : '');
 | 	if ($nouveau OR strlen($file) OR $update) { | ||||||
| 	$sql_nets = (($nets) ? sprintf(" and `item`.`network` = '%s' ", dbesc($nets)) : ''); | 		$sql_table = "`item`"; | ||||||
|  | 		$sql_parent = "`parent`"; | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	if ($star OR $bmark) { | 	$sql_nets = (($nets) ? sprintf(" and $sql_table.`network` = '%s' ", dbesc($nets)) : ''); | ||||||
| 		$sql_table = "`item` INNER JOIN (SELECT DISTINCT(`parent`) FROM `item` WHERE 1 $sql_options and deleted = 0 ORDER BY `commented` DESC) AS `temp1` ON item.parent = `temp1`.parent "; |  | ||||||
| 		$sql_extra = ""; |  | ||||||
| 	} else |  | ||||||
| 		$sql_extra = " AND `item`.`parent` IN ( SELECT `parent` FROM `item` WHERE `id` = `parent` $sql_options ) "; |  | ||||||
| 
 | 
 | ||||||
| 	if($group) { | 	if($group) { | ||||||
| 		$r = q("SELECT `name`, `id` FROM `group` WHERE `id` = %d AND `uid` = %d LIMIT 1", | 		$r = q("SELECT `name`, `id` FROM `group` WHERE `id` = %d AND `uid` = %d LIMIT 1", | ||||||
|  | @ -595,29 +522,33 @@ function network_content(&$a, $update = 0) { | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		$contacts = expand_groups(array($group)); | 		$contacts = expand_groups(array($group)); | ||||||
|  | 
 | ||||||
|  | 		$contact_str_self = ""; | ||||||
|  | 
 | ||||||
| 		if((is_array($contacts)) && count($contacts)) { | 		if((is_array($contacts)) && count($contacts)) { | ||||||
| 			$contact_str = implode(',',$contacts); | 			$contact_str = implode(',',$contacts); | ||||||
|  | 			$self = q("SELECT `id` FROM `contact` WHERE `uid` = %d AND `self`", intval($_SESSION['uid'])); | ||||||
|  | 			if (count($self)) | ||||||
|  | 				$contact_str_self = ",".$self[0]["id"]; | ||||||
| 		} | 		} | ||||||
| 		else { | 		else { | ||||||
| 				$contact_str = ' 0 '; | 				$contact_str = ' 0 '; | ||||||
| 				info( t('Group is empty')); | 				info( t('Group is empty')); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		$sql_table = "`item` INNER JOIN (SELECT DISTINCT(`parent`) FROM `item` WHERE 1 $sql_options AND (`contact-id` IN ($contact_str) OR `allow_gid` like '".protect_sprintf('%<'.intval($group).'>%')."') and deleted = 0 ORDER BY `created` DESC) AS `temp1` ON item.parent = `temp1`.parent "; | 		$sql_post_table = " INNER JOIN (SELECT DISTINCT(`parent`) FROM `item` WHERE (`contact-id` IN ($contact_str) OR `allow_gid` like '".protect_sprintf('%<'.intval($group).'>%')."') and deleted = 0 ORDER BY `created` DESC) AS `temp1` ON $sql_table.$sql_parent = `temp1`.`parent` "; | ||||||
| 		$sql_extra = ""; | 
 | ||||||
| 		//$sql_extra = " AND `item`.`parent` IN ( SELECT DISTINCT(`parent`) FROM `item` WHERE 1 $sql_options AND ( `contact-id` IN ( $contact_str ) OR `allow_gid` like '" . protect_sprintf('%<' . intval($group) . '>%') . "' ) and deleted = 0 ) ";
 | 		$sql_extra3 .= " AND `contact-id` IN ($contact_str.$contact_str_self) "; | ||||||
| 		$o = '<h2>' . t('Group: ') . $r[0]['name'] . '</h2>' . $o; | 		$o = '<h2>' . t('Group: ') . $r[0]['name'] . '</h2>' . $o; | ||||||
| 	} | 	} elseif($cid) { | ||||||
| 	elseif($cid) { |  | ||||||
| 
 | 
 | ||||||
| 		$r = q("SELECT `id`,`name`,`network`,`writable`,`nurl` FROM `contact` WHERE `id` = %d
 | 		$r = q("SELECT `id`,`name`,`network`,`writable`,`nurl` FROM `contact` WHERE `id` = %d
 | ||||||
| 				AND `blocked` = 0 AND `pending` = 0 LIMIT 1",
 | 				AND `blocked` = 0 AND `pending` = 0 LIMIT 1",
 | ||||||
| 			intval($cid) | 			intval($cid) | ||||||
| 		); | 		); | ||||||
| 		if(count($r)) { | 		if(count($r)) { | ||||||
| 			$sql_table = "`item` INNER JOIN (SELECT DISTINCT(`parent`) FROM `item` WHERE 1 $sql_options AND `contact-id` = ".intval($cid)." and deleted = 0 ORDER BY `item`.`received` DESC) AS `temp1` ON item.parent = `temp1`.parent "; | 			$sql_post_table = " INNER JOIN (SELECT DISTINCT(`parent`) FROM `item` WHERE 1 $sql_options AND `contact-id` = ".intval($cid)." and deleted = 0 ORDER BY `item`.`received` DESC) AS `temp1` ON $sql_table.$sql_parent = `temp1`.`parent` "; | ||||||
| 			$sql_extra = ""; | 			$sql_extra = ""; | ||||||
| 			//$sql_extra = " AND `item`.`parent` IN ( SELECT DISTINCT(`parent`) FROM `item` WHERE 1 $sql_options AND `contact-id` = " . intval($cid) . " and deleted = 0 ) ";
 |  | ||||||
| 			$o = '<h2>' . t('Contact: ') . $r[0]['name'] . '</h2>' . $o; | 			$o = '<h2>' . t('Contact: ') . $r[0]['name'] . '</h2>' . $o; | ||||||
| 			if($r[0]['network'] === NETWORK_OSTATUS && $r[0]['writable'] && (! get_pconfig(local_user(),'system','nowarn_insecure'))) { | 			if($r[0]['network'] === NETWORK_OSTATUS && $r[0]['writable'] && (! get_pconfig(local_user(),'system','nowarn_insecure'))) { | ||||||
| 				notice( t('Private messages to this person are at risk of public disclosure.') . EOL); | 				notice( t('Private messages to this person are at risk of public disclosure.') . EOL); | ||||||
|  | @ -636,24 +567,19 @@ function network_content(&$a, $update = 0) { | ||||||
| 		$o .= get_events(); | 		$o .= get_events(); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	$sql_extra3 = ''; |  | ||||||
| 
 |  | ||||||
| 	if($datequery) { | 	if($datequery) { | ||||||
| 		$sql_extra3 .= protect_sprintf(sprintf(" AND item.created <= '%s' ", dbesc(datetime_convert(date_default_timezone_get(),'',$datequery)))); | 		$sql_extra3 .= protect_sprintf(sprintf(" AND $sql_table.created <= '%s' ", dbesc(datetime_convert(date_default_timezone_get(),'',$datequery)))); | ||||||
| 	} | 	} | ||||||
| 	if($datequery2) { | 	if($datequery2) { | ||||||
| 		$sql_extra3 .= protect_sprintf(sprintf(" AND item.created >= '%s' ", dbesc(datetime_convert(date_default_timezone_get(),'',$datequery2)))); | 		$sql_extra3 .= protect_sprintf(sprintf(" AND $sql_table.created >= '%s' ", dbesc(datetime_convert(date_default_timezone_get(),'',$datequery2)))); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	$sql_extra2 = (($nouveau) ? '' : " AND `item`.`parent` = `item`.`id` "); | 	//$sql_extra2 = (($nouveau) ? '' : " AND `item`.`parent` = `item`.`id` ");
 | ||||||
|  | 	$sql_extra2 = (($nouveau) ? '' : $sql_extra2); | ||||||
| 	$sql_extra3 = (($nouveau) ? '' : $sql_extra3); | 	$sql_extra3 = (($nouveau) ? '' : $sql_extra3); | ||||||
| 	//$sql_order = "`item`.`received`";
 |  | ||||||
| 	$sql_order = ""; | 	$sql_order = ""; | ||||||
| 	$order_mode = "received"; | 	$order_mode = "received"; | ||||||
| 
 | 
 | ||||||
| 	if ($sql_table == "") |  | ||||||
| 		$sql_table = "`item`"; |  | ||||||
| 
 |  | ||||||
| 	if(x($_GET,'search')) { | 	if(x($_GET,'search')) { | ||||||
| 		$search = escape_tags($_GET['search']); | 		$search = escape_tags($_GET['search']); | ||||||
| 
 | 
 | ||||||
|  | @ -666,44 +592,24 @@ function network_content(&$a, $update = 0) { | ||||||
| 			$tag = true; | 			$tag = true; | ||||||
| 
 | 
 | ||||||
| 		if($tag) { | 		if($tag) { | ||||||
| 			//$sql_extra = sprintf(" AND `term`.`term` = '%s' AND `term`.`otype` = %d AND `term`.`type` = %d ",
 |  | ||||||
| 			//		dbesc(protect_sprintf($search)), intval(TERM_OBJ_POST), intval(TERM_HASHTAG));
 |  | ||||||
| 			//$sql_table = "`term` LEFT JOIN `item` ON `item`.`id` = `term`.`oid` AND `item`.`uid` = `term`.`uid` ";
 |  | ||||||
| 
 |  | ||||||
| 			//$sql_order = "`term`.`tid`";
 |  | ||||||
| 
 |  | ||||||
| 			$sql_extra = ""; | 			$sql_extra = ""; | ||||||
| 
 | 
 | ||||||
| 			$sql_table = sprintf("`item` INNER JOIN (SELECT `oid` FROM `term` WHERE `term` = '%s' AND `otype` = %d AND `type` = %d AND `uid` = %d ORDER BY `tid` DESC) AS `term` ON `item`.`id` = `term`.`oid` ", | 			$sql_post_table = sprintf("INNER JOIN (SELECT `oid` FROM `term` WHERE `term` = '%s' AND `otype` = %d AND `type` = %d AND `uid` = %d ORDER BY `tid` DESC) AS `term` ON `item`.`id` = `term`.`oid` ", | ||||||
| 					dbesc(protect_sprintf($search)), intval(TERM_OBJ_POST), intval(TERM_HASHTAG), intval(local_user())); | 					dbesc(protect_sprintf($search)), intval(TERM_OBJ_POST), intval(TERM_HASHTAG), intval(local_user())); | ||||||
| 
 |  | ||||||
| 			$sql_order = "`item`.`received`"; |  | ||||||
| 			$order_mode = "received"; |  | ||||||
| 		} else { | 		} else { | ||||||
| 			if (get_config('system','use_fulltext_engine')) | 			if (get_config('system','use_fulltext_engine')) | ||||||
| 				$sql_extra = sprintf(" AND MATCH (`item`.`body`, `item`.`title`) AGAINST ('%s' in boolean mode) ", dbesc(protect_sprintf($search))); | 				$sql_extra = sprintf(" AND MATCH (`item`.`body`, `item`.`title`) AGAINST ('%s' in boolean mode) ", dbesc(protect_sprintf($search))); | ||||||
| 			else | 			else | ||||||
| 				$sql_extra = sprintf(" AND `item`.`body` REGEXP '%s' ", dbesc(protect_sprintf(preg_quote($search)))); | 				$sql_extra = sprintf(" AND `item`.`body` REGEXP '%s' ", dbesc(protect_sprintf(preg_quote($search)))); | ||||||
| 
 | 		} | ||||||
| 		$sql_order = "`item`.`received`"; | 		$sql_order = "`item`.`received`"; | ||||||
| 		$order_mode = "received"; | 		$order_mode = "received"; | ||||||
| 	} | 	} | ||||||
| 	} | 	if(strlen($file)) | ||||||
| 	if(strlen($file)) { |  | ||||||
| 		$sql_extra .= file_tag_file_query('item',unxmlify($file)); | 		$sql_extra .= file_tag_file_query('item',unxmlify($file)); | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	if($conv) { | 	if($conv) | ||||||
| 		$myurl = $a->get_baseurl() . '/profile/'. $a->user['nickname']; | 		$sql_extra2 .= " AND `mention`"; | ||||||
| 		$myurl = substr($myurl,strpos($myurl,'://')+3); |  | ||||||
| 		$myurl = str_replace('www.','',$myurl); |  | ||||||
| 		$diasp_url = str_replace('/profile/','/u/',$myurl); |  | ||||||
| 
 |  | ||||||
| 		$sql_extra .= sprintf(" AND `item`.`parent` IN (SELECT distinct(`parent`) from item where `author-link` IN ('https://%s', 'http://%s') OR `mention`)", |  | ||||||
| 			dbesc(protect_sprintf($myurl)), |  | ||||||
| 			dbesc(protect_sprintf($myurl)) |  | ||||||
| 		); |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	if($update) { | 	if($update) { | ||||||
| 
 | 
 | ||||||
|  | @ -714,9 +620,9 @@ function network_content(&$a, $update = 0) { | ||||||
| 	else { | 	else { | ||||||
| 		if( (! get_config('alt_pager', 'global')) && (! get_pconfig(local_user(),'system','alt_pager')) ) { | 		if( (! get_config('alt_pager', 'global')) && (! get_pconfig(local_user(),'system','alt_pager')) ) { | ||||||
| 		        $r = q("SELECT COUNT(*) AS `total`
 | 		        $r = q("SELECT COUNT(*) AS `total`
 | ||||||
| 			        FROM $sql_table LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | 			        FROM $sql_table $sql_post_table INNER JOIN `contact` ON `contact`.`id` = $sql_table.`contact-id` | ||||||
| 			        WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 |  | ||||||
| 			        AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | 			        AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
|  | 			        WHERE $sql_table.`uid` = %d AND $sql_table.`visible` = 1 AND $sql_table.`deleted` = 0 | ||||||
| 			        $sql_extra2 $sql_extra3 | 			        $sql_extra2 $sql_extra3 | ||||||
| 			        $sql_extra $sql_nets ",
 | 			        $sql_extra $sql_nets ",
 | ||||||
| 			        intval($_SESSION['uid']) | 			        intval($_SESSION['uid']) | ||||||
|  | @ -745,28 +651,26 @@ function network_content(&$a, $update = 0) { | ||||||
| 		$pager_sql = sprintf(" LIMIT %d, %d ",intval($a->pager['start']), intval($a->pager['itemspage'])); | 		$pager_sql = sprintf(" LIMIT %d, %d ",intval($a->pager['start']), intval($a->pager['itemspage'])); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	if($nouveau) { | ||||||
| 		$simple_update = (($update) ? " and `item`.`unseen` = 1 " : ''); | 		$simple_update = (($update) ? " and `item`.`unseen` = 1 " : ''); | ||||||
| 
 | 
 | ||||||
| 	if($nouveau) { |  | ||||||
| 		// "New Item View" - show all items unthreaded in reverse created date order
 | 		// "New Item View" - show all items unthreaded in reverse created date order
 | ||||||
| 
 |  | ||||||
| 		$items = q("SELECT `item`.*, `item`.`id` AS `item_id`, `item`.`network` AS `item_network`,
 | 		$items = q("SELECT `item`.*, `item`.`id` AS `item_id`, `item`.`network` AS `item_network`,
 | ||||||
| 			`contact`.`name`, `contact`.`photo`, `contact`.`url`, `contact`.`rel`, `contact`.`writable`, | 			`contact`.`name`, `contact`.`photo`, `contact`.`url`, `contact`.`rel`, `contact`.`writable`, | ||||||
| 			`contact`.`network`, `contact`.`thumb`, `contact`.`dfrn-id`, `contact`.`self`, | 			`contact`.`network`, `contact`.`thumb`, `contact`.`dfrn-id`, `contact`.`self`, | ||||||
| 			`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid` | 			`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid` | ||||||
| 			FROM $sql_table LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | 			FROM $sql_table $sql_post_table INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | ||||||
|  | 			AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
| 			WHERE `item`.`uid` = %d AND `item`.`visible` = 1 | 			WHERE `item`.`uid` = %d AND `item`.`visible` = 1 | ||||||
| 			AND `item`.`deleted` = 0 and `item`.`moderated` = 0 | 			AND `item`.`deleted` = 0 and `item`.`moderated` = 0 | ||||||
| 			$simple_update | 			$simple_update | ||||||
| 			AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 |  | ||||||
| 			$sql_extra $sql_nets | 			$sql_extra $sql_nets | ||||||
| 			ORDER BY `item`.`received` DESC $pager_sql ",
 | 			ORDER BY `item`.`received` DESC $pager_sql ",
 | ||||||
| 			intval($_SESSION['uid']) | 			intval($_SESSION['uid']) | ||||||
| 		); | 		); | ||||||
| 
 | 
 | ||||||
| 		$update_unseen = ' WHERE uid = ' . intval($_SESSION['uid']) . " AND unseen = 1 $sql_extra $sql_nets"; | 		$update_unseen = ' WHERE uid = ' . intval($_SESSION['uid']) . " AND unseen = 1 $sql_extra $sql_nets"; | ||||||
| 	} | 	} else { | ||||||
| 	else { |  | ||||||
| 
 | 
 | ||||||
| 		// Normal conversation view
 | 		// Normal conversation view
 | ||||||
| 
 | 
 | ||||||
|  | @ -782,31 +686,29 @@ function network_content(&$a, $update = 0) { | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		if ($sql_order == "") | 		if ($sql_order == "") | ||||||
| 			$sql_order = "`item`.$ordering"; | 			$sql_order = "$sql_table.$ordering"; | ||||||
| 
 | 
 | ||||||
| 		if (($_GET["offset"] != "")) | 		if (($_GET["offset"] != "")) | ||||||
| 			$sql_extra3 .= sprintf(" AND $sql_order <= '%s'", dbesc($_GET["offset"])); | 			$sql_extra3 .= sprintf(" AND $sql_order <= '%s'", dbesc($_GET["offset"])); | ||||||
| 
 | 
 | ||||||
| 		// Fetch a page full of parent items for this page
 | 		// Fetch a page full of parent items for this page
 | ||||||
| 
 |  | ||||||
| 		if($update) { | 		if($update) { | ||||||
| 			$r = q("SELECT `item`.`parent` AS `item_id`, `item`.`network` AS `item_network`, `contact`.`uid` AS `contact_uid`
 | 			$r = q("SELECT `item`.`parent` AS `item_id`, `item`.`network` AS `item_network`, `contact`.`uid` AS `contact_uid`
 | ||||||
| 				FROM $sql_table LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | 				FROM $sql_table $sql_post_table INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | ||||||
| 				WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND |  | ||||||
| 				(`item`.`deleted` = 0 OR item.verb = '" . ACTIVITY_LIKE ."' OR item.verb = '" . ACTIVITY_DISLIKE . "') |  | ||||||
| 				and `item`.`moderated` = 0 and `item`.`unseen` = 1 |  | ||||||
| 				AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | 				AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
| 				$sql_extra3 $sql_extra $sql_nets ",
 | 				WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND | ||||||
|  | 				(`item`.`deleted` = 0 OR `item`.`verb` = '" . ACTIVITY_LIKE ."' OR `item`.`verb` = '" . ACTIVITY_DISLIKE . "') | ||||||
|  | 				and `item`.`moderated` = 0 and `item`.`unseen` = 1 | ||||||
|  | 				$sql_extra3 $sql_extra $sql_nets ORDER BY `item_id` DESC LIMIT 100",
 | ||||||
| 				intval(local_user()) | 				intval(local_user()) | ||||||
| 			); | 			); | ||||||
| 		} | 		} else { | ||||||
| 		else { | 			$r = q("SELECT `thread`.`iid` AS `item_id`, `thread`.`network` AS `item_network`, `contact`.`uid` AS `contact_uid`
 | ||||||
| 			$r = q("SELECT `item`.`id` AS `item_id`, `item`.`network` AS `item_network`, `contact`.`uid` AS `contact_uid`
 | 				FROM $sql_table $sql_post_table INNER JOIN `contact` ON `contact`.`id` = `thread`.`contact-id` | ||||||
| 				FROM $sql_table LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | 				AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
| 				WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | 				WHERE `thread`.`uid` = %d AND `thread`.`visible` = 1 AND `thread`.`deleted` = 0 | ||||||
| 				AND `item`.`moderated` = 0 AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | 				AND `thread`.`moderated` = 0 | ||||||
| 				AND `item`.`parent` = `item`.`id` | 				$sql_extra2 $sql_extra3 $sql_extra $sql_nets | ||||||
| 				$sql_extra3 $sql_extra $sql_nets |  | ||||||
| 				ORDER BY $sql_order DESC $pager_sql ",
 | 				ORDER BY $sql_order DESC $pager_sql ",
 | ||||||
| 				intval(local_user()) | 				intval(local_user()) | ||||||
| 			); | 			); | ||||||
|  | @ -823,7 +725,7 @@ function network_content(&$a, $update = 0) { | ||||||
| 				if(! in_array($rr['item_id'],$parents_arr)) | 				if(! in_array($rr['item_id'],$parents_arr)) | ||||||
| 					$parents_arr[] = $rr['item_id']; | 					$parents_arr[] = $rr['item_id']; | ||||||
| 
 | 
 | ||||||
| 			//$parents_str = implode(', ', $parents_arr);
 | 			$parents_str = implode(", ", $parents_arr); | ||||||
| 
 | 
 | ||||||
| 			// splitted into separate queries to avoid the problem with very long threads
 | 			// splitted into separate queries to avoid the problem with very long threads
 | ||||||
| 			// so always the last X comments are loaded
 | 			// so always the last X comments are loaded
 | ||||||
|  | @ -834,26 +736,25 @@ function network_content(&$a, $update = 0) { | ||||||
| 
 | 
 | ||||||
| 			$items = array(); | 			$items = array(); | ||||||
| 
 | 
 | ||||||
| 			foreach ($parents_arr AS $parents_str) { | 			foreach ($parents_arr AS $parents) { | ||||||
| 
 | //					$sql_extra ORDER BY `item`.`commented` DESC LIMIT %d",
 | ||||||
| 				$thread_items = q("SELECT `item`.*, `item`.`id` AS `item_id`, `item`.`network` AS `item_network`,
 | 				$thread_items = q("SELECT `item`.*, `item`.`id` AS `item_id`, `item`.`network` AS `item_network`,
 | ||||||
| 					`contact`.`name`, `contact`.`photo`, `contact`.`url`, `contact`.`alias`, `contact`.`rel`, `contact`.`writable`, | 					`contact`.`name`, `contact`.`photo`, `contact`.`url`, `contact`.`alias`, `contact`.`rel`, `contact`.`writable`, | ||||||
| 					`contact`.`network`, `contact`.`thumb`, `contact`.`dfrn-id`, `contact`.`self`, | 					`contact`.`network`, `contact`.`thumb`, `contact`.`dfrn-id`, `contact`.`self`, | ||||||
| 					`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid` | 					`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid` | ||||||
| 					FROM $sql_table LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | 					FROM `item` INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | ||||||
|  | 					AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
| 					WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | 					WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | ||||||
| 					AND `item`.`moderated` = 0 | 					AND `item`.`moderated` = 0 | ||||||
| 					AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | 					AND `item`.`parent` = %d | ||||||
| 					AND `item`.`parent` IN ( %s ) | 					ORDER BY `item`.`commented` DESC LIMIT %d",
 | ||||||
| 					$sql_extra ORDER BY `item`.`commented` DESC LIMIT %d",
 |  | ||||||
| 					intval(local_user()), | 					intval(local_user()), | ||||||
| 					dbesc($parents_str), | 					intval($parents), | ||||||
| 					intval($max_comments + 1) | 					intval($max_comments + 1) | ||||||
| 				); | 				); | ||||||
| 				$items = array_merge($items, $thread_items); | 				$items = array_merge($items, $thread_items); | ||||||
| 			} | 			} | ||||||
| 			$items = conv_sort($items,$ordering); | 			$items = conv_sort($items,$ordering); | ||||||
| 
 |  | ||||||
| 		} else { | 		} else { | ||||||
| 			$items = array(); | 			$items = array(); | ||||||
| 		} | 		} | ||||||
|  | @ -882,6 +783,7 @@ function network_content(&$a, $update = 0) { | ||||||
| // Several people are complaining because there are unseen messages they can't find and as time goes
 | // Several people are complaining because there are unseen messages they can't find and as time goes
 | ||||||
| // on they just get buried deeper. It has happened to me a couple of times also.
 | // on they just get buried deeper. It has happened to me a couple of times also.
 | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| 	if((! $group) && (! $cid) && (! $star)) { | 	if((! $group) && (! $cid) && (! $star)) { | ||||||
| 		$r = q("UPDATE `item` SET `unseen` = 0
 | 		$r = q("UPDATE `item` SET `unseen` = 0
 | ||||||
| 			WHERE `unseen` = 1 AND `uid` = %d",
 | 			WHERE `unseen` = 1 AND `uid` = %d",
 | ||||||
|  |  | ||||||
|  | @ -6,6 +6,7 @@ require_once('include/bbcode.php'); | ||||||
| require_once('include/security.php'); | require_once('include/security.php'); | ||||||
| require_once('include/redir.php'); | require_once('include/redir.php'); | ||||||
| require_once('include/tags.php'); | require_once('include/tags.php'); | ||||||
|  | require_once('include/threads.php'); | ||||||
| 
 | 
 | ||||||
| function photos_init(&$a) { | function photos_init(&$a) { | ||||||
| 
 | 
 | ||||||
|  | @ -253,6 +254,7 @@ function photos_post(&$a) { | ||||||
| 						intval($page_owner_uid) | 						intval($page_owner_uid) | ||||||
| 					); | 					); | ||||||
| 					create_tags_from_itemuri($rr['parent-uri'], $page_owner_uid); | 					create_tags_from_itemuri($rr['parent-uri'], $page_owner_uid); | ||||||
|  | 					delete_thread_uri($rr['parent-uri'], $page_owner_uid); | ||||||
| 
 | 
 | ||||||
| 					$drop_id = intval($rr['id']); | 					$drop_id = intval($rr['id']); | ||||||
| 
 | 
 | ||||||
|  | @ -323,6 +325,7 @@ function photos_post(&$a) { | ||||||
| 					intval($page_owner_uid) | 					intval($page_owner_uid) | ||||||
| 				); | 				); | ||||||
| 				create_tags_from_itemuri($i[0]['uri'], $page_owner_uid); | 				create_tags_from_itemuri($i[0]['uri'], $page_owner_uid); | ||||||
|  | 				delete_thread_uri($i[0]['uri'], $page_owner_uid); | ||||||
| 
 | 
 | ||||||
| 				$url = $a->get_baseurl(); | 				$url = $a->get_baseurl(); | ||||||
| 				$drop_id = intval($i[0]['id']); | 				$drop_id = intval($i[0]['id']); | ||||||
|  | @ -371,7 +374,7 @@ function photos_post(&$a) { | ||||||
| 					$width  = $ph->getWidth(); | 					$width  = $ph->getWidth(); | ||||||
| 					$height = $ph->getHeight(); | 					$height = $ph->getHeight(); | ||||||
| 
 | 
 | ||||||
| 					$x = q("update photo set data = '%s', height = %d, width = %d where `resource-id` = '%s' and uid = %d and scale = 0 limit 1", | 					$x = q("update photo set data = '%s', height = %d, width = %d where `resource-id` = '%s' and uid = %d and scale = 0", | ||||||
| 						dbesc($ph->imageString()), | 						dbesc($ph->imageString()), | ||||||
| 						intval($height), | 						intval($height), | ||||||
| 						intval($width), | 						intval($width), | ||||||
|  | @ -384,7 +387,7 @@ function photos_post(&$a) { | ||||||
| 						$width  = $ph->getWidth(); | 						$width  = $ph->getWidth(); | ||||||
| 						$height = $ph->getHeight(); | 						$height = $ph->getHeight(); | ||||||
| 
 | 
 | ||||||
| 						$x = q("update photo set data = '%s', height = %d, width = %d where `resource-id` = '%s' and uid = %d and scale = 1 limit 1", | 						$x = q("update photo set data = '%s', height = %d, width = %d where `resource-id` = '%s' and uid = %d and scale = 1", | ||||||
| 							dbesc($ph->imageString()), | 							dbesc($ph->imageString()), | ||||||
| 							intval($height), | 							intval($height), | ||||||
| 							intval($width), | 							intval($width), | ||||||
|  | @ -398,7 +401,7 @@ function photos_post(&$a) { | ||||||
| 						$width  = $ph->getWidth(); | 						$width  = $ph->getWidth(); | ||||||
| 						$height = $ph->getHeight(); | 						$height = $ph->getHeight(); | ||||||
| 
 | 
 | ||||||
| 						$x = q("update photo set data = '%s', height = %d, width = %d where `resource-id` = '%s' and uid = %d and scale = 2 limit 1", | 						$x = q("update photo set data = '%s', height = %d, width = %d where `resource-id` = '%s' and uid = %d and scale = 2", | ||||||
| 							dbesc($ph->imageString()), | 							dbesc($ph->imageString()), | ||||||
| 							intval($height), | 							intval($height), | ||||||
| 							intval($width), | 							intval($width), | ||||||
|  | @ -599,7 +602,7 @@ function photos_post(&$a) { | ||||||
| 				$newinform .= ','; | 				$newinform .= ','; | ||||||
| 			$newinform .= $inform; | 			$newinform .= $inform; | ||||||
| 
 | 
 | ||||||
| 			$r = q("UPDATE `item` SET `tag` = '%s', `inform` = '%s', `edited` = '%s', `changed` = '%s' WHERE `id` = %d AND `uid` = %d LIMIT 1", | 			$r = q("UPDATE `item` SET `tag` = '%s', `inform` = '%s', `edited` = '%s', `changed` = '%s' WHERE `id` = %d AND `uid` = %d", | ||||||
| 				dbesc($newtag), | 				dbesc($newtag), | ||||||
| 				dbesc($newinform), | 				dbesc($newinform), | ||||||
| 				dbesc(datetime_convert()), | 				dbesc(datetime_convert()), | ||||||
|  | @ -608,6 +611,7 @@ function photos_post(&$a) { | ||||||
| 				intval($page_owner_uid) | 				intval($page_owner_uid) | ||||||
| 			); | 			); | ||||||
| 			create_tags_from_item($item_id); | 			create_tags_from_item($item_id); | ||||||
|  | 			update_thread($item_id); | ||||||
| 
 | 
 | ||||||
| 			$best = 0; | 			$best = 0; | ||||||
| 			foreach($p as $scales) { | 			foreach($p as $scales) { | ||||||
|  | @ -668,7 +672,7 @@ function photos_post(&$a) { | ||||||
| 
 | 
 | ||||||
| 					$item_id = item_store($arr); | 					$item_id = item_store($arr); | ||||||
| 					if($item_id) { | 					if($item_id) { | ||||||
| 						q("UPDATE `item` SET `plink` = '%s' WHERE `uid` = %d AND `id` = %d LIMIT 1", | 						q("UPDATE `item` SET `plink` = '%s' WHERE `uid` = %d AND `id` = %d", | ||||||
| 							dbesc($a->get_baseurl() . '/display/' . $owner_record['nickname'] . '/' . $item_id), | 							dbesc($a->get_baseurl() . '/display/' . $owner_record['nickname'] . '/' . $item_id), | ||||||
| 							intval($page_owner_uid), | 							intval($page_owner_uid), | ||||||
| 							intval($item_id) | 							intval($item_id) | ||||||
|  | @ -877,7 +881,7 @@ function photos_post(&$a) { | ||||||
| 	$item_id = item_store($arr); | 	$item_id = item_store($arr); | ||||||
| 
 | 
 | ||||||
| 	if($item_id) { | 	if($item_id) { | ||||||
| 		q("UPDATE `item` SET `plink` = '%s' WHERE `uid` = %d AND `id` = %d LIMIT 1", | 		q("UPDATE `item` SET `plink` = '%s' WHERE `uid` = %d AND `id` = %d", | ||||||
| 			dbesc($a->get_baseurl() . '/display/' . $owner_record['nickname'] . '/' . $item_id), | 			dbesc($a->get_baseurl() . '/display/' . $owner_record['nickname'] . '/' . $item_id), | ||||||
| 			intval($page_owner_uid), | 			intval($page_owner_uid), | ||||||
| 			intval($item_id) | 			intval($item_id) | ||||||
|  | @ -1431,6 +1435,7 @@ function photos_content(&$a) { | ||||||
| 					intval($link_item['parent']), | 					intval($link_item['parent']), | ||||||
| 					intval(local_user()) | 					intval(local_user()) | ||||||
| 				); | 				); | ||||||
|  | 				update_thread($link_item['parent']); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -219,11 +219,11 @@ function profile_content(&$a, $update = 0) { | ||||||
| 
 | 
 | ||||||
| 		$r = q("SELECT distinct(parent) AS `item_id`, `item`.`network` AS `item_network`,
 | 		$r = q("SELECT distinct(parent) AS `item_id`, `item`.`network` AS `item_network`,
 | ||||||
| 			`contact`.`uid` AS `contact-uid` | 			`contact`.`uid` AS `contact-uid` | ||||||
| 			FROM `item` LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | 			FROM `item` INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | ||||||
|  | 			AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
| 			WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND | 			WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND | ||||||
| 			(`item`.`deleted` = 0 OR item.verb = '" . ACTIVITY_LIKE ."' OR item.verb = '" . ACTIVITY_DISLIKE . "') | 			(`item`.`deleted` = 0 OR item.verb = '" . ACTIVITY_LIKE ."' OR item.verb = '" . ACTIVITY_DISLIKE . "') | ||||||
| 			and `item`.`moderated` = 0 and `item`.`unseen` = 1 | 			and `item`.`moderated` = 0 and `item`.`unseen` = 1 | ||||||
| 			AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 |  | ||||||
| 			AND `item`.`wall` = 1 | 			AND `item`.`wall` = 1 | ||||||
| 			$sql_extra | 			$sql_extra | ||||||
| 			ORDER BY `item`.`created` DESC",
 | 			ORDER BY `item`.`created` DESC",
 | ||||||
|  | @ -238,18 +238,20 @@ function profile_content(&$a, $update = 0) { | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		if($datequery) { | 		if($datequery) { | ||||||
| 			$sql_extra2 .= protect_sprintf(sprintf(" AND item.created <= '%s' ", dbesc(datetime_convert(date_default_timezone_get(),'',$datequery)))); | 			$sql_extra2 .= protect_sprintf(sprintf(" AND `thread`.`created` <= '%s' ", dbesc(datetime_convert(date_default_timezone_get(),'',$datequery)))); | ||||||
| 		} | 		} | ||||||
| 		if($datequery2) { | 		if($datequery2) { | ||||||
| 			$sql_extra2 .= protect_sprintf(sprintf(" AND item.created >= '%s' ", dbesc(datetime_convert(date_default_timezone_get(),'',$datequery2)))); | 			$sql_extra2 .= protect_sprintf(sprintf(" AND `thread`.`created` >= '%s' ", dbesc(datetime_convert(date_default_timezone_get(),'',$datequery2)))); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		if( (! get_config('alt_pager', 'global')) && (! get_pconfig($a->profile['profile_uid'],'system','alt_pager')) ) { | 		if( (! get_config('alt_pager', 'global')) && (! get_pconfig($a->profile['profile_uid'],'system','alt_pager')) ) { | ||||||
| 		    $r = q("SELECT COUNT(*) AS `total`
 | 		    $r = q("SELECT COUNT(*) AS `total`
 | ||||||
| 			    FROM `item` LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | 			    FROM `thread` INNER JOIN `item` ON `item`.`id` = `thread`.`iid` | ||||||
| 			    WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | 			    INNER JOIN `contact` ON `contact`.`id` = `thread`.`contact-id` | ||||||
| 			    and `item`.`moderated` = 0 AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0  | 			    AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
| 			    AND `item`.`id` = `item`.`parent` AND `item`.`wall` = 1 | 			    WHERE `thread`.`uid` = %d AND `thread`.`visible` = 1 AND `thread`.`deleted` = 0 | ||||||
|  | 			    and `thread`.`moderated` = 0 | ||||||
|  | 			    AND `thread`.`wall` = 1 | ||||||
| 			    $sql_extra $sql_extra2 ",
 | 			    $sql_extra $sql_extra2 ",
 | ||||||
| 			    intval($a->profile['profile_uid']) | 			    intval($a->profile['profile_uid']) | ||||||
| 		    ); | 		    ); | ||||||
|  | @ -277,16 +279,16 @@ function profile_content(&$a, $update = 0) { | ||||||
| 
 | 
 | ||||||
| 		$pager_sql = sprintf(" LIMIT %d, %d ",intval($a->pager['start']), intval($a->pager['itemspage'])); | 		$pager_sql = sprintf(" LIMIT %d, %d ",intval($a->pager['start']), intval($a->pager['itemspage'])); | ||||||
| 
 | 
 | ||||||
| 		// FROM `item` FORCE INDEX (created, uid) LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id`
 | 		$r = q("SELECT `thread`.`iid` AS `item_id`, `thread`.`network` AS `item_network`,
 | ||||||
| 
 | 			`thread`.`uid` AS `contact-uid` | ||||||
| 		$r = q("SELECT `item`.`id` AS `item_id`, `item`.`network` AS `item_network`,
 | 			FROM `thread` INNER JOIN `item` ON `item`.`id` = `thread`.`iid` | ||||||
| 			`contact`.`uid` AS `contact-uid` | 			INNER JOIN `contact` ON `contact`.`id` = `thread`.`contact-id` | ||||||
| 			FROM `item` LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | 			AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
| 			WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | 			WHERE `thread`.`uid` = %d AND `thread`.`visible` = 1 AND `thread`.`deleted` = 0 | ||||||
| 			and `item`.`moderated` = 0 AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | 			and `thread`.`moderated` = 0 | ||||||
| 			AND `item`.`id` = `item`.`parent` AND `item`.`wall` = 1 | 			AND `thread`.`wall` = 1 | ||||||
| 			$sql_extra $sql_extra2 | 			$sql_extra $sql_extra2 | ||||||
| 			ORDER BY `item`.`created` DESC $pager_sql ",
 | 			ORDER BY `thread`.`created` DESC $pager_sql ",
 | ||||||
| 			intval($a->profile['profile_uid']) | 			intval($a->profile['profile_uid']) | ||||||
| 
 | 
 | ||||||
| 		); | 		); | ||||||
|  | @ -308,7 +310,7 @@ function profile_content(&$a, $update = 0) { | ||||||
| 			FROM `item`, `contact` | 			FROM `item`, `contact` | ||||||
| 			WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | 			WHERE `item`.`uid` = %d AND `item`.`visible` = 1 AND `item`.`deleted` = 0 | ||||||
| 			and `item`.`moderated` = 0 | 			and `item`.`moderated` = 0 | ||||||
| 			AND `contact`.`id` = `item`.`contact-id` | 			AND `contact`.`id` = `item`.`contact-id` AND `contact`.`uid` = `item`.`uid` | ||||||
| 			AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | 			AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
| 			AND `item`.`parent` IN ( %s ) | 			AND `item`.`parent` IN ( %s ) | ||||||
| 			$sql_extra ",
 | 			$sql_extra ",
 | ||||||
|  |  | ||||||
|  | @ -29,7 +29,7 @@ function profiles_init(&$a) { | ||||||
| 			intval($a->argv[2]), | 			intval($a->argv[2]), | ||||||
| 			intval(local_user()) | 			intval(local_user()) | ||||||
| 		); | 		); | ||||||
| 		$r = q("DELETE FROM `profile` WHERE `id` = %d AND `uid` = %d LIMIT 1", | 		$r = q("DELETE FROM `profile` WHERE `id` = %d AND `uid` = %d", | ||||||
| 			intval($a->argv[2]), | 			intval($a->argv[2]), | ||||||
| 			intval(local_user()) | 			intval(local_user()) | ||||||
| 		); | 		); | ||||||
|  | @ -408,7 +408,7 @@ function profiles_post(&$a) { | ||||||
| 			`work` = '%s', | 			`work` = '%s', | ||||||
| 			`education` = '%s', | 			`education` = '%s', | ||||||
| 			`hide-friends` = %d | 			`hide-friends` = %d | ||||||
| 			WHERE `id` = %d AND `uid` = %d LIMIT 1",
 | 			WHERE `id` = %d AND `uid` = %d",
 | ||||||
| 			dbesc($profile_name), | 			dbesc($profile_name), | ||||||
| 			dbesc($name), | 			dbesc($name), | ||||||
| 			dbesc($pdesc), | 			dbesc($pdesc), | ||||||
|  | @ -451,11 +451,11 @@ function profiles_post(&$a) { | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 		if($namechanged && $is_default) { | 		if($namechanged && $is_default) { | ||||||
| 			$r = q("UPDATE `contact` SET `name-date` = '%s' WHERE `self` = 1 AND `uid` = %d LIMIT 1", | 			$r = q("UPDATE `contact` SET `name-date` = '%s' WHERE `self` = 1 AND `uid` = %d", | ||||||
| 				dbesc(datetime_convert()), | 				dbesc(datetime_convert()), | ||||||
| 				intval(local_user()) | 				intval(local_user()) | ||||||
| 			); | 			); | ||||||
| 			$r = q("UPDATE `user` set `username` = '%s' where `uid` = %d limit 1", | 			$r = q("UPDATE `user` set `username` = '%s' where `uid` = %d", | ||||||
| 				dbesc($name), | 				dbesc($name), | ||||||
| 				intval(local_user()) | 				intval(local_user()) | ||||||
| 			); | 			); | ||||||
|  | @ -554,7 +554,7 @@ function profile_activity($changed, $value) { | ||||||
| 	if($i) { | 	if($i) { | ||||||
| 
 | 
 | ||||||
| 		// give it a permanent link
 | 		// give it a permanent link
 | ||||||
| 		q("update item set plink = '%s' where id = %d limit 1", | 		q("update item set plink = '%s' where id = %d", | ||||||
| 			dbesc($a->get_baseurl() . '/display/' . $a->user['nickname'] . '/' . $i), | 			dbesc($a->get_baseurl() . '/display/' . $a->user['nickname'] . '/' . $i), | ||||||
| 			intval($i) | 			intval($i) | ||||||
| 		); | 		); | ||||||
|  |  | ||||||
|  | @ -85,7 +85,7 @@ function pubsub_init(&$a) { | ||||||
| 			logger('pubsub: unsubscribe success'); | 			logger('pubsub: unsubscribe success'); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		$r = q("UPDATE `contact` SET `subhub` = %d WHERE `id` = %d LIMIT 1", | 		$r = q("UPDATE `contact` SET `subhub` = %d WHERE `id` = %d", | ||||||
| 			intval($subscribe), | 			intval($subscribe), | ||||||
| 			intval($contact['id']) | 			intval($contact['id']) | ||||||
| 		); | 		); | ||||||
|  |  | ||||||
|  | @ -131,7 +131,7 @@ function search_content(&$a) { | ||||||
| 		//$sql_extra = sprintf(" AND `term`.`term` = '%s' AND `term`.`otype` = %d AND `term`.`type` = %d",
 | 		//$sql_extra = sprintf(" AND `term`.`term` = '%s' AND `term`.`otype` = %d AND `term`.`type` = %d",
 | ||||||
| 		//$sql_extra = sprintf(" AND `term`.`term` = '%s' AND `term`.`otype` = %d AND `term`.`type` = %d group by `item`.`uri` ",
 | 		//$sql_extra = sprintf(" AND `term`.`term` = '%s' AND `term`.`otype` = %d AND `term`.`type` = %d group by `item`.`uri` ",
 | ||||||
| 		//			dbesc(protect_sprintf($search)), intval(TERM_OBJ_POST), intval(TERM_HASHTAG));
 | 		//			dbesc(protect_sprintf($search)), intval(TERM_OBJ_POST), intval(TERM_HASHTAG));
 | ||||||
| 		//$sql_table = "`term` LEFT JOIN `item` ON `item`.`id` = `term`.`oid` AND `item`.`uid` = `term`.`uid` ";
 | 		//$sql_table = "`term` INNER JOIN `item` ON `item`.`id` = `term`.`oid` AND `item`.`uid` = `term`.`uid` ";
 | ||||||
| 		//$sql_order = "`term`.`tid`";
 | 		//$sql_order = "`term`.`tid`";
 | ||||||
| 		//$sql_order = "`item`.`received`";
 | 		//$sql_order = "`item`.`received`";
 | ||||||
| 
 | 
 | ||||||
|  | @ -162,11 +162,12 @@ function search_content(&$a) { | ||||||
| 
 | 
 | ||||||
| 	if( (! get_config('alt_pager', 'global')) && (! get_pconfig(local_user(),'system','alt_pager')) ) { | 	if( (! get_config('alt_pager', 'global')) && (! get_pconfig(local_user(),'system','alt_pager')) ) { | ||||||
| 	        $r = q("SELECT distinct(`item`.`uri`) as `total`
 | 	        $r = q("SELECT distinct(`item`.`uri`) as `total`
 | ||||||
| 		        FROM $sql_table LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` LEFT JOIN `user` ON `user`.`uid` = `item`.`uid` | 		        FROM $sql_table INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | ||||||
|  | 		        AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
|  | 			INNER JOIN `user` ON `user`.`uid` = `item`.`uid` | ||||||
| 		        WHERE `item`.`visible` = 1 AND `item`.`deleted` = 0 and `item`.`moderated` = 0 | 		        WHERE `item`.`visible` = 1 AND `item`.`deleted` = 0 and `item`.`moderated` = 0 | ||||||
| 		        AND (( `item`.`allow_cid` = ''  AND `item`.`allow_gid` = '' AND `item`.`deny_cid`  = '' AND `item`.`deny_gid`  = '' AND `item`.`private` = 0 AND `user`.`hidewall` = 0) | 		        AND (( `item`.`allow_cid` = ''  AND `item`.`allow_gid` = '' AND `item`.`deny_cid`  = '' AND `item`.`deny_gid`  = '' AND `item`.`private` = 0 AND `user`.`hidewall` = 0) | ||||||
| 			        OR ( `item`.`uid` = %d )) | 			        OR ( `item`.`uid` = %d )) | ||||||
| 		        AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 |  | ||||||
| 		        $sql_extra ",
 | 		        $sql_extra ",
 | ||||||
| 		        intval(local_user()) | 		        intval(local_user()) | ||||||
| 	        ); | 	        ); | ||||||
|  | @ -186,12 +187,12 @@ function search_content(&$a) { | ||||||
| 		`contact`.`network`, `contact`.`thumb`, `contact`.`self`, `contact`.`writable`,  | 		`contact`.`network`, `contact`.`thumb`, `contact`.`self`, `contact`.`writable`,  | ||||||
| 		`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid`, | 		`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid`, | ||||||
| 		`user`.`nickname`, `user`.`uid`, `user`.`hidewall` | 		`user`.`nickname`, `user`.`uid`, `user`.`hidewall` | ||||||
| 		FROM $sql_table LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | 		FROM $sql_table INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` | ||||||
| 		LEFT JOIN `user` ON `user`.`uid` = `item`.`uid` | 		AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 | ||||||
|  | 		INNER JOIN `user` ON `user`.`uid` = `item`.`uid` | ||||||
| 		WHERE `item`.`visible` = 1 AND `item`.`deleted` = 0 and `item`.`moderated` = 0 | 		WHERE `item`.`visible` = 1 AND `item`.`deleted` = 0 and `item`.`moderated` = 0 | ||||||
| 		AND (( `item`.`allow_cid` = ''  AND `item`.`allow_gid` = '' AND `item`.`deny_cid`  = '' AND `item`.`deny_gid`  = '' AND `item`.`private` = 0 AND `user`.`hidewall` = 0 )  | 		AND (( `item`.`allow_cid` = ''  AND `item`.`allow_gid` = '' AND `item`.`deny_cid`  = '' AND `item`.`deny_gid`  = '' AND `item`.`private` = 0 AND `user`.`hidewall` = 0 )  | ||||||
| 			OR ( `item`.`uid` = %d )) | 			OR ( `item`.`uid` = %d )) | ||||||
| 		AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 |  | ||||||
| 		$sql_extra | 		$sql_extra | ||||||
| 		ORDER BY $sql_order DESC LIMIT %d , %d ",
 | 		ORDER BY $sql_order DESC LIMIT %d , %d ",
 | ||||||
| 		intval(local_user()), | 		intval(local_user()), | ||||||
|  |  | ||||||
|  | @ -9,7 +9,7 @@ function share_init(&$a) { | ||||||
| 		killme(); | 		killme(); | ||||||
| 
 | 
 | ||||||
| 	$r = q("SELECT item.*, contact.network FROM `item` 
 | 	$r = q("SELECT item.*, contact.network FROM `item` 
 | ||||||
| 		left join contact on `item`.`contact-id` = `contact`.`id`  | 		inner join contact on `item`.`contact-id` = `contact`.`id`  | ||||||
| 		WHERE `item`.`id` = %d AND `item`.`uid` = %d LIMIT 1",
 | 		WHERE `item`.`id` = %d AND `item`.`uid` = %d LIMIT 1",
 | ||||||
| 
 | 
 | ||||||
| 		intval($post_id), | 		intval($post_id), | ||||||
|  |  | ||||||
|  | @ -9,7 +9,7 @@ function wall_upload_post(&$a) { | ||||||
| 	if($a->argc > 1) { | 	if($a->argc > 1) { | ||||||
| 	        if(! x($_FILES,'media')) { | 	        if(! x($_FILES,'media')) { | ||||||
| 		        $nick = $a->argv[1]; | 		        $nick = $a->argv[1]; | ||||||
| 		        $r = q("SELECT `user`.*, `contact`.`id` FROM `user` LEFT JOIN `contact` on `user`.`uid` = `contact`.`uid`  WHERE `user`.`nickname` = '%s' AND `user`.`blocked` = 0 and `contact`.`self` = 1 LIMIT 1", | 		        $r = q("SELECT `user`.*, `contact`.`id` FROM `user` INNER JOIN `contact` on `user`.`uid` = `contact`.`uid`  WHERE `user`.`nickname` = '%s' AND `user`.`blocked` = 0 and `contact`.`self` = 1 LIMIT 1", | ||||||
| 			        dbesc($nick) | 			        dbesc($nick) | ||||||
| 		        ); | 		        ); | ||||||
| 
 | 
 | ||||||
|  | @ -18,7 +18,7 @@ function wall_upload_post(&$a) { | ||||||
| 		} | 		} | ||||||
|                 else { |                 else { | ||||||
| 			$user_info = api_get_user($a); | 			$user_info = api_get_user($a); | ||||||
| 		        $r = q("SELECT `user`.*, `contact`.`id` FROM `user` LEFT JOIN `contact` on `user`.`uid` = `contact`.`uid`  WHERE `user`.`nickname` = '%s' AND `user`.`blocked` = 0 and `contact`.`self` = 1 LIMIT 1", | 		        $r = q("SELECT `user`.*, `contact`.`id` FROM `user` INNER JOIN `contact` on `user`.`uid` = `contact`.`uid`  WHERE `user`.`nickname` = '%s' AND `user`.`blocked` = 0 and `contact`.`self` = 1 LIMIT 1", | ||||||
| 			        dbesc($user_info['screen_name']) | 			        dbesc($user_info['screen_name']) | ||||||
| 		        ); | 		        ); | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
							
								
								
									
										47
									
								
								update.php
									
										
									
									
									
								
							
							
						
						
									
										47
									
								
								update.php
									
										
									
									
									
								
							|  | @ -1,6 +1,6 @@ | ||||||
| <?php | <?php | ||||||
| 
 | 
 | ||||||
| define( 'UPDATE_VERSION' , 1169 ); | define( 'UPDATE_VERSION' , 1170 ); | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * |  * | ||||||
|  | @ -1557,3 +1557,48 @@ function update_1168() { | ||||||
| 
 | 
 | ||||||
| 	return UPDATE_SUCCESS; | 	return UPDATE_SUCCESS; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | function update_1169() { | ||||||
|  | 	$r = q("CREATE TABLE IF NOT EXISTS `thread` (
 | ||||||
|  | 		  `iid` int(10) unsigned NOT NULL DEFAULT '0', | ||||||
|  | 		  `uid` int(10) unsigned NOT NULL DEFAULT '0', | ||||||
|  | 		  `contact-id` int(10) unsigned NOT NULL DEFAULT '0', | ||||||
|  | 		  `created` datetime NOT NULL DEFAULT '0000-00-00 00:00:00', | ||||||
|  | 		  `edited` datetime NOT NULL DEFAULT '0000-00-00 00:00:00', | ||||||
|  | 		  `commented` datetime NOT NULL DEFAULT '0000-00-00 00:00:00', | ||||||
|  | 		  `received` datetime NOT NULL DEFAULT '0000-00-00 00:00:00', | ||||||
|  | 		  `changed` datetime NOT NULL DEFAULT '0000-00-00 00:00:00', | ||||||
|  | 		  `wall` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  | 		  `private` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  | 		  `pubmail` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  | 		  `moderated` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  | 		  `visible` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  | 		  `spam` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  | 		  `starred` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  | 		  `bookmark` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  | 		  `unseen` tinyint(1) NOT NULL DEFAULT '1', | ||||||
|  | 		  `deleted` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  | 		  `origin` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  | 		  `forum_mode` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  | 		  `mention` tinyint(1) NOT NULL DEFAULT '0', | ||||||
|  | 		  `network` char(32) NOT NULL, | ||||||
|  | 		  PRIMARY KEY (`iid`), | ||||||
|  | 		  KEY `uid` (`uid`), | ||||||
|  | 		  KEY `contact-id` (`contact-id`), | ||||||
|  | 		  KEY `created` (`created`), | ||||||
|  | 		  KEY `edited` (`edited`), | ||||||
|  | 		  KEY `commented` (`commented`), | ||||||
|  | 		  KEY `received` (`received`), | ||||||
|  | 		  KEY `changed` (`changed`), | ||||||
|  | 		  KEY `network` (`network`) | ||||||
|  | 		  KEY `visible_deleted_moderated_private_wall_received` (`visible`,`deleted`,`moderated`,`private`,`wall`,`received`), | ||||||
|  | 		  KEY `uid_visible_deleted_moderated_created` (`uid`,`visible`,`deleted`,`moderated`,`created`), | ||||||
|  | 		  KEY `uid_visible_deleted_moderated_commented` (`uid`,`visible`,`deleted`,`moderated`,`commented`) | ||||||
|  | 		) ENGINE=MyISAM  DEFAULT CHARSET=utf8;");
 | ||||||
|  | 	if (!$r) | ||||||
|  | 		return UPDATE_FAILED; | ||||||
|  | 
 | ||||||
|  | 	proc_run('php',"include/threadupdate.php"); | ||||||
|  | 
 | ||||||
|  | 	return UPDATE_SUCCESS; | ||||||
|  | } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue