Jetpack CRM – Clients, Leads, Invoices, Billing, Email Marketing, & Automation

The CRM for small businesses. Manage leads, invoicing, billing, email marketing, clients, contacts, quotes, automation. Works with WooCommerce too.

v6.8.1AutomatticUpdated 2026-05-28Added Jul 4, 201630k+ installs86% rating100% support resolved
24
Score
1,211
Errors
3,152
Warnings
+0
Change

Category Scores

Security0
Repo90
Performance100
Maintainability0

Top Issues by Category

maintainability2,510
security1,468
i18n290

Issues Details

4,363 issues found in latest scan

WARNING1,611
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedVariableFound

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

ERROR304
WordPress.Security.EscapeOutput.OutputNotEscaped

All output should be run through an escaping function (see the Security sections in the WordPress Developer Handbooks), found '"Copying $src to $dest...\n"'.

WARNING254
WordPress.Security.ValidatedSanitizedInput.MissingUnslash

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

ERROR232
missing_direct_file_access_protection

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

WARNING220
WordPress.DB.DirectDatabaseQuery.DirectQuery

Use of a direct database call is discouraged.

WARNING199
WordPress.Security.NonceVerification.Recommended

Processing form data without nonce verification.

WARNING190
WordPress.DB.DirectDatabaseQuery.NoCaching

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

WARNING190
WordPress.Security.NonceVerification.Missing

Processing form data without nonce verification.

ERROR167
WordPress.DB.PreparedSQL.NotPrepared

Use placeholders and $wpdb->prepare(); found $ZBSCRM_t

ERROR162
WordPress.WP.I18n.MissingTranslatorsComment

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.

WARNING129
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedHooknameFound

Hook names invoked by a theme/plugin should start with the theme/plugin prefix. Found: "after-zerobscrm-admin-init".

ERROR117
WordPress.WP.I18n.NonSingularStringLiteralText

The $text parameter must be a single text string literal. Found: $colVal['fieldstr']

ERROR107
PluginCheck.Security.DirectDB.UnescapedDBParameter

Unescaped parameter $ZBSCRM_t['aka'] used in $wpdb->query()\n$ZBSCRM_t['aka'] used without escaping.

WARNING93
WordPress.Security.ValidatedSanitizedInput.InputNotSanitized

Detected usage of a non-sanitized input variable: $_FILES['zbs_file_attachment']

WARNING65
WordPress.Security.ValidatedSanitizedInput.InputNotValidated

Detected usage of a possibly undefined superglobal array index: $_FILES['zbsc_file_' . $cfSubKey]['tmp_name']. Check that the array index exists before using it.

WARNING46
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedConstantFound

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

WARNING42
PluginCheck.Security.DirectDB.UnescapedDBParameter

Unescaped parameter $ZBSCRM_t[$tableKey] used in $wpdb->query()\n$ZBSCRM_t[$tableKey] used without escaping.

WARNING29
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedFunctionFound

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

ERROR21
WordPress.Security.EscapeOutput.ExceptionNotEscaped

All output should be run through an escaping function (see the Security sections in the WordPress Developer Handbooks), found '"$path does not exist."'.

ERROR19
WordPress.DateTime.RestrictedFunctions.date_date

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

WARNING18
WordPress.PHP.DevelopmentFunctions.error_log_print_r

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

ERROR16
WordPress.WP.AlternativeFunctions.unlink_unlink

unlink() is discouraged. Use wp_delete_file() to delete a file.

WARNING14
WordPress.Security.SafeRedirect.wp_redirect_wp_redirect

wp_redirect() found. Using wp_safe_redirect(), along with the "allowed_redirect_hosts" filter if needed, can help avoid any chances of malicious redirects within code. It is also important to remember to call exit() after a redirect so that no other unwanted code is executed.

WARNING12
WordPress.DB.PreparedSQL.InterpolatedNotPrepared

Use placeholders and $wpdb->prepare(); found interpolated variable $meta at "DELETE FROM $wpdb->postmeta WHERE `meta_key` = '$meta'"

ERROR11
WordPress.WP.I18n.TextDomainMismatch

Mismatched text domain. Expected 'zero-bs-crm' but got 'jetpack-assets'.

Latest Snapshot

Findings

4,363

Errors

1,211

Warnings

3,152

Score History

First score snapshot

First scan completed Jun 20, 2026

v6.8.1 · Plugin Check 2.0.0 · Model 2026.06-mvp-static-v2

Jun 20, 2026

v6.8.1

24

Latest

Findings
4,363
Errors
1,211
Warnings
3,152
Plugin Check
2.0.0
Model
2026.06-mvp-static-v2

Related Plugins