Ejemplo n.º 1
0
        public void TestSyncRenewAccount()
        {
            var service = appHost.Container.Resolve <HourlyServices>();

            var req = new SyncAccountsHourly();

            service.Any(req);
            var discourseClient = appHost.Resolve <IDiscourseClient>() as MockDiscourseClient;

            Assert.That(discourseClient != null);
            Assert.That(discourseClient.UnsuspendCalledCount == 1);
        }
        public object Any(SyncAccountsHourly request)
        {
            var users = DiscourseClient.AdminGetUsers(1000);

            foreach (var discourseUser in users)
            {
                //Don't process discourse administrators or users already approved.
                if (discourseUser.Admin || (discourseUser.Suspended == null || discourseUser.Suspended == false))
                {
                    continue;
                }

                UserServiceResponse existingCustomerSubscription;
                try
                {
                    existingCustomerSubscription = ServiceStackAccountClient.GetUserSubscription(discourseUser.Email);
                }
                catch (Exception e)
                {
                    Log.Error("Failed to check user {0} subscription. Retrying... - {1}".Fmt(discourseUser.Username, e.Message));
                    try
                    {
                        existingCustomerSubscription = ServiceStackAccountClient.GetUserSubscription(discourseUser.Email);
                    }
                    catch (Exception ex)
                    {
                        Log.Error("Failed to check user {0} subscription. Cancelling sync. - {1}".Fmt(discourseUser.Username, ex.Message));
                        break;
                    }
                }

                if (existingCustomerSubscription.HasValidSubscription())
                {
                    try
                    {
                        Thread.Sleep(2000);
                        if (discourseUser.Suspended == true)
                        {
                            Log.Info("Unsuspending user '{0}'.".Fmt(discourseUser.Email));
                            UnsuspendUser(discourseUser);
                        }
                    }
                    catch (Exception e)
                    {
                        Log.Error("Failed to suspend Discourse for user '{0}'. - {1}".Fmt(discourseUser.Email, e.Message));
                    }
                }
            }
            return(null);
        }