PPOM – Product Addons & Custom Fields for WooCommerce

Easily add a range of custom fields to WooCommerce products, from text boxes to date selectors, allowing customers to personalize their orders.

v34.0.2ThemeisleUpdated 2026-06-02Added Apr 24, 201520k+ installs88% rating100% support resolved
21
Score
336
Errors
1,325
Warnings
+0
Change

Category Scores

Security0
Repo72
Performance100
Maintainability0

Top Issues by Category

maintainability1,123
security520
supply_chain2
i18n1

Issues Details

1,661 issues found in latest scan

WARNING944
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedVariableFound

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

ERROR233
WordPress.Security.EscapeOutput.OutputNotEscaped

All output should be run through an escaping function (see the Security sections in the WordPress Developer Handbooks), found '"<div class=\"updated\"><p>{$message}</p></div>"'.

WARNING84
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedHooknameFound

Hook names invoked by a theme/plugin should start with the theme/plugin prefix. Found: &quot;&#039;nm_input_class-&#039; . $type&quot;.

WARNING82
WordPress.Security.NonceVerification.Recommended

Processing form data without nonce verification.

WARNING65
WordPress.Security.ValidatedSanitizedInput.MissingUnslash

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

ERROR47
WordPress.Security.EscapeOutput.UnsafePrintingFunction

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

WARNING31
WordPress.Security.ValidatedSanitizedInput.InputNotSanitized

Detected usage of a non-sanitized input variable: $_FILES[&#039;file&#039;][&#039;tmp_name&#039;]

WARNING24
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedClassFound

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

WARNING23
WordPress.Security.NonceVerification.Missing

Processing form data without nonce verification.

WARNING17
PluginCheck.Security.DirectDB.UnescapedDBParameter

Unescaped parameter $prepared used in $wpdb-&gt;get_results()\n$prepared assigned unsafely at line 83.

ERROR17
missing_direct_file_access_protection

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

WARNING16
WordPress.Security.ValidatedSanitizedInput.InputNotValidated

Detected usage of a possibly undefined superglobal array index: $_POST[&#039;ppom_product_id&#039;]. Check that the array index exists before using it.

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

ERROR10
WordPress.WP.AlternativeFunctions.strip_tags_strip_tags

strip_tags() is discouraged. Use the more comprehensive wp_strip_all_tags() instead.

WARNING6
WordPress.Security.SafeRedirect.wp_redirect_wp_redirect

wp_redirect() found. Using wp_safe_redirect(), along with the &quot;allowed_redirect_hosts&quot; 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.

ERROR6
WordPress.WP.AlternativeFunctions.unlink_unlink

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

ERROR5
WordPress.DateTime.RestrictedFunctions.date_date

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

ERROR4
WordPress.WP.AlternativeFunctions.rename_rename

rename() is discouraged. Use WP_Filesystem::move() to rename a file.

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

WARNING3
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedFunctionFound

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

ERROR3
WordPress.WP.AlternativeFunctions.file_system_operations_fclose

File operations should use WP_Filesystem methods instead of direct PHP filesystem calls. Found: fclose().

ERROR3
WordPress.WP.AlternativeFunctions.file_system_operations_fopen

File operations should use WP_Filesystem methods instead of direct PHP filesystem calls. Found: fopen().

ERROR2
hidden_files

Hidden files are not permitted.

WARNING1
PluginCheck.CodeAnalysis.DiscouragedFunctions.load_plugin_textdomainFound

load_plugin_textdomain() has been discouraged since WordPress version 4.6. When your plugin is hosted on WordPress.org, you no longer need to manually include this function call for translations under your plugin slug. WordPress will automatically load the translations for you as needed.

ERROR1
PluginCheck.CodeAnalysis.EnqueuedResourceOffloading.OffloadedContent

Found call to wp_enqueue_style() with external resource. Offloading styles to your servers or any remote service is disallowed.

Latest Snapshot

Findings

1,661

Errors

336

Warnings

1,325

Score History

First score snapshot

First scan completed Jun 20, 2026

v34.0.2 · Plugin Check 2.0.0 · Model 2026.06-mvp-static-v2

Jun 20, 2026

v34.0.2

21

Latest

Findings
1,661
Errors
336
Warnings
1,325
Plugin Check
2.0.0
Model
2026.06-mvp-static-v2

Related Plugins