public PartialViewResult Listings(AmazonListingGroup amazonListingGroup, int page = 1)
        {
            ViewData["AmazonProductDetailsUrl"] = _amazonAppSettings.AmazonProductDetailsUrl;
            var results = new PagedList <AmazonListing>(amazonListingGroup.Items, page, _siteSettings.DefaultPageSize);

            return(PartialView(results));
        }
Exemple #2
0
        public FileStream GetProductsImageFeeds(AmazonListingGroup amazonListingGroup)
        {
            var feeds = amazonListingGroup.Items.Where(x => x.Status == AmazonListingStatus.NotOnAmazon ||
                                                       x.Status == AmazonListingStatus.Inactive).Select(_amazonGenerateFeedContentService.GetProductImage).ToList();

            return(_amazonGenerateFeedContentService.GetFeed(feeds, AmazonEnvelopeMessageType.ProductImage, AmazonEnvelopeMessageOperationType.Update));
        }
 public void UpdateAmazonListings(AmazonListingGroup amazonListingGroup)
 {
     foreach (var item in amazonListingGroup.Items)
     {
         UpdateAmazonListing(item);
     }
 }
        public AmazonLog Add(AmazonLogType type, AmazonLogStatus status, Exception elmahError, Error amazonError,
                             AmazonApiSection?apiSection, string apiOperation, AmazonOrder amazonOrder, AmazonListing amazonListing,
                             AmazonListingGroup amazonListingGroup,
                             string message = "", string details = "")
        {
            var log = new AmazonLog
            {
                LogType            = type,
                LogStatus          = status,
                AmazonOrder        = amazonOrder,
                ApiSection         = apiSection,
                ApiOperation       = !string.IsNullOrWhiteSpace(apiOperation) ? apiOperation : null,
                AmazonListing      = amazonListing,
                AmazonListingGroup = amazonListingGroup,
                Message            = !string.IsNullOrWhiteSpace(message) ? message : null,
                Detail             = !string.IsNullOrWhiteSpace(details) ? details : null,
                Site = CurrentRequestData.CurrentSite
            };

            if (elmahError != null)
            {
                log.Message = elmahError.Message;
                log.Detail  = elmahError.StackTrace;
            }
            if (amazonError != null)
            {
                log.ErrorCode = amazonError.Code;
                log.ErrorType = amazonError.Type;
                log.Message   = amazonError.Message;
                log.Detail    = amazonError.Detail.ToString();
            }

            return(Save(log));
        }
 public ViewResult AddMany(AmazonListingGroup amazonListingGroup)
 {
     return(View(new AmazonListingModel()
     {
         AmazonListingGroup = amazonListingGroup
     }));
 }
Exemple #6
0
        public void ListingController_CloseMany_ShouldCallGetAmazonSyncModel()
        {
            var model = new AmazonListingGroup();

            var result = _listingController.CloseMany(model);

            A.CallTo(() => _amazonListingSyncManager.GetAmazonSyncModel(model)).MustHaveHappened();
        }
Exemple #7
0
        public void ListingController_CloseMany_ShouldCallUpdateAmazonListing()
        {
            var model = new AmazonListingGroup();

            var result = _listingController.CloseMany(model);

            A.CallTo(() => _prepareForSyncAmazonListingService.UpdateAmazonListings(model)).MustHaveHappened();
        }
Exemple #8
0
        public void AmazonListingService_GetAmazonListingModel_ShouldReturnAmazonListingModelType()
        {
            var model = new AmazonListingGroup();

            var results = _amazonListingService.GetAmazonListingModel(model);

            results.Should().BeOfType <AmazonListingModel>();
        }
        public void Save(AmazonListingGroup item)
        {
            var id = item.Id;

            _session.Transact(session => session.SaveOrUpdate(item));
            _amazonLogService.Add(AmazonLogType.ListingGroups, id > 0 ? AmazonLogStatus.Update : AmazonLogStatus.Insert,
                                  null, null, null, null, null, null, item);
        }
        public void AmazonListingGroupService_Delete_ShouldCallAddLog()
        {
            var item = new AmazonListingGroup();

            _amazonListingGroupService.Delete(item);

            A.CallTo(() => _amazonLogService.Add(AmazonLogType.ListingGroups, AmazonLogStatus.Delete, null, null, null, null, null, null, item, string.Empty, string.Empty)).MustHaveHappened();
        }
