Paid Membership Subscriptions – Effortless Memberships, Recurring Payments & Content Restriction

Feature-packed membership plugin for creating subscription plans, adding recurring payments & content restriction on your membership site.

v3.0.5CozmoslabsUpdated 2026-06-02Added Nov 4, 201510k+ installs94% rating100% support resolved
21
Score
1,918
Errors
5,065
Warnings
+0
Change

Category Scores

Security0
Repo86
Performance76
Maintainability0

Top Issues by Category

maintainability3,486
security2,124
i18n1,127
performance26

Issues Details

6,983 issues found in latest scan

WARNING1,004
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedHooknameFound

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

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

WARNING826
WordPress.Security.NonceVerification.Recommended

Processing form data without nonce verification.

WARNING720
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedFunctionFound

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

WARNING719
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedVariableFound

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

WARNING594
WordPress.Security.ValidatedSanitizedInput.MissingUnslash

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

WARNING441
WordPress.Security.NonceVerification.Missing

Processing form data without nonce verification.

ERROR240
wp_function_not_compatible_with_requires_wp

Function "add_term_meta()" requires WordPress 4.4.0, but your plugin minimum supported version is WordPress 3.1.0.

ERROR198
WordPress.DateTime.RestrictedFunctions.date_date

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

ERROR168
WordPress.WP.I18n.UnorderedPlaceholdersText

Multiple placeholders in translatable strings should be ordered. Expected "%1$1s, %2$2s", but got "%1s, %2s" in 'Follow these steps to start a membership site quickly. %1s out of %2s complete.'.

WARNING128
WordPress.DB.DirectDatabaseQuery.DirectQuery

Use of a direct database call is discouraged.

WARNING121
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedClassFound

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

WARNING119
WordPress.DB.DirectDatabaseQuery.NoCaching

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

ERROR94
missing_direct_file_access_protection

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

ERROR68
WordPress.Security.EscapeOutput.ExceptionNotEscaped

All output should be run through an escaping function (see the Security sections in the WordPress Developer Handbooks), found '"Cannot save property `{$key}` containing an API resource of type "'.

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

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

WARNING45
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedConstantFound

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

WARNING35
WordPress.NamingConventions.PrefixAllGlobals.DynamicHooknameFound

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

ERROR35
WordPress.Security.EscapeOutput.OutputNotEscaped

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

WARNING33
WordPress.Security.ValidatedSanitizedInput.InputNotSanitized

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

WARNING26
WordPressVIPMinimum.Performance.WPQueryParams.PostNotIn_exclude

Using exclusionary parameters, like exclude, in calls to get_posts() should be done with caution, see https://wpvip.com/documentation/performance-improvements-by-removing-usage-of-post__not_in/ for more information.

ERROR25
WordPress.DB.PreparedSQL.NotPrepared

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

ERROR22
PluginCheck.Security.DirectDB.UnescapedDBParameter

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

WARNING22
PluginCheck.Security.DirectDB.UnescapedDBParameter

Unescaped parameter $column_name used in $wpdb->get_var()

Latest Snapshot

Findings

6,983

Errors

1,918

Warnings

5,065

Score History

First score snapshot

First scan completed Jun 20, 2026

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

Jun 20, 2026

v3.0.5

21

Latest

Findings
6,983
Errors
1,918
Warnings
5,065
Plugin Check
2.0.0
Model
2026.06-mvp-static-v2

Related Plugins