From 4961fb3a45b31f6428a34d66bb817bf7fb473866 Mon Sep 17 00:00:00 2001 From: Michael Vogel Date: Tue, 26 Jul 2016 22:10:13 +0200 Subject: [PATCH 1/7] Unused indexes removed, queries changed --- include/Contact.php | 57 +++++++++++++++++++++++------------------ include/dba.php | 2 ++ include/dbstructure.php | 15 ++++++----- include/onepoll.php | 5 ++-- mod/contacts.php | 11 +------- mod/follow.php | 4 +-- mod/item.php | 2 +- mod/network.php | 9 +++---- mod/nodeinfo.php | 20 ++++++++++++--- 9 files changed, 69 insertions(+), 56 deletions(-) diff --git a/include/Contact.php b/include/Contact.php index 9d69a81a4e..0bc7ca0a48 100644 --- a/include/Contact.php +++ b/include/Contact.php @@ -599,57 +599,64 @@ function posts_from_gcontact($a, $gcontact_id) { return $o; } - /** - * @brief Returns posts from a given contact + * @brief Returns posts from a given contact url * * @param App $a argv application class - * @param int $contact_id contact + * @param int $contact_url Contact URL * * @return string posts in HTML */ -function posts_from_contact($a, $contact_id) { +function posts_from_contact_url($a, $contact_url) { require_once('include/conversation.php'); - $r = q("SELECT `url` FROM `contact` WHERE `id` = %d", intval($contact_id)); - if (!$r) - return false; + // There are no posts with "uid = 0" with connector networks + // This speeds up the query a lot + $r = q("SELECT `network`, `id` AS `author-id` FROM `contact` + WHERE `contact`.`nurl` = '%s' AND `contact`.`uid` = 0", + dbesc(normalise_link($contact_url))); + if (in_array($r[0]["network"], array(NETWORK_DFRN, NETWORK_DIASPORA, NETWORK_OSTATUS, ""))) + $sql = "(`item`.`uid` = 0 OR (`item`.`uid` = %d AND `item`.`private`))"; + else + $sql = "`item`.`uid` = %d"; - $contact = $r[0]; + $author_id = intval($r[0]["author-id"]); - if(get_config('system', 'old_pager')) { + if (get_config('system', 'old_pager')) { $r = q("SELECT COUNT(*) AS `total` FROM `item` - WHERE `item`.`uid` = %d AND `author-link` IN ('%s', '%s')", - intval(local_user()), - dbesc(str_replace("https://", "http://", $contact["url"])), - dbesc(str_replace("http://", "https://", $contact["url"]))); + WHERE `author-id` = %d and $sql", + intval($author_id), + intval(local_user())); $a->set_pager_total($r[0]['total']); } - $r = q("SELECT `item`.`uri`, `item`.*, `item`.`id` AS `item_id`, +/* +"SELECT `item`.`uri`, `item`.*, `item`.`id` AS `item_id`, `author-name` AS `name`, `owner-avatar` AS `photo`, `owner-link` AS `url`, `owner-avatar` AS `thumb` - FROM `item` FORCE INDEX (`uid_contactid_id`) - WHERE `item`.`uid` = %d AND `contact-id` = %d - AND `author-link` IN ('%s', '%s') - AND NOT `deleted` AND NOT `moderated` AND `visible` - ORDER BY `item`.`id` DESC LIMIT %d, %d", + FROM `item` FORCE INDEX (`authorid_created`) + WHERE `item`.`author-id` = %d AND $sql + AND NOT `deleted` AND NOT `moderated` AND `visible` + +*/ + + $r = q(item_query()." AND `item`.`author-id` = %d AND ".$sql. + " ORDER BY `item`.`created` DESC LIMIT %d, %d", + intval($author_id), intval(local_user()), - intval($contact_id), - dbesc(str_replace("https://", "http://", $contact["url"])), - dbesc(str_replace("http://", "https://", $contact["url"])), intval($a->pager['start']), intval($a->pager['itemspage']) ); - $o .= conversation($a,$r,'community',false); + $o = conversation($a,$r,'community',false); - if(!get_config('system', 'old_pager')) + if(!get_config('system', 'old_pager')) { $o .= alt_pager($a,count($r)); - else + } else { $o .= paginate($a); + } return $o; } diff --git a/include/dba.php b/include/dba.php index 3484ac6683..a9bd571e72 100644 --- a/include/dba.php +++ b/include/dba.php @@ -65,6 +65,7 @@ class dba { $this->db = @new mysqli($server,$user,$pass,$db); if(! mysqli_connect_errno()) { $this->connected = true; + //mysqli_set_charset($this->db, 'utf8'); } } else { @@ -72,6 +73,7 @@ class dba { $this->db = mysql_connect($server,$user,$pass); if($this->db && mysql_select_db($db,$this->db)) { $this->connected = true; + //mysql_set_charset('utf8', $this->db); } } if(! $this->connected) { diff --git a/include/dbstructure.php b/include/dbstructure.php index bd35d0974a..5b1ffc3309 100644 --- a/include/dbstructure.php +++ b/include/dbstructure.php @@ -852,19 +852,19 @@ function db_definition() { "uid_created" => array("uid","created"), "uid_unseen_contactid" => array("uid","unseen","contact-id"), "uid_network_received" => array("uid","network","received"), - "uid_received" => array("uid","received"), - "uid_network_commented" => array("uid","network","commented"), - "uid_commented" => array("uid","commented"), + //"uid_received" => array("uid","received"), + //"uid_network_commented" => array("uid","network","commented"), + //"uid_commented" => array("uid","commented"), "uid_title" => array("uid","title"), "uid_thrparent" => array("uid","thr-parent"), "uid_parenturi" => array("uid","parent-uri"), "uid_contactid_id" => array("uid","contact-id","id"), - "uid_contactid_created" => array("uid","contact-id","created"), + //"uid_contactid_created" => array("uid","contact-id","created"), "gcontactid_uid_created" => array("gcontact-id","uid","created"), "authorid_created" => array("author-id","created"), "ownerid_created" => array("owner-id","created"), - "wall_body" => array("wall","body(6)"), - "uid_visible_moderated_created" => array("uid","visible","moderated","created"), + //"wall_body" => array("wall","body(6)"), + //"uid_visible_moderated_created" => array("uid","visible","moderated","created"), "uid_uri" => array("uid","uri"), "uid_wall_created" => array("uid","wall","created"), "resource-id" => array("resource-id"), @@ -873,7 +873,8 @@ function db_definition() { "contactid_allowcid_allowpid_denycid_denygid" => array("contact-id","allow_cid(10)","allow_gid(10)","deny_cid(10)","deny_gid(10)"), "uid_wall_parent_created" => array("uid","wall","parent","created"), "uid_type_changed" => array("uid","type","changed"), - "contactid_verb" => array("contact-id","verb"), + //"contactid_verb" => array("contact-id","verb"), + "contactid" => array("contact-id"), "deleted_changed" => array("deleted","changed"), "uid_wall_changed" => array("uid","wall","changed"), "uid_eventid" => array("uid","event-id"), diff --git a/include/onepoll.php b/include/onepoll.php index eb1045de14..12bae166dc 100644 --- a/include/onepoll.php +++ b/include/onepoll.php @@ -476,9 +476,10 @@ function onepoll_run(&$argv, &$argc){ // If it seems to be a reply but a header couldn't be found take the last message with matching subject if(!x($datarray,'parent-uri') and $reply) { - $r = q("SELECT `uri` , `parent-uri` FROM `item` WHERE `title` = \"%s\" AND `uid` = %d ORDER BY `created` DESC LIMIT 1", + $r = q("SELECT `uri` , `parent-uri` FROM `item` WHERE `title` = \"%s\" AND `uid` = %d AND `network` = '%s' ORDER BY `created` DESC LIMIT 1", dbesc(protect_sprintf($datarray['title'])), - intval($importer_uid)); + intval($importer_uid), + dbesc(NETWORK_MAIL)); if(count($r)) $datarray['parent-uri'] = $r[0]['parent-uri']; } diff --git a/mod/contacts.php b/mod/contacts.php index 4eb435fc75..044cc65107 100644 --- a/mod/contacts.php +++ b/mod/contacts.php @@ -887,16 +887,7 @@ function contact_posts($a, $contact_id) { $o .= $tab_str; - $r = q("SELECT `id` FROM `item` WHERE `contact-id` = %d LIMIT 1", intval($contact_id)); - if ($r) - $o .= posts_from_contact($a, $contact_id); - elseif ($contact["url"]) { - $r = q("SELECT `id` FROM `gcontact` WHERE `nurl` = '%s' LIMIT 1", - dbesc(normalise_link($contact["url"]))); - - if ($r[0]["id"] <> 0) - $o .= posts_from_gcontact($a, $r[0]["id"]); - } + $o .= posts_from_contact_url($a, $contact["url"]); return $o; } diff --git a/mod/follow.php b/mod/follow.php index b92a0d980f..1f56caea50 100644 --- a/mod/follow.php +++ b/mod/follow.php @@ -137,13 +137,13 @@ function follow_content(&$a) { $a->page['aside'] = ""; profile_load($a, "", 0, get_contact_details_by_url($ret["url"])); - // Show last public posts if ($gcontact_id <> 0) { $o .= replace_macros(get_markup_template('section_title.tpl'), array('$title' => t('Status Messages and Posts') )); - $o .= posts_from_gcontact($a, $gcontact_id); + // Show last public posts + $o .= posts_from_contact_url($a, $ret["url"]); } return $o; diff --git a/mod/item.php b/mod/item.php index 6f5f8fc1ea..963912800f 100644 --- a/mod/item.php +++ b/mod/item.php @@ -1032,7 +1032,7 @@ function item_post(&$a) { // Currently the only realistic fixes are to use a reliable server - which precludes shared hosting, // or cut back on plugins which do remote deliveries. - proc_run('php', "include/notifier.php", $notify_type, "$post_id"); + proc_run('php', "include/notifier.php", $notify_type, $post_id); logger('post_complete'); diff --git a/mod/network.php b/mod/network.php index 6ebedbcae8..f62799f768 100644 --- a/mod/network.php +++ b/mod/network.php @@ -577,8 +577,8 @@ function network_content(&$a, $update = 0) { $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_order = "`item`.`received`"; - $order_mode = "received"; + $sql_order = "`item`.`id`"; + $order_mode = "id"; } } if(strlen($file)) { @@ -596,8 +596,7 @@ function network_content(&$a, $update = 0) { // only setup pagination on initial page view $pager_sql = ''; - } - else { + } else { if(get_config('system', 'old_pager')) { $r = q("SELECT COUNT(*) AS `total` FROM $sql_table $sql_post_table INNER JOIN `contact` ON `contact`.`id` = $sql_table.`contact-id` @@ -636,7 +635,7 @@ function network_content(&$a, $update = 0) { $simple_update = (($update) ? " AND `item`.`unseen` " : ''); if ($sql_order == "") - $sql_order = "`item`.`received`"; + $sql_order = "`item`.`id`"; // "New Item View" - show all items unthreaded in reverse created date order $items = q("SELECT %s FROM $sql_table $sql_post_table %s diff --git a/mod/nodeinfo.php b/mod/nodeinfo.php index ba310a1051..b90e05174e 100644 --- a/mod/nodeinfo.php +++ b/mod/nodeinfo.php @@ -174,7 +174,7 @@ function nodeinfo_cron() { return; $last = get_config('nodeinfo','last_calucation'); - +/* if($last) { // Calculate every 24 hours $next = $last + (24 * 60 * 60); @@ -183,7 +183,7 @@ function nodeinfo_cron() { return; } } - logger("cron_start"); +*/ logger("cron_start"); $users = q("SELECT profile.*, `user`.`login_date`, `lastitem`.`lastitem_date` FROM (SELECT MAX(`item`.`changed`) as `lastitem_date`, `item`.`uid` @@ -224,12 +224,24 @@ function nodeinfo_cron() { set_config('nodeinfo','active_users_monthly', $active_users_monthly); } - //$posts = q("SELECT COUNT(*) AS local_posts FROM `item` WHERE `wall` AND `uid` != 0 AND `id` = `parent` AND left(body, 6) != '[share'"); +// $posts = q("SELECT COUNT(*) AS `local_posts` FROM `thread` +// INNER JOIN `contact` ON `contact`.`id` = `thread`.`contact-id` AND `contact`.`uid` = `thread`.`uid` +// WHERE `contact`.`self`"); + $posts = q("SELECT COUNT(*) AS local_posts FROM `thread` WHERE `thread`.`wall`"); +/* + $posts = q("SELECT COUNT(*) AS local_posts FROM `thread` + INNER JOIN `item` ON `item`.`id` = `thread`.`iid` + WHERE `thread`.`wall` AND NOT `thread`.`private` AND + `thread`.`uid` != 0 AND LEFT(`item`.`body`, 6) != '[share' AND + `thread`.`network` IN ('%s', '%s', '%s')", + dbesc(NETWORK_OSTATUS), dbesc(NETWORK_DIASPORA), dbesc(NETWORK_DFRN)); +*/ +/* $posts = q("SELECT COUNT(*) AS `local_posts` FROM `item` INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` WHERE `contact`.`self` and `item`.`id` = `item`.`parent` AND left(body, 6) != '[share' AND `item`.`network` IN ('%s', '%s', '%s')", dbesc(NETWORK_OSTATUS), dbesc(NETWORK_DIASPORA), dbesc(NETWORK_DFRN)); - +*/ if (!is_array($posts)) $local_posts = -1; else From b1999459afe1f955e7373f4b4894b44324b10e1e Mon Sep 17 00:00:00 2001 From: Michael Date: Wed, 16 Nov 2016 06:29:30 +0000 Subject: [PATCH 2/7] Removed commented code --- include/dba.php | 2 -- 1 file changed, 2 deletions(-) diff --git a/include/dba.php b/include/dba.php index 7ca520712a..082a54bd49 100644 --- a/include/dba.php +++ b/include/dba.php @@ -65,7 +65,6 @@ class dba { $this->db = @new mysqli($server,$user,$pass,$db); if (! mysqli_connect_errno()) { $this->connected = true; - //mysqli_set_charset($this->db, 'utf8'); } if (isset($a->config["system"]["db_charset"])) { $this->db->set_charset($a->config["system"]["db_charset"]); @@ -75,7 +74,6 @@ class dba { $this->db = mysql_connect($server,$user,$pass); if ($this->db && mysql_select_db($db,$this->db)) { $this->connected = true; - //mysql_set_charset('utf8', $this->db); } if (isset($a->config["system"]["db_charset"])) mysql_set_charset($a->config["system"]["db_charset"], $this->db); From 5572bd0cf97973ac45b79c7aad36c83cb83cf855 Mon Sep 17 00:00:00 2001 From: Michael Date: Sat, 10 Dec 2016 12:19:57 +0000 Subject: [PATCH 3/7] Redo the index changes for testing purposes --- include/dbstructure.php | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/include/dbstructure.php b/include/dbstructure.php index e501b4dc38..cf878bdb38 100644 --- a/include/dbstructure.php +++ b/include/dbstructure.php @@ -905,19 +905,19 @@ function db_definition($charset) { "uid_created" => array("uid","created"), "uid_unseen_contactid" => array("uid","unseen","contact-id"), "uid_network_received" => array("uid","network","received"), - //"uid_received" => array("uid","received"), - //"uid_network_commented" => array("uid","network","commented"), - //"uid_commented" => array("uid","commented"), + "uid_received" => array("uid","received"), + "uid_network_commented" => array("uid","network","commented"), + "uid_commented" => array("uid","commented"), "uid_title" => array("uid","title"), "uid_thrparent" => array("uid","thr-parent"), "uid_parenturi" => array("uid","parent-uri"), "uid_contactid_id" => array("uid","contact-id","id"), - //"uid_contactid_created" => array("uid","contact-id","created"), + "uid_contactid_created" => array("uid","contact-id","created"), "gcontactid_uid_created" => array("gcontact-id","uid","created"), "authorid_created" => array("author-id","created"), "ownerid_created" => array("owner-id","created"), - //"wall_body" => array("wall","body(6)"), - //"uid_visible_moderated_created" => array("uid","visible","moderated","created"), + "wall_body" => array("wall","body(6)"), + "uid_visible_moderated_created" => array("uid","visible","moderated","created"), "uid_uri" => array("uid","uri"), "uid_wall_created" => array("uid","wall","created"), "resource-id" => array("resource-id"), @@ -926,8 +926,7 @@ function db_definition($charset) { "contactid_allowcid_allowpid_denycid_denygid" => array("contact-id","allow_cid(10)","allow_gid(10)","deny_cid(10)","deny_gid(10)"), "uid_wall_parent_created" => array("uid","wall","parent","created"), "uid_type_changed" => array("uid","type","changed"), - //"contactid_verb" => array("contact-id","verb"), - "contactid" => array("contact-id"), + "contactid_verb" => array("contact-id","verb"), "deleted_changed" => array("deleted","changed"), "uid_wall_changed" => array("uid","wall","changed"), "uid_eventid" => array("uid","event-id"), From 00c74a7d6da821e202c6058ce73c5495cbeb8ab7 Mon Sep 17 00:00:00 2001 From: Michael Date: Sat, 10 Dec 2016 12:21:16 +0000 Subject: [PATCH 4/7] Some more ... --- include/dbstructure.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/include/dbstructure.php b/include/dbstructure.php index cf878bdb38..94e8da4a44 100644 --- a/include/dbstructure.php +++ b/include/dbstructure.php @@ -918,7 +918,7 @@ function db_definition($charset) { "ownerid_created" => array("owner-id","created"), "wall_body" => array("wall","body(6)"), "uid_visible_moderated_created" => array("uid","visible","moderated","created"), - "uid_uri" => array("uid","uri"), + "uid_uri" => array("uid", "uri"), "uid_wall_created" => array("uid","wall","created"), "resource-id" => array("resource-id"), "uid_type" => array("uid","type"), From c666c98559d6e3a06eb220e870c5f9e08dfee394 Mon Sep 17 00:00:00 2001 From: Michael Date: Sat, 10 Dec 2016 12:28:49 +0000 Subject: [PATCH 5/7] Code bautification --- include/Contact.php | 19 +++++-------------- mod/nodeinfo.php | 13 ++++--------- 2 files changed, 9 insertions(+), 23 deletions(-) diff --git a/include/Contact.php b/include/Contact.php index e1fd296852..6b969de1fe 100644 --- a/include/Contact.php +++ b/include/Contact.php @@ -683,10 +683,11 @@ function posts_from_contact_url($a, $contact_url) { $r = q("SELECT `network`, `id` AS `author-id` FROM `contact` WHERE `contact`.`nurl` = '%s' AND `contact`.`uid` = 0", dbesc(normalise_link($contact_url))); - if (in_array($r[0]["network"], array(NETWORK_DFRN, NETWORK_DIASPORA, NETWORK_OSTATUS, ""))) - $sql = "(`item`.`uid` = 0 OR (`item`.`uid` = %d AND `item`.`private`))"; - else + if (in_array($r[0]["network"], array(NETWORK_DFRN, NETWORK_DIASPORA, NETWORK_OSTATUS, ""))) { + $sql = "(`item`.`uid` = 0 OR (`item`.`uid` = %d AND `item`.`private`))"; + } else { $sql = "`item`.`uid` = %d"; + } $author_id = intval($r[0]["author-id"]); @@ -699,16 +700,6 @@ function posts_from_contact_url($a, $contact_url) { $a->set_pager_total($r[0]['total']); } -/* -"SELECT `item`.`uri`, `item`.*, `item`.`id` AS `item_id`, - `author-name` AS `name`, `owner-avatar` AS `photo`, - `owner-link` AS `url`, `owner-avatar` AS `thumb` - FROM `item` FORCE INDEX (`authorid_created`) - WHERE `item`.`author-id` = %d AND $sql - AND NOT `deleted` AND NOT `moderated` AND `visible` - -*/ - $r = q(item_query()." AND `item`.`author-id` = %d AND ".$sql. " ORDER BY `item`.`created` DESC LIMIT %d, %d", intval($author_id), @@ -719,7 +710,7 @@ function posts_from_contact_url($a, $contact_url) { $o = conversation($a,$r,'community',false); - if(!get_config('system', 'old_pager')) { + if (!get_config('system', 'old_pager')) { $o .= alt_pager($a,count($r)); } else { $o .= paginate($a); diff --git a/mod/nodeinfo.php b/mod/nodeinfo.php index 334dcb055d..5c70603468 100644 --- a/mod/nodeinfo.php +++ b/mod/nodeinfo.php @@ -174,7 +174,7 @@ function nodeinfo_cron() { return; $last = get_config('nodeinfo','last_calucation'); -/* + if($last) { // Calculate every 24 hours $next = $last + (24 * 60 * 60); @@ -183,7 +183,7 @@ function nodeinfo_cron() { return; } } -*/ logger("cron_start"); + logger("cron_start"); $users = qu("SELECT `user`.`uid`, `user`.`login_date`, `contact`.`last-item` FROM `user` @@ -217,13 +217,8 @@ function nodeinfo_cron() { set_config('nodeinfo','active_users_monthly', $active_users_monthly); } - $posts = qu("SELECT COUNT(*) AS local_posts FROM `thread` WHERE `thread`.`wall`"); -/* - $posts = qu("SELECT COUNT(*) AS `local_posts` FROM `item` - INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` - WHERE `contact`.`self` and `item`.`id` = `item`.`parent` AND left(body, 6) != '[share' AND `item`.`network` IN ('%s', '%s', '%s')", - dbesc(NETWORK_OSTATUS), dbesc(NETWORK_DIASPORA), dbesc(NETWORK_DFRN)); -*/ + $posts = qu("SELECT COUNT(*) AS local_posts FROM `thread` WHERE `thread`.`wall` AND `thread`.`uid` != 0"); + if (!is_array($posts)) $local_posts = -1; else From 23a97465e5aebf4014de116c7f83956c9b50589a Mon Sep 17 00:00:00 2001 From: Michael Date: Sun, 11 Dec 2016 07:09:48 +0000 Subject: [PATCH 6/7] Avoid SQL errors --- mod/network.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/mod/network.php b/mod/network.php index 6a074d0832..cafaa11aec 100644 --- a/mod/network.php +++ b/mod/network.php @@ -442,8 +442,8 @@ function network_content(&$a, $update = 0) { // desired. $sql_post_table = ""; - $sql_options = (($star) ? " and starred = 1 " : ''); - $sql_options .= (($bmark) ? " and bookmark = 1 " : ''); + $sql_options = (($star) ? " AND `thread`.`starred` " : ''); + $sql_options .= (($bmark) ? " AND `thread`.`bookmark` " : ''); $sql_extra = $sql_options; $sql_extra2 = ""; $sql_extra3 = ""; From 5c0440244898ff38155bea4b6f2ea68cad3f8173 Mon Sep 17 00:00:00 2001 From: Michael Date: Sun, 11 Dec 2016 17:37:12 +0000 Subject: [PATCH 7/7] String is no integer --- include/Contact.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/include/Contact.php b/include/Contact.php index 6b969de1fe..8a33e3fe91 100644 --- a/include/Contact.php +++ b/include/Contact.php @@ -670,7 +670,7 @@ function posts_from_gcontact($a, $gcontact_id) { * @brief Returns posts from a given contact url * * @param App $a argv application class - * @param int $contact_url Contact URL + * @param string $contact_url Contact URL * * @return string posts in HTML */