Points Management System For Gamification, Ranks, Badges, and Loyalty Rewards Program – myCred

myCred is a flexible WordPress loyalty points and gamification plugin for points, badges, ranks, referrals, and WooCommerce rewards.

v3.1.2Saad IqbalUpdated 2026-06-18Added Apr 22, 201310k+ installs92% rating100% support resolved
21
Score
1,469
Errors
3,333
Warnings
+0
Change

Category Scores

Security0
Repo80
Performance90
Maintainability0

Top Issues by Category

maintainability2,338
security1,950
i18n306

Issues Details

4,802 issues found in latest scan

WARNING1,094
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedVariableFound

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

ERROR580
WordPress.Security.EscapeOutput.OutputNotEscaped

All output should be run through an escaping function (see the Security sections in the WordPress Developer Handbooks), found '" <a href='{$skip_url}' class='button button-small button-secondary'>{$use_plugin_anonymously_text}</a>"'.

WARNING553
WordPress.Security.NonceVerification.Recommended

Processing form data without nonce verification.

WARNING336
WordPress.DB.PreparedSQL.InterpolatedNotPrepared

Use placeholders and $wpdb-&gt;prepare(); found interpolated variable $between at &quot;SELECT $having FROM %i WHERE ctype = %s AND ref = %s $specific AND user_id = %d $between;&quot;

WARNING243
WordPress.Security.NonceVerification.Missing

Processing form data without nonce verification.

WARNING225
WordPress.DB.DirectDatabaseQuery.DirectQuery

Use of a direct database call is discouraged.

WARNING212
WordPress.DB.DirectDatabaseQuery.NoCaching

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

ERROR182
missing_direct_file_access_protection

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

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

ERROR164
WordPress.DateTime.RestrictedFunctions.date_date

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

WARNING117
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedFunctionFound

Functions declared in the global namespace by a theme/plugin should start with the theme/plugin prefix. Found: &quot;_fs_text&quot;.

WARNING99
PluginCheck.Security.DirectDB.UnescapedDBParameter

Unescaped parameter $cubepoints used in $wpdb-&gt;get_results()

WARNING93
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedConstantFound

Global constants defined by a theme/plugin should start with the theme/plugin prefix. Found: &quot;FS_API__ADDRESS&quot;.

WARNING64
WordPress.WP.EnqueuedResourceParameters.NotInFooter

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.

WARNING59
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedClassFound

Classes declared by a theme/plugin should start with the theme/plugin prefix. Found: &quot;FS_Admin_Menu_Manager&quot;.

ERROR54
PluginCheck.Security.DirectDB.UnescapedDBParameter

Unescaped parameter $after_sql used in $wpdb->get_var()\n$after_sql assigned unsafely at line 206.

WARNING49
WordPress.WP.EnqueuedResourceParameters.MissingVersion

Resource version not set in call to wp_enqueue_script(). This means new versions of the script may not always be loaded due to browser caching.

ERROR48
WordPress.DB.PreparedSQL.NotPrepared

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

ERROR45
block_api_version_too_low

Editor blocks must define "apiVersion" 3 or higher in block.json for WordPress 7.0+ iframe editor compatibility.

ERROR43
WordPress.WP.I18n.MissingArgDomain

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

WARNING37
WordPress.DB.PreparedSQLPlaceholders.ReplacementsWrongNumber

Incorrect number of replacements passed to $wpdb-&gt;prepare(). Found 1 replacement parameters, expected 2.

WARNING34
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedHooknameFound

Hook names invoked by a theme/plugin should start with the theme/plugin prefix. Found: &quot;You must exchange at least&quot;.

ERROR33
WordPress.WP.I18n.NonSingularStringLiteralText

The $text parameter must be a single text string literal. Found: $align

ERROR28
WordPress.WP.I18n.TextDomainMismatch

Mismatched text domain. Expected 'mycred' but got ''.

ERROR23
WordPress.WP.I18n.UnorderedPlaceholdersText

Multiple placeholders in translatable strings should be ordered. Expected "%1$d, %2$d", but got "%d, %d" in 'Import complete - A total of <strong>%d</strong> balances were successfully imported. <strong>%d</strong> was skipped.'.

Latest Snapshot

Findings

4,802

Errors

1,469

Warnings

3,333

Score History

First score snapshot

First scan completed Jun 20, 2026

v3.1.2 · Plugin Check 2.0.0 · Model 2026.06-mvp-static-v2

Jun 20, 2026

v3.1.2

21

Latest

Findings
4,802
Errors
1,469
Warnings
3,333
Plugin Check
2.0.0
Model
2026.06-mvp-static-v2

Related Plugins