/// <summary> /// Gets the url for presenting plans to user /// </summary> /// <param name="reader">The settings reader.</param> /// <returns> /// url as <c>string</c> /// </returns> public static string GetPlanChoosingUrl(IDbSettingsReader reader) => $"{reader.GetAppBaseUrl()}/{reader.GetShopifyControllerName()}/{SHOPIFY_ACTIONS.ChoosePlan}";
/// <summary> /// Gets the url for handing payment charge result coming from shopify API /// </summary> /// <param name="reader">The settings reader.</param> /// <returns> /// url as <c>string</c> /// </returns> public static string GetChargeResultHandlerUrl(IDbSettingsReader reader) => $"{reader.GetAppBaseUrl()}/{reader.GetShopifyControllerName()}/{SHOPIFY_ACTIONS.ChargeResult}";
/// <summary> /// Gets the url for handling user's selected plan /// </summary> /// <param name="reader">The settings reader.</param> /// <returns> /// url as <c>string</c> /// </returns> public static string GetSelectedPlanHandlerUrl(IDbSettingsReader reader, int planId) => $"{reader.GetAppBaseUrl()}/{reader.GetShopifyControllerName()}/{SHOPIFY_ACTIONS.SelectedPlan}?planId={planId}";
public void OnAuthorization(AuthorizationFilterContext filterContext) { //already logged in by Identity now check subscription if (filterContext.Result == null) { _Logger.LogInformation("Starting subscription check."); var context = filterContext.HttpContext; _Logger.LogInformation("Getting current user."); AppUser currentUser = _UserCache.GetLoggedOnUser().Result; if (currentUser == null) { _Logger.LogError("User must be logged on before checking subscription.Redirecting to login page."); //throw new Exception("Subscription check must be done on logged on user. But current user is found null."); filterContext.Result = new RedirectToActionResult(ACCOUNT_ACTIONS.Login.ToString(), _Settings.GetAccountControllerName(), new { }); } else { _Logger.LogInformation($"Current user is '{currentUser.MyShopifyDomain}'"); //admin must have access token atleast if (currentUser.ShopIsConnected == false /*&& !currentUser.IsAdmin*/) { _Logger.LogWarning($"User '{currentUser.MyShopifyDomain}' has no shopify access token. Charge status check cannot be done on diconnected shop.Redirecting to '{_Settings.GetShopifyControllerName()}/{SHOPIFY_ACTIONS.HandShake.ToString()}'."); filterContext.Result = _CreateRedirectResult(_Settings.GetShopifyControllerName(), SHOPIFY_ACTIONS.HandShake.ToString()); } //billing connected or disconnected, for admin it is never checked else if (currentUser.BillingIsConnected == false && !currentUser.IsAdmin) { _Logger.LogWarning($"User '{currentUser.MyShopifyDomain}' billing charge id is null.Charge status check cannot be done on null charge id.Redirecting to '{_Settings.GetShopifyControllerName()}/{SHOPIFY_ACTIONS.ChoosePlan.ToString()}'."); filterContext.Result = _CreateRedirectResult(_Settings.GetShopifyControllerName(), SHOPIFY_ACTIONS.ChoosePlan.ToString()); } else { ShopifyRecurringChargeObject chargeStatus = null; //for admin user if no billing charge id all good, but if theres one then we will look into it if (currentUser.IsAdmin) { _Logger.LogInformation($"Skipping charge status check because user '{currentUser.MyShopifyDomain}' is admin."); chargeStatus = new ShopifyRecurringChargeObject() { Status = SHOPIFY_CHARGE_STATUS.active.ToString() }; } else { _Logger.LogInformation($"Checking charge status for user '{currentUser.MyShopifyDomain}'."); try { chargeStatus = Task.Run(() => _ShopifyApi.GetRecurringChargeAsync(currentUser.MyShopifyDomain, currentUser.ShopifyAccessToken, currentUser.ShopifyChargeId.Value)).Result; } catch (Exception ex) { _Logger.LogError($"Error occurred duing GetRecurringChargeAsync() call.{ex.Message}.{ex.StackTrace}"); throw ex; } } if (chargeStatus.Status == SHOPIFY_CHARGE_STATUS.accepted.ToString() || chargeStatus.Status == SHOPIFY_CHARGE_STATUS.active.ToString()) { _Logger.LogInformation($"Require subscription passed for user '{currentUser.MyShopifyDomain}'"); } else { _Emailer.InActiveChargeIdDetectedAsync(currentUser, chargeStatus.Status); if (chargeStatus.Status == SHOPIFY_CHARGE_STATUS.declined.ToString() || chargeStatus.Status == SHOPIFY_CHARGE_STATUS.expired.ToString() || chargeStatus.Status == SHOPIFY_CHARGE_STATUS.pending.ToString()) { _Logger.LogWarning($"Require subscription did not pass for user '{currentUser.MyShopifyDomain}'"); _Logger.LogWarning($"User '{currentUser.MyShopifyDomain}' has declined/expired/pending charge status."); _Logger.LogWarning($"Unsetting charge info for user '{currentUser.MyShopifyDomain}'."); UserDbServiceHelper.UnSetUserChargeInfo(_UserDbService, currentUser.Id); _Logger.LogWarning($"Removing user '{currentUser.MyShopifyDomain}' from cache."); _UserCache.ClearLoggedOnUser();//resset cache so that next try makes BillingIsConnected = false var handShakeAction = SHOPIFY_ACTIONS.HandShake.ToString(); _Logger.LogWarning($"Redirecting user '{currentUser.MyShopifyDomain}' to '{_Settings.GetShopifyControllerName()}/{handShakeAction}'."); filterContext.Result = _CreateRedirectResult(_Settings.GetShopifyControllerName(), handShakeAction); } else if (chargeStatus.Status == SHOPIFY_CHARGE_STATUS.frozen.ToString()) { _Logger.LogError($"User '{currentUser.MyShopifyDomain}' has frozen shopify store account. Throwing error."); throw new UnauthorizedAccessException("Your shopify account is frozen.Once shopify unfreezes your store account you will be able to use this app again."); } } } } } }