[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"$fjEu8KkRrldUW_zu4NVp_3r1ulle7pyny653tnLgxh4g":3},{"slug":4,"name":5,"version":6,"author":7,"author_profile":8,"description":9,"short_description":10,"active_installs":11,"downloaded":12,"rating":13,"num_ratings":14,"last_updated":15,"tested_up_to":16,"requires_at_least":17,"requires_php":18,"tags":19,"homepage":23,"download_link":24,"security_score":25,"vuln_count":26,"unpatched_count":26,"last_vuln_date":27,"fetched_at":28,"vulnerabilities":29,"developer":30,"crawl_stats":27,"alternatives":38,"analysis":142,"fingerprints":270},"snapshots","SnapShots","2.8.2","EverPress","https:\u002F\u002Fprofiles.wordpress.org\u002Feverpress\u002F","\u003Cp>You are developing things on a WordPress site and would like to have a \u003Cem>snapshot\u003C\u002Fem> of the current state of your site? \u003Cstrong>SnapShots\u003C\u002Fstrong> will help you save states of your WordPress environment.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>Save snapshots of your site with a simple click.\u003C\u002Fli>\n\u003Cli>Name your snapshots for easy distinction.\u003C\u002Fli>\n\u003Cli>SnapShots stores current location and redirects after restore.\u003C\u002Fli>\n\u003Cli>Stores and restores database tables and files in upload folder.\u003C\u002Fli>\n\u003Cli>Automatically logs in current user.\u003C\u002Fli>\n\u003Cli>Automatically clears old snapshots with same name.\u003C\u002Fli>\n\u003Cli>Small footprint and minimal UI.\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Cspan class=\"embed-youtube\" style=\"text-align:center; display: block;\">\u003Ciframe loading=\"lazy\" class=\"youtube-player\" width=\"750\" height=\"422\" src=\"https:\u002F\u002Fwww.youtube.com\u002Fembed\u002F-ybCpL5Ri44?version=3&rel=1&showsearch=0&showinfo=1&iv_load_policy=1&fs=1&hl=en-US&autohide=2&wmode=transparent\" allowfullscreen=\"true\" style=\"border:0;\" sandbox=\"allow-scripts allow-same-origin allow-popups allow-presentation allow-popups-to-escape-sandbox\">\u003C\u002Fiframe>\u003C\u002Fspan>\n\u003Ch3>Options\u003C\u002Fh3>\n\u003Cp>All options are defined via constants and can get overwritten with a filter. The format of options is\u003C\u002Fp>\n\u003Cpre>\u003Ccode>SNAPSHOTS_[OPTION_NAME]\n\u003C\u002Fcode>\u003C\u002Fpre>\n\u003Cp>Best to define your custom option constants in the \u003Ccode>wp-config.php\u003C\u002Fcode> file.\u003C\u002Fp>\n\u003Cp>You can use filters options like\u003C\u002Fp>\n\u003Cpre>\u003Ccode>add_filter( 'snapshots_[option_name]', function( $default_option ){\n return $my_option;\n});\n\u003C\u002Fcode>\u003C\u002Fpre>\n\u003Ch4>Default Options\u003C\u002Fh4>\n\u003Cpre>\u003Ccode>\u002F\u002F Default save location.\nSNAPSHOTS_FOLDER : WP_CONTENT_DIR . '\u002F.snapshots'\n\n\u002F\u002F add '--allow-root' to each command if you run the commands as root.\nSNAPSHOTS_CLI_ALLOW_ROOT: false\n\n\u002F\u002F define the location of your 'wp' binaries.\nSNAPSHOTS_CLI_PATH: '\u002Fusr\u002Flocal\u002Fbin'\n\n\u002F\u002F Number of shots kept with the same name.\nSNAPSHOTS_MAX_SHOTS: 2\n\n\u002F\u002F SnapShot includes files from content folder.\nSNAPSHOTS_SAVE_FILES: true\n\n\u002F\u002F SnapShot includes location (URL) during creation to redirect on restore.\nSNAPSHOTS_SAVE_LOCATION: true\n\u003C\u002Fcode>\u003C\u002Fpre>\n","Quickly Create SnapShots of your development sites and restore them with a click.",20,5509,74,3,"2024-12-04T09:51:00.000Z","6.7.5","6.6","7.4",[20,21,22,4],"database","dev","development","","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fsnapshots.2.8.2.zip",92,0,null,"2026-03-15T15:16:48.613Z",[],{"slug":31,"display_name":7,"profile_url":8,"plugin_count":32,"total_installs":33,"avg_security_score":34,"avg_patch_time_days":35,"trust_score":36,"computed_at":37},"everpress",28,121400,91,255,73,"2026-04-04T14:10:28.563Z",[39,58,82,102,123],{"slug":40,"name":41,"version":42,"author":43,"author_profile":44,"description":45,"short_description":46,"active_installs":47,"downloaded":48,"rating":13,"num_ratings":14,"last_updated":49,"tested_up_to":50,"requires_at_least":51,"requires_php":23,"tags":52,"homepage":55,"download_link":56,"security_score":57,"vuln_count":26,"unpatched_count":26,"last_vuln_date":27,"fetched_at":28},"suicide","Suicide","2.0","Justin Watt","https:\u002F\u002Fprofiles.wordpress.org\u002Fjustincwatt\u002F","\u003Cp>Removes all the content from your blog’s database on a per table basis.\u003C\u002Fp>\n\u003Cp>To use simply install and visit the Tools > Suicide page.\u003C\u002Fp>\n\u003Cp>For multisite installs of WordPress visit Network Admin > Sites > Network Suicide to choose which sites you would like to remove content from.\u003C\u002Fp>\n\u003Cp>If you’re interested in contributing to the code behind this plugin, it’s also hosted on GitHub:\u003Cbr \u002F>\nhttps:\u002F\u002Fgithub.com\u002Fjustincwatt\u002Fwp-suicide\u003C\u002Fp>\n","Remove all content from your blog's database (by table). Multisite compatible.",30,17063,"2014-05-21T05:42:00.000Z","3.9.40","3.0",[20,22,53,54,40],"multisite","remove-content","http:\u002F\u002Fjustinsomnia.org\u002F2006\u002F04\u002Fwordpress-suicide\u002F","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fsuicide.zip",85,{"slug":59,"name":60,"version":61,"author":62,"author_profile":63,"description":64,"short_description":65,"active_installs":66,"downloaded":67,"rating":68,"num_ratings":69,"last_updated":70,"tested_up_to":71,"requires_at_least":72,"requires_php":18,"tags":73,"homepage":77,"download_link":78,"security_score":79,"vuln_count":80,"unpatched_count":26,"last_vuln_date":81,"fetched_at":28},"query-monitor","Query Monitor – The developer tools panel for WordPress","3.20.2","John Blackbourn","https:\u002F\u002Fprofiles.wordpress.org\u002Fjohnbillion\u002F","\u003Cp>Query Monitor is the developer tools panel for WordPress and WooCommerce. It enables debugging of database queries, PHP errors, hooks and actions, block editor blocks, enqueued scripts and stylesheets, HTTP API calls, and more.\u003C\u002Fp>\n\u003Cp>It includes some advanced features such as debugging of Ajax calls, REST API calls, user capability checks, and full support for block themes and full site editing. It includes the ability to narrow down much of its output by plugin or theme, allowing you to quickly determine poorly performing plugins, themes, or functions.\u003C\u002Fp>\n\u003Cp>Query Monitor focuses heavily on presenting its information in a useful manner, for example by showing aggregate database queries grouped by the plugins, themes, or functions that are responsible for them. It adds an admin toolbar menu showing an overview of the current page, with complete debugging information shown in panels once you select a menu item.\u003C\u002Fp>\n\u003Cp>Query Monitor supports versions of WordPress up to three years old, and PHP version 7.4 or higher.\u003C\u002Fp>\n\u003Cp>For complete information, please see \u003Ca href=\"https:\u002F\u002Fquerymonitor.com\u002F\" rel=\"nofollow ugc\">the Query Monitor website\u003C\u002Fa>.\u003C\u002Fp>\n\u003Cp>Here’s an overview of what’s shown for each page load:\u003C\u002Fp>\n\u003Cul>\n\u003Cli>Database queries, including notifications for slow, duplicate, or erroneous queries. Allows filtering by query type (\u003Ccode>SELECT\u003C\u002Fcode>, \u003Ccode>UPDATE\u003C\u002Fcode>, \u003Ccode>DELETE\u003C\u002Fcode>, etc), responsible component (plugin, theme, WordPress core), and calling function, and provides separate aggregate views for each.\u003C\u002Fli>\n\u003Cli>The template filename, the complete template hierarchy, and names of all template parts that were loaded or not loaded (for block themes and classic themes).\u003C\u002Fli>\n\u003Cli>PHP errors presented nicely along with their responsible component and call stack, and a visible warning in the admin toolbar.\u003C\u002Fli>\n\u003Cli>Usage of “Doing it Wrong” or “Deprecated” functionality in the code on your site.\u003C\u002Fli>\n\u003Cli>Blocks and associated properties within post content and within full site editing (FSE).\u003C\u002Fli>\n\u003Cli>Matched rewrite rules, associated query strings, and query vars.\u003C\u002Fli>\n\u003Cli>Enqueued scripts and stylesheets, along with their dependencies, dependents, and alerts for broken dependencies.\u003C\u002Fli>\n\u003Cli>Language settings and loaded translation files (MO files and JSON files) for each text domain.\u003C\u002Fli>\n\u003Cli>HTTP API requests, with response code, responsible component, and time taken, with alerts for failed or erroneous requests.\u003C\u002Fli>\n\u003Cli>User capability checks, along with the result and any parameters passed to the capability check.\u003C\u002Fli>\n\u003Cli>Environment information, including detailed information about PHP, the database, WordPress, and the web server.\u003C\u002Fli>\n\u003Cli>The values of all WordPress conditional functions such as \u003Ccode>is_single()\u003C\u002Fcode>, \u003Ccode>is_home()\u003C\u002Fcode>, etc.\u003C\u002Fli>\n\u003Cli>Transients that were updated.\u003C\u002Fli>\n\u003Cli>Usage of \u003Ccode>switch_to_blog()\u003C\u002Fcode> and \u003Ccode>restore_current_blog()\u003C\u002Fcode> on Multisite installations.\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Cp>In addition:\u003C\u002Fp>\n\u003Cul>\n\u003Cli>Whenever a redirect occurs, Query Monitor adds an HTTP header containing the call stack, so you can use your favourite HTTP inspector or browser developer tools to trace what triggered the redirect.\u003C\u002Fli>\n\u003Cli>The response from any jQuery-initiated Ajax request on the page will contain various debugging information in its headers. PHP errors also get output to the browser’s developer console.\u003C\u002Fli>\n\u003Cli>The response from an authenticated WordPress REST API request will contain an overview of performance information and PHP errors in its headers, as long as the authenticated user has permission to view Query Monitor’s output. An \u003Ca href=\"https:\u002F\u002Fdeveloper.wordpress.org\u002Frest-api\u002Fusing-the-rest-api\u002Fglobal-parameters\u002F#_envelope\" rel=\"nofollow ugc\">an enveloped REST API request\u003C\u002Fa> will include even more debugging information in the \u003Ccode>qm\u003C\u002Fcode> property of the response.\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Cp>By default, Query Monitor’s output is only shown to Administrators on single-site installations, and Super Admins on Multisite installations.\u003C\u002Fp>\n\u003Cp>In addition to this, you can set an authentication cookie which allows you to view Query Monitor output when you’re not logged in (or if you’re logged in as a non-Administrator). See the Settings panel for details.\u003C\u002Fp>\n\u003Ch3>Other Plugins\u003C\u002Fh3>\n\u003Cp>I maintain several other plugins for developers. Check them out:\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Ca href=\"https:\u002F\u002Fwordpress.org\u002Fplugins\u002Fuser-switching\u002F\" rel=\"ugc\">User Switching\u003C\u002Fa> provides instant switching between user accounts in WordPress.\u003C\u002Fli>\n\u003Cli>\u003Ca href=\"https:\u002F\u002Fwordpress.org\u002Fplugins\u002Fwp-crontrol\u002F\" rel=\"ugc\">WP Crontrol\u003C\u002Fa> lets you view and control what’s happening in the WP-Cron system\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch3>Privacy Statement\u003C\u002Fh3>\n\u003Cp>Query Monitor is private by default and always will be. It does not persistently store any of the data that it collects. It does not send data to any third party, nor does it include any third party resources. \u003Ca href=\"https:\u002F\u002Fquerymonitor.com\u002Fprivacy\u002F\" rel=\"nofollow ugc\">Query Monitor’s full privacy statement can be found here\u003C\u002Fa>.\u003C\u002Fp>\n\u003Ch3>Accessibility Statement\u003C\u002Fh3>\n\u003Cp>Query Monitor aims to be fully accessible to all of its users. \u003Ca href=\"https:\u002F\u002Fquerymonitor.com\u002Faccessibility\u002F\" rel=\"nofollow ugc\">Query Monitor’s full accessibility statement can be found here\u003C\u002Fa>.\u003C\u002Fp>\n","Query Monitor is the developer tools panel for WordPress and WooCommerce.",200000,19156533,98,463,"2025-12-11T22:16:00.000Z","6.9.4","6.1",[74,75,22,76,59],"debug","debug-bar","performance","https:\u002F\u002Fquerymonitor.com\u002F","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fquery-monitor.3.20.2.zip",97,1,"2026-03-30 23:21:22",{"slug":83,"name":84,"version":85,"author":86,"author_profile":87,"description":88,"short_description":89,"active_installs":90,"downloaded":91,"rating":68,"num_ratings":92,"last_updated":93,"tested_up_to":71,"requires_at_least":94,"requires_php":95,"tags":96,"homepage":99,"download_link":100,"security_score":101,"vuln_count":26,"unpatched_count":26,"last_vuln_date":27,"fetched_at":28},"yoast-test-helper","Yoast Test Helper","1.18","Yoast","https:\u002F\u002Fprofiles.wordpress.org\u002Fyoast\u002F","\u003Cp>This plugin makes testing Yoast SEO, Yoast SEO add-ons and integrations and resetting the different features a lot easier. It also makes testing database migrations a lot easier as it allows you to set the database version and see if the upgrade process runs smoothly.\u003C\u002Fp>\n\u003Ch4>Features\u003C\u002Fh4>\n\u003Cp>This test helper plugin has several features:\u003C\u002Fp>\n\u003Cul>\n\u003Cli>Easily enable Yoast SEO development mode.\u003C\u002Fli>\n\u003Cli>Saving and restoring Yoast SEO and Yoast SEO extension options, to test upgrade paths.\u003C\u002Fli>\n\u003Cli>Add options debug info to Yoast SEO admin pages.\u003C\u002Fli>\n\u003Cli>Reset the internal link counter, prominent words calculation and other features.\u003C\u002Fli>\n\u003Cli>Add two post types (Books and Movies) with two taxonomies (Category and Genre) each and optionally disable the block editor for them.\u003C\u002Fli>\n\u003Cli>Easily add an inline script after a selected script.\u003C\u002Fli>\n\u003Cli>Replace your \u003Ccode>.test\u003C\u002Fcode> TLD with \u003Ccode>example.com\u003C\u002Fcode> in your Schema output, so you can easily copy paste to Google’s Structured Data Testing Tool.\u003C\u002Fli>\n\u003Cli>Change the number of URLs shown in an XML Sitemap.\u003C\u002Fli>\n\u003Cli>Easily change your MyYoast URL.\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Cp>If you find bugs or would like to contribute, see our \u003Ca href=\"https:\u002F\u002Fgithub.com\u002FYoast\u002Fyoast-test-helper\" rel=\"nofollow ugc\">GitHub repo\u003C\u002Fa>.\u003C\u002Fp>\n","This plugin makes testing Yoast SEO, Yoast SEO add-ons and integrations and resetting the different features a lot easier.",60000,762113,12,"2025-12-01T18:28:00.000Z","6.4","7.2.5",[22,97,98],"yoast","yoast-seo","https:\u002F\u002Fgithub.com\u002Fyoast\u002Fyoast-test-helper","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fyoast-test-helper.1.18.zip",100,{"slug":103,"name":104,"version":105,"author":106,"author_profile":107,"description":108,"short_description":109,"active_installs":110,"downloaded":111,"rating":68,"num_ratings":112,"last_updated":113,"tested_up_to":71,"requires_at_least":114,"requires_php":115,"tags":116,"homepage":121,"download_link":122,"security_score":101,"vuln_count":26,"unpatched_count":26,"last_vuln_date":27,"fetched_at":28},"what-the-file","What The File","1.6.1","Barry Kooij","https:\u002F\u002Fprofiles.wordpress.org\u002Fbarrykooij\u002F","\u003Cp>What The File adds an option to your toolbar showing what file and template parts are used to display the page you’re currently viewing.\u003C\u002Fp>\n\u003Cp>You can click the file name to directly edit it through the theme editor, though I don’t recommend this for bigger changes.\u003C\u002Fp>\n\u003Cp>What The File supports BuddyPress and Roots Theme based themes.\u003C\u002Fp>\n\u003Cp>More information can be found \u003Ca href=\"http:\u002F\u002Fwww.barrykooij.com\u002Fwhat-the-file\u002F\" rel=\"nofollow ugc\">here\u003C\u002Fa>.\u003C\u002Fp>\n\u003Ch4>Looking for a great related posts plugin for WordPress?\u003C\u002Fh4>\n\u003Cp>Another plugin I’ve built, that I’m very proud of is Related Posts for WordPress. Related Posts for WordPress offers you the ability to link related posts to each other with just 1 click! And it’s 100% free! \u003Ca href=\"https:\u002F\u002Fwordpress.org\u002Fplugins\u002Frelated-posts-for-wp\u002F\" rel=\"ugc\">Check it out on the WordPress repository.\u003C\u002Fa>\u003C\u002Fp>\n","What The File is the best tool to find out what template parts are used to display the page you're currently viewing!",40000,585647,882,"2026-02-19T17:21:00.000Z","3.1","5.3",[22,117,118,119,120],"file","template","template-editing","toolbar","http:\u002F\u002Fwww.barrykooij.com\u002Fwhat-the-file\u002F","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fwhat-the-file.1.6.1.zip",{"slug":124,"name":125,"version":126,"author":127,"author_profile":128,"description":129,"short_description":130,"active_installs":131,"downloaded":132,"rating":68,"num_ratings":32,"last_updated":133,"tested_up_to":134,"requires_at_least":135,"requires_php":23,"tags":136,"homepage":23,"download_link":141,"security_score":25,"vuln_count":26,"unpatched_count":26,"last_vuln_date":27,"fetched_at":28},"prevent-browser-caching","Prevent Browser Caching","2.3.5","kostyatereshchuk","https:\u002F\u002Fprofiles.wordpress.org\u002Fkostyatereshchuk\u002F","\u003Cp>Are you a frontend developer? Do you want to clear browser cache for all users? Just activate this plugin and show your work!\u003C\u002Fp>\n\u003Cp>Prevent Browser Caching allows you to update the assets version of all CSS and JS files automatically or manually in one click.\u003C\u002Fp>\n\u003Cp>Now you can show the latest changes on the site without asking the client to clear the cache.\u003C\u002Fp>\n\u003Ch4>How it works?\u003C\u002Fh4>\n\u003Cp>Usually, WordPress loads assets using query param “ver” in the URL (e.g., style.css?ver=4.9.6). It allows browsers to cache these files until the parameter will not be updated.\u003C\u002Fp>\n\u003Cp>To prevent caching of CSS and JS files, this plugin adds a unique number (e.g., 1526905286) to the “ver” parameter (e.g., style.css?ver=4.9.6.1526905286) for all links, loaded using wp_enqueue_style and wp_enqueue_script functions.\u003C\u002Fp>\n\u003Ch4>For developers\u003C\u002Fh4>\n\u003Cp>By default, this plugin updates all assets files every time a user loads a page and adds options in the admin panel (Settings -> Prevent Browser Caching) which allows you to configure updating of these files.\u003C\u002Fp>\n\u003Cp>But you can also set the version of CSS and JS files programmatically.\u003C\u002Fp>\n\u003Cp>Just insert this code in functions.php file of your theme and change the value of assets_version when you need to update assets:\u003C\u002Fp>\n\u003Cpre>\u003Ccode>prevent_browser_caching( array( \n    'assets_version' => '123' \n) );\n\u003C\u002Fcode>\u003C\u002Fpre>\n","Updates the assets version of all CSS and JS files. Shows the latest changes on the site without asking the client to clear browser cache.",10000,109482,"2024-04-09T17:18:00.000Z","6.5.8","4.0",[137,138,139,22,140],"assets","browser-cache","clear","frontend","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fprevent-browser-caching.2.3.5.zip",{"attackSurface":143,"codeSignals":170,"taintFlows":192,"riskAssessment":255,"analyzedAt":269},{"hooks":144,"ajaxHandlers":166,"restRoutes":167,"shortcodes":168,"cronEvents":169,"entryPointCount":26,"unprotectedCount":26},[145,151,154,158,163],{"type":146,"name":147,"callback":148,"file":149,"line":150},"action","init","actions","includes\\plugin.php",14,{"type":146,"name":147,"callback":152,"file":149,"line":153},"enqueue_scripts",15,{"type":146,"name":155,"callback":156,"priority":11,"file":149,"line":157},"admin_bar_menu","toolbar_snapshots",16,{"type":159,"name":160,"callback":160,"priority":161,"file":162,"line":150},"filter","upgrader_pre_install",10,"includes\\upgrade.php",{"type":159,"name":164,"callback":164,"priority":161,"file":162,"line":165},"upgrader_post_install",32,[],[],[],[],{"dangerousFunctions":171,"sqlUsage":176,"outputEscaping":182,"fileOperations":183,"externalRequests":26,"nonceChecks":26,"capabilityChecks":14,"bundledLibraries":191},[172],{"fn":173,"file":149,"line":174,"context":175},"exec",215,"exec( $rawcmd, $output, $error );",{"prepared":80,"raw":80,"locations":177},[178],{"file":179,"line":180,"context":181},"includes\\cli.php",326,"$wpdb->query() with variable interpolation",{"escaped":183,"rawEcho":184,"locations":185},6,2,[186,189],{"file":179,"line":187,"context":188},383,"raw output",{"file":149,"line":190,"context":188},249,[],[193,216,245],{"entryPoint":194,"graph":195,"unsanitizedCount":80,"severity":215},"backup (includes\\plugin.php:165)",{"nodes":196,"edges":211},[197,202,206],{"id":198,"type":199,"label":200,"file":149,"line":201},"n0","source","$_GET",178,{"id":203,"type":204,"label":205,"file":149,"line":201},"n1","transform","→ command()",{"id":207,"type":208,"label":209,"file":149,"line":190,"wp_function":210},"n2","sink","echo() [XSS]","echo",[212,214],{"from":198,"to":203,"sanitized":213},false,{"from":203,"to":207,"sanitized":213},"medium",{"entryPoint":217,"graph":218,"unsanitizedCount":244,"severity":215},"\u003Cplugin> (includes\\plugin.php:0)",{"nodes":219,"edges":238},[220,223,227,229,231,234,236],{"id":198,"type":199,"label":221,"file":149,"line":222},"$_GET (x3)",34,{"id":203,"type":208,"label":224,"file":149,"line":225,"wp_function":226},"wp_redirect() [Open Redirect]",36,"wp_redirect",{"id":207,"type":199,"label":200,"file":149,"line":228},172,{"id":230,"type":208,"label":209,"file":149,"line":190,"wp_function":210},"n3",{"id":232,"type":199,"label":233,"file":149,"line":201},"n4","$_GET (x4)",{"id":235,"type":204,"label":205,"file":149,"line":201},"n5",{"id":237,"type":208,"label":209,"file":149,"line":190,"wp_function":210},"n6",[239,241,242,243],{"from":198,"to":203,"sanitized":240},true,{"from":207,"to":230,"sanitized":240},{"from":232,"to":235,"sanitized":213},{"from":235,"to":237,"sanitized":213},4,{"entryPoint":246,"graph":247,"unsanitizedCount":26,"severity":254},"actions (includes\\plugin.php:27)",{"nodes":248,"edges":252},[249,251],{"id":198,"type":199,"label":250,"file":149,"line":222},"$_GET (x2)",{"id":203,"type":208,"label":224,"file":149,"line":225,"wp_function":226},[253],{"from":198,"to":203,"sanitized":240},"low",{"summary":256,"deductions":257},"The 'snapshots' plugin v2.8.2 exhibits a generally good security posture, with no known historical vulnerabilities and a relatively small attack surface. The static analysis reveals a lack of unprotected entry points, indicating that basic security measures like authentication and authorization checks are likely in place for most interactions. Furthermore, the plugin demonstrates good practices in output escaping, with a high percentage of outputs being properly handled.\n\nHowever, there are specific areas of concern. The presence of the 'exec' function is a significant red flag, as it can be exploited for Remote Code Execution if not handled with extreme care and sanitization. The taint analysis revealing two flows with unsanitized paths is particularly worrying in conjunction with the 'exec' function. This suggests a potential pathway for attackers to inject malicious commands. The lack of nonce checks is also a notable weakness, particularly if there are any hidden or less obvious entry points that weren't captured by the initial attack surface scan.\n\nOverall, while the plugin's history is clean, the static analysis points to critical potential risks. The 'exec' function combined with unsanitized taint flows presents a high-risk scenario for code injection. The absence of nonce checks further amplifies this risk. It is strongly recommended to investigate and thoroughly sanitize all inputs leading to the 'exec' function and to implement nonce checks on all applicable entry points.",[258,260,262,265,267],{"reason":259,"points":153},"Dangerous function 'exec' used",{"reason":261,"points":92},"Taint flows with unsanitized paths",{"reason":263,"points":264},"No nonce checks",7,{"reason":266,"points":14},"SQL queries not fully prepared",{"reason":268,"points":184},"Unescaped output detected","2026-03-16T22:48:32.499Z",{"wat":271,"direct":280},{"assetPaths":272,"generatorPatterns":275,"scriptPaths":276,"versionParams":277},[273,274],"\u002Fwp-content\u002Fplugins\u002Fsnapshots\u002Fassets\u002Fstyle.css","\u002Fwp-content\u002Fplugins\u002Fsnapshots\u002Fassets\u002Fscript.js",[],[274],[278,279],"snapshots\u002Fstyle.css?ver=","snapshots\u002Fscript.js?ver=",{"cssClasses":281,"htmlComments":286,"htmlAttributes":287,"restEndpoints":290,"jsGlobals":291,"shortcodeOutput":292},[282,283,284,285],"snapshot-extra-title","search-snapshot","restore-snapshot","delete-snapshot",[],[288,289],"data-date","data-name",[],[4],[]]