{"id":295371,"date":"2026-04-14T13:50:01","date_gmt":"2026-04-14T13:50:01","guid":{"rendered":"https:\/\/wordpress.org\/plugins\/serpiq\/"},"modified":"2026-04-15T07:53:17","modified_gmt":"2026-04-15T07:53:17","slug":"seotune-search-insights","status":"publish","type":"plugin","link":"https:\/\/test.wordpress.org\/plugins\/seotune-search-insights\/","author":23473007,"comment_status":"closed","ping_status":"closed","template":"","meta":{"_crdt_document":"","version":"1.0.1","stable_tag":"1.0.1","tested":"6.9.4","requires":"6.2","requires_php":"8.0","requires_plugins":null,"header_name":"Seotune Search Insights","header_author":"Seotune","header_description":"Seotune Search Insights: dashboards and SEO reports from Google Search Console data (OAuth). Keywords, opportunities, cannibalization, and more. Third-party plugin; not affiliated with Google.","assets_banners_color":"797c95","last_updated":"2026-04-15 07:53:17","external_support_url":"","external_repository_url":"","donate_link":"","header_plugin_uri":"https:\/\/wordpress.org\/plugins\/seotune-search-insights\/","header_author_uri":"https:\/\/seotune.app","rating":5,"author_block_rating":0,"active_installs":0,"downloads":167,"num_ratings":1,"support_threads":0,"support_threads_resolved":0,"author_block_count":0,"sections":["description","installation","faq","changelog"],"tags":{"1.0.0":{"tag":"1.0.0","author":"seotune","date":"2026-04-14 13:49:34"},"1.0.1":{"tag":"1.0.1","author":"seotune","date":"2026-04-15 07:53:17"}},"upgrade_notice":[],"ratings":{"1":0,"2":0,"3":0,"4":0,"5":1},"assets_icons":{"icon-128x128.png":{"filename":"icon-128x128.png","revision":3506117,"resolution":"128x128","location":"assets","locale":"","width":128,"height":128},"icon-256x256.png":{"filename":"icon-256x256.png","revision":3506106,"resolution":"256x256","location":"assets","locale":"","width":256,"height":256}},"assets_banners":{"banner-1544x500.png":{"filename":"banner-1544x500.png","revision":3506124,"resolution":"1544x500","location":"assets","locale":"","width":1544,"height":500},"banner-772x250.png":{"filename":"banner-772x250.png","revision":3506124,"resolution":"772x250","location":"assets","locale":"","width":772,"height":250}},"assets_blueprints":{},"all_blocks":[],"tagged_versions":["1.0.0","1.0.1"],"block_files":[],"assets_screenshots":{"screenshot-1.png":{"filename":"screenshot-1.png","revision":3506106,"resolution":"1","location":"assets","locale":"","width":1280,"height":800},"screenshot-2.png":{"filename":"screenshot-2.png","revision":3506106,"resolution":"2","location":"assets","locale":"","width":1280,"height":800},"screenshot-3.png":{"filename":"screenshot-3.png","revision":3506106,"resolution":"3","location":"assets","locale":"","width":1280,"height":800},"screenshot-4.png":{"filename":"screenshot-4.png","revision":3506106,"resolution":"4","location":"assets","locale":"","width":1280,"height":800},"screenshot-5.png":{"filename":"screenshot-5.png","revision":3506106,"resolution":"5","location":"assets","locale":"","width":1280,"height":800},"screenshot-6.png":{"filename":"screenshot-6.png","revision":3506106,"resolution":"6","location":"assets","locale":"","width":1280,"height":800},"screenshot-7.png":{"filename":"screenshot-7.png","revision":3506106,"resolution":"7","location":"assets","locale":"","width":1280,"height":800},"screenshot-8.png":{"filename":"screenshot-8.png","revision":3506106,"resolution":"8","location":"assets","locale":"","width":1280,"height":800},"screenshot-9.png":{"filename":"screenshot-9.png","revision":3506106,"resolution":"9","location":"assets","locale":"","width":1280,"height":800}},"screenshots":{"1":"Dashboard overview with KPIs, charts, top queries and pages, and recent alerts.","2":"Keywords report: sortable, filterable table with Search Console metrics and CSV export.","3":"Settings: Google OAuth (Client ID \/ Secret), connection status, and Sync &amp; Import controls.","4":"Opportunities: high-impression \/ low-CTR and positions 8\u201320 \u201cquick win\u201d reports.","5":"Internal Links: opportunities from your WordPress content and Search Console signals, with filters."},"jetpack_post_was_ever_published":false},"plugin_section":[],"plugin_tags":[232,46987,472,4057,186],"plugin_category":[36,55,57],"plugin_contributors":[260176],"plugin_business_model":[],"class_list":["post-295371","plugin","type-plugin","status-publish","hentry","plugin_tags-analytics","plugin_tags-google-search-console","plugin_tags-keywords","plugin_tags-queries","plugin_tags-seo","plugin_category-analytics","plugin_category-seo-and-marketing","plugin_category-taxonomy","plugin_contributors-seotune","plugin_committers-seotune"],"banners":{"banner":"https:\/\/ps.w.org\/seotune-search-insights\/assets\/banner-772x250.png?rev=3506124","banner_2x":"https:\/\/ps.w.org\/seotune-search-insights\/assets\/banner-1544x500.png?rev=3506124","banner_rtl":false,"banner_2x_rtl":false},"icons":{"svg":false,"icon":"https:\/\/ps.w.org\/seotune-search-insights\/assets\/icon-128x128.png?rev=3506117","icon_2x":"https:\/\/ps.w.org\/seotune-search-insights\/assets\/icon-256x256.png?rev=3506106","generated":false},"screenshots":[{"src":"https:\/\/ps.w.org\/seotune-search-insights\/assets\/screenshot-1.png?rev=3506106","caption":"Dashboard overview with KPIs, charts, top queries and pages, and recent alerts."},{"src":"https:\/\/ps.w.org\/seotune-search-insights\/assets\/screenshot-2.png?rev=3506106","caption":"Keywords report: sortable, filterable table with Search Console metrics and CSV export."},{"src":"https:\/\/ps.w.org\/seotune-search-insights\/assets\/screenshot-3.png?rev=3506106","caption":"Settings: Google OAuth (Client ID \/ Secret), connection status, and Sync &amp; Import controls."},{"src":"https:\/\/ps.w.org\/seotune-search-insights\/assets\/screenshot-4.png?rev=3506106","caption":"Opportunities: high-impression \/ low-CTR and positions 8\u201320 \u201cquick win\u201d reports."},{"src":"https:\/\/ps.w.org\/seotune-search-insights\/assets\/screenshot-5.png?rev=3506106","caption":"Internal Links: opportunities from your WordPress content and Search Console signals, with filters."},{"src":"https:\/\/ps.w.org\/seotune-search-insights\/assets\/screenshot-6.png?rev=3506106","caption":""},{"src":"https:\/\/ps.w.org\/seotune-search-insights\/assets\/screenshot-7.png?rev=3506106","caption":""},{"src":"https:\/\/ps.w.org\/seotune-search-insights\/assets\/screenshot-8.png?rev=3506106","caption":""},{"src":"https:\/\/ps.w.org\/seotune-search-insights\/assets\/screenshot-9.png?rev=3506106","caption":""}],"raw_content":"<!--section=description-->\n<p>Seotune Search Insights connects to Google Search Console, stores search analytics in your WordPress database, and provides an admin dashboard with KPIs, reports, and actionable SEO insights.<\/p>\n\n<p>For setup help, see the <a href=\"https:\/\/seotune.app\/documentation\/\">Documentation<\/a>.<\/p>\n\n<p><strong>Without external accounts:<\/strong> The plugin installs and activates like any other plugin, but <strong>reports and sync require<\/strong> a Google Cloud OAuth client and a Google account with access to a Search Console property for your site. Until you complete connection in <strong>Seotune Search Insights \u2192 Settings<\/strong>, no Search Console data is fetched and dashboards stay empty.<\/p>\n\n<p><strong>Features<\/strong><\/p>\n\n<ul>\n<li><strong>Connection<\/strong>: OAuth connection to GSC; automatic detection of the property matching your site domain (no manual property picker).<\/li>\n<li><strong>Dashboard<\/strong>: Overview with clicks, impressions, CTR, position; charts; top queries and pages; recent alerts.<\/li>\n<li><strong>Keywords<\/strong>: Filterable, sortable report with export to CSV.<\/li>\n<li><strong>Pages<\/strong>: Same for page URLs with export to CSV.<\/li>\n<li><strong>Opportunities<\/strong>: Two reports \u2014 high impressions \/ low CTR, and keywords in positions 8\u201320 (quick wins); CSV export.<\/li>\n<li><strong>Cannibalization<\/strong>: Queries with multiple pages competing; per-query URL list. Normalized by URL (fragment stripped).<\/li>\n<li><strong>Decay<\/strong>: Pages with declining organic performance vs the previous period; filters, probable-cause hints, CSV export.<\/li>\n<li><strong>Content Refresh<\/strong>: Pages prioritized for refresh (urgency levels) with reasons and metrics; CSV export.<\/li>\n<li><strong>Internal Links<\/strong>: Internal linking opportunities from WordPress content and GSC signals; filters; CSV export.<\/li>\n<li><strong>Question Queries<\/strong>: Question-style search queries with difficulty signals and metrics (from GSC data).<\/li>\n<li><strong>Alerts<\/strong>: Automatic detection of position drop, CTR drop, traffic drop, impressions spike (runs after daily sync); list on the Dashboard and CSV export.<\/li>\n<li><strong>Export<\/strong>: CSV export for queries, pages, opportunities, alerts, decay, content refresh, and internal linking (with filters where applicable; UTF-8 BOM for Excel).<\/li>\n<li><strong>Settings<\/strong>: Google OAuth credentials, connect\/disconnect, Sync &amp; Import (auto-import last 28 days on first connection, sync now 3\/7 days, import range in background), advanced import tuning, and import diagnostics.<\/li>\n<\/ul>\n\n<p>Data is synced for the last 3 days on manual run or via a daily cron. After the <strong>first successful connection<\/strong> to Google Search Console, Seotune Search Insights automatically imports the last <strong>28 days<\/strong> so that the Dashboard and reports are not empty; you can then use Sync &amp; Import to extend or restart the import for a larger range. After the first import, data is updated automatically every day via cron. Historical data can be imported in background batches (by default 7 days per batch and 1000 rows per DB write) that stay within sensible Google Search Console usage and are tuned for performance; you can adjust these values from Settings \u2192 Sync &amp; Import if needed. The Sync &amp; Import card also includes an <strong>Import diagnostics<\/strong> panel that shows recent import activity, cron status, and common issues (e.g. cron not running, API quota, PHP\/DB limits) without exposing sensitive query data. Custom database tables use a <strong>plugin-specific<\/strong> prefix (in addition to your WordPress table prefix).<\/p>\n\n<h3>Privacy<\/h3>\n\n<p>This plugin <strong>does not<\/strong> send your site\u2019s front-end visitor traffic to Seotune Search Insights or to a proprietary Seotune API. It <strong>does not<\/strong> add visitor tracking, advertising pixels, or marketing analytics to the public site.<\/p>\n\n<p><strong>Declared service data (administrators)<\/strong><\/p>\n\n<ul>\n<li><strong>Google OAuth 2.0 &amp; Search Console API<\/strong> (required for core features): After you add OAuth credentials and connect, the server communicates with Google to authorize and to read Search Console data you are allowed to access. Tokens and imported metrics are stored <strong>in your WordPress database<\/strong>. Google\u2019s terms and privacy policies apply to Google accounts and APIs: <a href=\"https:\/\/policies.google.com\/privacy\">Google Privacy Policy<\/a>, <a href=\"https:\/\/developers.google.com\/terms\">Google APIs Terms of Service<\/a>.<\/li>\n<li><strong>Admin UI typography<\/strong>: The dashboard uses the operating system\u2019s UI fonts (system font stack in local CSS) in the <strong>WordPress admin only<\/strong>; it does not load third-party font stylesheets for Seotune Search Insights screens.<\/li>\n<\/ul>\n\n<p><strong>Responsibility<\/strong>: Site owners should inform end users where required by law (e.g. privacy policy, cookie\/consent flows) that Search Console-related data is processed when administrators connect Google services.<\/p>\n\n<p>Technical map (endpoints, when requests run): <code>documentation\/network-and-privacy.txt<\/code>. Narrative guide: <code>documentation\/index.html<\/code> (Privacy &amp; third-party services).<\/p>\n\n<h3>Troubleshooting<\/h3>\n\n<h3>Import diagnostics panel<\/h3>\n\n<p>In <strong>Seotune Search Insights \u2192 Settings \u2192 Sync &amp; Import<\/strong> you will find an <strong>Import diagnostics<\/strong> box:<\/p>\n\n<ul>\n<li>A status badge (OK \/ WARNING \/ ERROR) with a short message and a hint.<\/li>\n<li>A table of the latest import jobs (manual sync, historical batches, internal links index), showing time, range, rows, duration, and result.<\/li>\n<li>A <strong>Copy log for support<\/strong> button that copies a plain-text summary (timestamps, job types, technical messages) which you can paste into a support ticket. No search queries, URLs, or user-identifiable data are included.<\/li>\n<\/ul>\n\n<p>The panel is read-only and is meant to help you and support quickly understand what is happening on your server.<\/p>\n\n<h3>Common messages and what to do<\/h3>\n\n<ul>\n<li><p><strong>\u201cCron may not be running regularly\u201d \/ \u201cNo plugin cron jobs have run in the last few hours\u201d<\/strong><br \/>\nThis usually means WordPress cron is disabled or not being triggered. Check <code>wp-config.php<\/code> for <code>DISABLE_WP_CRON<\/code>. If it is set to <code>true<\/code>, configure a real server cron job that calls <code>wp-cron.php<\/code> every few minutes, or ask your hosting provider to set this up.<\/p><\/li>\n<li><p><strong>\u201cHistorical import is marked as running, but no backfill batches have completed yet\u201d<\/strong><br \/>\nThe backfill state is \u201crunning\u201d but no historical batches are logged. This is typically another sign that cron is not firing. Verify the cron configuration as above, then wait a few minutes and refresh the page.<\/p><\/li>\n<li><p><strong>\u201cHistorical import seems stuck (no progress for a while)\u201d<\/strong><br \/>\nIf the progress bar stays at 0% or does not move for a long time, use <strong>Stop \/ Reset import<\/strong> in the Sync &amp; Import card, then start a new import with smaller batches (lower \u201cDays per batch\u201d). Also make sure cron is running.<\/p><\/li>\n<li><p><strong>Search Console quota \/ rate limit errors in the log<\/strong><br \/>\nIf recent log entries mention quota or rate-limit errors from the Google Search Console API, try lowering <strong>Days per batch<\/strong> for the historical import, and consider running imports at quieter times of day. If the issue persists, you may need to wait for quotas to reset or use a dedicated Google Cloud project.<\/p><\/li>\n<li><p><strong>PHP execution time, memory, or database errors in the log<\/strong><br \/>\nMessages mentioning maximum execution time, memory limits, or database connection issues indicate that the server limits are too strict for large imports. Try reducing <strong>Days per batch<\/strong> and, if needed, ask your hosting provider to increase PHP <code>memory_limit<\/code> and <code>max_execution_time<\/code>, or to relax database limits for background jobs.<\/p><\/li>\n<\/ul>\n\n<h3>Hosting requirements (for smooth import)<\/h3>\n\n<p>Seotune Search Insights\u2019 <strong>historical import<\/strong> runs in the background via WordPress cron: each cron run processes one batch (a few days of data), then schedules the next. For the import to complete without blocking or stalling, the hosting environment must meet the following.<\/p>\n\n<p><strong>Default settings<\/strong> (7 days per batch, 60 seconds delay between batches, 1000 rows per DB batch) are chosen to work on most hosting. On servers with more resources you can increase <strong>Days per batch<\/strong> and reduce <strong>Delay between batches<\/strong> in Seotune Search Insights \u2192 Settings \u2192 Sync &amp; Import for a faster import.<\/p>\n\n<p><strong>Minimum (plugin runs, import may be slow or need tuning)<\/strong><\/p>\n\n<ul>\n<li><strong>PHP<\/strong>: 8.0 or higher (required by the plugin).<\/li>\n<li><strong>PHP memory_limit<\/strong>: at least <strong>128 MB<\/strong>. Lower values can cause out-of-memory errors during import.<\/li>\n<li><strong>PHP max_execution_time<\/strong>: at least <strong>60 seconds<\/strong> for each cron run (single batch). Many shared hosts use 30s; that can be enough for small batches but may cause timeouts on heavier batches.<\/li>\n<li><strong>WordPress cron<\/strong>: Must run regularly (at least every 5\u201310 minutes). If <code>DISABLE_WP_CRON<\/code> is set to <code>true<\/code> in <code>wp-config.php<\/code>, a <strong>system cron job<\/strong> must call <code>wp-cron.php<\/code> (or trigger WordPress cron) every few minutes; otherwise the import never advances.<\/li>\n<li><strong>MySQL<\/strong>: Standard WordPress requirements; no extra extensions needed. The plugin writes data in batches (configurable: 100\u20132000 rows per batch).<\/li>\n<\/ul>\n\n<p><strong>Recommended (smooth, reliable import)<\/strong><\/p>\n\n<ul>\n<li><strong>PHP memory_limit<\/strong>: <strong>256 MB<\/strong> or more.<\/li>\n<li><strong>PHP max_execution_time<\/strong>: <strong>120\u2013300 seconds<\/strong> for cron\/CLI so each batch has enough time to fetch data from Google and write to the database.<\/li>\n<li><strong>Cron<\/strong>: Triggered every <strong>1\u20132 minutes<\/strong> (e.g. system cron every 2 minutes) so batches run frequently and the import completes in a reasonable time.<\/li>\n<li><strong>Network<\/strong>: Outbound HTTPS to Google APIs (Search Console) without long timeouts or blocks.<\/li>\n<\/ul>\n\n<p><strong>Restrictive shared hosting (e.g. some Aruba, or low-resource plans)<\/strong><\/p>\n\n<p>On hosting with strict limits (low memory, 30s execution time, or cron that rarely runs), the import can block, time out, or appear stuck. To improve reliability:<\/p>\n\n<ol>\n<li><strong>Cron<\/strong>: Ensure WordPress cron actually runs. If the host uses <code>DISABLE_WP_CRON<\/code>, set up a real cron job (e.g. <code>*\/5 * * * *<\/code> to hit <code>https:\/\/yoursite.com\/wp-cron.php?doing_wp_cron<\/code> or run <code>wp cron event run --due-now<\/code> via WP-CLI every few minutes). Ask the host (e.g. Aruba) how to add a cron job and what the URL\/command should be.<\/li>\n<li><strong>Days per batch<\/strong>: In <strong>Seotune Search Insights \u2192 Settings \u2192 Sync &amp; Import<\/strong>, set <strong>Days per batch<\/strong> to <strong>3\u20135<\/strong> (or even 1 for very slow hosts). Smaller batches reduce memory and execution time per run.<\/li>\n<li><strong>Rows per DB batch<\/strong>: In the same section, set <strong>Rows per DB batch<\/strong> to <strong>500<\/strong> (or 100 if you still see timeouts or DB errors). Lower values reduce load per request.<\/li>\n<li><strong>PHP limits<\/strong>: Ask the hosting provider to raise <strong>memory_limit<\/strong> to at least 256 MB and <strong>max_execution_time<\/strong> to at least 120 seconds for PHP (or for the cron\/CLI context, if they differentiate).<\/li>\n<\/ol>\n\n<p>If the import still fails or gets stuck, use <strong>Import diagnostics<\/strong> in Settings (and <strong>Copy log for support<\/strong>) to see whether the cause is cron not running, timeouts, memory, or API quota; then adjust the above or contact the host with the requested limits.<\/p>\n\n<h3>Development<\/h3>\n\n<p><strong>Backend (Composer)<\/strong><\/p>\n\n<ul>\n<li>From the plugin root: <code>composer install<\/code>.<\/li>\n<li>Keep the <code>vendor\/<\/code> directory when deploying (plugin requires it for the Google API client).<\/li>\n<li>Autoload: <code>composer.json<\/code> uses a <strong>classmap<\/strong> for <code>includes\/<\/code> (no PSR-4 path mismatch warnings).<\/li>\n<li><code>monolog\/monolog<\/code> is required by <code>google\/apiclient<\/code>; it stays in <code>composer.json<\/code> as <code>^2.9<\/code> to pin Monolog 2.x and remain compatible with PHP 8.0 (Monolog 3 needs PHP 8.1+).<\/li>\n<\/ul>\n\n<p><strong>Frontend (React)<\/strong><\/p>\n\n<ul>\n<li>From <code>admin\/react-app<\/code>: <code>npm install<\/code> then <code>npm run build<\/code>.<\/li>\n<li>Build outputs a <strong>single<\/strong> <code>admin\/assets\/js\/admin-app.js<\/code> (IIFE bundle for classic <code>wp_enqueue_script<\/code>, no <code>import.meta<\/code>) plus <code>admin\/assets\/js\/admin-app.css<\/code> (extracted CSS). Deploy both files; without the built JS, a placeholder script is loaded.<\/li>\n<li><strong>WordPress.org \/ source access:<\/strong> The default release zip <strong>includes<\/strong> <code>admin\/react-app\/<\/code> (Vite\/React sources, <code>package-lock.json<\/code>; <code>node_modules<\/code> excluded \u2014 run <code>npm ci<\/code> inside <code>admin\/react-app<\/code> to rebuild). Compiled <code>admin-app.js<\/code> + <code>admin-app.css<\/code> are also present. Optional: add a <strong>public git mirror<\/strong> URL below for convenience. Details: <code>documentation\/source-and-build.txt<\/code>.<\/li>\n<li><strong>Public source code repository:<\/strong> <em>(Optional \u2014 add GitHub\/GitLab URL if you publish a mirror; not required for review because sources ship in the plugin package.)<\/em><\/li>\n<\/ul>\n\n<p><strong>Release zip(s) (from plugin root, after <code>composer<\/code> \/ <code>npm<\/code> as needed)<\/strong><\/p>\n\n<ul>\n<li><strong>Version bump &amp; SVN:<\/strong> see <code>scripts\/README-release.txt<\/code> (Stable tag, version constant in <code>seotune-search-insights.php<\/code> aligned with the plugin header, changelog, Subversion tag folder).<\/li>\n<li><code>npm run release<\/code> \u2014 creates a zip in <code>dist\/<\/code> (includes <code>admin\/react-app<\/code> sources; excludes <code>node_modules<\/code> and <code>documentation\/<\/code>).<\/li>\n<li><code>npm run release:src<\/code> \u2014 creates only the <code>*-with-sources.zip<\/code> variant with the <strong>same contents<\/strong> (alias for workflows that expect the filename).<\/li>\n<li><code>npm run release:all<\/code> \u2014 writes both filenames; the archives are identical (duplicate name for compatibility).<\/li>\n<\/ul>\n\n<p><strong>Translations (i18n)<\/strong><\/p>\n\n<ul>\n<li>Text domain: <code>seotune-search-insights<\/code>. PHP uses <code>load_plugin_textdomain<\/code> with <code>languages\/<\/code>.<\/li>\n<li>Admin UI strings use <code>@wordpress\/i18n<\/code> (<code>__()<\/code>, <code>sprintf<\/code>, <code>_n<\/code>) in JSX; <code>wp_set_script_translations()<\/code> loads Jed JSON for the built script.<\/li>\n<li>Regenerate templates (from plugin root, WP-CLI):<br \/>\n  wp i18n make-pot . languages\/seotune-search-insights.pot --slug=seotune-search-insights --domain=seotune-search-insights --exclude=vendor,admin\/react-app\/node_modules,dist,admin\/assets,documentation,scripts<br \/>\nUpdate <code>languages\/seotune-search-insights-en_US.po<\/code> with <code>wp i18n update-po languages\/seotune-search-insights.pot languages\/seotune-search-insights-en_US.po<\/code>.<br \/>\nBuild JS JSON (maps all React sources to the single bundle):<br \/>\n  wp i18n make-json languages\/seotune-search-insights-en_US.po --use-map=languages\/wp-i18n-map.json --domain=seotune-search-insights --extensions=jsx,js<br \/>\nCommit <code>languages\/seotune-search-insights.pot<\/code>, <code>languages\/seotune-search-insights-en_US.po<\/code>, <code>languages\/wp-i18n-map.json<\/code>, and <code>languages\/seotune-search-insights-*-*.json<\/code> with the plugin.<\/li>\n<\/ul>\n\n<!--section=installation-->\n<p><strong>Video tutorial (installation &amp; setup)<\/strong><br \/>\nhttps:\/\/www.youtube.com\/watch?v=QF8Wkk7Sg1I<\/p>\n\n<ol>\n<li>Upload the <code>seotune-search-insights<\/code> folder to <code>\/wp-content\/plugins\/<\/code>.<\/li>\n<li>Activate Seotune Search Insights from the Plugins menu.<\/li>\n<li>Go to Seotune Search Insights \u2192 Settings: enter your Google OAuth Client ID and Secret, then Connect to Google.<\/li>\n<\/ol>\n\n<p><strong>Bundled documentation (HTML)<\/strong> <em>(in the full source tree \/ developer checkout; omitted from the production <code>npm run release<\/code> zip to keep the download smaller)<\/em><\/p>\n\n<ul>\n<li>Full guide (installation, OAuth, sync, troubleshooting, privacy): open <code>documentation\/index.html<\/code> in a browser, or print to PDF from the browser.<\/li>\n<li>Maintainers: section \u201cPlugin readme &amp; listing compliance\u201d in <code>documentation\/index.html<\/code>; copy-ready notes in <code>documentation\/listing-description-notes.txt<\/code> (third-party services, no overpromising, trademarks, privacy note for installers).<\/li>\n<li>Third-party licenses (Composer, JS bundle): <code>documentation\/third-party-licenses.txt<\/code>.<\/li>\n<li>Admin UI source\/build and WordPress.org expectations: <code>documentation\/source-and-build.txt<\/code>.<\/li>\n<li>Network endpoints &amp; privacy (Google): <code>documentation\/network-and-privacy.txt<\/code>.<\/li>\n<li>Security, REST permissions, enqueue (guidelines 8 &amp; 13): <code>documentation\/security-rest-and-assets.txt<\/code>.<\/li>\n<li>Front-end vs admin UX (guidelines 10 &amp; 11): <code>documentation\/admin-ux-and-frontend.txt<\/code>.<\/li>\n<li>Trialware \/ complete plugin (guidelines 5 &amp; 16): <code>documentation\/trialware-and-complete-plugin.txt<\/code>.<\/li>\n<li>Trademarks &amp; naming (guideline 17): <code>documentation\/trademarks-and-naming.txt<\/code>.<\/li>\n<li>Registro audit WordPress.org (gap, priorit\u00e0): <code>documentation\/wordpress-org-audit-register.txt<\/code>.<\/li>\n<li>Contributors WordPress.org (slug readme): <code>documentation\/CONTRIBUTORS-wordpress-org.txt<\/code>.<\/li>\n<\/ul>\n\n<!--section=faq-->\n<dl>\n<dt id=\"do%20i%20need%20a%20google%20account%20and%20oauth%20credentials%3F\"><h3>Do I need a Google account and OAuth credentials?<\/h3><\/dt>\n<dd><p>Yes. Seotune Search Insights reads <strong>your<\/strong> Google Search Console data for the site you verify in Search Console. You create an <strong>OAuth client<\/strong> in Google Cloud Console, paste the Client ID and Client Secret into <strong>Seotune Search Insights \u2192 Settings<\/strong>, then click <strong>Connect to Google<\/strong> and approve access in your browser. Without this step, the plugin cannot fetch metrics and reports stay empty.<\/p><\/dd>\n<dt id=\"where%20is%20my%20search%20console%20data%20stored%3F\"><h3>Where is my Search Console data stored?<\/h3><\/dt>\n<dd><p>Imported metrics, OAuth tokens, and plugin settings are stored <strong>in your WordPress database<\/strong> on your server (custom tables use a plugin-specific prefix). Data is not sent to Seotune Search Insights or to a third-party analytics service for Seotune Search Insights\u2019s own use. Only administrators who can access your WordPress admin can see the dashboard.<\/p><\/dd>\n<dt id=\"how%20often%20does%20data%20update%3F%20why%20might%20numbers%20look%20old%3F\"><h3>How often does data update? Why might numbers look old?<\/h3><\/dt>\n<dd><p>After you connect, Seotune Search Insights <strong>syncs recent days<\/strong> on a schedule and can <strong>import more history<\/strong> from <strong>Seotune Search Insights \u2192 Settings \u2192 Sync &amp; Import<\/strong>. Day-to-day updates rely on <strong>WordPress cron<\/strong> (and your server running scheduled tasks). If numbers do not refresh, cron may not be running\u2014see <strong>Troubleshooting<\/strong> and <strong>Hosting requirements<\/strong> below.<\/p><\/dd>\n<dt id=\"what%20happens%20when%20i%20uninstall%20the%20plugin%3F\"><h3>What happens when I uninstall the plugin?<\/h3><\/dt>\n<dd><p>By default, uninstalling <strong>does not<\/strong> remove plugin tables or options. If you want a full cleanup, enable the option to <strong>delete plugin data on uninstall<\/strong> in <strong>Seotune Search Insights \u2192 Settings<\/strong> (wording may vary; see the bundled manual under <em>Uninstall &amp; data removal<\/em>) <strong>before<\/strong> you delete the plugin from <strong>Plugins<\/strong>. When that option is on, the plugin\u2019s <code>uninstall.php<\/code> removes the plugin tables and related stored settings (including OAuth tokens) as implemented in that release.<\/p><\/dd>\n<dt id=\"does%20seotune%20search%20insights%20track%20my%20website%20visitors%3F\"><h3>Does Seotune Search Insights track my website visitors?<\/h3><\/dt>\n<dd><p>No. Seotune Search Insights does <strong>not<\/strong> add visitor tracking, advertising pixels, or marketing scripts to your public pages. It works with <strong>Search Console<\/strong> data that Google already collects for your property, shown to <strong>logged-in administrators<\/strong> in the WordPress admin.<\/p><\/dd>\n\n<\/dl>\n\n<!--section=changelog-->\n<h4>1.0.1<\/h4>\n\n<ul>\n<li>Fix: ship SeoTune brand images (menu icon + header logo) inside the WordPress.org download so they display correctly in the sidebar, header, and About tab.<\/li>\n<\/ul>\n\n<h4>1.0.0<\/h4>\n\n<ul>\n<li>Readme and translations: <strong>Seotune Search Insights<\/strong> branding only in user-facing text; database table prefix described generically (no marketing confusion with internal table names); developer notes reference the main plugin file version constant instead of naming it in the readme.<\/li>\n<li><strong>OpenAI \/ AI insights integration removed<\/strong> from the base plugin (REST routes, PHP <code>Insights<\/code> class, Settings tab, feature flag, docs, and privacy readme section). The distributed build targets Google Search Console only.<\/li>\n<li>Readme: <strong>Tags<\/strong> reviewed for directory SEO \u2014 final set: <code>seo<\/code>, <code>google search console<\/code>, <code>analytics<\/code>, <code>keywords<\/code>, <code>queries<\/code> (replaced generic <code>insights<\/code> with GSC-aligned <code>queries<\/code>).<\/li>\n<li>Readme: <strong>Tested up to<\/strong> set to <strong>6.9<\/strong>.<\/li>\n<li>Readme: <strong>Frequently Asked Questions<\/strong> section (OAuth, data storage, cron\/sync, uninstall, visitor privacy).<\/li>\n<li>Versioning, readme header, and LICENSE file aligned for distribution (plugin version 1.0.0 matches Stable tag).<\/li>\n<li>Admin app package.json version aligned with plugin release.<\/li>\n<li>Added <code>documentation\/index.html<\/code>: user-facing manual (requirements, Google OAuth, GSC connection, sync\/import, features, troubleshooting, uninstall, privacy &amp; third-party services).<\/li>\n<li>Internationalization: Jed JSON for the admin bundle; React uses <code>@wordpress\/i18n<\/code>; PHP REST\/OAuth\/sync error strings wrapped with <code>__()<\/code>; script translations loaded via <code>wp_set_script_translations<\/code>.<\/li>\n<li>Documentation: readme\/listing compliance section in <code>documentation\/index.html<\/code> and <code>documentation\/listing-description-notes.txt<\/code> for listing transparency (Google API, OAuth, trademarks, privacy).<\/li>\n<li>Release: default <code>npm run release<\/code> includes <code>admin\/react-app<\/code> in the zip (GPL source access); excludes <code>node_modules<\/code> and <code>documentation\/<\/code>; root <code>composer.json<\/code> and <code>composer.lock<\/code> are included for Composer transparency.<\/li>\n<li>Composer autoload switched to classmap for <code>includes\/<\/code> (clean <code>composer dump-autoload<\/code>); Monolog kept at <code>^2.9<\/code> as required by Google client + PHP 8.0 compatibility.<\/li>\n<li>Admin UI: React admin mounted with static imports (single Vite\/Rollup IIFE bundle, <code>base: '.\/'<\/code>); CSS extracted to <code>admin-app.css<\/code> for WordPress enqueue compatibility.<\/li>\n<\/ul>\n\n<h4>0.2.0<\/h4>\n\n<ul>\n<li>Admin UI: new header with section name only and hamburger menu containing all sections (including Settings).<\/li>\n<li>Removed duplicate section titles from all report pages (Dashboard, Keywords, Pages, etc.).<\/li>\n<li>Header: property selector (domain name with icon and chevron) and last sync timestamp on the same row.<\/li>\n<li>Header: global date range dropdown (Last 7 days, Last 28 days, Last 90 days, Custom) on the same row; all reports use the same range; removed per-page date filters.<\/li>\n<li>Settings: added Save Settings button in the Google Search Console tab.<\/li>\n<li>Readme: new \"Hosting requirements (for smooth import)\" section (PHP limits, cron, tips for restrictive hosting e.g. Aruba).<\/li>\n<li>Header title styling: font-size 23px, font-weight 400.<\/li>\n<\/ul>\n\n<h4>0.1.0<\/h4>\n\n<ul>\n<li>Initial release.<\/li>\n<li>Google Search Console OAuth; sync queries and pages; dashboard with KPIs and charts.<\/li>\n<li>Reports: Keywords, Pages, Opportunities (high-imp low-CTR, position 8\u201320), Cannibalization.<\/li>\n<li>Alerts (position\/CTR\/traffic drop, impressions spike); cron after sync.<\/li>\n<li>CSV export for all reports.<\/li>\n<li>Settings: GSC credentials, connect\/disconnect, manual sync.<\/li>\n<\/ul>","raw_excerpt":"Search Console analytics and SEO insights in your WordPress admin. Connect with OAuth; data stored in your DB. Not affiliated with Google.","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin\/295371","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin"}],"about":[{"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/types\/plugin"}],"replies":[{"embeddable":true,"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/comments?post=295371"}],"author":[{"embeddable":true,"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wporg\/v1\/users\/seotune"}],"wp:attachment":[{"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/media?parent=295371"}],"wp:term":[{"taxonomy":"plugin_section","embeddable":true,"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_section?post=295371"},{"taxonomy":"plugin_tags","embeddable":true,"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_tags?post=295371"},{"taxonomy":"plugin_category","embeddable":true,"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_category?post=295371"},{"taxonomy":"plugin_contributors","embeddable":true,"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_contributors?post=295371"},{"taxonomy":"plugin_business_model","embeddable":true,"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_business_model?post=295371"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}