Woo Guard
You are reviewing generated or changed WooCommerce code before it ships. Apply the rules below as a guard pass after the first implementation pass. WooCommerce is a moving platform — order storage changed engines, checkout changed frameworks — and code written from memory targets the WooCommerce of three years ago. With money on the line, "works on my demo store" is not a standard.
These rules exist because AI agents produce WooCommerce code with systematic failures: order meta read through
(broken on HPOS stores), products updated by direct meta writes that skip lookup tables and hooks, checkout validated only in JavaScript, prices computed in floats, and
hooks registered before confirming WooCommerce is active.
How to use this skill
Guard-pass mode (recommended): after WooCommerce code has been generated or edited, apply the rules to the diff or target files, then run the self-check before delivery.
Live mode (explicit): when the user invokes this skill before writing WooCommerce code, apply the same rules while writing, then run the self-check before delivery.
Review mode (the user asks you to review or audit WooCommerce code): walk references/review-checklist.md and produce a structured findings report. Do not edit code in review mode unless asked.
Security floor — these hold in all WooCommerce code, at maximum severity, because money is on the line:
- Escape all output with the context-correct function.
- then sanitize all request data before it touches logic.
- Capability check plus nonce on every state change.
- for every query containing a variable.
If wp-guard is installed, run it alongside for the full WordPress layer.
Adapt to the project first
- Read the project's agent instructions and the extension's declared WooCommerce version range. Project conventions win on conflict.
- Determine the order storage mode this code must support: HPOS, legacy posts, or both (the default assumption is both).
- Determine the checkout in play: Blocks/Store API, legacy shortcode checkout, or both. Hooks for one do not fire in the other.
- Check whether WooCommerce activity is guarded: feature checks or
class_exists( 'WooCommerce' )
before any call or hook.
The Rules
Order and product data — must fix
-
Orders are not posts. Access orders only through the CRUD API:
,
,
,
$order->update_meta_data()
+
. Forbidden on order data:
,
,
/
with
, and direct
joins on postmeta. These work on legacy stores and silently break on HPOS stores. Details:
references/hpos-and-crud.md.
-
CRUD objects, getters/setters, then save. Products, customers, and coupons go through their CRUD objects (
, setters,
). Direct meta writes skip lookup-table sync, skip the hooks other extensions rely on, and skip cache invalidation. Stock changes go through
wc_update_product_stock()
semantics; order state changes through
— which fire the emails and hooks the store expects.
-
Declare feature compatibility. Any extension touching orders declares HPOS compatibility (
FeaturesUtil::declare_compatibility( 'custom_order_tables', … )
); any extension touching checkout declares
compatibility (or incompatibility, honestly). A missing declaration shows every store owner a warning banner with your plugin's name on it.
Checkout and money — must fix
-
Checkout validation is server-side. Validate at
woocommerce_checkout_process
(legacy) or through Store API extension schemas (Blocks). JavaScript validation is UX, never security. Know which checkout the store runs and wire both when the extension claims general compatibility.
-
Money is not a float. Prices and totals go through
for storage-safe values,
for display, and WooCommerce's own tax/rounding settings for arithmetic. No hand-rolled currency symbols, no
on prices, no float equality on totals.
Runtime discipline — should fix
-
Guard the runtime context. and
are null in REST, cron, CLI, and admin contexts — check before touching them. Never assume a logged-in customer in webhook or gateway callbacks. Verify every
hook and
function exists in the supported version range — WooCommerce renames and retires hooks across majors.
-
Hooks over template overrides. Prefer, in order: existing WooCommerce hooks/filters → the
woocommerce_locate_template
filter → a theme-level override. A template override shipped inside a plugin freezes a copied file at one WooCommerce version and breaks on template updates — flag it in review, always.
-
Background work scales with order volume. Batch jobs, syncs, and webhook fan-out go through Action Scheduler (bundled with WooCommerce), not raw WP-Cron loops. Handlers are idempotent — order events fire more than once in real stores.
Self-check before delivery
- Grep your diff for , ,
post_type => 'shop_order'
: any of them touching orders? (Rule 1)
- Any product/order/customer write that bypasses a CRUD object's ? (Rule 2)
- Does the extension declare HPOS (and checkout-blocks, if relevant) compatibility? (Rule 3)
- Is every checkout rule enforced server-side, for the checkout(s) the store actually runs? (Rule 4)
- Any float arithmetic, hardcoded currency symbol, or on money? (Rule 5)
- Any / access that can run in REST/cron/CLI? Any unverified hook name? (Rule 6)
- Any template file shipped in the plugin? (Rule 7)
- Security floor: every output escaped, every request input unslashed then sanitized, every state change capability-checked and nonce-verified, every variable query prepared?
If any answer is wrong, fix it before showing the user.
Reporting format (review mode)
**Rule N violation** in `path/file.php:<line or function>`
- What: <one sentence>
- Risk: <HPOS breakage / skipped hooks / money error / checkout bypass — one phrase>
- Fix: <one sentence>
Group by file, lead with Rules 1–5 findings. If a file is clean, don't mention it.
Severity guide
- Must fix: Rules 1–5 — broken stores, skipped business logic, wrong money
- Should fix: Rules 6–8 — context crashes, update fragility, jobs that die at scale
References
- references/hpos-and-crud.md — HPOS background, CRUD patterns, compatibility declaration, violation table
- references/checkout-and-money.md — legacy vs Blocks checkout, Store API validation, price and currency handling
- references/review-checklist.md — structured walk-through for review mode
- references/sources.md — WooCommerce developer documentation URLs; read only when citing
What this skill does not do
- Cover the full WordPress layer beyond the security floor — i18n and asset/query discipline are wp-guard's jurisdiction when it is installed.
- Review store configuration, theme styling, or payment provider account setup.
- Decide pricing or business logic — it guards how WooCommerce code ships, not what the store sells.