{"id":50496,"date":"2016-08-25T09:13:41","date_gmt":"2016-08-25T09:13:41","guid":{"rendered":"https:\/\/wordpress.org\/plugins-wp\/wp-login-door\/"},"modified":"2025-06-11T16:21:45","modified_gmt":"2025-06-11T16:21:45","slug":"wp-login-door","status":"publish","type":"plugin","link":"https:\/\/pcd.wordpress.org\/plugins\/wp-login-door\/","author":15083688,"comment_status":"closed","ping_status":"closed","template":"","meta":{"_crdt_document":"","version":"1.5","stable_tag":"1.5","tested":"6.8.5","requires":"4.0.0","requires_php":"","requires_plugins":null,"header_name":"WP Login Door","header_author":"Nicolas Simonnet","header_description":"","assets_banners_color":"c3c3c3","last_updated":"2025-06-11 16:21:45","external_support_url":"","external_repository_url":"","donate_link":"http:\/\/dirtymarmotte.net\/en\/donations\/","header_plugin_uri":"http:\/\/dirtymarmotte.net\/","header_author_uri":"http:\/\/dirtymarmotte.net","rating":5,"author_block_rating":0,"active_installs":400,"downloads":4499,"num_ratings":6,"support_threads":0,"support_threads_resolved":0,"author_block_count":0,"sections":["description","installation","faq","changelog"],"tags":{"1.5":{"tag":"1.5","author":"toxnico","date":"2025-06-11 16:21:45"}},"upgrade_notice":[],"ratings":{"1":0,"2":0,"3":0,"4":0,"5":6},"assets_icons":{"icon-128x128.png":{"filename":"icon-128x128.png","revision":1484033,"resolution":"128x128","location":"assets","locale":""}},"assets_banners":{"banner-772x250.png":{"filename":"banner-772x250.png","revision":1484011,"resolution":"772x250","location":"assets","locale":""}},"assets_blueprints":{},"all_blocks":[],"tagged_versions":["1.5"],"block_files":[],"assets_screenshots":[],"screenshots":[],"jetpack_post_was_ever_published":false},"plugin_section":[],"plugin_tags":[2438,1244,602,600,14731],"plugin_category":[38,54],"plugin_contributors":[93859],"plugin_business_model":[],"class_list":["post-50496","plugin","type-plugin","status-publish","hentry","plugin_tags-bruteforce","plugin_tags-hide","plugin_tags-login","plugin_tags-security","plugin_tags-xmlrpc","plugin_category-authentication","plugin_category-security-and-spam-protection","plugin_contributors-toxnico","plugin_committers-toxnico"],"banners":{"banner":"https:\/\/ps.w.org\/wp-login-door\/assets\/banner-772x250.png?rev=1484011","banner_2x":false,"banner_rtl":false,"banner_2x_rtl":false},"icons":{"svg":false,"icon":"https:\/\/ps.w.org\/wp-login-door\/assets\/icon-128x128.png?rev=1484033","icon_2x":false,"generated":false},"screenshots":[],"raw_content":"<!--section=description-->\n<p>Did you ever feel like your website or blog login page is ridiculously fragile and reachable, and could be easily broken in by an intruder?<\/p>\n\n<p>Personally I hate to think of hundreds of people playing with my door lock hundreds of times a day. It's the same with my blog login page.<\/p>\n\n<p>On Wordpress, there are two main potential vectors of bruteforce intrusion:\n*  http:\/\/my-site.com\/wp-login.php, which is the login page\n*  http:\/\/my-site.com\/xmlrpc.php, which is an API gateway for interacting with third party applications.<\/p>\n\n<p>This plugin adds one security layer in front of your login page, and by the way you can also disable XML-RPC with a simple checkbox if you don't need it (XML-RPC is a <em><strong>WIDELY<\/strong><\/em> used vector of attacks).<\/p>\n\n<p>The idea is simple: you choose a pair of words, and when you want to access your login page, you just have to provide them in the URL like this: http:\/\/my-site.com\/wp-login.php?word1=word2. That's all!\nIf you try to access your login page without this pair of words, you get a configurable error message, where you can insult the attacker as much as you want ;)<\/p>\n\n<!--section=installation-->\n<ol>\n<li>Upload the plugin files to the <code>\/wp-content\/plugins\/wp-login-door<\/code> directory, or install the plugin through the WordPress plugins screen directly.<\/li>\n<li>Activate the plugin through the 'Plugins' screen in WordPress<\/li>\n<li>Use the Settings-&gt;Wp Login Door screen to configure the plugin<\/li>\n<li>Enjoy your new door :)<\/li>\n<\/ol>\n\n<!--section=faq-->\n<dl>\n<dt id='what%20if%20i%20lose%20my%20pair%20of%20words%3F'><h3>What if I lose my pair of words?<\/h3><\/dt>\n<dd><p>You can disable the plugin from your FTP server.\nThen login as usual, reactivate the plugin, and check your word pair.<\/p><\/dd>\n<dt id='is%20that%20free%3F'><h3>Is that free?<\/h3><\/dt>\n<dd><p>I don't know if the beerware license is GPL 2 compatible, but if you like this plugin and if we meet someday, you can buy me a beer.<\/p><\/dd>\n<dt id='is%20that%20all%20%3F'><h3>Is that all ?<\/h3><\/dt>\n<dd><p>Yes!<\/p><\/dd>\n\n<\/dl>\n\n<!--section=changelog-->\n<h4>1.5<\/h4>\n\n<ul>\n<li>Let go the 'postpass' standard action (used when user types a password to open a protected post)<\/li>\n<\/ul>\n\n<h4>1.4<\/h4>\n\n<ul>\n<li>Removed some php notices in the administration section.<\/li>\n<\/ul>\n\n<h4>1.1.1<\/h4>\n\n<ul>\n<li>Bug correction. During refactoring, I misspelled the key name sanitization callback, and it could cause problems on some installations, such as key name field not stored.<\/li>\n<\/ul>\n\n<h4>1.1<\/h4>\n\n<ul>\n<li>Added a new setting to redirect home instead of displaying an error message.<\/li>\n<\/ul>\n\n<h4>1.0<\/h4>\n\n<ul>\n<li>First release<\/li>\n<\/ul>","raw_excerpt":"Adds a secret URL key to access the login page and lets you disable XML-RPC, protecting against bruteforce attacks.","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/pcd.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin\/50496","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/pcd.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin"}],"about":[{"href":"https:\/\/pcd.wordpress.org\/plugins\/wp-json\/wp\/v2\/types\/plugin"}],"replies":[{"embeddable":true,"href":"https:\/\/pcd.wordpress.org\/plugins\/wp-json\/wp\/v2\/comments?post=50496"}],"author":[{"embeddable":true,"href":"https:\/\/pcd.wordpress.org\/plugins\/wp-json\/wporg\/v1\/users\/toxnico"}],"wp:attachment":[{"href":"https:\/\/pcd.wordpress.org\/plugins\/wp-json\/wp\/v2\/media?parent=50496"}],"wp:term":[{"taxonomy":"plugin_section","embeddable":true,"href":"https:\/\/pcd.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_section?post=50496"},{"taxonomy":"plugin_tags","embeddable":true,"href":"https:\/\/pcd.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_tags?post=50496"},{"taxonomy":"plugin_category","embeddable":true,"href":"https:\/\/pcd.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_category?post=50496"},{"taxonomy":"plugin_contributors","embeddable":true,"href":"https:\/\/pcd.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_contributors?post=50496"},{"taxonomy":"plugin_business_model","embeddable":true,"href":"https:\/\/pcd.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_business_model?post=50496"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}