Exemple #11
0
        public void SubmitProductFeeds(AmazonSyncModel model, AmazonListingGroup item)
        {
            var feeds = _amazonFeedsApiService.GetProductsMainFeeds(item);

            var submissionIds = _amazonRequestService.SubmitMainFeeds(model, feeds);

            _amazonRequestService.CheckIfRequestsWereProcessed(model, item, submissionIds);
        }
Exemple #12
0
        public void ListingController_ChooseProductVariant_ShouldCallGetAmazonDashboardModel()
        {
            var model = new AmazonListingGroup();

            var result = _listingController.ChooseProductVariant(model);

            A.CallTo(() => _amazonListingService.GetAmazonListingModel(model)).MustHaveHappened();
        }
 public ActionResult Delete(AmazonListingGroup amazonListingGroup)
 {
     if (amazonListingGroup != null)
     {
         return(View(amazonListingGroup));
     }
     return(RedirectToAction("Index"));
 }
Exemple #14
0
        public FileStream GetProductsDeleteFeeds(AmazonListingGroup amazonListingGroup)
        {
            var feeds = amazonListingGroup.Items.Where(x => x.Status == AmazonListingStatus.Active).Select(x => new Product {
                SKU = x.SellerSKU
            }).ToList();

            return(_amazonGenerateFeedContentService.GetFeed(feeds, AmazonEnvelopeMessageType.Product, AmazonEnvelopeMessageOperationType.Delete));
        }
        public void AmazonListingSyncManager_GetAmazonSyncModel_ShouldReturnAmazonSyncModelType()
        {
            var model = new AmazonListingGroup();

            var results = _amazonListingSyncManager.GetAmazonSyncModel(model);

            results.Should().BeOfType <AmazonSyncModel>();
        }
Exemple #16
0
 public AmazonSyncModel GetAmazonSyncModel(AmazonListingGroup amazonListingGroup)
 {
     return(new AmazonSyncModel()
     {
         Id = amazonListingGroup.Id,
         Title = amazonListingGroup.Name,
         AmazonListingGroup = amazonListingGroup
     });
 }
 public ActionResult Add_POST(AmazonListingGroup amazonListingGroup)
 {
     if (ModelState.IsValid)
     {
         _amazonListingGroupService.Save(amazonListingGroup);
         return(RedirectToAction("Edit", "ListingGroup", new { id = amazonListingGroup.Id }));
     }
     return(PartialView(amazonListingGroup));
 }
 public AmazonListingModel GetAmazonListingModel(AmazonListingGroup amazonListingGroup)
 {
     return(new AmazonListingModel()
     {
         ProductVariants = _productVariantService.GetAllVariants(String.Empty),
         AmazonListingGroup = amazonListingGroup,
         Categories = _optionService.GetCategoryOptions()
     });
 }
        public void PrepareForSyncAmazonListingService_InitAmazonListingFromProductVariant_ShouldCallSave()
        {
            var item = new Currency()
            {
                Code = "GBP", Id = 1
            };

            Session.Transact(session => session.Save(item));

            var mockingKernel = new MockingKernel();

            MrCMSKernel.OverrideKernel(mockingKernel);
            mockingKernel.Bind <ISession>().ToMethod(context => A.Fake <ISession>());
            mockingKernel.Bind <EcommerceSettings>().ToMethod(context => new EcommerceSettings()
            {
                CurrencyId = 1
            });

            var product = new Product()
            {
                BrandPage = new Brand()
                {
                    Name = "B"
                }
            };
            var productVariant = new ProductVariant()
            {
                Product                = product,
                SKU                    = "S1",
                BasePrice              = 1,
                StockRemaining         = 2,
                Name                   = "P",
                ManufacturerPartNumber = "MPN1",
                Barcode                = ""
            };
            var amazonListingGroup = new AmazonListingGroup()
            {
                Id = 1,
                FulfillmentChannel = AmazonFulfillmentChannel.MFN
            };
            var model = new AmazonListing()
            {
                ProductVariant        = productVariant,
                StandardProductId     = "1P",
                StandardProductIDType = StandardProductIDType.EAN,
                AmazonListingGroup    = amazonListingGroup
            };

            A.CallTo(() => _amazonListingGroupService.Get(amazonListingGroup.Id)).Returns(amazonListingGroup);

            A.CallTo(() => _productVariantService.GetProductVariantBySKU(model.ProductVariant.SKU)).Returns(productVariant);

            var results = _prepareForSyncAmazonListingService.InitAmazonListingFromProductVariant(model, model.ProductVariant.SKU, amazonListingGroup.Id);

            A.CallTo(() => _amazonListingGroupService.Save(amazonListingGroup)).MustHaveHappened();
        }
 public ActionResult CloseMany(AmazonListingGroup amazonListingGroup)
 {
     if (amazonListingGroup != null)
     {
         ViewData["AmazonManageInventoryUrl"] = _amazonAppSettings.AmazonManageInventoryUrl;
         _prepareForSyncAmazonListingService.UpdateAmazonListings(amazonListingGroup);
         return(View(_amazonListingSyncManager.GetAmazonSyncModel(amazonListingGroup)));
     }
     return(RedirectToAction("Index", "ListingGroup"));
 }
        public void AmazonListingGroupService_Delete_ShouldRemoveItemFromTheSession()
        {
            var item = new AmazonListingGroup();

            Session.Transact(session => session.Save(item));

            _amazonListingGroupService.Delete(item);

            Session.QueryOver <AmazonListingGroup>().RowCount().Should().Be(0);
        }
        public void AmazonListingGroupService_Get_ShouldReturnPersistedEntryFromSession()
        {
            var item = new AmazonListingGroup();

            Session.Transact(session => session.Save(item));

            var results = _amazonListingGroupService.Get(1);

            results.As <AmazonListingGroup>().Id.Should().Be(1);
        }
 public ActionResult Edit_POST(AmazonListingGroup amazonListingGroup)
 {
     ViewData["AmazonProductDetailsUrl"] = _amazonAppSettings.AmazonProductDetailsUrl;
     if (ModelState.IsValid)
     {
         _amazonListingGroupService.Save(amazonListingGroup);
         return(RedirectToAction("Edit", "ListingGroup", new { id = amazonListingGroup.Id }));
     }
     return(PartialView(amazonListingGroup));
 }
