Added core pricing metafield and status check job

This commit is contained in:
2020-05-07 21:33:16 -04:00
parent ef5e4422c0
commit 9d3eac20dc
19 changed files with 341 additions and 119 deletions

View File

@@ -1,27 +1,24 @@
using PartSource.Data.Shopify;
using PartSource.Services;
using PartSource.Automation.Jobs.Interfaces;
using PartSource.Automation.Services;
using PartSource.Automation.Jobs.Interfaces;
using PartSource.Automation.Models;
using PartSource.Data;
using PartSource.Services.Integrations;
using Ratermania.Shopify.Entities;
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Linq;
using PartSource.Data;
using PartSource.Data.Models;
using System.Threading.Tasks;
using Microsoft.EntityFrameworkCore;
using PartSource.Services.Integrations;
using PartSource.Automation.Models;
namespace PartSource.Automation.Jobs
{
public class DeleteProducts : IAutomationJob
{
private readonly ShopifyClient _shopifyClient;
private readonly PartSourceContext _partSourceContext;
public DeleteProducts(ShopifyClient shopifyClient)
public DeleteProducts(ShopifyClient shopifyClient, PartSourceContext partSourceContext)
{
_shopifyClient = shopifyClient;
_partSourceContext = partSourceContext;
}
// If this job fails, oh well. Run it again and again until it works, or use the Shopify UI (LOL)
@@ -38,20 +35,34 @@ namespace PartSource.Automation.Jobs
};
}
IEnumerable<Product> products = await _shopifyClient.Products.Get();
IList<long?> shopifyIds = _partSourceContext.ImportData
.Select(i => i.ShopifyId)
.Distinct()
.ToList();
while (products != null)
foreach (long? id in shopifyIds)
{
foreach (Product product in products)
{
bool result = await _shopifyClient.Products.Delete(product);
}
Product product = await _shopifyClient.Products.GetById((long)id);
products = await _shopifyClient.Products.GetNext();
await _shopifyClient.Products.Delete(product);
Console.Write('.');
Console.WriteLine(id);
}
//IEnumerable<Product> products = await _shopifyClient.Products.Get();
//while (products != null)
//{
// foreach (Product product in products)
// {
// bool result = await _shopifyClient.Products.Delete(product);
// }
// products = await _shopifyClient.Products.GetNext();
// Console.Write('.');
//}
return new AutomationJobResult
{
Message = "All products deleted. Don't forget to truncate the ImportData table",