Ultimate WP Mail

Custom email and SMS notifications. Automatic send actions. WPForms SMS integration. WooCommerce notifications for purchases, abandoned cart and more!

v1.3.12RustauriusUpdated Added 800 installs90% rating
24
Score
400
Errors
546
Warnings
+0
Change

Category Scores

Security0
Repo94
Performance100
Maintainability0

Issues to Review

Prioritized issue groups from the latest Plugin Check scan

946 findings

Security

571

10 issue groups

Maintainability

318

12 issue groups

I18n

28

3 issue groups

ERRORSecurityUnsafe printing functionAll output should be run through an escaping function (like esc_html_e() or esc_attr_e()), found '_e'.186
Category
Security
Occurrences
186
Severity
error

Sample message

All output should be run through an escaping function (like esc_html_e() or esc_attr_e()), found '_e'.

ERRORSecurityOutput is not escapedAll output should be run through an escaping function (see the Security sections in the WordPress Developer Handbooks), found '$args['after_widget']'.130
Category
Security
Occurrences
130
Severity
error

Sample message

All output should be run through an escaping function (see the Security sections in the WordPress Developer Handbooks), found '$args['after_widget']'.

WARNINGSecurityRequest data is not unslashed$_GET['code'] not unslashed before sanitization. Use wp_unslash() or similar86
Category
Security
Occurrences
86
Severity
warning

Sample message

$_GET['code'] not unslashed before sanitization. Use wp_unslash() or similar

WARNINGMaintainabilityNon-prefixed classClasses declared by a theme/plugin should start with the theme/plugin prefix. Found: "EWD_UWPM_Interests_Widget".66
Category
Maintainability
Occurrences
66
Severity
warning

Sample message

Classes declared by a theme/plugin should start with the theme/plugin prefix. Found: "EWD_UWPM_Interests_Widget".

WARNINGMaintainabilityNon-prefixed hook nameHook names invoked by a theme/plugin should start with the theme/plugin prefix. Found: "'ewd-uwpm-settings-' . $setting".63
Category
Maintainability
Occurrences
63
Severity
warning

Sample message

Hook names invoked by a theme/plugin should start with the theme/plugin prefix. Found: "'ewd-uwpm-settings-' . $setting".

WARNINGSecurityNonce verification recommendedProcessing form data without nonce verification.38
Category
Security
Occurrences
38
Severity
warning

Sample message

Processing form data without nonce verification.

WARNINGMaintainabilityNon-prefixed global variableGlobal variables defined by a theme/plugin should start with the theme/plugin prefix. Found: "$args".37
Category
Maintainability
Occurrences
37
Severity
warning

Sample message

Global variables defined by a theme/plugin should start with the theme/plugin prefix. Found: "$args".

WARNINGSecurityInterpolated SQL is not preparedUse placeholders and $wpdb->prepare(); found interpolated variable $cutoff_time at \t\t\tAND $wpdb->usermeta.meta_value < $cutoff_time\n36
Category
Security
Occurrences
36
Severity
warning

Sample message

Use placeholders and $wpdb->prepare(); found interpolated variable $cutoff_time at \t\t\tAND $wpdb->usermeta.meta_value < $cutoff_time\n

WARNINGSecurityMissing nonce verificationProcessing form data without nonce verification.35
Category
Security
Occurrences
35
Severity
warning

Sample message

Processing form data without nonce verification.

WARNINGMaintainabilityDirect QueryUse of a direct database call is discouraged.34
Category
Maintainability
Occurrences
34
Severity
warning

Sample message

Use of a direct database call is discouraged.

Show 15 more
WARNINGMaintainabilityNo Caching28
Category
Maintainability
Occurrences
28
Severity
warning

Sample message

Direct database call without caching detected. Consider using wp_cache_get() / wp_cache_set() or wp_cache_delete().

WARNINGMaintainabilityNon-prefixed function22
Category
Maintainability
Occurrences
22
Severity
warning

Sample message

Functions declared in the global namespace by a theme/plugin should start with the theme/plugin prefix. Found: "ewd_add_frontend_ajax_url".

WARNINGSecurityInput is not sanitized22
Category
Security
Occurrences
22
Severity
warning

Sample message

Detected usage of a non-sanitized input variable: $_GET['code']

ERRORMaintainabilityMissing direct file access protection22
Category
Maintainability
Occurrences
22
Severity
error

Sample message

PHP file should prevent direct access. Add a check like: if ( ! defined( 'ABSPATH' ) ) exit;

WARNINGSecurityInput is not validated19
Category
Security
Occurrences
19
Severity
warning

Sample message

