{"id":308381,"date":"2026-05-09T21:37:31","date_gmt":"2026-05-09T21:37:31","guid":{"rendered":"https:\/\/wordpress.org\/plugins\/disposable-email-blocker\/"},"modified":"2026-05-09T21:37:28","modified_gmt":"2026-05-09T21:37:28","slug":"wpcoretools-disposable-email-guard","status":"publish","type":"plugin","link":"https:\/\/nl.wordpress.org\/plugins\/wpcoretools-disposable-email-guard\/","author":23437078,"comment_status":"closed","ping_status":"closed","template":"","meta":{"_crdt_document":"","version":"1.0.2","stable_tag":"1.0.2","tested":"7.0","requires":"6.2","requires_php":"7.4","requires_plugins":null,"header_name":"WPCoreTools Disposable Email Guard","header_author":"WPCoreTools","header_description":"Block disposable, burner, temp-mail, and (optionally) anonymous\/privacy email providers (Proton, Tuta, SimpleLogin) on WordPress + WooCommerce sign-ups, profile changes, comments, and any custom form. Bundled domain lists work fully offline; no external service is contacted by default.","assets_banners_color":"39475f","last_updated":"2026-05-09 21:37:28","external_support_url":"","external_repository_url":"","donate_link":"","header_plugin_uri":"https:\/\/wpcoretools.com\/plugins\/wpcoretools-disposable-email-guard\/","header_author_uri":"https:\/\/wpcoretools.com\/","rating":0,"author_block_rating":0,"active_installs":0,"downloads":23,"num_ratings":0,"support_threads":0,"support_threads_resolved":0,"author_block_count":0,"sections":["description","installation","faq","changelog"],"tags":{"1.0.2":{"tag":"1.0.2","author":"wpcoretools","date":"2026-05-09 21:37:28"}},"upgrade_notice":[],"ratings":[],"assets_icons":{"icon-128x128.png":{"filename":"icon-128x128.png","revision":3527445,"resolution":"128x128","location":"assets","locale":""},"icon-256x256.png":{"filename":"icon-256x256.png","revision":3527445,"resolution":"256x256","location":"assets","locale":""}},"assets_banners":{"banner-1544x500.png":{"filename":"banner-1544x500.png","revision":3527445,"resolution":"1544x500","location":"assets","locale":""},"banner-772x250.png":{"filename":"banner-772x250.png","revision":3527445,"resolution":"772x250","location":"assets","locale":""}},"assets_blueprints":{},"all_blocks":[],"tagged_versions":["1.0.2"],"block_files":[],"assets_screenshots":[],"screenshots":[],"jetpack_post_was_ever_published":false},"plugin_section":[262246],"plugin_tags":[2656,262432,12886,2182,12887],"plugin_category":[],"plugin_contributors":[254220],"plugin_business_model":[],"class_list":["post-308381","plugin","type-plugin","status-publish","hentry","plugin_section-dashboard-widgets","plugin_tags-anti-spam","plugin_tags-burner-email","plugin_tags-disposable-email","plugin_tags-email-validation","plugin_tags-temporary-email","plugin_contributors-wpcoretools","plugin_committers-wpcoretools"],"banners":{"banner":"https:\/\/ps.w.org\/wpcoretools-disposable-email-guard\/assets\/banner-772x250.png?rev=3527445","banner_2x":"https:\/\/ps.w.org\/wpcoretools-disposable-email-guard\/assets\/banner-1544x500.png?rev=3527445","banner_rtl":false,"banner_2x_rtl":false},"icons":{"svg":false,"icon":"https:\/\/ps.w.org\/wpcoretools-disposable-email-guard\/assets\/icon-128x128.png?rev=3527445","icon_2x":"https:\/\/ps.w.org\/wpcoretools-disposable-email-guard\/assets\/icon-256x256.png?rev=3527445","generated":false},"screenshots":[],"raw_content":"<!--section=description-->\n<p>This plugin refuses sign-ups, comments, checkouts, and form submissions when the email address belongs to a disposable, burner, or temp-mail service. All checks run on your own server against domain lists that ship inside the plugin file \u2014 no email address is ever sent to a third-party service, and the plugin does not contact any external server in its default configuration.<\/p>\n\n<p>Five well-known community-maintained disposable-email lists are bundled as snapshots. Two are active out of the box (around 9,800 unique domains combined); three larger lists are available as opt-in for stricter coverage. An optional auto-update from the upstream GitHub URLs is also available, off by default.<\/p>\n\n<h4>What it detects<\/h4>\n\n<ul>\n<li>Disposable and burner addresses (default ON) \u2014 Mailinator, YOPmail, Guerrilla Mail, 10minutemail, Temp-Mail, and similar services.<\/li>\n<li>Anonymous \/ privacy mail (default OFF) \u2014 Proton Mail, Tutanota, Mailbox.org, Posteo, StartMail, SimpleLogin, addy.io, DuckDuckGo Email Protection, Firefox Relay, Apple Hide My Email. Off by default because plenty of legitimate paying customers prefer these services.<\/li>\n<li>Plus-addressing aliases (default OFF) \u2014 <code>user+tag@example.com<\/code> style sub-addresses.<\/li>\n<li>Dead and no-MX domains (default OFF) \u2014 typos like <code>gnail.com<\/code>, parked or expired domains. One DNS lookup per new domain, then cached.<\/li>\n<li>Custom block and allow rules with wildcard patterns: <code>*@spammer.com<\/code>, <code>*@*.ru<\/code>, <code>spam*@*<\/code>.<\/li>\n<\/ul>\n\n<h4>Where it checks<\/h4>\n\n<p>WordPress core:<\/p>\n\n<ul>\n<li>Registration form<\/li>\n<li>Profile email change<\/li>\n<li>Comment author email (off by default)<\/li>\n<li>Programmatic user creation (<code>wp_insert_user<\/code>, REST API, WP-CLI, other plugins)<\/li>\n<li>Lost-password form<\/li>\n<li>Multisite signup form<\/li>\n<\/ul>\n\n<p>WooCommerce:<\/p>\n\n<ul>\n<li>Customer registration<\/li>\n<li>Checkout (billing email)<\/li>\n<li>My Account \u2192 Edit Account email change<\/li>\n<li>Product reviews<\/li>\n<li>Coupon application \u2014 refuse coupons when the billing email is on a blocklist (anti-abuse safety net)<\/li>\n<\/ul>\n\n<p>Form plugins:<\/p>\n\n<ul>\n<li>Contact Form 7 \u2014 built-in, no configuration needed<\/li>\n<li>Gravity Forms \u2014 built-in, no configuration needed<\/li>\n<li>Any other form plugin via the <code>wpcdeg_check<\/code> filter (one line of PHP from your form's email-validation hook)<\/li>\n<\/ul>\n\n<h4>Three modes<\/h4>\n\n<ul>\n<li><strong>Block<\/strong> \u2014 reject the submission with a clear error message.<\/li>\n<li><strong>Flag<\/strong> \u2014 let the submission through, but tag the user \/ comment \/ order with <code>wpcdeg_flagged<\/code> meta so you can review them in a list. Pairs with WooCommerce auto-hold and coupon refusal.<\/li>\n<li><strong>Log only<\/strong> \u2014 record matches in the detection log without rejecting or tagging anything. Useful for a dry-run before turning enforcement on.<\/li>\n<\/ul>\n\n<h4>Domain lists<\/h4>\n\n<p>Five bundled snapshots are available, each toggled independently:<\/p>\n\n<ul>\n<li><code>disposable-email-domains<\/code> (MIT) \u2014 ON by default, ~5,400 domains.<\/li>\n<li><code>7c\/fakefilter<\/code> \u2014 ON by default, ~4,500 domains.<\/li>\n<li><code>groundcat\/disposable-email-domain-list<\/code> (MIT) \u2014 opt-in, ~27,000 domains.<\/li>\n<li><code>wesbos\/burner-email-providers<\/code> (MIT) \u2014 opt-in, ~27,000 domains.<\/li>\n<li><code>disposable\/disposable-email-domains<\/code> (MIT) \u2014 opt-in, ~72,000 domains.<\/li>\n<\/ul>\n\n<p>Each ships as a snapshot inside the plugin (<code>data\/sources\/{id}.txt<\/code>) and is loaded from disk; no network call is required for any of them to function.<\/p>\n\n<p>If you want the snapshots refreshed on a schedule from their GitHub raw URLs, an optional auto-update feature is available. It is off by default. See \"External services\" below for what is contacted and what is sent.<\/p>\n\n<h4>Tools<\/h4>\n\n<ul>\n<li>Stats dashboard with a 14-day activity chart, per-reason breakdown, and top detected domains.<\/li>\n<li>WP Dashboard widget with the same at-a-glance summary.<\/li>\n<li>Detection log with date \/ reason \/ context filters and CSV export.<\/li>\n<li>Optional periodic email digest, daily or weekly.<\/li>\n<li>CSV \/ TXT bulk import for the blocklist and the allowlist.<\/li>\n<li>Settings JSON export and import for moving configuration between sites.<\/li>\n<li>WP-CLI: <code>wp wpcdeg refresh \/ test \/ stats \/ log \/ sources \/ clear-log<\/code>.<\/li>\n<li>HPOS and Cart\/Checkout Blocks compatibility declarations.<\/li>\n<\/ul>\n\n<h4>Privacy<\/h4>\n\n<ul>\n<li>No email address is ever sent to a third-party service.<\/li>\n<li>The plugin does not contact any external server in its default configuration.<\/li>\n<li>If you enable the optional auto-update feature, the plugin issues HTTPS GET requests to <code>raw.githubusercontent.com<\/code> for the source URLs you have selected. The request body is empty, the User-Agent is <code>WPCoreToolsDisposableEmailGuard\/&lt;version&gt;<\/code>, and no email addresses, user data, or your site URL are transmitted. Full disclosure under \"External services\" below.<\/li>\n<li>The detection log stores the email address, domain, reason, and IP address locally for admin review. Retention is configurable from 7 to 365 days (default 90); a daily WP-Cron job purges older rows.<\/li>\n<li>On uninstall, all data is deleted only if you turned on the \"Delete data on uninstall\" setting.<\/li>\n<\/ul>\n\n<h3>External services<\/h3>\n\n<p>This plugin can optionally contact one external service. The feature is <strong>off by default<\/strong> and must be explicitly enabled via the setup wizard or the Lists tab (Settings \u2192 WPCoreTools Disposable Email Guard \u2192 Lists \u2192 \"Auto-update from upstream sources\").<\/p>\n\n<h4>GitHub (raw.githubusercontent.com)<\/h4>\n\n<ul>\n<li><strong>What it is:<\/strong> GitHub serves the raw source files of five public, community-maintained lists of disposable-email domains. The plugin downloads only the list files; nothing else.<\/li>\n<li><strong>What it is used for:<\/strong> Refreshing the bundled snapshots of the disposable-email lists you have selected, so your active blocklist stays current between plugin releases.<\/li>\n<li><strong>When data is sent:<\/strong> Only when the \"Auto-update from upstream sources\" setting is enabled, and only on the schedule you configure (hourly \/ twice-daily \/ daily \/ weekly), or when you click the \"Update now\" button on the Lists tab.<\/li>\n<li><strong>What is sent:<\/strong> One HTTPS GET request per enabled source URL. The request body is empty. The User-Agent is <code>WPCoreToolsDisposableEmailGuard\/&lt;plugin-version&gt;<\/code>. No email addresses, user data, IP information beyond what GitHub's CDN normally logs, or your site URL are transmitted.<\/li>\n<li><strong>Where the requests go:<\/strong>\n\n<ul>\n<li><code>https:\/\/raw.githubusercontent.com\/disposable-email-domains\/disposable-email-domains\/main\/disposable_email_blocklist.conf<\/code><\/li>\n<li><code>https:\/\/raw.githubusercontent.com\/7c\/fakefilter\/main\/txt\/data.txt<\/code><\/li>\n<li><code>https:\/\/raw.githubusercontent.com\/groundcat\/disposable-email-domain-list\/master\/domains.txt<\/code><\/li>\n<li><code>https:\/\/raw.githubusercontent.com\/wesbos\/burner-email-providers\/master\/emails.txt<\/code><\/li>\n<li><code>https:\/\/raw.githubusercontent.com\/disposable\/disposable-email-domains\/master\/domains.txt<\/code><\/li>\n<\/ul><\/li>\n<li><strong>Service operator:<\/strong> GitHub, Inc.<\/li>\n<li><strong>Terms of service:<\/strong> https:\/\/docs.github.com\/en\/site-policy\/github-terms\/github-terms-of-service<\/li>\n<li><strong>Privacy statement:<\/strong> https:\/\/docs.github.com\/en\/site-policy\/privacy-policies\/github-general-privacy-statement<\/li>\n<\/ul>\n\n<p>If you would rather not contact GitHub at all, leave \"Auto-update from upstream sources\" off (its default state). The bundled snapshots provide full functionality offline.<\/p>\n\n<p>You may also add your own custom URLs on the Lists tab (e.g. an internal threat-feed URL or a private gist). Those URLs are contacted on the same schedule and follow the same rules; they are entirely under your control.<\/p>\n\n<!--section=installation-->\n<ol>\n<li>Upload the plugin folder to <code>\/wp-content\/plugins\/<\/code>, or install it via Plugins \u2192 Add New.<\/li>\n<li>Activate the plugin.<\/li>\n<li>Visit Settings \u2192 WPCoreTools Disposable Email Guard. The first-time setup wizard runs automatically.<\/li>\n<\/ol>\n\n<p>The bundled domain lists are active immediately on activation; the plugin works fully offline. Anonymous-provider blocking, plus-addressing checks, dead-domain MX checks, and the optional auto-update of source snapshots are all off by default and must be enabled explicitly.<\/p>\n\n<!--section=faq-->\n<dl>\n<dt id=\"does%20this%20send%20my%20visitors%27%20email%20addresses%20to%20an%20external%20service%3F\"><h3>Does this send my visitors' email addresses to an external service?<\/h3><\/dt>\n<dd><p>No. Every check runs locally against domain lists that ship inside the plugin file. By default the plugin makes no outbound connections at all.<\/p><\/dd>\n<dt id=\"does%20the%20plugin%20contact%20github%20or%20any%20other%20server%20in%20its%20default%20configuration%3F\"><h3>Does the plugin contact GitHub or any other server in its default configuration?<\/h3><\/dt>\n<dd><p>No. The bundled snapshots are loaded from disk. The optional auto-update feature, which would contact GitHub to refresh those snapshots, is off by default and must be enabled in the setup wizard or the Lists tab. See \"External services\" for the full disclosure.<\/p><\/dd>\n<dt id=\"will%20this%20block%20legitimate%20proton%20mail%20or%20tutanota%20users%3F\"><h3>Will this block legitimate Proton Mail or Tutanota users?<\/h3><\/dt>\n<dd><p>Only if you turn on the \"Anonymous \/ privacy providers\" toggle. It is off by default for exactly that reason.<\/p><\/dd>\n<dt id=\"how%20are%20the%20disposable%20lists%20kept%20up%20to%20date%3F\"><h3>How are the disposable lists kept up to date?<\/h3><\/dt>\n<dd><p>Two ways. Either install a fresh version of the plugin (each release bundles updated snapshots), or opt into the auto-update feature, which lets WP-Cron fetch the source URLs from GitHub on a schedule (hourly, twice-daily, daily, or weekly).<\/p><\/dd>\n<dt id=\"can%20i%20dry-run%20before%20i%20switch%20on%20blocking%3F\"><h3>Can I dry-run before I switch on blocking?<\/h3><\/dt>\n<dd><p>Yes. Set Mode to \"Log only\" \u2014 emails are recorded but no submissions are rejected. Or use \"Flag\" mode to allow signups but tag the user \/ order \/ comment for admin review.<\/p><\/dd>\n<dt id=\"what%20is%20%22flag%22%20mode%3F\"><h3>What is \"Flag\" mode?<\/h3><\/dt>\n<dd><p>A non-destructive alternative to outright blocking. Submissions go through, but matching users get a <code>wpcdeg_flagged<\/code> user meta and a \"Flagged\" column on the Users list, comments get a meta tag, and WooCommerce orders get an order note plus a \"Flagged\" column on the Orders list. Useful when you do not want to lock out potential Proton or Tutanota customers but still want to triage them.<\/p><\/dd>\n<dt id=\"does%20it%20work%20with%20woocommerce%20hpos%3F\"><h3>Does it work with WooCommerce HPOS?<\/h3><\/dt>\n<dd><p>Yes, both the legacy posts-table orders list and HPOS are supported.<\/p><\/dd>\n<dt id=\"does%20it%20work%20with%20contact%20form%207%20and%20gravity%20forms%3F\"><h3>Does it work with Contact Form 7 and Gravity Forms?<\/h3><\/dt>\n<dd><p>Yes, built-in integration on both. For other form plugins (WPForms, Elementor Forms, Forminator, Fluent Forms, etc.), call the <code>wpcdeg_check<\/code> filter from your form's email-validation hook.<\/p><\/dd>\n<dt id=\"what%20happens%20if%20a%20remote%20list%20url%20is%20unreachable%20when%20auto-update%20runs%3F\"><h3>What happens if a remote list URL is unreachable when auto-update runs?<\/h3><\/dt>\n<dd><p>The previous successful copy is kept (no data loss); the failure is recorded in the per-source meta. If no fetch has ever succeeded, the bundled snapshot continues to be used.<\/p><\/dd>\n<dt id=\"will%20it%20slow%20down%20my%20site%3F\"><h3>Will it slow down my site?<\/h3><\/dt>\n<dd><p>No. Each email check is an O(1) lookup against an in-memory map, loaded once per request and cached for an hour.<\/p><\/dd>\n<dt id=\"does%20the%20mx%20record%20check%20slow%20down%20sign-ups%3F\"><h3>Does the MX record check slow down sign-ups?<\/h3><\/dt>\n<dd><p>Only the first lookup per domain \u2014 results are cached for 24 hours on success and 1 hour on failure. Most sign-ups hit the cache immediately. The check is opt-in and off by default.<\/p><\/dd>\n\n<\/dl>\n\n<!--section=changelog-->\n<h4>1.0.2<\/h4>\n\n<p>Initial public release.<\/p>\n\n<ul>\n<li>Five bundled disposable-email source snapshots, two enabled by default; works fully offline.<\/li>\n<li>Three modes: block, flag, log only.<\/li>\n<li>Optional anonymous-provider blocking, plus-addressing checks, dead-MX checks (all off by default).<\/li>\n<li>WordPress integrations: registration, profile, comments, lost-password, multisite signup, programmatic user creation.<\/li>\n<li>WooCommerce integrations: registration, checkout, My Account email change, product reviews, coupon-abuse blocker, auto-hold for flagged orders. HPOS and Cart\/Checkout Blocks compatible.<\/li>\n<li>Built-in Contact Form 7 and Gravity Forms integration; generic <code>wpcdeg_check<\/code> filter for other form plugins.<\/li>\n<li>Custom block \/ allow lists with wildcard support.<\/li>\n<li>Detection log with filters and CSV export, stats dashboard with 14-day chart, optional periodic email digest.<\/li>\n<li>WP-CLI: <code>refresh<\/code>, <code>test<\/code>, <code>stats<\/code>, <code>log<\/code>, <code>sources<\/code>, <code>clear-log<\/code>.<\/li>\n<li>CSV \/ TXT bulk import; settings JSON export and import.<\/li>\n<li>Per-reason customizable user-facing messages; quiet-hour cron scheduling in site timezone.<\/li>\n<\/ul>","raw_excerpt":"Block disposable, burner, and temp-mail addresses on WordPress and WooCommerce sign-ups, comments, checkout, and any custom form. Works fully offline.","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/nl.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin\/308381","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/nl.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin"}],"about":[{"href":"https:\/\/nl.wordpress.org\/plugins\/wp-json\/wp\/v2\/types\/plugin"}],"replies":[{"embeddable":true,"href":"https:\/\/nl.wordpress.org\/plugins\/wp-json\/wp\/v2\/comments?post=308381"}],"author":[{"embeddable":true,"href":"https:\/\/nl.wordpress.org\/plugins\/wp-json\/wporg\/v1\/users\/wpcoretools"}],"wp:attachment":[{"href":"https:\/\/nl.wordpress.org\/plugins\/wp-json\/wp\/v2\/media?parent=308381"}],"wp:term":[{"taxonomy":"plugin_section","embeddable":true,"href":"https:\/\/nl.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_section?post=308381"},{"taxonomy":"plugin_tags","embeddable":true,"href":"https:\/\/nl.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_tags?post=308381"},{"taxonomy":"plugin_category","embeddable":true,"href":"https:\/\/nl.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_category?post=308381"},{"taxonomy":"plugin_contributors","embeddable":true,"href":"https:\/\/nl.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_contributors?post=308381"},{"taxonomy":"plugin_business_model","embeddable":true,"href":"https:\/\/nl.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_business_model?post=308381"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}