WPML Multilingual & Multicurrency for WooCommerce

Make your store multilingual and enable multiple currencies.

v5.5.6Amir HelzerUpdated 2026-06-09Added Feb 6, 2012100k+ installs84% rating0% support resolved
24
Score
1,453
Errors
1,618
Warnings
+0
Change

Category Scores

Security0
Repo94
Performance100
Maintainability0

Top Issues by Category

security2,224
maintainability694
i18n63

Issues Details

3,071 issues found in latest scan

ERROR546
WordPress.DB.PreparedSQL.NotPrepared

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

ERROR374
missing_direct_file_access_protection

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

WARNING294
WordPress.Security.NonceVerification.Recommended

Processing form data without nonce verification.

ERROR263
WordPress.Security.EscapeOutput.ExceptionNotEscaped

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

WARNING209
WordPress.Security.ValidatedSanitizedInput.MissingUnslash

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

WARNING200
WordPress.Security.NonceVerification.Missing

Processing form data without nonce verification.

WARNING185
WordPress.DB.PreparedSQL.InterpolatedNotPrepared

Use placeholders and $wpdb->prepare(); found interpolated variable $currency at \t\t\t\t\tWHERE meta_key IN ('_price', '_regular_price', '_sale_price', '_price_$currency', '_regular_price_$currency', '_sale_price_$currency')\n

WARNING176
WordPress.Security.ValidatedSanitizedInput.InputNotSanitized

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

WARNING141
PluginCheck.Security.DirectDB.UnescapedDBParameter

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

ERROR129
WordPress.Security.EscapeOutput.OutputNotEscaped

All output should be run through an escaping function (see the Security sections in the WordPress Developer Handbooks), found '"Template: {$name}\n"'.

WARNING96
WordPress.PHP.DevelopmentFunctions.error_log_trigger_error

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

WARNING65
WordPress.Security.ValidatedSanitizedInput.InputNotValidated

Detected usage of a possibly undefined superglobal array index: $_COOKIE['woocommerce_items_in_cart']. Check that the array index exists before using it.

WARNING61
WordPress.DB.DirectDatabaseQuery.DirectQuery

Use of a direct database call is discouraged.

WARNING60
WordPress.DB.DirectDatabaseQuery.NoCaching

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

ERROR49
WordPress.WP.I18n.TextDomainMismatch

Mismatched text domain. Expected 'woocommerce-multilingual' but got 'sitepress'.

WARNING23
WordPress.NamingConventions.PrefixAllGlobals.DynamicHooknameFound

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

WARNING20
WordPress.DB.SlowDBQuery.slow_db_query_meta_key

Detected usage of meta_key, possible slow query.

WARNING17
WordPress.DB.SlowDBQuery.slow_db_query_meta_value

Detected usage of meta_value, possible slow query.

WARNING15
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedVariableFound

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

ERROR14
WordPress.WP.I18n.NonSingularStringLiteralText

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

ERROR13
WordPress.DateTime.RestrictedFunctions.date_date

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

WARNING9
WordPress.DB.PreparedSQLPlaceholders.ReplacementsWrongNumber

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

WARNING8
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedHooknameFound

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

ERROR7
WordPress.Security.EscapeOutput.UnsafePrintingFunction

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

ERROR7
WordPress.WP.AlternativeFunctions.rand_mt_rand

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

Latest Snapshot

Findings

3,071

Errors

1,453

Warnings

1,618

Score History

First score snapshot

First scan completed Jun 19, 2026

v5.5.6 · Plugin Check 2.0.0 · Model 2026.06-mvp-static-v2

Jun 19, 2026

v5.5.6

24

Latest

Findings
3,071
Errors
1,453
Warnings
1,618
Plugin Check
2.0.0
Model
2026.06-mvp-static-v2

Related Plugins