Detected usage of a possibly undefined superglobal array index: $_GET['code']. Check that the array index exists before using it.

WARNINGMaintainabilityDynamic hook name16
Category
Maintainability
Occurrences
16
Severity
warning

Sample message

Hook names invoked by a theme/plugin should start with the theme/plugin prefix. Found: "$this->cron_interval_identifier".

ERRORI18nMissing Translators Comment16
Category
I18n
Occurrences
16
Severity
error

Sample message

A function call to __() with texts containing placeholders was found, but was not accompanied by a "translators:" comment on the line above to clarify the meaning of the placeholders.

WARNINGSecurityDatabase parameter is not escaped11
Category
Security
Occurrences
11
Severity
warning

Sample message

Unescaped parameter $sql used in $wpdb->get_results()\n$sql assigned unsafely at line 450.

WARNINGMaintainabilityNon-prefixed constant10
Category
Maintainability
Occurrences
10
Severity
warning

Sample message

Global constants defined by a theme/plugin should start with the theme/plugin prefix. Found: "EWD_UWPM_EMAIL_CATEGORY_TAXONOMY".

ERRORMaintainabilitydate date9
Category
Maintainability
Occurrences
9
Severity
error

Sample message

date() is affected by runtime timezone changes which can cause date/time to be incorrectly displayed. Use gmdate() instead.

ERRORSecurityDatabase parameter is not escaped8
Category
Security
Occurrences
8
Severity
error

Sample message

Unescaped parameter $cutoff_time used in $wpdb->get_results()\n$cutoff_time used without escaping.

ERRORI18nText Domain Mismatch7
Category
I18n
Occurrences
7
Severity
error

Sample message

Mismatched text domain. Expected 'ultimate-wp-mail' but got 'order-tracking'.

WARNINGMaintainabilityerror log debug backtrace6
Category
Maintainability
Occurrences
6
Severity
warning

Sample message

debug_backtrace() found. Debug code should not normally be used in production.

WARNINGMaintainabilityNot In Footer5
Category
Maintainability
Occurrences
5
Severity
warning

Sample message

In footer ($in_footer) is not set explicitly wp_enqueue_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.

ERRORI18nMissing Arg Domain5
Category
I18n
Occurrences
5
Severity
error

Sample message

Missing $domain parameter in function call to __().

External Connections

Potential connections found in static code analysis.

21 domains

Outbound calls

102

External assets

2

Incoming endpoints

17

Notable Domains

etoilewebdesign.com25 · outbound
amsul.github.io5 · outbound
amsul.ca3 · outbound
ansciath.tumblr.com2 · outbound
bgrins.github.io2 · outbound
hellohappy.org2 · outbound

Platform / Reference Domains

github.com17 · platform/reference
w3.org12 · platform/reference
wordpress.org10 · platform/reference
codex.wordpress.org7 · platform/reference

External Asset Domains

youtube.com7 · asset + outbound

Incoming Endpoints

wp_ajax_nopriv_public

wp_ajax

Admin AJAX endpoints16
wp_ajax_ewd_uwpm_ajax_preview_emailauthenticated

wp_ajax

wp_ajax_ewd_uwpm_display_upgrade_boxauthenticated

wp_ajax

wp_ajax_ewd_uwpm_email_all_usersauthenticated

wp_ajax

wp_ajax_ewd_uwpm_email_specific_userauthenticated

wp_ajax

wp_ajax_ewd_uwpm_email_user_listauthenticated

wp_ajax

wp_ajax_ewd_uwpm_get_email_log_detailsauthenticated

wp_ajax

wp_ajax_ewd_uwpm_hide_review_askauthenticated

wp_ajax

wp_ajax_ewd_uwpm_hide_upgrade_boxauthenticated

wp_ajax

wp_ajax_ewd_uwpm_interests_sign_upauthenticated

wp_ajax

wp_ajax_ewd_uwpm_send_feature_suggestionauthenticated

wp_ajax

wp_ajax_ewd_uwpm_send_feedbackauthenticated

wp_ajax

wp_ajax_ewd_uwpm_send_test_emailauthenticated

wp_ajax

4 more hidden

Score History

First score snapshot

v1.3.12

24

Latest

Findings
946
Errors
400
Warnings
546
Check
2.0.0

Relationship Map

Author, categories, issues, domains, and nearby plugins.

37 nodes

Related Plugins

Configure SMTP

6k+ active installs

99
Emails Catch All

600 active installs

99
SMTP for Contact Form 7

1k+ active installs

99
SAR Friendly SMTP

2k+ active installs

98
Simple SMTP

2k+ active installs

97