Exemple #24
0
        public void CheckIfRequestsWereProcessed(AmazonSyncModel model, AmazonListingGroup item, List <string> submissionIds)
        {
            var uploadSuccess = false;
            var retryCount    = 0;

            var feedContent = _amazonFeedsApiService.GetProductsImageFeeds(item);

            while (!uploadSuccess)
            {
                retryCount++;
                if (retryCount == 5)
                {
                    AmazonProgressBarHelper.Update(model.Task, "Error",
                                                   "Request timed out. Please check logs for potential errors and try again later.", 100,
                                                   100);
                    break;
                }

                try
                {
                    AmazonProgressBarHelper.Update(model.Task, "Push", "Checking if request was processed...", 100, 75);
                    if (_amazonFeedsApiService.GetFeedSubmissionList(submissionIds.First()).FeedProcessingStatus ==
                        "_DONE_")
                    {
                        AmazonProgressBarHelper.Update(model.Task, "Push", "Request was processed", 100, 75);
                        foreach (var amazonListing in item.Items)
                        {
                            AmazonProgressBarHelper.Update(model.Task, "Push", "Updating local status of Amazon Listing with SKU:" + amazonListing.SellerSKU, 100, 85);
                            _amazonListingService.UpdateAmazonListingStatusAndAsin(amazonListing, null);
                        }

                        SubmitProductImageFeed(model, feedContent, ref submissionIds);

                        uploadSuccess = true;
                    }
                    else
                    {
                        AmazonProgressBarHelper.Update(model.Task, "Push",
                                                       "Nothing yet, we will wait 2 min. more and try again...", 100, 75);

                        Thread.Sleep(120000);
                    }
                }
                catch (Exception ex)
                {
                    CurrentRequestData.ErrorSignal.Raise(ex);

                    AmazonProgressBarHelper.Update(model.Task, "Push",
                                                   "Amazon Api is busy, we will wait additional 2 min. and try again...", 100,
                                                   75);

                    Thread.Sleep(120000);
                }
            }
        }
        public void ListingGroupController_DeletePOST_ReturnsRedirectToEdit()
        {
            var model = new AmazonListingGroup()
            {
                Id = 1
            };

            var result = _listingGroupController.Delete_POST(model);

            result.As <RedirectToRouteResult>().RouteValues["action"].Should().Be("Index");
        }
        public void ListingGroupController_DeletePOST_ShouldCallDelete()
        {
            var model = new AmazonListingGroup()
            {
                Id = 1
            };

            var result = _listingGroupController.Delete_POST(model);

            A.CallTo(() => _amazonListingGroupService.Delete(model)).MustHaveHappened();
        }
        public void AmazonListingGroupService_Save_ShouldUpdateInSession()
        {
            var item = new AmazonListingGroup();

            Session.Transact(session => session.Save(item));
            item.Name = "updated";

            _amazonListingGroupService.Save(item);
            Session.Evict(item);

            Session.Get <AmazonListingGroup>(1).Name.Should().Be("updated");
        }
        public void CloseAmazonListings(AmazonSyncModel model, AmazonListingGroup amazonListingGroup)
        {
            var feedContent = _amazonFeedsApiService.GetProductsDeleteFeeds(amazonListingGroup);

            var submissionId = _amazonRequestService.SubmitCloseRequest(model, feedContent);

            var isUploaded   = false;
            var retryCounter = 0;

            while (!isUploaded)
            {
                retryCounter++;
                retryCounter++;
                if (retryCounter == 3)
                {
                    AmazonProgressBarHelper.Update(model.Task, "Error",
                                                   "Request timed out. Please check logs for potential errors and try again later.", 100,
                                                   100);
                    break;
                }

                try
                {
                    AmazonProgressBarHelper.Update(model.Task, "Push", "Checking if request was processed...", 100, 75);
                    if (_amazonFeedsApiService.GetFeedSubmissionList(submissionId).FeedProcessingStatus == "_DONE_")
                    {
                        AmazonProgressBarHelper.Update(model.Task, "Push", "Request was processed", 100, 90);
                        foreach (var amazonListing in amazonListingGroup.Items)
                        {
                            AmazonProgressBarHelper.Update(model.Task, "Push", "Updating local status of Amazon Listing #" + amazonListing.SellerSKU, 100, 90);
                            _amazonListingService.UpdateAmazonListingStatus(amazonListing);
                        }

                        isUploaded = true;
                    }
                    else
                    {
                        AmazonProgressBarHelper.Update(model.Task, "Push", "Nothing yet, we will wait 2 min. more and try again...", 100, 75);
                        Thread.Sleep(120000);
                    }
                }
                catch (Exception ex)
                {
                    _amazonLogService.Add(AmazonLogType.Listings, AmazonLogStatus.Error, ex, null,
                                          AmazonApiSection.Feeds, null, null, null, null, "Closing Amazon Listings");

                    AmazonProgressBarHelper.Update(model.Task, "Push", "Amazon Api is busy, we will need to wait additional 2 min. and try again", 100, 75);
                    Thread.Sleep(120000);
                }
            }
        }
