grahambudd
Forum Replies Created
-
Forum: Plugins
In reply to: [SearchWP Live Ajax Search] Dequeue styles via code doesn’t workIt appears that a priority greater than 20 is needed to dequeue the styles. So this works:
function custom_search_dequeue_scripts() { wp_dequeue_style( 'searchwp-live-search' ); } add_action( 'wp_enqueue_scripts', 'custom_search_dequeue_scripts', 21 );
Forum: Plugins
In reply to: [SearchWP Live Ajax Search] 1.8.0 bug with Relevanssi PremiumThank you for that information. The filter does work so we can use that until the plugin is updated.
@subiewrx I can confirm that 4.1.10 addresses this issue on my system.
@subiewrx I can confirm that I see this same issue on both 4.1.9.3 and 4.1.9.4. In my case the issue is the
limit_modified_date
value is ending up blank in the database query. If I save a post with the “Don’t update the modified date” checked it saves the SEO data fine. If I have that unchecked it fails for all post types, including pages.This is the error from the error log. You can see limit_modified_date = ” in there. Which is causing the error.
[30-Mar-2022 17:15:35 UTC] WordPress database error Incorrect integer value: '' for column
site-2019.
fb_aioseo_posts.
limit_modified_date` at row 1 for query UPDATE fb_aioseo_posts
SETid
= ‘1854’,post_id
= 1288,title
= ‘Learn About Us | #site_title’,description
= ‘Trying once more a custom meta description.’,keywords
= ‘[]’,keyphrases
= ‘{\”focus\”:[],\”additional\”:[]}’,page_analysis
= ‘{\”analysis\”:{\”basic\”:{\”metadescriptionLength\”:{\”title\”:\”Meta description length\”,\”description\”:\”The meta description is too short.\”,\”score\”:6,\”maxScore\”:9,\”error\”:1},\”lengthContent\”:{\”title\”:\”Content length\”,\”description\”:\”This is far below the recommended minimum of words.\”,\”score\”:-20,\”maxScore\”:9,\”error\”:1},\”isInternalLink\”:{\”title\”:\”Internal links\”,\”description\”:\”We couldn\’t find any internal links in your content. Add internal links in your content.\”,\”score\”:3,\”maxScore\”:9,\”error\”:1},\”isExternalLink\”:{\”title\”:\”External links\”,\”description\”:\”No outbound links were found. Link out to external resources.\”,\”score\”:3,\”maxScore\”:9,\”error\”:1},\”errors\”:4},\”title\”:{\”titleLength\”:{\”title\”:\”SEO Title length\”,\”description\”:\”The title is too short.\”,\”score\”:6,\”maxScore\”:9,\”error\”:1},\”errors\”:1},\”readability\”:{\”contentHasAssets\”:{\”error\”:1,\”title\”:\”Images\\/videos in content\”,\”description\”:\”You are not using rich media like images or videos.\”,\”score\”:1,\”maxScore\”:5},\”paragraphLength\”:{\”title\”:\”Paragraphs length\”,\”description\”:\”You are using short paragraphs.\”,\”score\”:5,\”maxScore\”:5,\”error\”:0},\”sentenceLength\”:{\”title\”:\”Sentences length\”,\”description\”:\”Sentence length is looking great!\”,\”score\”:9,\”maxScore\”:9,\”error\”:0},\”passiveVoice\”:{\”title\”:\”Passive voice\”,\”description\”:\”You\’re using enough active voice. That\’s great!\”,\”score\”:9,\”maxScore\”:9,\”error\”:0},\”transitionWords\”:[],\”consecutiveSentences\”:{\”title\”:\”Consecutive sentences\”,\”description\”:\”There is enough variety in your sentences. That\’s great!\”,\”score\”:9,\”maxScore\”:9,\”error\”:0},\”subheadingsDistribution\”:{\”title\”:\”Subheading distribution\”,\”description\”:\”You are not using any subheadings, but your text is short enough and probably doesn\’t need them.\”,\”score\”:9,\”maxScore\”:9,\”error\”:0},\”calculateFleschReading\”:{\”title\”:\”Flesch reading ease\”,\”description\”:\”The copy scores 0 in the test, which is considered very difficult to read. Try to make shorter sentences, using less difficult words to improve readability.\”,\”score\”:3,\”maxScore\”:9,\”error\”:1},\”errors\”:2}}}’,canonical_url
= NULL,og_title
= NULL,og_description
= NULL,og_object_type
= ‘activity’,og_image_type
= ‘default’,og_image_url
= NULL,og_image_width
= NULL,og_image_height
= NULL,og_image_custom_url
= NULL,og_image_custom_fields
= NULL,og_video
= ”,og_custom_url
= NULL,og_article_section
= NULL,og_article_tags
= ‘[]’,twitter_use_og
= 0,twitter_card
= ‘summary’,twitter_image_type
= ‘default’,twitter_image_url
= NULL,twitter_image_custom_url
= NULL,twitter_image_custom_fields
= NULL,twitter_title
= NULL,twitter_description
= NULL,seo_score
= ’64’,schema_type
= ‘none’,schema_type_options
= ‘{\”article\”:{\”articleType\”:\”BlogPosting\”},\”course\”:{\”name\”:\”\”,\”description\”:\”\”,\”provider\”:\”\”},\”faq\”:{\”pages\”:[]},\”product\”:{\”reviews\”:[]},\”recipe\”:{\”ingredients\”:[],\”instructions\”:[],\”keywords\”:[]},\”software\”:{\”reviews\”:[],\”operatingSystems\”:[]},\”webPage\”:{\”webPageType\”:\”WebPage\”},\”book\”:[],\”event\”:[],\”jobPosting\”:[],\”music\”:[],\”person\”:[],\”restaurant\”:[],\”service\”:[],\”video\”:[]}’,pillar_content
= 0,robots_default
= 1,robots_noindex
= 0,robots_noarchive
= 0,robots_nosnippet
= 0,robots_nofollow
= 0,robots_noimageindex
= 0,robots_noodp
= 0,robots_notranslate
= 0,robots_max_snippet
= -1,robots_max_videopreview
= -1,robots_max_imagepreview
= ‘large’,tabs
= ‘{\”tab\”:\”general\”,\”tab_social\”:\”facebook\”,\”tab_sidebar\”:\”general\”,\”tab_modal\”:\”general\”,\”tab_modal_social\”:\”facebook\”}’,images
= NULL,image_scan_date
= ‘2021-01-14 17:17:58’,priority
= ‘default’,frequency
= ‘default’,videos
= NULL,video_thumbnail
= NULL,video_scan_date
= NULL,location
= NULL,local_seo
= NULL,limit_modified_date
= ”,updated
= ‘2022-03-30 17:15:35’
WHERE 1 = 1 AND
id
= ‘1854’
/* 1 = 1 */ made by AIOSEO\Plugin\Common\Utils\Database::run`@arnaudbroes certainly, I’ve reached out there and look forward to working through the items with you.
-Graham
@arnaudbroes , no there are no console errors. I do see some error log errors, which may be related. Nothing that specifically appears to be the write from this robots.txt save process, but things which may be triggered by other parts of the plugin and are preventing the save from happening later.
It is possible this bug is related to the other errors I’ve reported here with incorrect bool to empty string write errors.
When I hit save on the robots.txt admin page, I see these errors in the log:
[05-Jan-2021 13:40:31 UTC] PHP Notice: Undefined property: AIOSEO\Plugin\Common\Models\Notification::$id in /var/www/html/htdocs/wp-content/plugins/all-in-one-seo-pack/app/Common/Models/Model.php on line 362 [05-Jan-2021 13:40:32 UTC] WordPress database error Incorrect integer value: '' for column <code>site-2019</code>.<code>fb_aioseo_notifications</code>.<code>dismissed</code> at row 1 for query INSERT INTO fb_aioseo_notifications SET <code>slug</code> = '5ff46c508ae80', <code>title</code> = 'Physical Robots.txt File Detected', <code>content</code> = 'AIOSEO has detected a physical robots.txt file in the root folder of your WordPress installation. We recommend removing this file as it could cause conflicts with WordPress\' dynamically generated one. AIOSEO can import this file and delete it, or you can simply delete it.', <code>type</code> = 'error', <code>level</code> = '[\"all\"]', <code>notification_id</code> = NULL, <code>notification_name</code> = 'robots-physical-file', <code>start</code> = '2021-01-05 13:40:32', <code>end</code> = NULL, <code>button1_label</code> = 'Import and Delete', <code>button1_action</code> = 'https://action#tools/import-robots-txt?redirect=aioseo-tools', <code>button2_label</code> = 'Delete', <code>button2_action</code> = 'https://action#tools/delete-robots-txt?redirect=aioseo-tools', <code>dismissed</code> = '', <code>created</code> = '2021-01-05 13:40:32', <code>updated</code> = '2021-01-05 13:40:32' /* 1 = 1 */ made by AIOSEO\Plugin\Common\Utils\Database::run [05-Jan-2021 13:40:32 UTC] PHP Notice: Undefined property: AIOSEO\Plugin\Common\Models\Notification::$id in /var/www/html/htdocs/wp-content/plugins/all-in-one-seo-pack/app/Common/Models/Model.php on line 362
This issue also impacts other saves of content. For example trying to save a custom description on a page yields a similar error and no data are saved:
WordPress database error Incorrect integer value: ” for column
site-2019
.fb_aioseo_posts
.twitter_use_og
at row 1 for query UPDATE fb_aioseo_posts
SETid
= ‘1854’,post_id
= 1288,title
= NULL,description
= ‘Testing to see if custom meta descriptions save or not.’,keywords
= ‘[]’,keyphrases
= ‘{\”focus\”:[],\”additional\”:[]}’,page_analysis
= ‘{\”analysis\”:{\”basic\”:{\”lengthContent\”:{\”title\”:\”Content Length\”,\”description\”:\”This is far below the recommended minimum of words.\”,\”score\”:-20,\”maxScore\”:9,\”error\”:1},\”isInternalLink\”:{\”title\”:\”Internal links\”,\”description\”:\”We couldn\’t find any internal links in your content. Add internal links in your content.\”,\”score\”:3,\”maxScore\”:9,\”error\”:1},\”isExternalLink\”:{\”title\”:\”External links\”,\”description\”:\”No outbound links were found. Link out to external resources.\”,\”score\”:3,\”maxScore\”:9,\”error\”:1},\”errors\”:3},\”title\”:{\”titleLength\”:{\”title\”:\”SEO Title length\”,\”description\”:\”The title is too short.\”,\”score\”:6,\”maxScore\”:9,\”error\”:1},\”errors\”:1},\”readability\”:{\”contentHasAssets\”:{\”error\”:1,\”title\”:\”Images\\/Videos in content\”,\”description\”:\”You are not using rich media like images or videos.\”,\”score\”:1,\”maxScore\”:5},\”passiveVoice\”:{\”title\”:\”Passive Voice\”,\”description\”:\”You\’re using enough active voice. That\’s great!\”,\”score\”:9,\”maxScore\”:9,\”error\”:0},\”subheadingsDistribution\”:{\”title\”:\”Subheading distribution\”,\”description\”:\”You are not using any subheadings, but your text is short enough and probably doesn\’t need them.\”,\”score\”:9,\”maxScore\”:9,\”error\”:0},\”errors\”:1}}}’,canonical_url
= NULL,og_title
= NULL,og_description
= NULL,og_object_type
= ‘activity’,og_image_type
= ‘default’,og_image_custom_url
= NULL,og_image_custom_fields
= NULL,og_custom_image_width
= NULL,og_custom_image_height
= NULL,og_video
= ”,og_custom_url
= NULL,og_article_section
= NULL,og_article_tags
= ‘[]’,twitter_use_og
= ”,twitter_card
= ‘summary’,twitter_image_type
= ‘default’,twitter_image_custom_url
= NULL,twitter_image_custom_fields
= NULL,twitter_title
= NULL,twitter_description
= NULL,seo_score
= ’61’,schema_type
= ‘none’,schema_type_options
= ‘{\”webPage\”:{\”webPageType\”:\”WebPage\”},\”article\”:{\”articleType\”:\”BlogPosting\”},\”book\”:[],\”course\”:[],\”event\”:[],\”jobPosting\”:[],\”music\”:[],\”person\”:[],\”product\”:[],\”recipe\”:[],\”restaurant\”:[],\”service\”:[],\”software\”:[],\”video\”:[]}’,pillar_content
= ”,robots_default
= ‘1’,robots_noindex
= ”,robots_noarchive
= ”,robots_nosnippet
= ”,robots_nofollow
= ”,robots_noimageindex
= ”,robots_noodp
= ”,robots_notranslate
= ”,robots_max_snippet
= ‘-1’,robots_max_videopreview
= -1,robots_max_imagepreview
= ‘large’,tabs
= ‘{\”tab\”:\”general\”,\”tab_social\”:\”facebook\”,\”tab_sidebar\”:\”general\”,\”tab_modal\”:\”general\”,\”tab_modal_social\”:\”facebook\”}’,images
= NULL,image_scan_date
= ‘2021-01-04 22:39:52’,priority
= ‘default’,frequency
= ‘default’,videos
= NULL,video_thumbnail
= NULL,video_scan_date
= NULL,location
= NULL,local_seo
= ‘{\”businessInfo\”:{\”name\”:\”\”,\”urls\”:{\”website\”:\”\”,\”aboutPage\”:\”\”,\”contactPage\”:\”\”},\”address\”:{\”line1\”:\”\”,\”line2\”:\”\”,\”zip\”:\”\”,\”city\”:\”\”,\”state\”:\”\”,\”country\”:\”\”},\”contact\”:{\”email\”:\”\”,\”phone\”:\”\”,\”fax\”:\”\”},\”ids\”:{\”vatID\”:\”\”,\”taxID\”:\”\”,\”chamberID\”:\”\”},\”payment\”:{\”priceIndication\”:\”\”,\”currenciesAccepted\”:\”\”,\”methodsAccepted\”:\”\”},\”areaServed\”:\”\”},\”openingHours\”:{\”show\”:false,\”closedLabel\”:\”\”,\”open24h\”:false,\”open24hLabel\”:\”\”,\”open247\”:false,\”use24hFormat\”:false,\”twoSets\”:false,\”timezone\”:\”\”,\”hours\”:[]}}’,updated
= ‘2021-01-04 22:40:23’
WHERE 1 = 1 AND
id
= ‘1854’
/* 1 = 1 */ made by AIOSEO\Plugin\Common\Utils\Database::runI think I’ve found the culprit. In the
set
function in Model.php, around line 250 there is:$key = $this->transform( $key, true );
If I log
$key
immediately before this step, the dismissed value of 0 is present. When I log$key
immediately after this line, dismissed is blank.Within the
transform
function in Model.php there is this (around line 200):foreach ( $this->booleanFields as $field ) { if ( isset( $data[ $field ] ) && '' === $data[ $field ] ) { unset( $data[ $field ] ); } elseif ( isset( $data[ $field ] ) ) { $data[ $field ] = (bool) $data[ $field ]; } }
When
dismissed
is 0, this results in it being set as false, which is then blank and causes the database error when writing to the database. I’m not sure the best solution, if removing dismissed from the set of booleanFields is better, or if refactoring the database write to handle this is preferable.Sorry, this is a duplicate of another ticket I opened because the ticket system was marking it as spam. I am updating that other ticket: https://www.ads-software.com/support/topic/database-error-with-notifications/#post-13864109
- This reply was modified 3 years, 10 months ago by grahambudd.
If it is helpful, I tracked down the
public static function addNotification
function in Notification.php and I see this code around line 170:// Set the dismissed status to false. $fields['dismissed'] = 0;
If I change this to something like:
$fields['dismissed'] = 5;
then the notifications do get written (albeit with a dismissed status of 1). I highly suspect this is due to PHP shenanigans around bools and truthiness.Forum: Plugins
In reply to: [W3 Total Cache] Updating to 0.14.0 leads to 404 error for imagesForum: Plugins
In reply to: [W3 Total Cache] After update NO more images are displayed!Based on the note that the relative path was being added to the URL, I highly suspect this is the same issue as here https://www.ads-software.com/support/topic/updating-to-0-14-0-leads-to-404-error-for-images/ and probably the same root cause. I added more detailed notes to that ticket, but I believe the error is in UriRewriter.php in the _processUriCB method.
Forum: Plugins
In reply to: [W3 Total Cache] Updating to 0.14.0 leads to 404 error for images@vmarko , @eugeniopl ,
99% sure this is due to the new local URI determination in the latest update. I had this happen as well and hunted down the issue. The error is in UriRewriter.php in the _processUriCB method.
The old logic checked for a file relative URI with a bunch of tests including:
&& false === strpos($uri, '//') // protocol (non-data)
while the new update uses this:
&& '/' !== substr($uri, 0, 1) // Root-relative (/) and protocol/non-data (//).
The difference is that the old code looks for ‘//’ anywhere in the string, the new logic only looks for it at the start. So you cannot have http or https at the start. So this sort of CSS breaks:
url('https://www.mydomain.com/wp-content/uploads/myimagename.jpg')
while this works:
url('//www.mydomain.com/wp-content/uploads/myimagename.jpg')
Once I changed my URLs in CSS to exclude the protocol, it was happy again. That said I think this is a bug and should be fixed. Let me know if I can provide any more details.
- This reply was modified 4 years, 6 months ago by grahambudd. Reason: adding @mentions
- This reply was modified 4 years, 6 months ago by grahambudd.