Added core pricing metafield and status check job
This commit is contained in:
@@ -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",
|
||||
|
||||
Reference in New Issue
Block a user