New fields for the term table, improved query for the tag search. Changed the cache handling for rendered bbcode.
This commit is contained in:
		
					parent
					
						
							
								67d39770ed
							
						
					
				
			
			
				commit
				
					
						7c4a1a059d
					
				
			
		
					 11 changed files with 233 additions and 218 deletions
				
			
		
							
								
								
									
										2
									
								
								boot.php
									
										
									
									
									
								
							
							
						
						
									
										2
									
								
								boot.php
									
										
									
									
									
								
							|  | @ -18,7 +18,7 @@ define ( 'FRIENDICA_PLATFORM',     'Friendica'); | ||||||
| define ( 'FRIENDICA_CODENAME',     'Ginger'); | define ( 'FRIENDICA_CODENAME',     'Ginger'); | ||||||
| define ( 'FRIENDICA_VERSION',      '3.3.3' ); | define ( 'FRIENDICA_VERSION',      '3.3.3' ); | ||||||
| define ( 'DFRN_PROTOCOL_VERSION',  '2.23'    ); | define ( 'DFRN_PROTOCOL_VERSION',  '2.23'    ); | ||||||
| define ( 'DB_UPDATE_VERSION',      1180      ); | define ( 'DB_UPDATE_VERSION',      1181      ); | ||||||
| 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' ); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -776,6 +776,8 @@ function db_definition() { | ||||||
| 					"last-child" => array("type" => "tinyint(1) unsigned", "not null" => "1", "default" => "1"), | 					"last-child" => array("type" => "tinyint(1) unsigned", "not null" => "1", "default" => "1"), | ||||||
| 					"mention" => array("type" => "tinyint(1)", "not null" => "1", "default" => "0"), | 					"mention" => array("type" => "tinyint(1)", "not null" => "1", "default" => "0"), | ||||||
| 					"network" => array("type" => "varchar(32)", "not null" => "1", "default" => ""), | 					"network" => array("type" => "varchar(32)", "not null" => "1", "default" => ""), | ||||||
|  | 					"rendered-hash" => array("type" => "varchar(32)", "not null" => "1", "default" => ""), | ||||||
|  | 					"rendered-html" => array("type" => "mediumtext", "not null" => "1"), | ||||||
| 					), | 					), | ||||||
| 			"indexes" => array( | 			"indexes" => array( | ||||||
| 					"PRIMARY" => array("id"), | 					"PRIMARY" => array("id"), | ||||||
|  | @ -1188,6 +1190,9 @@ function db_definition() { | ||||||
| 					"type" => array("type" => "tinyint(3) unsigned", "not null" => "1", "default" => "0"), | 					"type" => array("type" => "tinyint(3) unsigned", "not null" => "1", "default" => "0"), | ||||||
| 					"term" => array("type" => "varchar(255)", "not null" => "1", "default" => ""), | 					"term" => array("type" => "varchar(255)", "not null" => "1", "default" => ""), | ||||||
| 					"url" => array("type" => "varchar(255)", "not null" => "1", "default" => ""), | 					"url" => array("type" => "varchar(255)", "not null" => "1", "default" => ""), | ||||||
|  | 					"guid" => array("type" => "varchar(255)", "not null" => "1", "default" => ""), | ||||||
|  | 					"created" => array("type" => "datetime", "not null" => "1", "default" => "0000-00-00 00:00:00"), | ||||||
|  | 					"received" => array("type" => "datetime", "not null" => "1", "default" => "0000-00-00 00:00:00"), | ||||||
| 					"aid" => array("type" => "int(10) unsigned", "not null" => "1", "default" => "0"), | 					"aid" => array("type" => "int(10) unsigned", "not null" => "1", "default" => "0"), | ||||||
| 					"uid" => array("type" => "int(10) unsigned", "not null" => "1", "default" => "0"), | 					"uid" => array("type" => "int(10) unsigned", "not null" => "1", "default" => "0"), | ||||||
| 					), | 					), | ||||||
|  | @ -1196,7 +1201,7 @@ function db_definition() { | ||||||
| 					"oid_otype_type_term" => array("oid","otype","type","term"), | 					"oid_otype_type_term" => array("oid","otype","type","term"), | ||||||
| 					"uid_term_tid" => array("uid","term","tid"), | 					"uid_term_tid" => array("uid","term","tid"), | ||||||
| 					"type_term" => array("type","term"), | 					"type_term" => array("type","term"), | ||||||
| 					"uid_otype_type_term_tid" => array("uid","otype","type","term","tid"), | 					"uid_otype_type_term_created" => array("uid","otype","type","term","created"), | ||||||
| 					"otype_type_term_tid" => array("otype","type","term","tid"), | 					"otype_type_term_tid" => array("otype","type","term","tid"), | ||||||
| 					) | 					) | ||||||
| 			); | 			); | ||||||
|  |  | ||||||
|  | @ -1346,6 +1346,9 @@ function item_store($arr,$force_parent = false, $notify = false, $dontcache = fa | ||||||
| 		return 0; | 		return 0; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	// Fill the cache field
 | ||||||
|  | 	put_item_in_cache($arr); | ||||||
|  | 
 | ||||||
| 	call_hooks('post_remote',$arr); | 	call_hooks('post_remote',$arr); | ||||||
| 
 | 
 | ||||||
| 	if(x($arr,'cancel')) { | 	if(x($arr,'cancel')) { | ||||||
|  | @ -1478,9 +1481,6 @@ function item_store($arr,$force_parent = false, $notify = false, $dontcache = fa | ||||||
| 	// in it.
 | 	// in it.
 | ||||||
| 	if (!$deleted AND !$dontcache) { | 	if (!$deleted AND !$dontcache) { | ||||||
| 
 | 
 | ||||||
| 		// Store the fresh generated item into the cache
 |  | ||||||
| 		put_item_in_cache($arr); |  | ||||||
| 
 |  | ||||||
| 		$r = q('SELECT * FROM `item` WHERE id = %d', intval($current_post)); | 		$r = q('SELECT * FROM `item` WHERE id = %d', intval($current_post)); | ||||||
| 		if (count($r) == 1) { | 		if (count($r) == 1) { | ||||||
| 			call_hooks('post_remote_end', $r[0]); | 			call_hooks('post_remote_end', $r[0]); | ||||||
|  |  | ||||||
|  | @ -870,13 +870,6 @@ function scale_external_images($srctext, $include_link = true, $scale_replace = | ||||||
| 			if(! $i) | 			if(! $i) | ||||||
| 				return $srctext; | 				return $srctext; | ||||||
| 
 | 
 | ||||||
| 			$cachefile = get_cachefile(hash("md5", $scaled)); |  | ||||||
| 			if ($cachefile != '') { |  | ||||||
| 				$stamp1 = microtime(true); |  | ||||||
| 				file_put_contents($cachefile, $i); |  | ||||||
| 				$a->save_timestamp($stamp1, "file"); |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			// guess mimetype from headers or filename
 | 			// guess mimetype from headers or filename
 | ||||||
| 			$type = guess_image_type($mtch[1],true); | 			$type = guess_image_type($mtch[1],true); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -52,7 +52,7 @@ function complete_conversation($itemid, $conversation_url, $only_add_conversatio | ||||||
| 
 | 
 | ||||||
| 	$a->last_ostatus_conversation_url = $conversation_url; | 	$a->last_ostatus_conversation_url = $conversation_url; | ||||||
| 
 | 
 | ||||||
| 	$messages = q("SELECT `uid`, `parent`, `created` FROM `item` WHERE `id` = %d LIMIT 1", intval($itemid)); | 	$messages = q("SELECT `uid`, `parent`, `created`, `received`, `guid` FROM `item` WHERE `id` = %d LIMIT 1", intval($itemid)); | ||||||
| 	if (!$messages) | 	if (!$messages) | ||||||
| 		return; | 		return; | ||||||
| 	$message = $messages[0]; | 	$message = $messages[0]; | ||||||
|  | @ -62,8 +62,9 @@ function complete_conversation($itemid, $conversation_url, $only_add_conversatio | ||||||
| 		intval($message["uid"]), intval($itemid), intval(TERM_OBJ_POST), intval(TERM_CONVERSATION)); | 		intval($message["uid"]), intval($itemid), intval(TERM_OBJ_POST), intval(TERM_CONVERSATION)); | ||||||
| 
 | 
 | ||||||
| 	if (!$conversation) { | 	if (!$conversation) { | ||||||
| 		$r = q("INSERT INTO `term` (`uid`, `oid`, `otype`, `type`, `term`, `url`) VALUES (%d, %d, %d, %d, '%s', '%s')", | 		$r = q("INSERT INTO `term` (`uid`, `oid`, `otype`, `type`, `term`, `url`, `created`, `received`, `guid`) VALUES (%d, %d, %d, %d, '%s', '%s', '%s', '%s', '%s')", | ||||||
| 			intval($message["uid"]), intval($itemid), intval(TERM_OBJ_POST), intval(TERM_CONVERSATION), dbesc($message["created"]), dbesc($conversation_url)); | 			intval($message["uid"]), intval($itemid), intval(TERM_OBJ_POST), intval(TERM_CONVERSATION), | ||||||
|  | 			dbesc($message["created"]), dbesc($conversation_url), dbesc($message["created"]), dbesc($message["received"]), dbesc($message["guid"])); | ||||||
| 		logger('complete_conversation: Storing conversation url '.$conversation_url.' for id '.$itemid); | 		logger('complete_conversation: Storing conversation url '.$conversation_url.' for id '.$itemid); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -9,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`, `parent` FROM `item` WHERE `id` = %d LIMIT 1", intval($itemid)); | 	$messages = q("SELECT `guid`, `uid`, `id`, `edited`, `deleted`, `created`, `received`, `title`, `body`, `tag`, `parent` FROM `item` WHERE `id` = %d LIMIT 1", intval($itemid)); | ||||||
| 
 | 
 | ||||||
| 	if (!$messages) | 	if (!$messages) | ||||||
| 		return; | 		return; | ||||||
|  | @ -69,8 +69,10 @@ function create_tags_from_item($itemid) { | ||||||
| 			$term = $tag; | 			$term = $tag; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		$r = q("INSERT INTO `term` (`uid`, `oid`, `otype`, `type`, `term`, `url`) VALUES (%d, %d, %d, %d, '%s', '%s')", | 		$r = q("INSERT INTO `term` (`uid`, `oid`, `otype`, `type`, `term`, `url`, `guid`, `created`, `received`)
 | ||||||
| 			intval($message["uid"]), intval($itemid), intval(TERM_OBJ_POST), intval($type), dbesc($term), dbesc($link)); | 				VALUES (%d, %d, %d, %d, '%s', '%s', '%s', '%s', '%s')",
 | ||||||
|  | 			intval($message["uid"]), intval($itemid), intval(TERM_OBJ_POST), intval($type), | ||||||
|  | 			dbesc($term), dbesc($link), dbesc($message["guid"]), dbesc($message["created"]), dbesc($message["received"])); | ||||||
| 
 | 
 | ||||||
| 		// Search for mentions
 | 		// Search for mentions
 | ||||||
| 		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))) { | ||||||
|  | @ -96,10 +98,17 @@ function create_tags_from_itemuri($itemuri, $uid) { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| function update_items() { | function update_items() { | ||||||
| 	//$messages = q("SELECT `id` FROM `item` where tag !='' ORDER BY `created` DESC limit 10");
 | 	global $db; | ||||||
| 	$messages = q("SELECT `id` FROM `item` where tag !=''"); |  | ||||||
| 
 | 
 | ||||||
| 	foreach ($messages as $message) |         $messages = $db->q("SELECT `oid`,`item`.`guid`, `item`.`created`, `item`.`received` FROM `term` INNER JOIN `item` ON `item`.`id`=`term`.`oid` WHERE `term`.`otype` = 1 AND `term`.`guid` = ''", true); | ||||||
| 		create_tags_from_item($message["id"]); | 
 | ||||||
|  |         logger("fetched messages: ".count($messages)); | ||||||
|  |         while ($message = $db->qfetch()) { | ||||||
|  | 		q("UPDATE `term` SET `guid` = '%s', `created` = '%s', `received` = '%s' WHERE `otype` = %d AND `oid` = %d", | ||||||
|  | 			dbesc($message["guid"]), dbesc($message["created"]), dbesc($message["received"]), | ||||||
|  | 			intval(TERM_OBJ_POST), intval($message["oid"])); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  |         $db->qclose(); | ||||||
| } | } | ||||||
| ?>
 | ?>
 | ||||||
|  |  | ||||||
							
								
								
									
										22
									
								
								include/tagupdate.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								include/tagupdate.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,22 @@ | ||||||
|  | <?php | ||||||
|  | require_once("boot.php"); | ||||||
|  | require_once("include/tags.php"); | ||||||
|  | 
 | ||||||
|  | global $a, $db; | ||||||
|  | 
 | ||||||
|  | if(is_null($a)) | ||||||
|  | 	$a = new App; | ||||||
|  | 
 | ||||||
|  | if(is_null($db)) { | ||||||
|  | 	@include(".htconfig.php"); | ||||||
|  | 	require_once("include/dba.php"); | ||||||
|  | 	$db = new dba($db_host, $db_user, $db_pass, $db_data); | ||||||
|  | 	unset($db_host, $db_user, $db_pass, $db_data); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | load_config('config'); | ||||||
|  | load_config('system'); | ||||||
|  | 
 | ||||||
|  | update_items(); | ||||||
|  | killme(); | ||||||
|  | ?>
 | ||||||
|  | @ -1296,16 +1296,26 @@ function redir_private_images($a, &$item) { | ||||||
| 
 | 
 | ||||||
| }} | }} | ||||||
| 
 | 
 | ||||||
| function put_item_in_cache($item) { | function put_item_in_cache(&$item, $update = false) { | ||||||
| 	$cachefile = get_cachefile(urlencode($item["guid"])."-".hash("md5", $item['body'])); | 
 | ||||||
|  | 	if (($item["rendered-hash"] != hash("md5", $item["body"])) OR ($item["rendered-hash"] == "") OR | ||||||
|  | 		($item["rendered-html"] == "") OR get_config("system", "ignore_cache")) { | ||||||
|  | 
 | ||||||
|  | 		// The function "redir_private_images" changes the body.
 | ||||||
|  | 		// I'm not sure if we should store it permanently, so we save the old value.
 | ||||||
|  | 		$body = $item["body"]; | ||||||
| 
 | 
 | ||||||
| 	if (($cachefile != '') AND !file_exists($cachefile)) { |  | ||||||
| 		$s = prepare_text($item['body']); |  | ||||||
| 		$a = get_app(); | 		$a = get_app(); | ||||||
| 		$stamp1 = microtime(true); | 		redir_private_images($a, $item); | ||||||
| 		file_put_contents($cachefile, $s); | 
 | ||||||
| 		$a->save_timestamp($stamp1, "file"); | 		$item["rendered-html"] = prepare_text($item["body"]); | ||||||
| 		logger('put item '.$item["guid"].' into cachefile '.$cachefile); | 		$item["rendered-hash"] = hash("md5", $item["body"]); | ||||||
|  | 		$item["body"] = $body; | ||||||
|  | 
 | ||||||
|  | 		if ($update AND ($item["id"] != 0)) { | ||||||
|  | 			q("UPDATE `item` SET `rendered-html` = '%s', `rendered-hash` = '%s' WHERE `id` = %d", | ||||||
|  | 				dbesc($item["rendered-html"]), dbesc($item["rendered-hash"]), intval($item["id"])); | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -1359,28 +1369,8 @@ function prepare_body(&$item,$attach = false, $preview = false) { | ||||||
| 	$item['hashtags'] = $hashtags; | 	$item['hashtags'] = $hashtags; | ||||||
| 	$item['mentions'] = $mentions; | 	$item['mentions'] = $mentions; | ||||||
| 
 | 
 | ||||||
| 
 | 	put_item_in_cache($item, true); | ||||||
| 	$cachefile = get_cachefile(urlencode($item["guid"])."-".hash("md5", $item['body'])); | 	$s = $item["rendered-html"]; | ||||||
| 
 |  | ||||||
| 	if (($cachefile != '')) { |  | ||||||
| 		if (file_exists($cachefile)) { |  | ||||||
| 			$stamp1 = microtime(true); |  | ||||||
| 			$s = file_get_contents($cachefile); |  | ||||||
| 			$a->save_timestamp($stamp1, "file"); |  | ||||||
| 		} else { |  | ||||||
| 			redir_private_images($a, $item); |  | ||||||
| 			$s = prepare_text($item['body']); |  | ||||||
| 
 |  | ||||||
| 			$stamp1 = microtime(true); |  | ||||||
| 			file_put_contents($cachefile, $s); |  | ||||||
| 			$a->save_timestamp($stamp1, "file"); |  | ||||||
| 
 |  | ||||||
| 			logger('prepare_body: put item '.$item["id"].' into cachefile '.$cachefile); |  | ||||||
| 		} |  | ||||||
| 	} else { |  | ||||||
| 		redir_private_images($a, $item); |  | ||||||
| 		$s = prepare_text($item['body']); |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	require_once("mod/proxy.php"); | 	require_once("mod/proxy.php"); | ||||||
| 	$s = proxy_parse_html($s); | 	$s = proxy_parse_html($s); | ||||||
|  |  | ||||||
							
								
								
									
										228
									
								
								mod/item.php
									
										
									
									
									
								
							
							
						
						
									
										228
									
								
								mod/item.php
									
										
									
									
									
								
							|  | @ -746,14 +746,18 @@ function item_post(&$a) { | ||||||
| 		killme(); | 		killme(); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	// Fill the cache field
 | ||||||
|  | 	put_item_in_cache($datarray); | ||||||
| 
 | 
 | ||||||
| 	if($orig_post) { | 	if($orig_post) { | ||||||
| 		$r = q("UPDATE `item` SET `title` = '%s', `body` = '%s', `tag` = '%s', `attach` = '%s', `file` = '%s', `edited` = '%s', `changed` = '%s' WHERE `id` = %d AND `uid` = %d", | 		$r = q("UPDATE `item` SET `title` = '%s', `body` = '%s', `tag` = '%s', `attach` = '%s', `file` = '%s', `rendered-html` = '%s', `rendered-hash` = '%s', `edited` = '%s', `changed` = '%s' WHERE `id` = %d AND `uid` = %d", | ||||||
| 			dbesc($datarray['title']), | 			dbesc($datarray['title']), | ||||||
| 			dbesc($datarray['body']), | 			dbesc($datarray['body']), | ||||||
| 			dbesc($datarray['tag']), | 			dbesc($datarray['tag']), | ||||||
| 			dbesc($datarray['attach']), | 			dbesc($datarray['attach']), | ||||||
| 			dbesc($datarray['file']), | 			dbesc($datarray['file']), | ||||||
|  | 			dbesc($datarray['rendered-html']), | ||||||
|  | 			dbesc($datarray['rendered-hash']), | ||||||
| 			dbesc(datetime_convert()), | 			dbesc(datetime_convert()), | ||||||
| 			dbesc(datetime_convert()), | 			dbesc(datetime_convert()), | ||||||
| 			intval($post_id), | 			intval($post_id), | ||||||
|  | @ -778,10 +782,10 @@ function item_post(&$a) { | ||||||
| 		$post_id = 0; | 		$post_id = 0; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 	$r = q("INSERT INTO `item` (`guid`, `extid`, `uid`,`type`,`wall`,`gravity`, `network`, `contact-id`,`owner-name`,`owner-link`,`owner-avatar`, 
 | 	$r = q("INSERT INTO `item` (`guid`, `extid`, `uid`,`type`,`wall`,`gravity`, `network`, `contact-id`,`owner-name`,`owner-link`,`owner-avatar`, `author-name`, `author-link`, `author-avatar`,
 | ||||||
| 		`author-name`, `author-link`, `author-avatar`, `created`, `edited`, `commented`, `received`, `changed`, `uri`, `thr-parent`, `title`, `body`, `app`, `location`, `coord`,  | 		`created`, `edited`, `commented`, `received`, `changed`, `uri`, `thr-parent`, `title`, `body`, `app`, `location`, `coord`, `tag`, `inform`, `verb`, `object-type`, `postopts`, | ||||||
| 		`tag`, `inform`, `verb`, `object-type`, `postopts`, `allow_cid`, `allow_gid`, `deny_cid`, `deny_gid`, `private`, `pubmail`, `attach`, `bookmark`,`origin`, `moderated`, `file` ) | 		`allow_cid`, `allow_gid`, `deny_cid`, `deny_gid`, `private`, `pubmail`, `attach`, `bookmark`,`origin`, `moderated`, `file`, `rendered-html`, `rendered-hash`) | ||||||
| 		VALUES( '%s', '%s', %d, '%s', %d, %d, '%s', %d, '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', %d, %d, '%s', %d, %d, %d, '%s' )",
 | 		VALUES( '%s', '%s', %d, '%s', %d, %d, '%s', %d, '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', %d, %d, '%s', %d, %d, %d, '%s', '%s', '%s')",
 | ||||||
| 		dbesc($datarray['guid']), | 		dbesc($datarray['guid']), | ||||||
| 		dbesc($datarray['extid']), | 		dbesc($datarray['extid']), | ||||||
| 		intval($datarray['uid']), | 		intval($datarray['uid']), | ||||||
|  | @ -823,121 +827,122 @@ function item_post(&$a) { | ||||||
| 		intval($datarray['bookmark']), | 		intval($datarray['bookmark']), | ||||||
| 		intval($datarray['origin']), | 		intval($datarray['origin']), | ||||||
| 		intval($datarray['moderated']), | 		intval($datarray['moderated']), | ||||||
| 		dbesc($datarray['file']) | 		dbesc($datarray['file']), | ||||||
|  | 		dbesc($datarray['rendered-html']), | ||||||
|  | 		dbesc($datarray['rendered-hash']) | ||||||
| 	       ); | 	       ); | ||||||
| 
 | 
 | ||||||
| 	$r = q("SELECT `id` FROM `item` WHERE `uri` = '%s' LIMIT 1", | 	$r = q("SELECT `id` FROM `item` WHERE `uri` = '%s' LIMIT 1", | ||||||
| 		dbesc($datarray['uri'])); | 		dbesc($datarray['uri'])); | ||||||
| 	if(count($r)) { | 	if(!count($r)) { | ||||||
| 		$post_id = $r[0]['id']; |  | ||||||
| 		logger('mod_item: saved item ' . $post_id); |  | ||||||
| 
 |  | ||||||
| 		// update filetags in pconfig
 |  | ||||||
| 		file_tag_update_pconfig($uid,$categories_old,$categories_new,'category'); |  | ||||||
| 
 |  | ||||||
| 		// Store the fresh generated item into the cache
 |  | ||||||
| 		put_item_in_cache($datarray); |  | ||||||
| 
 |  | ||||||
| 		if($parent) { |  | ||||||
| 
 |  | ||||||
| 			// This item is the last leaf and gets the comment box, clear any ancestors
 |  | ||||||
| 			$r = q("UPDATE `item` SET `last-child` = 0, `changed` = '%s' WHERE `parent` = %d ", |  | ||||||
| 				dbesc(datetime_convert()), |  | ||||||
| 				intval($parent) |  | ||||||
| 			); |  | ||||||
| 			update_thread($parent, true); |  | ||||||
| 
 |  | ||||||
| 			// 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
 |  | ||||||
| 				WHERE `id` = %d",
 |  | ||||||
| 				dbesc($parent_item['allow_cid']), |  | ||||||
| 				dbesc($parent_item['allow_gid']), |  | ||||||
| 				dbesc($parent_item['deny_cid']), |  | ||||||
| 				dbesc($parent_item['deny_gid']), |  | ||||||
| 				intval($parent_item['private']), |  | ||||||
| 				intval($post_id) |  | ||||||
| 			); |  | ||||||
| 
 |  | ||||||
| 			if($contact_record != $author) { |  | ||||||
| 				notification(array( |  | ||||||
| 					'type'         => NOTIFY_COMMENT, |  | ||||||
| 					'notify_flags' => $user['notify-flags'], |  | ||||||
| 					'language'     => $user['language'], |  | ||||||
| 					'to_name'      => $user['username'], |  | ||||||
| 					'to_email'     => $user['email'], |  | ||||||
| 					'uid'          => $user['uid'], |  | ||||||
| 					'item'         => $datarray, |  | ||||||
| 					'link'		=> $a->get_baseurl().'/display/'.urlencode($datarray['guid']), |  | ||||||
| 					'source_name'  => $datarray['author-name'], |  | ||||||
| 					'source_link'  => $datarray['author-link'], |  | ||||||
| 					'source_photo' => $datarray['author-avatar'], |  | ||||||
| 					'verb'         => ACTIVITY_POST, |  | ||||||
| 					'otype'        => 'item', |  | ||||||
| 					'parent'       => $parent, |  | ||||||
| 					'parent_uri'   => $parent_item['uri'] |  | ||||||
| 				)); |  | ||||||
| 
 |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 			// 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); |  | ||||||
| 
 |  | ||||||
| 		} else { |  | ||||||
| 			$parent = $post_id; |  | ||||||
| 
 |  | ||||||
| 			if($contact_record != $author) { |  | ||||||
| 				notification(array( |  | ||||||
| 					'type'         => NOTIFY_WALL, |  | ||||||
| 					'notify_flags' => $user['notify-flags'], |  | ||||||
| 					'language'     => $user['language'], |  | ||||||
| 					'to_name'      => $user['username'], |  | ||||||
| 					'to_email'     => $user['email'], |  | ||||||
| 					'uid'          => $user['uid'], |  | ||||||
| 					'item'         => $datarray, |  | ||||||
| 					'link'		=> $a->get_baseurl().'/display/'.urlencode($datarray['guid']), |  | ||||||
| 					'source_name'  => $datarray['author-name'], |  | ||||||
| 					'source_link'  => $datarray['author-link'], |  | ||||||
| 					'source_photo' => $datarray['author-avatar'], |  | ||||||
| 					'verb'         => ACTIVITY_POST, |  | ||||||
| 					'otype'        => 'item' |  | ||||||
| 				)); |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		// fallback so that parent always gets set to non-zero.
 |  | ||||||
| 
 |  | ||||||
| 		if(! $parent) |  | ||||||
| 			$parent = $post_id; |  | ||||||
| 
 |  | ||||||
| 		$r = q("UPDATE `item` SET `parent` = %d, `parent-uri` = '%s', `plink` = '%s', `changed` = '%s', `last-child` = 1, `visible` = 1
 |  | ||||||
| 			WHERE `id` = %d",
 |  | ||||||
| 			intval($parent), |  | ||||||
| 			dbesc(($parent == $post_id) ? $uri : $parent_item['uri']), |  | ||||||
| 			dbesc($a->get_baseurl().'/display/'.urlencode($datarray['guid'])), |  | ||||||
| 			dbesc(datetime_convert()), |  | ||||||
| 			intval($post_id) |  | ||||||
| 		); |  | ||||||
| 
 |  | ||||||
| 		// 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.
 |  | ||||||
| 		// They will show up as people comment on them.
 |  | ||||||
| 
 |  | ||||||
| 		if(! $parent_item['visible']) { |  | ||||||
| 			$r = q("UPDATE `item` SET `visible` = 1 WHERE `id` = %d", |  | ||||||
| 				intval($parent_item['id']) |  | ||||||
| 			); |  | ||||||
| 			update_thread($parent_item['id']); |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 	else { |  | ||||||
| 		logger('mod_item: unable to retrieve post that was just stored.'); | 		logger('mod_item: unable to retrieve post that was just stored.'); | ||||||
| 		notice( t('System error. Post not saved.') . EOL); | 		notice( t('System error. Post not saved.') . EOL); | ||||||
| 		goaway($a->get_baseurl() . "/" . $return_path ); | 		goaway($a->get_baseurl() . "/" . $return_path ); | ||||||
| 		// NOTREACHED
 | 		// NOTREACHED
 | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	$post_id = $r[0]['id']; | ||||||
|  | 	logger('mod_item: saved item ' . $post_id); | ||||||
|  | 
 | ||||||
|  | 	$datarray["id"] = $post_id; | ||||||
|  | 	$datarray["plink"] = $a->get_baseurl().'/display/'.urlencode($datarray["guid"]); | ||||||
|  | 
 | ||||||
|  | 	// update filetags in pconfig
 | ||||||
|  | 	file_tag_update_pconfig($uid,$categories_old,$categories_new,'category'); | ||||||
|  | 
 | ||||||
|  | 	if($parent) { | ||||||
|  | 
 | ||||||
|  | 		// This item is the last leaf and gets the comment box, clear any ancestors
 | ||||||
|  | 		$r = q("UPDATE `item` SET `last-child` = 0, `changed` = '%s' WHERE `parent` = %d ", | ||||||
|  | 			dbesc(datetime_convert()), | ||||||
|  | 			intval($parent) | ||||||
|  | 		); | ||||||
|  | 		update_thread($parent, true); | ||||||
|  | 
 | ||||||
|  | 		// 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
 | ||||||
|  | 			WHERE `id` = %d",
 | ||||||
|  | 			dbesc($parent_item['allow_cid']), | ||||||
|  | 			dbesc($parent_item['allow_gid']), | ||||||
|  | 			dbesc($parent_item['deny_cid']), | ||||||
|  | 			dbesc($parent_item['deny_gid']), | ||||||
|  | 			intval($parent_item['private']), | ||||||
|  | 			intval($post_id) | ||||||
|  | 		); | ||||||
|  | 
 | ||||||
|  | 		if($contact_record != $author) { | ||||||
|  | 			notification(array( | ||||||
|  | 				'type'         => NOTIFY_COMMENT, | ||||||
|  | 				'notify_flags' => $user['notify-flags'], | ||||||
|  | 				'language'     => $user['language'], | ||||||
|  | 				'to_name'      => $user['username'], | ||||||
|  | 				'to_email'     => $user['email'], | ||||||
|  | 				'uid'          => $user['uid'], | ||||||
|  | 				'item'         => $datarray, | ||||||
|  | 				'link'		=> $a->get_baseurl().'/display/'.urlencode($datarray['guid']), | ||||||
|  | 				'source_name'  => $datarray['author-name'], | ||||||
|  | 				'source_link'  => $datarray['author-link'], | ||||||
|  | 				'source_photo' => $datarray['author-avatar'], | ||||||
|  | 				'verb'         => ACTIVITY_POST, | ||||||
|  | 				'otype'        => 'item', | ||||||
|  | 				'parent'       => $parent, | ||||||
|  | 				'parent_uri'   => $parent_item['uri'] | ||||||
|  | 			)); | ||||||
|  | 
 | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 		// 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); | ||||||
|  | 
 | ||||||
|  | 	} else { | ||||||
|  | 		$parent = $post_id; | ||||||
|  | 
 | ||||||
|  | 		if($contact_record != $author) { | ||||||
|  | 			notification(array( | ||||||
|  | 				'type'         => NOTIFY_WALL, | ||||||
|  | 				'notify_flags' => $user['notify-flags'], | ||||||
|  | 				'language'     => $user['language'], | ||||||
|  | 				'to_name'      => $user['username'], | ||||||
|  | 				'to_email'     => $user['email'], | ||||||
|  | 				'uid'          => $user['uid'], | ||||||
|  | 				'item'         => $datarray, | ||||||
|  | 				'link'		=> $a->get_baseurl().'/display/'.urlencode($datarray['guid']), | ||||||
|  | 				'source_name'  => $datarray['author-name'], | ||||||
|  | 				'source_link'  => $datarray['author-link'], | ||||||
|  | 				'source_photo' => $datarray['author-avatar'], | ||||||
|  | 				'verb'         => ACTIVITY_POST, | ||||||
|  | 				'otype'        => 'item' | ||||||
|  | 			)); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	// fallback so that parent always gets set to non-zero.
 | ||||||
|  | 
 | ||||||
|  | 	if(! $parent) | ||||||
|  | 		$parent = $post_id; | ||||||
|  | 
 | ||||||
|  | 	$r = q("UPDATE `item` SET `parent` = %d, `parent-uri` = '%s', `plink` = '%s', `changed` = '%s', `last-child` = 1, `visible` = 1
 | ||||||
|  | 		WHERE `id` = %d",
 | ||||||
|  | 		intval($parent), | ||||||
|  | 		dbesc(($parent == $post_id) ? $uri : $parent_item['uri']), | ||||||
|  | 		dbesc($a->get_baseurl().'/display/'.urlencode($datarray['guid'])), | ||||||
|  | 		dbesc(datetime_convert()), | ||||||
|  | 		intval($post_id) | ||||||
|  | 	); | ||||||
|  | 
 | ||||||
|  | 	// 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.
 | ||||||
|  | 	// They will show up as people comment on them.
 | ||||||
|  | 
 | ||||||
|  | 	if(! $parent_item['visible']) { | ||||||
|  | 		$r = q("UPDATE `item` SET `visible` = 1 WHERE `id` = %d", | ||||||
|  | 			intval($parent_item['id']) | ||||||
|  | 		); | ||||||
|  | 		update_thread($parent_item['id']); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	// update the commented timestamp on the parent
 | 	// update the commented timestamp on the parent
 | ||||||
| 
 | 
 | ||||||
| 	q("UPDATE `item` set `commented` = '%s', `changed` = '%s' WHERE `id` = %d", | 	q("UPDATE `item` set `commented` = '%s', `changed` = '%s' WHERE `id` = %d", | ||||||
|  | @ -948,9 +953,6 @@ function item_post(&$a) { | ||||||
| 	if ($post_id != $parent) | 	if ($post_id != $parent) | ||||||
| 		update_thread($parent); | 		update_thread($parent); | ||||||
| 
 | 
 | ||||||
| 	$datarray['id']    = $post_id; |  | ||||||
| 	$datarray['plink'] = $a->get_baseurl().'/display/'.urlencode($datarray['guid']); |  | ||||||
| 
 |  | ||||||
| 	call_hooks('post_local_end', $datarray); | 	call_hooks('post_local_end', $datarray); | ||||||
| 
 | 
 | ||||||
| 	if(strlen($emailcc) && $profile_uid == local_user()) { | 	if(strlen($emailcc) && $profile_uid == local_user()) { | ||||||
|  |  | ||||||
|  | @ -127,67 +127,49 @@ function search_content(&$a) { | ||||||
| 	if (get_config('system','only_tag_search')) | 	if (get_config('system','only_tag_search')) | ||||||
| 		$tag = true; | 		$tag = true; | ||||||
| 
 | 
 | ||||||
| 	if($tag) { |  | ||||||
| 		$sql_extra = ""; |  | ||||||
| 
 |  | ||||||
| 		$sql_table = sprintf("`item` INNER JOIN (SELECT `oid` FROM `term` WHERE `term` = '%s' AND `otype` = %d AND `type` = %d AND `uid` IN (%d, 0)) AS `term` ON `item`.`id` = `term`.`oid` ", |  | ||||||
| 					dbesc(protect_sprintf($search)), intval(TERM_OBJ_POST), intval(TERM_HASHTAG), intval(local_user())); |  | ||||||
| 
 |  | ||||||
| 		$sql_order = "`item`.`id`"; |  | ||||||
| 	} else { |  | ||||||
| 		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))); |  | ||||||
| 		} else { |  | ||||||
| 			$sql_extra = sprintf(" AND `item`.`body` REGEXP '%s' ", dbesc(protect_sprintf(preg_quote($search)))); |  | ||||||
| 		} |  | ||||||
| 		$sql_table = "`item`"; |  | ||||||
| 		$sql_order = "`item`.`id`"; |  | ||||||
| 		//$sql_order = "`item`.`received`";
 |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	// Here is the way permissions work in the search module...
 | 	// Here is the way permissions work in the search module...
 | ||||||
| 	// Only public posts can be shown
 | 	// Only public posts can be shown
 | ||||||
| 	// OR your own posts if you are a logged in member
 | 	// OR your own posts if you are a logged in member
 | ||||||
| 	// No items will be shown if the member has a blocked profile wall.
 | 	// No items will be shown if the member has a blocked profile wall.
 | ||||||
| 
 | 
 | ||||||
| 	if(get_config('system', 'old_pager')) { | 	if($tag) { | ||||||
| 	        $r = q("SELECT distinct(`item`.`uri`) as `total`
 | 		logger("Start tag search for '".$search."'"); | ||||||
| 		        FROM $sql_table INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` |  | ||||||
| 		        AND `contact`.`blocked` = 0 AND `contact`.`pending` = 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 `item`.`uid` = 0) |  | ||||||
| 			        OR (`item`.`uid` = %d)) |  | ||||||
| 		        $sql_extra ",
 |  | ||||||
| 		        intval(local_user()) |  | ||||||
| 	        ); |  | ||||||
| 
 | 
 | ||||||
| 	        if(count($r)) | 		$r = q("SELECT `item`.`uri`, `item`.*, `item`.`id` AS `item_id`,
 | ||||||
| 		        $a->set_pager_total(count($r)); | 				`contact`.`name`, `contact`.`photo`, `contact`.`url`, `contact`.`alias`, `contact`.`rel`, | ||||||
|  | 				`contact`.`network`, `contact`.`thumb`, `contact`.`self`, `contact`.`writable`, | ||||||
|  | 				`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid` | ||||||
|  | 			FROM `term` | ||||||
|  | 				INNER JOIN `item` ON `item`.`id`=`term`.`oid` | ||||||
|  | 				INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` AND NOT `contact`.`blocked` AND NOT `contact`.`pending` | ||||||
|  | 			WHERE `item`.`visible` AND NOT `item`.`deleted` AND NOT `item`.`moderated` | ||||||
|  | 				AND `term`.`uid` IN (%d,0) AND `term`.`otype` = %d AND `term`.`type` = %d AND `term`.`term` = '%s' AND `term`.`guid` != '' | ||||||
|  | 			GROUP BY `term`.`guid` ORDER BY term.created DESC LIMIT %d , %d ",
 | ||||||
|  | 				intval(local_user()), intval(TERM_OBJ_POST), intval(TERM_HASHTAG), dbesc(protect_sprintf($search)), | ||||||
|  | 				intval($a->pager['start']), intval($a->pager['itemspage'])); | ||||||
|  | 	} else { | ||||||
|  | 		logger("Start fulltext search for '".$search."'"); | ||||||
| 
 | 
 | ||||||
| 	        if(! count($r)) { | 		if (get_config('system','use_fulltext_engine')) { | ||||||
| 		        info( t('No results.') . EOL); | 			$sql_extra = sprintf(" AND MATCH (`item`.`body`, `item`.`title`) AGAINST ('%s' in boolean mode) ", dbesc(protect_sprintf($search))); | ||||||
| 		        return $o; | 		} else { | ||||||
| 	        } | 			$sql_extra = sprintf(" AND `item`.`body` REGEXP '%s' ", dbesc(protect_sprintf(preg_quote($search)))); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		$r = q("SELECT `item`.`uri`, `item`.*, `item`.`id` AS `item_id`,
 | ||||||
|  | 				`contact`.`name`, `contact`.`photo`, `contact`.`url`, `contact`.`alias`, `contact`.`rel`, | ||||||
|  | 				`contact`.`network`, `contact`.`thumb`, `contact`.`self`, `contact`.`writable`, | ||||||
|  | 				`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid` | ||||||
|  | 			FROM `item` | ||||||
|  | 				INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` AND NOT `contact`.`blocked` AND NOT `contact`.`pending` | ||||||
|  | 			WHERE `item`.`visible` AND NOT `item`.`deleted` AND NOT `item`.`moderated` | ||||||
|  | 				AND (`item`.`uid` = 0 OR (`item`.`uid` = %s AND (`item`.`private` OR NOT `item`.`network` IN ('%s', '%s', '%s')))) | ||||||
|  | 				$sql_extra | ||||||
|  | 			GROUP BY `item`.`uri` ORDER BY `item`.`id` DESC LIMIT %d , %d ",
 | ||||||
|  | 				intval(local_user()), dbesc(NETWORK_DFRN), dbesc(NETWORK_OSTATUS), dbesc(NETWORK_DIASPORA), | ||||||
|  | 				intval($a->pager['start']), intval($a->pager['itemspage'])); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	$r = q("SELECT `item`.`uri`, `item`.*, `item`.`id` AS `item_id`,
 |  | ||||||
| 		`contact`.`name`, `contact`.`photo`, `contact`.`url`, `contact`.`alias`, `contact`.`rel`, |  | ||||||
| 		`contact`.`network`, `contact`.`thumb`, `contact`.`self`, `contact`.`writable`, |  | ||||||
| 		`contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid` |  | ||||||
| 		FROM $sql_table INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` |  | ||||||
| 		AND `contact`.`blocked` = 0 AND `contact`.`pending` = 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 `item`.`uid`=0) |  | ||||||
| 			OR `item`.`uid` = %d) |  | ||||||
| 		$sql_extra |  | ||||||
| 		GROUP BY `item`.`uri` |  | ||||||
| 		ORDER BY $sql_order DESC LIMIT %d , %d ",
 |  | ||||||
| 		intval(local_user()), |  | ||||||
| 		intval($a->pager['start']), |  | ||||||
| 		intval($a->pager['itemspage']) |  | ||||||
| 
 |  | ||||||
| 	); |  | ||||||
| 
 |  | ||||||
| 	if(! count($r)) { | 	if(! count($r)) { | ||||||
| 		info( t('No results.') . EOL); | 		info( t('No results.') . EOL); | ||||||
| 		return $o; | 		return $o; | ||||||
|  | @ -199,13 +181,16 @@ function search_content(&$a) { | ||||||
| 	else | 	else | ||||||
| 		$o .= '<h2>Search results for: ' . $search . '</h2>'; | 		$o .= '<h2>Search results for: ' . $search . '</h2>'; | ||||||
| 
 | 
 | ||||||
|  | 	logger("Start Conversation"); | ||||||
| 	$o .= conversation($a,$r,'search',false); | 	$o .= conversation($a,$r,'search',false); | ||||||
| 
 | 
 | ||||||
|  | 	logger("Start Pager"); | ||||||
| 	if(!get_config('system', 'old_pager')) { | 	if(!get_config('system', 'old_pager')) { | ||||||
| 	        $o .= alt_pager($a,count($r)); | 	        $o .= alt_pager($a,count($r)); | ||||||
| 	} else { | 	} else { | ||||||
| 	        $o .= paginate($a); | 	        $o .= paginate($a); | ||||||
| 	} | 	} | ||||||
|  | 	logger("Done"); | ||||||
| 
 | 
 | ||||||
| 	return $o; | 	return $o; | ||||||
| } | } | ||||||
|  |  | ||||||
							
								
								
									
										10
									
								
								update.php
									
										
									
									
									
								
							
							
						
						
									
										10
									
								
								update.php
									
										
									
									
									
								
							|  | @ -1,6 +1,6 @@ | ||||||
| <?php | <?php | ||||||
| 
 | 
 | ||||||
| define( 'UPDATE_VERSION' , 1180 ); | define( 'UPDATE_VERSION' , 1181 ); | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * |  * | ||||||
|  | @ -1640,3 +1640,11 @@ function update_1178() { | ||||||
| 
 | 
 | ||||||
| 	return UPDATE_SUCCESS; | 	return UPDATE_SUCCESS; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | function update_1180() { | ||||||
|  | 
 | ||||||
|  | 	// Fill the new fields in the term table.
 | ||||||
|  | 	proc_run('php',"include/tagupdate.php"); | ||||||
|  | 
 | ||||||
|  | 	return UPDATE_SUCCESS; | ||||||
|  | } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue