Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Role Expiration Date is Ignored in Sales Promotion #214

Closed
parasdaryanani opened this issue Oct 6, 2019 · 4 comments
Closed

Role Expiration Date is Ignored in Sales Promotion #214

parasdaryanani opened this issue Oct 6, 2019 · 4 comments
Labels
Milestone

Comments

@parasdaryanani
Copy link
Contributor

Describe the bug

Sales based on membership roles ignore the role expiry date, i.e. if a user has an expired membership, they still get promotions based on the role.

Software Versions

  • DNN: 08.03.00
  • Hotcakes: 03.02.01

To Reproduce

Steps to reproduce the behavior:

  1. Create a new user X
  2. Create 2 roles: 'pro' and 'premier'.
  3. Assign pro membership to X with expiry date 01/01/2020.
  4. Assign premier membership to X with expiry date 01/01/2015.
  5. Create a storewide sale for 'pro' role = 5% discount.
  6. Create a storewide sale for 'premier' role = 10% discount.
  7. Create a dummy product with price $100.
  8. Login as X and add the dummy product to cart.

Expected behavior

Since X's premier membership is expired, the sale should not apply and the cart price should be $100 - 5% = $95.

Actual behavior

Both premier and pro membership are taken into account and price in cart is $100 - 5% - 10% = $85.

Additional context

Expiry date is not taken into account when applying promotions, as seen in Hotcakes.Commerce.Dnn\Marketing\Qualifications\UserIsInRole.cs

private List<RoleInfo> GetCustomerRoles(CustomerAccount customer)
        {
            var user = DnnUserController.Instance.GetUser(_portalId, Convert.ToInt32(customer.Bvin));
            var roles = RoleController.Instance.GetUserRoles(user, true);
            return roles.OfType<RoleInfo>().ToList();
        }

Adding a filter based on expiry date as below resolves the issue:

private List<RoleInfo> GetCustomerRoles(CustomerAccount customer)
        {
            var user = DnnUserController.Instance.GetUser(_portalId, Convert.ToInt32(customer.Bvin));
            var roles = RoleController.Instance.GetUserRoles(user, true);
            // filter roles to those that are not expired
            var activeroles = from role in roles
                              where role.ExpiryDate != DateTime.MinValue 
                                    && role.ExpiryDate > DateTime.Now
                              select role;
            return activeroles.OfType<RoleInfo>().ToList();
        }

The question is whether this is the correct way to resolve the issue, or whether the fix should be applied elsewhere?

@WillStrohl WillStrohl added the bug label Nov 5, 2019
@WillStrohl WillStrohl changed the title Role expiry date is ignored in sales Role Expiration Date is Ignored in Sales Promotion Nov 21, 2019
@WillStrohl WillStrohl added this to the 03.03.00 milestone Nov 21, 2019
@WillStrohl
Copy link
Member

Have you already tried applying the fix you outlined? If you have what testing have you done to verify it? I haven't dug into this in great detail myself yet, but so far, this looks right.

@parasdaryanani
Copy link
Contributor Author

Yes I tried this but had to modify the LINQ query as it filtered out roles that do not expire because of role.ExpiryDate != DateTime.MinValue.

Changed this as follows:

private List<RoleInfo> GetCustomerRoles(CustomerAccount customer)
        {
            var user = DnnUserController.Instance.GetUser(_portalId, Convert.ToInt32(customer.Bvin));
            var roles = RoleController.Instance.GetUserRoles(user, true);
            // filter roles to those that are not expired
            var activeroles = from role in roles
                              where role.ExpiryDate == DateTime.MinValue // permanent roles
                                    || role.ExpiryDate > DateTime.Now // active roles
                              select role;
            return activeroles.OfType<RoleInfo>().ToList();
        }

I used the above "steps to reproduce" to manually test for expected results with VS debugging. This works as expected.

Any suggestions on what to do next?

@WillStrohl
Copy link
Member

Please create a pull request so someone can debug it.

@WillStrohl
Copy link
Member

We just finished cooking up a fresh batch of Hotcakes for you. Enjoy! ;)

https://dnncommunity.org/blogs/Post/5689/Hotcakes-Commerce-03-03-00-Release-Marks-a-Major-Milestone

mtrutledge added a commit to mtrutledge/core that referenced this issue Sep 15, 2021
* Phone number requirement feature

* Improved string performance in store settings

* Minor typos in gift card configuration

* Removed explicit TabIndex assignments

* Removed explicit TabIndex assignments

* Resolved minor DOM warning issue with same-name elements

* Adds UPS response to diagnostic logging

* Corrects South Korea's ISO data

* Only show product sort when there is more than one option

* Resolves HotcakesCommerce#214
Filtered out expired user roles

* Resolved issues w/ radcombobox removal in all settings views

* Not showing disabled products as related items

* Assigns imported images to imported products

* Adds a scheduled task to clear temp files

* Updates to help with debugging during development

* Updated underlying build website to DNN Platform 9.2.2

* Updated DNN reference DLLs to 9.2.2

nuget to come later

* Cleaning up DNN upgrade artifacts before first build

* Successfully building against DNN 9.2.2 (no code changes necessary)

* Un-sync'd DLL from previous updates

* Resolved theme pane placement for modules during wizard config

* Replaced the base DNN package with v9.2.2

* Removing Hotcakes DLLs from tracking

* Adding missed DLLs from DNN upgrade

* Added the rest of the missing DLLs from the DNN upgrade

* Resolved build/install issues & EVS warnings

* Resolved display issues with the dashboard

* Resolves dashboard display issues

* Returning the Small product image instead of Medium

* This DLL "changed" for some reason, but it's still the same. :(

* Added admin buttons to front-end views

* Merged admin button updates to the Social Spokes viewset

* Merged admin button updates into the DevSamples

includes updates from previous commits

* Reverted mobile CSS changes

* Copied _default viewset to be available as a legacy option

* Allow viewset developers to easily create AddToCart links in views

* Able to specify a classname  to options & improved string performance

* Updated default text for the file upload

* Fixes HotcakesCommerce#269 by localizing the HccHttpContext at sitemap creation

* Fixes HotcakesCommerce#269 by localizing the HccHttpContext at sitemap creation

* removed whitespace

* Replaced the Copy to Clipboard functionality...

(removes SWF dependency)

* Localized the orders grid

* Replaced the Copy to Clipboard functionality (part two)...

(removes SWF dependency)

* Removed ability to show card numbers

* Added JS API support for HTTP/S protocol in HCC library

* Filtering user inputs in checkout & product views

* Changed the pane where the search input is added in the wizard

* Bootstrap 3 viewset as the default viewset

* Resolved display issue with additional images

* Fixed product name typo & adding tiny images

* Updated the sample product images

* Localized product choices & resolved icon display issues

* Adding HCC branding to default e-mail templates

* Improved branding for missing product/category images

* Only logging errors, not debugging

* Removed obsolete endpoints and related code

Almost all endpoints have been obsolete since v2.0 or earlier (except 2 for Evoq Social, 3.0.0).

* Resolves a non-cached page load grid issue found during testing

* Resolved BS3 viewset display issues during testing

* INitial commit for BS4 viewset (only the main category view is done)

* Deprecated Manufactures for Manufacturers

* Resolves minor issues found during testing

* Resolved minor JS bug in drilldown views

* Updated Category & Product views to BS4

* Minor viewset updates after testing

* BS4 conversion updates for the cart

* BS3 minor usability fixes from testing

* BS4 conversion updates for checkout views

* BS3 minor usability updates from testing

* BS4 conversion updates for receipt views

* BS4 conversion updates for order history views

* Enhanced visual support for payment & stock labels

* BS4 conversion updates for wish list, order history, content blocks

* BS4 conversion of the address book views

* BS4 conversion for the reviews views

* BS3 search view UX updates from testing

* BS4 conversion updates for the search views

* BS3 mobile UX updates from testing

* Resolves a bug displaying products in Product Grid settings

* Fixed sample products cupcake typo

* BS4 conversion for optional product views

* Fixed remaining typos with cupcakes & manufacturers

* Added a jQuery plugin for BS4 tabs (jQuery UI inspired)

* BS4 conversion for affiliate views

* Minor typo in BS3 viewset

* Updated missed EM tags

* Localized Receive Payments admin view

* Resolved image display issue with info tabs

* Enabled lists in the new html editor

* updated the credit card logos in all viewsets

* Release notes & versioning

* Updated DevSamples with new viewsets

* Core scripts served minified, except when DNN is in debug mode

* Final packaging updates prior to release

* Missed commits from build testing

* No actual changes. Alphabetized the properties while documenting.

* Fixes HotcakesCommerce#288

* No actual changes. Alphabetized the properties while documenting.

* Only show available products @sitemap

* Added a Porto5 viewset

