FOX – Currency Switcher Professional for WooCommerce

FOX - Currency Switcher Professional for WooCommerce (former name is WOOCS) is currency plugin for woocommerce and multi currency shop, switch & pay

v1.4.9RealMag777Updated Added 50k+ installs88% rating83% support resolved
30
Score
211
Errors
1,022
Warnings
+0
Change

Category Scores

Security0
Repo94
Performance96
Maintainability32

Top Issues by Category

security775
maintainability439
i18n11
performance4

Issues Details

1,233 issues found in latest scan

WARNING345
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedVariableFound

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

WARNING180
WordPress.Security.NonceVerification.Recommended

Processing form data without nonce verification.

ERROR177
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='{$support_link}' target='_blank'>"'.

WARNING126
WordPress.Security.ValidatedSanitizedInput.InputNotSanitized

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

WARNING126
WordPress.Security.ValidatedSanitizedInput.MissingUnslash

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

WARNING100
WordPress.Security.ValidatedSanitizedInput.InputNotValidated

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

WARNING55
WordPress.Security.NonceVerification.Missing

Processing form data without nonce verification.

WARNING20
Internal.LineEndings.Mixed

File has mixed line endings; this may cause incorrect results

WARNING16
WordPress.DB.DirectDatabaseQuery.NoCaching

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

WARNING15
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedHooknameFound

Hook names invoked by a theme/plugin should start with the theme/plugin prefix. Found: &quot;formatted_woocommerce_price&quot;.

ERROR15
missing_direct_file_access_protection

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

WARNING13
WordPress.DB.DirectDatabaseQuery.DirectQuery

Use of a direct database call is discouraged.

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

WARNING6
PluginCheck.Security.DirectDB.UnescapedDBParameter

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

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

ERROR3
Generic.PHP.DisallowShortOpenTag.EchoFound

Short PHP opening tag used with echo; expected "<?php echo $key ..." but found "<?= $key ..."

WARNING3
WordPress.DB.PreparedSQL.InterpolatedNotPrepared

Use placeholders and $wpdb-&gt;prepare(); found interpolated variable {$placeholders} at &quot;SELECT meta_value FROM {$wpdb-&gt;prefix}postmeta WHERE meta_key = %s AND post_id IN({$placeholders})&quot;

ERROR3
WordPress.DateTime.RestrictedFunctions.date_date

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

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

WARNING2
WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedFunctionFound

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

WARNING2
WordPress.PHP.DevelopmentFunctions.error_log_error_log

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

WARNING2
WordPress.Security.ValidatedSanitizedInput.InputNotValidatedNotSanitized

Detected usage of a non-sanitized, non-validated input variable _SERVER: &quot;://$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]&quot;

ERROR2
WordPress.WP.I18n.UnorderedPlaceholdersText

Multiple placeholders in translatable strings should be ordered. Expected "%1$s, %2$s, %3$s, %4$s", but got "%s, %s, %s, %s" in 'In the free version of the plugin %s you can operate with 2 ANY currencies only%s! If you want to use more currencies %s you can make upgrade to the premium version%s of the plugin'.

WARNING1
WordPress.DB.DirectDatabaseQuery.SchemaChange

Attempting a database schema change is discouraged.

WARNING1
WordPress.NamingConventions.PrefixAllGlobals.DynamicHooknameFound

Hook names invoked by a theme/plugin should start with the theme/plugin prefix. Found: &quot;$action_hook&quot;.

Latest Snapshot

Findings

1,233

Errors

211

Warnings

1,022

Score History

First score snapshot

First scan completed

v1.4.9 · Plugin Check 2.0.0 · Model 2026.06-mvp-static-v2

v1.4.9

30

Latest

Findings
1,233
Errors
211
Warnings
1,022
Plugin Check
2.0.0
Model
2026.06-mvp-static-v2

Related Plugins