{"id":323963,"date":"2026-06-14T15:36:50","date_gmt":"2026-06-14T15:36:50","guid":{"rendered":"https:\/\/en-gb.wordpress.org\/plugins\/predax-fraud-guard-for-woocommerce\/"},"modified":"2026-06-15T05:29:37","modified_gmt":"2026-06-15T05:29:37","slug":"predax-fraud-guard-for-woocommerce","status":"publish","type":"plugin","link":"https:\/\/wordpress.org\/plugins\/predax-fraud-guard-for-woocommerce\/","author":23475053,"comment_status":"closed","ping_status":"closed","template":"","meta":{"version":"1.7.0","stable_tag":"1.7.0","tested":"7.0","requires":"5.8","requires_php":"7.4","requires_plugins":null,"header_name":"Predax Fraud Guard for WooCommerce","header_author":"Predax","header_description":"Tag and optionally block high-risk WooCommerce checkouts using Predax IP intelligence.","assets_banners_color":"091c1e","last_updated":"2026-06-15 05:29:37","external_support_url":"","external_repository_url":"","donate_link":"","header_plugin_uri":"https:\/\/predax.io\/integrations\/woocommerce","header_author_uri":"https:\/\/predax.io","rating":0,"author_block_rating":0,"active_installs":0,"downloads":43,"num_ratings":0,"support_threads":0,"support_threads_resolved":0,"author_block_count":0,"sections":["description","installation","faq","changelog"],"tags":{"1.7.0":{"tag":"1.7.0","author":"ipsentry","date":"2026-06-15 05:29:37"}},"upgrade_notice":{"1.7.0":"<p>IPSentry is now Predax \u2014 first WordPress.org release. Your settings, API key, and order data are preserved. Checkout screening is unchanged and still fully opt-in (no outbound requests until you add a key and enable a mode).<\/p>","1.6.2":"<p>WP.org compliance pass: removes self-updater, extracts inline script\/style tags, tightens sanitisation, and makes the community-feedback telemetry opt-in (off by default). Core checkout screening is unchanged. Upgrade is safe.<\/p>","1.6.1":"<p>OAuth connect popup now auto-closes reliably after authorization. Per-user OAuth transients prevent conflicts on multi-admin sites. Safe to upgrade \u2014 no behaviour changes.<\/p>","1.6.0":"<p>Adds a 3-step setup wizard with One-Click Connect (OAuth) shown on first activation. Existing installs unaffected \u2014 the wizard only triggers on fresh activation with no API key. Re-run anytime from Developer \u2192 Run Setup Wizard.<\/p>","1.5.0":"<p>Adds Events Log page and risk column on the orders list. Safe to upgrade \u2014 no behaviour changes, new DB table created automatically on first load.<\/p>","1.4.3":"<p>Adds a dedicated admin menu page (Predax \u2192 Fraud Guard). Safe to upgrade \u2014 all existing settings are preserved.<\/p>","1.4.2":"<p>Adds settings import\/export and a configurable support email address for block messages. Safe to upgrade \u2014 no behaviour changes on upgrade.<\/p>","1.4.0":"<p>Adds order hold, velocity rules, country mismatch detection, disposable email blocking, and chargeback feedback. All new features default to off.<\/p>"},"ratings":[],"assets_icons":{"icon-128x128.png":{"filename":"icon-128x128.png","revision":3572045,"resolution":"128x128","location":"assets","locale":"","width":128,"height":128},"icon-256x256.png":{"filename":"icon-256x256.png","revision":3572045,"resolution":"256x256","location":"assets","locale":"","width":256,"height":256}},"assets_banners":{"banner-1544x500.png":{"filename":"banner-1544x500.png","revision":3572045,"resolution":"1544x500","location":"assets","locale":"","width":1544,"height":500},"banner-772x250.png":{"filename":"banner-772x250.png","revision":3572045,"resolution":"772x250","location":"assets","locale":"","width":772,"height":250}},"assets_blueprints":{},"all_blocks":[],"tagged_versions":["1.7.0"],"block_files":[],"assets_screenshots":{"screenshot-1.png":{"filename":"screenshot-1.png","revision":3572431,"resolution":"1","location":"assets","locale":"","width":1425,"height":1609},"screenshot-2.png":{"filename":"screenshot-2.png","revision":3572431,"resolution":"2","location":"assets","locale":"","width":1425,"height":1471},"screenshot-3.png":{"filename":"screenshot-3.png","revision":3572431,"resolution":"3","location":"assets","locale":"","width":1425,"height":960},"screenshot-4.png":{"filename":"screenshot-4.png","revision":3572431,"resolution":"4","location":"assets","locale":"","width":1425,"height":1936},"screenshot-5.png":{"filename":"screenshot-5.png","revision":3572431,"resolution":"5","location":"assets","locale":"","width":1425,"height":1191}},"screenshots":{"1":"WooCommerce \u2192 Settings \u2192 Predax: API key, risk thresholds, and per-signal VPN \/ proxy \/ Tor \/ datacenter rules.","2":"Order detail: the Predax risk score, flags, and country appear as an order note and order tags.","3":"Orders list: the Predax column shows each order's risk score and top threat flag.","4":"Advanced rules: order velocity, billing-country mismatch, disposable-email, and timezone checks.","5":"Geo blocking: allow, flag, or block checkout by country, region, or IP \/ CIDR list."}},"plugin_section":[],"plugin_tags":[237432,132861,267120,267121,286],"plugin_category":[45],"plugin_contributors":[264383],"plugin_business_model":[],"class_list":["post-323963","plugin","type-plugin","status-publish","hentry","plugin_tags-checkout-security","plugin_tags-fraud-prevention","plugin_tags-ip-detection","plugin_tags-vpn-detection","plugin_tags-woocommerce","plugin_category-ecommerce","plugin_contributors-ipsentry","plugin_committers-ipsentry"],"banners":{"banner":"https:\/\/ps.w.org\/predax-fraud-guard-for-woocommerce\/assets\/banner-772x250.png?rev=3572045","banner_2x":"https:\/\/ps.w.org\/predax-fraud-guard-for-woocommerce\/assets\/banner-1544x500.png?rev=3572045","banner_rtl":false,"banner_2x_rtl":false},"icons":{"svg":false,"icon":"https:\/\/ps.w.org\/predax-fraud-guard-for-woocommerce\/assets\/icon-128x128.png?rev=3572045","icon_2x":"https:\/\/ps.w.org\/predax-fraud-guard-for-woocommerce\/assets\/icon-256x256.png?rev=3572045","generated":false},"screenshots":[{"src":"https:\/\/ps.w.org\/predax-fraud-guard-for-woocommerce\/assets\/screenshot-1.png?rev=3572431","caption":"WooCommerce \u2192 Settings \u2192 Predax: API key, risk thresholds, and per-signal VPN \/ proxy \/ Tor \/ datacenter rules."},{"src":"https:\/\/ps.w.org\/predax-fraud-guard-for-woocommerce\/assets\/screenshot-2.png?rev=3572431","caption":"Order detail: the Predax risk score, flags, and country appear as an order note and order tags."},{"src":"https:\/\/ps.w.org\/predax-fraud-guard-for-woocommerce\/assets\/screenshot-3.png?rev=3572431","caption":"Orders list: the Predax column shows each order's risk score and top threat flag."},{"src":"https:\/\/ps.w.org\/predax-fraud-guard-for-woocommerce\/assets\/screenshot-4.png?rev=3572431","caption":"Advanced rules: order velocity, billing-country mismatch, disposable-email, and timezone checks."},{"src":"https:\/\/ps.w.org\/predax-fraud-guard-for-woocommerce\/assets\/screenshot-5.png?rev=3572431","caption":"Geo blocking: allow, flag, or block checkout by country, region, or IP \/ CIDR list."}],"raw_content":"<!--section=description-->\n<p><strong>Predax Fraud Guard for WooCommerce<\/strong> is an opt-in checkout-screening tool. After you enter a Predax API key and choose a protection mode, the plugin sends the customer's IP to the Predax API during WooCommerce checkout so your store can decide whether to allow, tag, or block the order.<\/p>\n\n<p>On a fresh install the plugin does nothing \u2014 no outbound requests are made until <strong>you<\/strong> complete setup and pick a protection mode. The default mode once configured is <strong>tag-only<\/strong> (no blocking), so you can see flagged orders in your dashboard before turning on anything that rejects a customer.<\/p>\n\n<h4>How It Works<\/h4>\n\n<ol>\n<li><strong>You install and activate the plugin.<\/strong> Nothing happens \u2014 the plugin stays dormant until you finish setup.<\/li>\n<li><strong>You enter a Predax API key<\/strong> (free account available at <a href=\"https:\/\/predax.io\">predax.io<\/a>).<\/li>\n<li><strong>You pick a protection mode<\/strong> in Fraud Guard \u2192 Settings (or in the 3-step setup wizard). Choices: Tag + note, Block high risk, or Block critical only.<\/li>\n<li><strong>On each WooCommerce checkout after that point<\/strong>, the plugin sends the customer's IP address to the Predax API, receives back a risk score and signal flags (is_vpn \/ is_proxy \/ is_tor \/ is_datacenter), and tags \/ holds \/ blocks the order according to your configuration. Results are cached for up to 5 minutes per IP.<\/li>\n<\/ol>\n\n<p>You can revoke the API key or switch the mode back to \"Tag only\" at any time.<\/p>\n\n<h4>Risk Tagging<\/h4>\n\n<p>Orders that reach the tag threshold (default: risk score 40) are tagged based on band:<\/p>\n\n<ul>\n<li><strong>Risk 40\u201369<\/strong> \u2014 tagged \"Predax: Medium Risk\" with an order note<\/li>\n<li><strong>Risk 70\u201389<\/strong> \u2014 tagged \"Predax: High Risk\" with an order note<\/li>\n<li><strong>Risk 90\u2013100<\/strong> \u2014 tagged \"Predax: Critical Risk\" with an order note<\/li>\n<\/ul>\n\n<h4>Features<\/h4>\n\n<ul>\n<li><strong>Checkout screening<\/strong> (after you enable a protection mode) \u2014 every order is checked against Predax IP threat intelligence<\/li>\n<li><strong>VPN \/ Proxy \/ Tor \/ Datacenter flags<\/strong> \u2014 detect anonymised connections at checkout<\/li>\n<li><strong>Risk score threshold blocking<\/strong> \u2014 optionally block checkouts above a configurable risk score<\/li>\n<li><strong>Automatic order hold<\/strong> (opt-in) \u2014 move high-risk orders to On Hold for manual review instead of processing them<\/li>\n<li><strong>Order velocity rules<\/strong> (opt-in) \u2014 flag or block customers placing too many orders in a short window<\/li>\n<li><strong>Billing country vs IP mismatch<\/strong> (opt-in) \u2014 flag or block orders where billing country differs from detected IP country<\/li>\n<li><strong>Disposable email detection<\/strong> (opt-in) \u2014 reject checkouts using throwaway email providers (30+ supported)<\/li>\n<li><strong>Refund \/ chargeback feedback<\/strong> (opt-in) \u2014 when a tagged order is refunded or cancelled, add its IP to your local deny list, and\/or report the outcome to the Community Threat Network (when that opt-in is enabled)<\/li>\n<li><strong>Order meta logging<\/strong> \u2014 stores risk score, threat flags, and detected country on every order for WooCommerce reporting<\/li>\n<li><strong>Events Log<\/strong> \u2014 a dashboard page showing blocked attempts and flagged orders<\/li>\n<\/ul>\n\n<h4>Defaults<\/h4>\n\n<p>All protection toggles default to <strong>off<\/strong> on a fresh install. The only thing the plugin writes to options on activation is a database version marker for the events-log table. You will need to explicitly enable any rule you want to apply.<\/p>\n\n<h4>Free Tier<\/h4>\n\n<p>Sign up at <a href=\"https:\/\/predax.io\">predax.io<\/a> for a free API key. No credit card required.<\/p>\n\n<h3>Third Party Services<\/h3>\n\n<p>This plugin connects to external services operated by Predax (https:\/\/predax.io) only when you have explicitly enabled a protection mode. By activating this plugin and entering an API key you agree to the <a href=\"https:\/\/predax.io\/terms\">Predax Terms of Service<\/a> and <a href=\"https:\/\/predax.io\/privacy\">Privacy Policy<\/a>.<\/p>\n\n<p>You are responsible for ensuring your use of customer IP data at checkout complies with applicable privacy laws (including but not limited to GDPR, CCPA) and your own store's privacy policy. This plugin does not assert PCI-DSS, GDPR, or CCPA compliance on your behalf.<\/p>\n\n<h4>Predax IP Intelligence API<\/h4>\n\n<p>Used to look up a risk score and classification signals for each checkout IP.<\/p>\n\n<ul>\n<li><strong>Data sent:<\/strong> the customer's IP address at checkout; the browser-reported IANA timezone string (when available on the classic checkout form \u2014 used for the timezone-mismatch signal); your custom scoring weights (only if Custom Scoring is enabled).<\/li>\n<li><strong>What is NOT sent:<\/strong> no billing\/shipping names, street addresses, phone numbers, emails, product details, prices, or payment data. The billing-country-mismatch rule compares your order's billing country against the API's IP-country result locally \u2014 billing details never leave your site.<\/li>\n<li><strong>When:<\/strong> during WooCommerce checkout validation, and only while a protection mode is saved in settings.<\/li>\n<li><strong>Caching:<\/strong> classification results are cached in the site's transients for 5 minutes per IP, so repeat checkouts from the same IP do not generate duplicate API calls.<\/li>\n<li><strong>Endpoint:<\/strong> <code>POST https:\/\/predax.io\/api\/v1\/check\/ip<\/code><\/li>\n<li><strong>Service URL:<\/strong> https:\/\/predax.io<\/li>\n<li><strong>Terms of Service:<\/strong> https:\/\/predax.io\/terms<\/li>\n<li><strong>Privacy Policy:<\/strong> https:\/\/predax.io\/privacy<\/li>\n<\/ul>\n\n<h4>Predax Community Threat Network (opt-in, off by default)<\/h4>\n\n<p>The plugin can <strong>optionally<\/strong> send an anonymised telemetry signal \u2014 the IP address, its risk score and detection flags, its network (ASN) number and name, its country code, and the checkout outcome (allowed \/ monitored \/ blocked, or refund\/chargeback feedback) \u2014 to the Predax Community Threat Network so all participating stores benefit from a shared feed. The Refund \/ Chargeback Feedback \"Log\" action reports through this same channel, so it requires this opt-in; its \"Blacklist\" action updates your local deny list regardless.<\/p>\n\n<p>This feature is <strong>off by default<\/strong>. It is controlled by the <code>ipsentry_woo_community_enabled<\/code> option, which defaults to <code>'no'<\/code>, with a checkbox on the Advanced settings tab. The plugin will not send community-feedback telemetry unless you enable it. Customers' personal data (names, emails, billing\/shipping addresses, order contents) is never included in the telemetry payload.<\/p>\n\n<ul>\n<li><strong>Endpoint:<\/strong> <code>POST https:\/\/predax.io\/api\/v1\/telemetry\/event<\/code><\/li>\n<li><strong>Service URL:<\/strong> https:\/\/predax.io<\/li>\n<li><strong>Privacy Policy:<\/strong> https:\/\/predax.io\/privacy<\/li>\n<\/ul>\n\n<h4>OAuth One-Click Connect (optional)<\/h4>\n\n<p>Only triggered when an administrator clicks the <strong>Connect with Predax<\/strong> button in the setup wizard. Your browser is redirected to predax.io to authorise the connection, which returns an API key to your site.<\/p>\n\n<ul>\n<li><strong>Data sent:<\/strong> your WordPress site URL, site name, and a PKCE state\/code-challenge pair. No customer data is involved.<\/li>\n<li><strong>When:<\/strong> only during the click-to-connect OAuth flow.<\/li>\n<li><strong>Endpoint:<\/strong> <code>POST https:\/\/predax.io\/api\/v1\/oauth\/token<\/code><\/li>\n<li><strong>Service URL:<\/strong> https:\/\/predax.io<\/li>\n<li><strong>Privacy Policy:<\/strong> https:\/\/predax.io\/privacy<\/li>\n<\/ul>\n\n<h4>Cookies set by this plugin<\/h4>\n\n<ul>\n<li><strong><code>ipsentry_tz<\/code><\/strong> \u2014 set on WooCommerce checkout pages (only while an API key is configured) via <code>assets\/js\/ipsentry-woo-tz.js<\/code>. Stores the customer's browser-reported IANA timezone (string, max 64 chars). Used server-side for the optional timezone-mismatch fraud rule. Expires after 24 hours (<code>max-age=86400<\/code>), <code>path=\/<\/code>, <code>SameSite=Lax<\/code>, and marked <code>Secure<\/code> on HTTPS stores. The plugin reads this cookie only at checkout-validation time.<\/li>\n<\/ul>\n\n<p>The plugin does not set any advertising, analytics, or tracking cookies.<\/p>\n\n<!--section=installation-->\n<ol>\n<li>Make sure WooCommerce is installed and activated.<\/li>\n<li>Upload the <code>predax-fraud-guard-for-woocommerce<\/code> folder to <code>\/wp-content\/plugins\/<\/code>.<\/li>\n<li>Activate the plugin through the <strong>Plugins<\/strong> menu in WordPress.<\/li>\n<li>The Setup Wizard launches on first activation. Either click <strong>Connect with Predax<\/strong> for OAuth one-click connection, or enter your API key manually.<\/li>\n<li>Pick a protection preset (Recommended \/ Strict \/ Monitor Only). This is the step where you opt in \u2014 IP lookups begin after this point.<\/li>\n<li>Fine-tune individual rules at <strong>Fraud Guard \u2192 Settings<\/strong> any time.<\/li>\n<\/ol>\n\n<!--section=faq-->\n<dl>\n<dt id=\"does%20the%20plugin%20phone%20home%20before%20i%20finish%20setup%3F\"><h3>Does the plugin phone home before I finish setup?<\/h3><\/dt>\n<dd><p>No. Before you enter an API key and save a protection mode, the plugin makes zero outbound requests to predax.io. Nothing happens silently on activation.<\/p><\/dd>\n<dt id=\"will%20it%20block%20legitimate%20customers%3F\"><h3>Will it block legitimate customers?<\/h3><\/dt>\n<dd><p>Only if you enable a blocking mode. Until you complete setup, the mode is <strong>Tag only<\/strong> (no blocking \u2014 orders just get tags and notes). In the setup wizard, the pre-selected <strong>Recommended<\/strong> preset enables blocking of high-risk checkouts (risk score 50+); choose <strong>Monitor Only<\/strong> instead if you don't want any blocking yet \u2014 each preset card lists exactly what it switches on.<\/p><\/dd>\n<dt id=\"what%20is%20the%20risk%20score%3F\"><h3>What is the risk score?<\/h3><\/dt>\n<dd><p>A score from 0 to 100 representing how likely an IP is to be associated with fraud, anonymisation, or abuse. 0 = clean residential IP, 100 = known Tor exit or commercial VPN. The score combines VPN\/proxy\/Tor detection, datacenter identification, historical abuse signals, and geographic heuristics.<\/p><\/dd>\n<dt id=\"does%20it%20work%20with%20cloudflare%3F\"><h3>Does it work with Cloudflare?<\/h3><\/dt>\n<dd><p>Yes \u2014 enable <strong>Fraud Guard \u2192 Settings \u2192 Advanced \u2192 \"Behind a proxy \/ CDN\"<\/strong> (or the same toggle on the WooCommerce \u2192 Predax tab). With it on, the plugin reads the real customer IP from the <code>CF-Connecting-IP<\/code> \/ <code>X-Forwarded-For<\/code> headers instead of the Cloudflare edge IP. It is <strong>off by default<\/strong>: when your store connects directly to visitors, trusting those headers would let a customer spoof their IP to bypass fraud checks, so you only turn it on when a proxy\/CDN really is in front of your site.<\/p><\/dd>\n<dt id=\"how%20do%20i%20test%20it%20without%20affecting%20real%20customers%3F\"><h3>How do I test it without affecting real customers?<\/h3><\/dt>\n<dd><p>Fraud Guard \u2192 Settings \u2192 Developer tab \u2192 enter a Test IP Override. Every checkout is then evaluated as if it came from that IP. A red admin banner reminds you test mode is active. Clear the override before going live.<\/p>\n\n<p>Use <code>185.220.101.1<\/code> (risk 85, Tor-adjacent) to exercise blocking paths, or <code>1.1.1.1<\/code> to verify pass-through.<\/p><\/dd>\n<dt id=\"what%20order%20metadata%20is%20stored%3F\"><h3>What order metadata is stored?<\/h3><\/dt>\n<dd><p>On each tagged order the plugin stores:<\/p>\n\n<ul>\n<li><code>_ipsentry_risk_score<\/code> \u2014 numeric risk score (0\u2013100)<\/li>\n<li><code>_ipsentry_ip<\/code> \u2014 detected customer IP<\/li>\n<li><code>_ipsentry_country_code<\/code> \u2014 detected IP country code<\/li>\n<li><code>_ipsentry_flags<\/code> \u2014 comma-separated threat flag list<\/li>\n<\/ul><\/dd>\n<dt id=\"does%20it%20work%20alongside%20the%20predax%20security%20plugin%3F\"><h3>Does it work alongside the Predax Security plugin?<\/h3><\/dt>\n<dd><p>Yes. The plugins are independent but complementary \u2014 Security protects logins and registrations, Fraud Guard protects WooCommerce checkout. Both can share the same API key.<\/p><\/dd>\n\n<\/dl>\n\n<!--section=changelog-->\n<h4>1.7.0<\/h4>\n\n<ul>\n<li>Rebrand: IPSentry is now <strong>Predax<\/strong>. This is the first WordPress.org release of the WooCommerce plugin. The plugin name, admin menu, and links now use Predax (predax.io). Your existing settings, API key, and order data are preserved \u2014 internal option names are unchanged, so nothing needs reconfiguring.<\/li>\n<li>Admin menu moved to a lower position so it no longer sits among the core WordPress menu items.<\/li>\n<li>Compliance: the OAuth-callback exit page now registers and prints its CSS\/JS through the WordPress script API (wp_register_style\/wp_register_script + wp_print_styles\/wp_print_scripts) instead of hand-written tags. The WooCommerce settings save and checkout timezone read run inside WooCommerce's own nonce-verified flows and carry inline justifications for the static analyser.<\/li>\n<li>Compatibility: declared WooCommerce High-Performance Order Storage (HPOS) compatibility.<\/li>\n<li>Fix: the order-velocity time window now uses a timestamp-based date query (the previous datetime-string form could be misread by WooCommerce and count orders outside the window).<\/li>\n<li>Hardening: checkout error notices are HTML-escaped before being added; the settings-import upload is capped at 512 KB with bounded JSON depth; the API base URL accepts http\/https only; the timezone cookie is marked Secure on HTTPS stores; the Store API block path gained an explicit return after blocking.<\/li>\n<li>Clarity: Refund \/ Chargeback Feedback labels and docs now state that \"Log\" reports go through the Community Threat Network opt-in; the readme documents exact API endpoints and the full telemetry data list.<\/li>\n<li>New: IP allow-list (never block trusted IPs) and a managed deny-list, both supporting single IPs and CIDR ranges (IPv4 + IPv6), editable from the settings page and the WooCommerce \u2192 Predax tab.<\/li>\n<li>New: the Community Threat Network opt-in is now a settings toggle (still off by default) instead of import\/export only.<\/li>\n<li>New: Events Log retention setting (default 90 days; 0 = keep forever) with automatic daily cleanup, plus a 7-day\/all-time stats summary, CSV export, and a Clear Log button.<\/li>\n<li>New: \"Behind a proxy \/ CDN\" setting (off by default). Enable it when your store is behind Cloudflare, a CDN, or a reverse proxy so the real customer IP is read from forwarded headers; when off, only the direct connection IP is used, so the customer IP cannot be spoofed to bypass fraud checks.<\/li>\n<li>Security: the Events Log CSV export now neutralises spreadsheet formula-injection \u2014 a billing email such as \"=...@example.com\" can no longer execute as a formula when the export is opened in Excel\/Sheets.<\/li>\n<li>Fix: the \"Flag for review\" action on the velocity, disposable-email, and billing-country-mismatch rules now reliably tags the order, adds the order note, and writes the Events Log entry (previously these markers could be dropped on processed orders).<\/li>\n<li>Fix: a critically-risky IP (risk score 90+) is now always blocked while a blocking mode is active, even when its VPN\/proxy category is set to Monitor.<\/li>\n<li>Fix: the WooCommerce \u2192 Predax settings tab now saves correctly (removed an invalid nested import form; import is now on the Fraud Guard \u2192 Developer page).<\/li>\n<li>Hardening: \/0 (match-all) entries are rejected in the IP allow\/deny lists, and uninstall now cleans every site on a multisite network.<\/li>\n<li>No change to the opt-in model \u2014 the plugin still makes zero outbound requests until you enter an API key and save a protection mode.<\/li>\n<\/ul>\n\n<h4>1.6.2<\/h4>\n\n<ul>\n<li>Compliance: community-feedback telemetry is now explicitly opt-in (off by default) behind a new <code>ipsentry_woo_community_enabled<\/code> option. Existing installs stop sending telemetry until they flip this on.<\/li>\n<li>Compliance: all phoning-home defaults flipped to off \u2014 <code>block_proxy<\/code>, <code>block_tor<\/code>, and <code>monitor_vpn<\/code> default to <code>'no'<\/code> on fresh installs.<\/li>\n<li>Compliance: removed the self-hosted plugin updater class per WP.org Guideline 8.<\/li>\n<li>Compliance: extracted every inline <code>&lt;script&gt;<\/code> \/ <code>&lt;style&gt;<\/code> block to enqueued asset files. OAuth-callback exit page now references an external CSS\/JS pair.<\/li>\n<li>Compliance: Privacy Policy content hook (<code>wp_add_privacy_policy_content<\/code>) so admins can pull suggested text from Tools \u2192 Privacy.<\/li>\n<li>Compliance: Setup-wizard privacy-disclosure boxes added above OAuth button, manual API-key field, and preset-picker cards.<\/li>\n<li>Compliance: nonce-before-cap order fixed on every admin-post and AJAX handler.<\/li>\n<li>Compliance: input sanitisation tightened on every <code>$_GET<\/code> \/ <code>$_POST<\/code> \/ <code>$_FILES<\/code> read; imported settings values now validated per option type.<\/li>\n<li>Compliance: Test-mode admin notice now scoped to Predax pages only (not global).<\/li>\n<li>Added: <code>uninstall.php<\/code> drops the events-log table and deletes every <code>ipsentry_woo_*<\/code> option on plugin deletion.<\/li>\n<li>Added: <code>Domain Path: \/languages<\/code> header + minimal .pot translation template.<\/li>\n<li>Added: <code>.distignore<\/code> excluding dev artefacts from the WP.org zip.<\/li>\n<li>No behaviour change for existing installs other than the community-feedback gate \u2014 core IP checking still works as before.<\/li>\n<\/ul>\n\n<h4>1.6.1<\/h4>\n\n<ul>\n<li>Improved: OAuth connect popup now auto-closes reliably after authorization.<\/li>\n<li>Improved: Per-user OAuth transients prevent conflicts on multi-admin sites.<\/li>\n<\/ul>\n\n<h4>1.6.0<\/h4>\n\n<ul>\n<li>New: Setup Wizard \u2014 guided 3-step setup on first activation with fraud protection presets (Recommended, Strict, Monitor Only).<\/li>\n<li>New: One-Click Connect \u2014 click \"Connect with Predax\" in the setup wizard to link your store via OAuth. No API key to copy or paste.<\/li>\n<li>New: \"Run Setup Wizard\" link in Developer tab to re-run the wizard at any time.<\/li>\n<\/ul>\n\n<h4>1.5.0<\/h4>\n\n<ul>\n<li>New: Events Log admin page (Predax \u2192 Events Log) \u2014 two tabs showing blocked checkout attempts and flagged\/held orders with IP, risk score, flags, reason, and order links.<\/li>\n<li>New: Predax risk column on WooCommerce \u2192 Orders list \u2014 shows colour-coded score badge and top threat flag.<\/li>\n<li>Improvement: Orders now store a combined <code>_ipsentry_flags<\/code> meta key for quick flag lookup.<\/li>\n<\/ul>\n\n<h4>1.4.3<\/h4>\n\n<ul>\n<li>New: Dedicated settings page under Predax \u2192 Fraud Guard in the WordPress admin left nav \u2014 same tabbed UI as the Security plugin.<\/li>\n<\/ul>\n\n<h4>1.4.2<\/h4>\n\n<ul>\n<li>New: Settings import\/export \u2014 back up your configuration or copy it between sites.<\/li>\n<li>New: Support Email field \u2014 if set, checkout block error messages include a \"Contact us at\u2026\" line.<\/li>\n<\/ul>\n\n<h4>1.4.1<\/h4>\n\n<ul>\n<li>Fix: VPN\/proxy customers set to Monitor mode were incorrectly blocked by the risk threshold.<\/li>\n<\/ul>\n\n<h4>1.4.0<\/h4>\n\n<ul>\n<li>New: Automatic order hold, order velocity rules, billing country vs IP mismatch, disposable email detection, refund\/chargeback feedback, test IP override.<\/li>\n<\/ul>\n\n<h4>1.3.0<\/h4>\n\n<ul>\n<li>New: Off\/Monitor\/Block radio groups for VPN, proxy, and Tor.<\/li>\n<li>New: Custom risk scoring weights \u2014 adjust per-signal contribution to the final risk score.<\/li>\n<\/ul>\n\n<h4>1.2.0<\/h4>\n\n<ul>\n<li>New: Country-based blocking at checkout. Whitelist support. API timeout handling.<\/li>\n<\/ul>\n\n<h4>1.1.0<\/h4>\n\n<ul>\n<li>New: Configurable risk threshold. Order meta. Detailed order notes.<\/li>\n<\/ul>\n\n<h4>1.0.0<\/h4>\n\n<ul>\n<li>Initial release. Tag-only fraud screening at checkout. VPN \/ proxy \/ Tor \/ datacenter detection.<\/li>\n<\/ul>","raw_excerpt":"Reduce WooCommerce fraud with Predax IP intelligence. After you enable a protection mode, each checkout IP is screened for VPN\/proxy\/Tor risk.","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin\/323963","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin"}],"about":[{"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/types\/plugin"}],"replies":[{"embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/comments?post=323963"}],"author":[{"embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wporg\/v1\/users\/ipsentry"}],"wp:attachment":[{"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/media?parent=323963"}],"wp:term":[{"taxonomy":"plugin_section","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_section?post=323963"},{"taxonomy":"plugin_tags","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_tags?post=323963"},{"taxonomy":"plugin_category","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_category?post=323963"},{"taxonomy":"plugin_contributors","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_contributors?post=323963"},{"taxonomy":"plugin_business_model","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_business_model?post=323963"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}