This is not compatible with the Category Drilldown and Affiliate views

* Added Porto5 viewset to the build and install process

* removing the test project from the solution build

* BS4 Only show one of the shopping cart buttons w/ empty wish list

* BS4: Resolved display issue w/ cart header

* BS4 Checkout login label usability updates

* BS4 Product details corrected margin class

* BS4 Product details ensured label formatting is consistent

* BS4 prevent search engines from following add to cart links & 

using built-in cart routing method

* BS4 present search engines from following add to cart links

* Build and environment restoration artifacts

* No actual changes. Alphabetized the properties while documenting.

* Resolves sort order issue with displayed facets

* String optimizations to improve performance

* Final packaging updates for build

* Merged viewset updates into the DevSamples

* Updated the references in DevSamples

* Fixed typos in the release notes

* Typo and localization updates in the default template

* Resolves HotcakesCommerce#294

* Prep for 03.04.01 release

* Revert "Only show available products @sitemap"

This reverts commit 506cf6b.

* Basic solution for this enhancement - needs refining and polishing

* Changed Checkout.js to default-Legacy to match dev.env - Reset on invalid vat now takes the products TaxExempt value.

* Localized validation msg

* Provide Sitemap-URLs of active products only

* All Controllers: changed every occurrence of Response.Redirect to Redirect

* Adding support for submit type button elements to forms

* Closes HotcakesCommerce#313

Closes HotcakesCommerce#313

* data source update

* Updated .NET to 4.7.2 & DNN to 9.4.4

* Resolving build issues

* Initial addition of Prompt

* Moved localization to base class

* Added HCC branding to messages

* Added sales summary prompt

* Added a clear cache prompt

* Prevent a conflict with built-in prompt command

* Localized prompt descriptions

* Added logging to DNN user creation tasks

* Added a flag to sales-summary

* Fixed bug in Viewsets

* Bug Fix for api timeout

* Adds more logging to the DNN Membership workflow task

* Placeholder content for help for prompt commands

* Merge PR HotcakesCommerce#304 updates to the DevSamples

* Merged PR HotcakesCommerce#304 missing updates to the other viewsets

* Fix in SQL

* Fixed folder structure for DevSamples viewsets

* Resolves HotcakesCommerce#322

* Alphabetized the properties

* Resolves HotcakesCommerce#311

* Resolved domain name typos

* Updated the version for packaging

* Updated release notes for packaging

* Fix in Provider Script

* Resolves build issues

* Resolves build issues

* More Fix in Store Settings SQL script

* Updated release notes

* Preventing file locks during build

* Moved new store settings logic from SQL to IUpgradeable

* Resolves issue with incorrect key store setting on upgrade

* Replaced interpolation with string.Format for now

* Bug fix for JS issue in viewset

* Fixed issue in JS  for emails

* Merged viewset changes

* more bug fix in JS for viewsets

* Removed deprecated licensing DLL reference

* Was supposed to be building against DNN 9.2.2 not 9.4.4

* Formally removing HCC licensing on upgrade

* Updating DevSamples references

* Removed unnecessary PDB

* Resolved final build issues in DevSamples

* Updated Stripe to use Newtonsoft.Json 10.0.3

* Properly updated DevSample DLLs to 3.5.0

* Paypal Express Hold Authorization issue

A Paypal hold could fail due to end user's lack of funds or linked account. If this happens, the Paypal Express Hold should return a fail, not a success.

* Cancels Button Postback for Generate Url and Copy Url to allow user to use the links that were just generated

* Using the OrderTaskContext.Order.OrderNumber as a fallback in case the OrderNumber on the OrderTransaction object is an empty string

* Checks the RedirectResult from the HandleActionParams() and if it's something other than the Cart page, it redirects, otherwise it continues with loading the Shopping Cart

* Remove GB from EU VAT rules

Co-authored-by: Will Strohl <hismightiness@users.noreply.github.com>
Co-authored-by: Will Strohl <will@upendoventures.com>
Co-authored-by: Paras Daryanani <paras@celestialsites.com>
Co-authored-by: Navilois <a.krichmayr@gmail.com>
Co-authored-by: William Benz <william.a.benz@gmail.com>
Co-authored-by: Nirav <sniravj@gmail.com>
Co-authored-by: Scott Wilkinson <swilkinson@blueboltsolutions.com>
Co-authored-by: joshgk00 <josh@clicksandmortarwebsites.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Development

No branches or pull requests

2 participants