Turn your WordPress site into a marketing powerhouse. Grow your audience, boost engagement, and drive more sales with Brevo.
Category Scores
Top Issues by Category
security594
maintainability448
supply_chain5
Issues Details
1,106 issues found in latest scan
$_COOKIE['email_id'] not unslashed before sanitization. Use wp_unslash() or similar
Use placeholders and $wpdb->prepare(); found $alter_query
PHP file should prevent direct access. Add a check like: if ( ! defined( 'ABSPATH' ) ) exit;
Global variables defined by a theme/plugin should start with the theme/plugin prefix. Found: "$attachment".
All output should be run through an escaping function (see the Security sections in the WordPress Developer Handbooks), found '" git push origin master gh-pages v$newVersion\n"'.
Processing form data without nonce verification.
Direct database call without caching detected. Consider using wp_cache_get() / wp_cache_set() or wp_cache_delete().
Processing form data without nonce verification.
Detected usage of a non-sanitized input variable: $_COOKIE[SIB_Push_Public::INSTALLATION_ID_COOKIE_NAME]
Unescaped parameter $alter_query used in $wpdb->query()\n$alter_query assigned unsafely at line 102.
Classes declared by a theme/plugin should start with the theme/plugin prefix. Found: "Mailin".
Detected usage of a possibly undefined superglobal array index: $_FILES['image']. Check that the array index exists before using it.
Hook names invoked by a theme/plugin should start with the theme/plugin prefix. Found: "active_plugins".
error_log() found. Debug code should not normally be used in production.
All output should be run through an escaping function (like esc_html_e() or esc_attr_e()), found '_e'.
Detected usage of a non-sanitized, non-validated input variable _SERVER: "://$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]"
Using cURL functions is highly discouraged. Use wp_remote_get() instead.
parse_url() is discouraged because of inconsistency in the output across PHP versions; use wp_parse_url() instead.
Scripts must be registered/enqueued via wp_enqueue_script()
Use of heredoc syntax (<<<) is not allowed; use standard strings or inline HTML instead
In footer ($in_footer) is not set explicitly wp_register_script; It is recommended to load scripts in the footer. Please set this value to `true` to load it in the footer, or explicitly `false` if it should be loaded in the header.
Function "str_contains()" requires WordPress 5.9.0, but your plugin minimum supported version is WordPress 4.4.0.
| Code | Type | Message | Count |
|---|---|---|---|
| WordPress.Security.ValidatedSanitizedInput.MissingUnslash | WARNING | $_COOKIE['email_id'] not unslashed before sanitization. Use wp_unslash() or similar | 134 |
| WordPress.DB.PreparedSQL.NotPrepared | ERROR | Use placeholders and $wpdb->prepare(); found $alter_query | 129 |
| missing_direct_file_access_protection | ERROR | PHP file should prevent direct access. Add a check like: if ( ! defined( 'ABSPATH' ) ) exit; | 112 |
| WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedVariableFound | WARNING | Global variables defined by a theme/plugin should start with the theme/plugin prefix. Found: "$attachment". | 84 |
| WordPress.Security.EscapeOutput.OutputNotEscaped | ERROR | All output should be run through an escaping function (see the Security sections in the WordPress Developer Handbooks), found '" git push origin master gh-pages v$newVersion\n"'. | 82 |
| WordPress.Security.NonceVerification.Missing | WARNING | Processing form data without nonce verification. | 75 |
| WordPress.DB.DirectDatabaseQuery.DirectQuery | WARNING | Use of a direct database call is discouraged. | 74 |
| WordPress.DB.DirectDatabaseQuery.NoCaching | WARNING | Direct database call without caching detected. Consider using wp_cache_get() / wp_cache_set() or wp_cache_delete(). | 74 |
| WordPress.Security.NonceVerification.Recommended | WARNING | Processing form data without nonce verification. | 58 |
| WordPress.Security.ValidatedSanitizedInput.InputNotSanitized | WARNING | Detected usage of a non-sanitized input variable: $_COOKIE[SIB_Push_Public::INSTALLATION_ID_COOKIE_NAME] | 43 |
| PluginCheck.Security.DirectDB.UnescapedDBParameter | ERROR | Unescaped parameter $alter_query used in $wpdb->query()\n$alter_query assigned unsafely at line 102. | 35 |
| WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedClassFound | WARNING | Classes declared by a theme/plugin should start with the theme/plugin prefix. Found: "Mailin". | 25 |
| WordPress.Security.ValidatedSanitizedInput.InputNotValidated | WARNING | Detected usage of a possibly undefined superglobal array index: $_FILES['image']. Check that the array index exists before using it. | 19 |
| WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedHooknameFound | WARNING | Hook names invoked by a theme/plugin should start with the theme/plugin prefix. Found: "active_plugins". | 18 |
| Generic.PHP.ForbiddenFunctions.Found | ERROR | The use of function passthru() is forbidden | 12 |
| WordPress.PHP.DevelopmentFunctions.error_log_error_log | WARNING | error_log() found. Debug code should not normally be used in production. | 12 |
| WordPress.Security.EscapeOutput.UnsafePrintingFunction | ERROR | All output should be run through an escaping function (like esc_html_e() or esc_attr_e()), found '_e'. | 11 |
| WordPress.Security.ValidatedSanitizedInput.InputNotValidatedNotSanitized | WARNING | Detected usage of a non-sanitized, non-validated input variable _SERVER: "://$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]" | 8 |
| WordPress.WP.AlternativeFunctions.curl_curl_setopt | ERROR | Using cURL functions is highly discouraged. Use wp_remote_get() instead. | 7 |
| WordPress.WP.AlternativeFunctions.parse_url_parse_url | ERROR | parse_url() is discouraged because of inconsistency in the output across PHP versions; use wp_parse_url() instead. | 7 |
| WordPress.WP.EnqueuedResources.NonEnqueuedScript | ERROR | Scripts must be registered/enqueued via wp_enqueue_script() | 7 |
| PluginCheck.CodeAnalysis.Heredoc.NotAllowed | ERROR | Use of heredoc syntax (<<<) is not allowed; use standard strings or inline HTML instead | 6 |
| WordPress.WP.EnqueuedResourceParameters.NotInFooter | WARNING | In footer ($in_footer) is not set explicitly wp_register_script; It is recommended to load scripts in the footer. Please set this value to `true` to load it in the footer, or explicitly `false` if it should be loaded in the header. | 5 |
| hidden_files | ERROR | Hidden files are not permitted. | 5 |
| wp_function_not_compatible_with_requires_wp | ERROR | Function "str_contains()" requires WordPress 5.9.0, but your plugin minimum supported version is WordPress 4.4.0. | 5 |
Latest Snapshot
Findings
1,106
Errors
460
Warnings
646
Score History
First score snapshot
First scan completed Jun 19, 2026
v3.3.4 · Plugin Check 2.0.0 · Model 2026.06-mvp-static-v2
Jun 19, 2026
v3.3.4
20
Latest
- Findings
- 1,106
- Errors
- 460
- Warnings
- 646
- Plugin Check
- 2.0.0
- Model
- 2026.06-mvp-static-v2
| Scan | Score | Findings | Errors | Warnings | Plugin | Plugin Check | Model |
|---|---|---|---|---|---|---|---|
| Jun 19, 2026Latest | 20 | 1,106 | 460 | 646 | v3.3.4 | 2.0.0 | 2026.06-mvp-static-v2 |