Online Scheduling and Appointment Booking System – Bookly

Appointment booking system for WordPress — schedule appointments, manage calendars, send reminders, take payments. Start booking today!

v27.7BooklyUpdated 2026-06-04Added Oct 10, 201460k+ installs88% rating
25
Score
3,528
Errors
870
Warnings
+0
Change

Category Scores

Security0
Repo100
Performance100
Maintainability0

Top Issues by Category

i18n2,584
security1,077
maintainability705

Issues Details

4,398 issues found in latest scan

ERROR2,439
WordPress.WP.I18n.TextDomainMismatch

Mismatched text domain. Expected 'bookly-responsive-appointment-booking-tool' but got 'bookly'.

ERROR410
WordPress.DB.PreparedSQL.NotPrepared

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

ERROR304
WordPress.Security.EscapeOutput.OutputNotEscaped

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

WARNING210
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedVariableFound

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

WARNING160
WordPress.DB.DirectDatabaseQuery.DirectQuery

Use of a direct database call is discouraged.

WARNING145
WordPress.DB.DirectDatabaseQuery.NoCaching

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

ERROR106
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.

ERROR69
WordPress.DateTime.RestrictedFunctions.date_date

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

ERROR67
PluginCheck.Security.DirectDB.UnescapedDBParameter

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

WARNING63
WordPress.Security.ValidatedSanitizedInput.InputNotSanitized

Detected usage of a non-sanitized input variable: $_COOKIE[$cookie_name]

WARNING52
PluginCheck.Security.DirectDB.UnescapedDBParameter

Unescaped parameter $foreign_key->TABLE_NAME used in $wpdb->query()\n$foreign_key->CONSTRAINT_NAME used without escaping.

WARNING52
WordPress.Security.ValidatedSanitizedInput.MissingUnslash

$_COOKIE[$cookie_name] not unslashed before sanitization. Use wp_unslash() or similar

WARNING47
WordPress.DB.DirectDatabaseQuery.SchemaChange

Attempting a database schema change is discouraged.

WARNING39
WordPress.Security.NonceVerification.Recommended

Processing form data without nonce verification.

ERROR32
WordPress.Security.EscapeOutput.ExceptionNotEscaped

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

WARNING29
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedHooknameFound

Hook names invoked by a theme/plugin should start with the theme/plugin prefix. Found: "admin_page_access_denied".

ERROR26
WordPress.WP.AlternativeFunctions.rand_mt_rand

mt_rand() is discouraged. Use the far less predictable wp_rand() instead.

WARNING23
WordPress.Security.ValidatedSanitizedInput.InputNotValidated

Detected usage of a possibly undefined superglobal array index: $_FILES['files']['name'][0]. Check that the array index exists before using it.

ERROR23
WordPress.WP.I18n.MissingArgDomain

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

WARNING16
WordPress.Security.NonceVerification.Missing

Processing form data without nonce verification.

ERROR16
WordPress.WP.I18n.UnorderedPlaceholdersText

Multiple placeholders in translatable strings should be ordered. Expected "%1$s, %2$d", but got "%s, %d" in '"%s" is too long (%d characters max).'.

ERROR10
WordPress.Security.EscapeOutput.UnsafePrintingFunction

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

ERROR10
wp_function_not_compatible_with_requires_wp

Function "get_avatar_url()" requires WordPress 4.2.0, but your plugin minimum supported version is WordPress 3.7.0.

WARNING9
Squiz.PHP.DiscouragedFunctions.Discouraged

The use of function ini_set() is discouraged

WARNING9
WordPress.DB.PreparedSQL.InterpolatedNotPrepared

Use placeholders and $wpdb->prepare(); found interpolated variable $foreign_key->CONSTRAINT_NAME at "ALTER TABLE `$foreign_key->TABLE_NAME` DROP FOREIGN KEY `$foreign_key->CONSTRAINT_NAME`"

Latest Snapshot

Findings

4,398

Errors

3,528

Warnings

870

Score History

First score snapshot

First scan completed Jun 20, 2026

v27.7 · Plugin Check 2.0.0 · Model 2026.06-mvp-static-v2

Jun 20, 2026

v27.7

25

Latest

Findings
4,398
Errors
3,528
Warnings
870
Plugin Check
2.0.0
Model
2026.06-mvp-static-v2

Related Plugins