Exemple #29
0
        public List <FileStream> GetProductsMainFeeds(AmazonListingGroup amazonListingGroup)
        {
            var feedCollection = new List <FileStream>();

            var products = amazonListingGroup.Items.Select(_amazonGenerateFeedContentService.GetProduct).ToList();

            feedCollection.Add(_amazonGenerateFeedContentService.GetFeed(products, AmazonEnvelopeMessageType.Product, AmazonEnvelopeMessageOperationType.Update));

            var prices = amazonListingGroup.Items.Select(_amazonGenerateFeedContentService.GetProductPrice).ToList();

            feedCollection.Add(_amazonGenerateFeedContentService.GetFeed(prices, AmazonEnvelopeMessageType.Price, AmazonEnvelopeMessageOperationType.Update));

            var inventories = amazonListingGroup.Items.Select(_amazonGenerateFeedContentService.GetProductInventory).ToList();

            feedCollection.Add(_amazonGenerateFeedContentService.GetFeed(inventories, AmazonEnvelopeMessageType.Inventory, AmazonEnvelopeMessageOperationType.Update));

            return(feedCollection);
        }
        public void InitAmazonListingsFromProductVariants(AmazonListingGroup amazonListingGroup, string rawProductVariantsIds)
        {
            try
            {
                var productVariantsIds = rawProductVariantsIds.Trim().Split(',');
                foreach (var item in productVariantsIds)
                {
                    if (String.IsNullOrWhiteSpace(item))
                    {
                        continue;
                    }

                    var amazonListing = _amazonListingService.GetByProductVariantSku(item);

                    InitAmazonListingFromProductVariant(amazonListing, item, amazonListingGroup.Id);
                }
            }
            catch (Exception ex)
            {
                CurrentRequestData.ErrorSignal.Raise(ex);
            }
        }