Description
This plugin allows you to restrict the usage of WooCommerce coupons based on user roles, including guest users.
You can specify which roles (including guests) are allowed or excluded from using a coupon, providing more control over your discount strategies.
Features
- Restrict coupon usage based on user roles.
- Option to specify both allowed and excluded roles.
- Support for guest users with a “Customer Is A Guest” pseudo-role.
- Customize the error message via a filter.
Filters
runthings_wc_coupons_role_restrict_error_message
This filter allows customization of the error message shown when a coupon is not valid for the user’s account type.
For detailed documentation and advanced examples, see the full documentation on GitHub.
Parameters:
$message
(string
): The default error message, e.g.,"Sorry, this coupon is not valid for your account type."
.$context
(array
): Additional context for the error, including the coupon, user roles, and guest status.
$context
object format:
The $context
array contains the following keys:
– coupon
(WC_Coupon
): The coupon object being validated.
– is_guest
(bool
): Whether the current user is a guest (not logged in).
– user
(WP_User
): The current user object. For guests, this will be an empty user object.
– allowed_roles
(array
): Roles explicitly allowed to use the coupon, in the format [role_id => role_name]
.
– excluded_roles
(array
): Roles explicitly excluded from using the coupon, in the format [role_id => role_name]
.
– effective_allowed_roles
(array
): The final calculated roles allowed to use the coupon, after considering exclusions, in the format [role_id => role_name]
. This is the set of roles that can use the coupon.
License
This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program; if not, see http://www.gnu.org/licenses/gpl-3.0.html.
Icon – Discount by Gregor Cresnar, from Noun Project, https://thenounproject.com/browse/icons/term/discount/ (CC BY 3.0)
Icon – restriction by Puspito, from Noun Project, https://thenounproject.com/browse/icons/term/restriction/ (CC BY 3.0)
Screenshots
Installation
- Upload the plugin files to the
/wp-content/plugins/runthings-wc-coupons-role-restrict
directory, or install the plugin through the WordPress plugins screen directly. - Activate the plugin through the ‘Plugins’ screen in WordPress.
- Go to WooCommerce > Coupons and edit or create a coupon.
- In the “Usage restriction” tab, you will see the options to select allowed and excluded roles for the coupon, including the “Customer Is A Guest” pseudo-role.
FAQ
-
Why was this plugin created?
-
This plugin was created to provide a more secure option for restricting coupon usage.
The default email usage restriction for coupons in WooCommerce is based on the unverified billing email address field, which can be freely set by users.
By using role restrictions, you can ensure that only verified and authorized users in specific roles—or guests, when appropriate—can use certain coupons, making it a secure option.
My personal motivation was to have 100% discount coupons that could be used only be staff or developers, without the possibility of this being exploited by somebody putting a fake staff email into the billing email address field.
-
How do I restrict a coupon to specific roles?
-
Edit the coupon and go to the “Usage restriction” tab.
In the “Roles” section, select the roles allowed to use the coupon.
If you want to exclude specific roles, select them in the “Excluded roles” section. For guest users, select or exclude the “Customer Is A Guest” pseudo-role.
-
What happens if a role is both allowed and excluded?
-
If a role is both allowed and excluded, the exclusion will take precedence, and users with that role will not be able to use the coupon.
-
How do I allow a coupon for guests only?
-
To restrict a coupon to guests only, select the “Customer Is A Guest” pseudo-role in the “Roles” section and leave all other roles unselected.
-
Can I use this plugin with other WooCommerce coupon restrictions?
-
Yes, this plugin works alongside other WooCommerce coupon restrictions such as minimum spend, maximum spend, and product restrictions.
Reviews
There are no reviews for this plugin.
ডেভেলপার এবং কন্ট্রিবিউটর
“Coupons Role Restriction for WooCommerce” is open source software. The following people have contributed to this plugin.
কন্ট্রিবিউটরTranslate “Coupons Role Restriction for WooCommerce” into your language.
ডেভেলপমেন্ট এ আগ্রহী?
Browse the code, check out the SVN repository, or subscribe to the development log by RSS.
Changelog
1.1.0 – 17th November 2024
- Introduced “Customer Is A Guest” pseudo-role, enabling role restrictions to target guest users.
- Fixed a bug which would auto exclude the guest when any role was set as excluded.
- Added support for passing a context object to the
runthings_wc_coupons_role_restrict_error_message
filter. - Context includes additional information such as
coupon
,is_guest
,user
,allowed_roles
,excluded_roles
, andeffective_allowed_roles
. - Improved documentation for filters, including usage examples and detailed context information.
- Updated screenshots.
1.0.1 – 15th July 2024
- Fix code snippet formatting in documentation.
1.0.0 – 11th July 2024
- Initial release.
- Restrict coupons by role.
- Allow coupons by role.
- Filter
runthings_wc_coupons_role_restrict_error_message
to customise error message.