|
|
|
|
@@ -8,6 +8,7 @@ This file holds the functions necesary to:
|
|
|
|
|
"""
|
|
|
|
|
import logging
|
|
|
|
|
from io import BytesIO
|
|
|
|
|
import datetime
|
|
|
|
|
|
|
|
|
|
from woocommerce import API
|
|
|
|
|
import requests
|
|
|
|
|
@@ -17,6 +18,7 @@ from django.core.files import File
|
|
|
|
|
from companies.models import Company
|
|
|
|
|
from products.models import Product
|
|
|
|
|
from products.serializers import ProductSerializer
|
|
|
|
|
from history.models import HistorySync
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def get_wcapi_instance(url, key, secret, version="wc/v3"):
|
|
|
|
|
@@ -30,7 +32,7 @@ def get_wcapi_instance(url, key, secret, version="wc/v3"):
|
|
|
|
|
return wcapi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def migrate_shop_products(url, key, secret, version="wc/v3"):
|
|
|
|
|
def migrate_shop_products(url, key, secret, user=None, version="wc/v3"):
|
|
|
|
|
"""Tries to connect to WooCommerce site @ url with given credentials
|
|
|
|
|
|
|
|
|
|
If succesful, returns list of Product instances created
|
|
|
|
|
@@ -51,64 +53,60 @@ def migrate_shop_products(url, key, secret, version="wc/v3"):
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
|
# list products
|
|
|
|
|
response = wcapi.get('/products/')
|
|
|
|
|
response = wcapi.get('products/')
|
|
|
|
|
if response.status_code == 200:
|
|
|
|
|
products = response.json()
|
|
|
|
|
elif response.status_code == 401:
|
|
|
|
|
logging.error(f"{response.status_code} [{response.url}]: {response.json()}")
|
|
|
|
|
return None
|
|
|
|
|
else:
|
|
|
|
|
logging.error(f"Could not load products from {url}: [{response.status_code}]")
|
|
|
|
|
print(f"Could not load products fom {url}: [{response.status_code}]")
|
|
|
|
|
import ipdb; ipdb.set_trace()
|
|
|
|
|
logging.error(f"Could not load products from {response.url}: [{response.status_code}]")
|
|
|
|
|
print(f"Could not load products fom {response.url}: [{response.status_code}]")
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
|
# create HistorySync instance and link to every product created
|
|
|
|
|
history = HistorySync.objects.create(
|
|
|
|
|
company=company,
|
|
|
|
|
sync_date=datetime.datetime.now(),
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
product_fields = [f.name for f in Product._meta.get_fields()]
|
|
|
|
|
counter = 0
|
|
|
|
|
products_created = []
|
|
|
|
|
for product in products:
|
|
|
|
|
instance_data = {'company':company.id}
|
|
|
|
|
# extract m2m field data
|
|
|
|
|
tags = [t.get('name') for t in product.pop('tags')]
|
|
|
|
|
attributes = [t.get('name') for t in product.pop('attributes')]
|
|
|
|
|
# prepare instance data
|
|
|
|
|
instance_data = {
|
|
|
|
|
'company':company.id,
|
|
|
|
|
'creator': user.id if user is not None else None,
|
|
|
|
|
'history': history.id,
|
|
|
|
|
'url': product['permalink'],
|
|
|
|
|
}
|
|
|
|
|
# parse the product info
|
|
|
|
|
for key in product:
|
|
|
|
|
if key in product_fields:
|
|
|
|
|
instance_data[key] = product[key]
|
|
|
|
|
# remove unwanted fields
|
|
|
|
|
instance_data.pop('id')
|
|
|
|
|
# extract m2m field data
|
|
|
|
|
tags = instance_data.pop('tags')
|
|
|
|
|
attributes = instance_data.pop('attributes')
|
|
|
|
|
|
|
|
|
|
# create instance with serializer
|
|
|
|
|
'''
|
|
|
|
|
serializer = ProductSerializer(data=instance_data)
|
|
|
|
|
if serializer.is_valid():
|
|
|
|
|
new = serializer.save()
|
|
|
|
|
if tags:
|
|
|
|
|
new.tags.set(tags)
|
|
|
|
|
if attributes:
|
|
|
|
|
new.attributes.set(attributes)
|
|
|
|
|
new.save()
|
|
|
|
|
else:
|
|
|
|
|
logging.error(f"{serializer.errors}")
|
|
|
|
|
continue
|
|
|
|
|
'''
|
|
|
|
|
# alternative method
|
|
|
|
|
serializer = ProductSerializer(data=instance_data)
|
|
|
|
|
if serializer.is_valid():
|
|
|
|
|
try:
|
|
|
|
|
new = Product.objects.create(**serializer.validated_data)
|
|
|
|
|
if tags:
|
|
|
|
|
new.tags.set(tags)
|
|
|
|
|
if attributes:
|
|
|
|
|
new.attributes.set(attributes)
|
|
|
|
|
new.tags = tags
|
|
|
|
|
new.attributes = attributes
|
|
|
|
|
new.save()
|
|
|
|
|
except Exception as e:
|
|
|
|
|
import ipdb; ipdb.set_trace()
|
|
|
|
|
logging.error(f"Could not create product instance: {str(e)}")
|
|
|
|
|
continue
|
|
|
|
|
try:
|
|
|
|
|
# get image
|
|
|
|
|
headers={
|
|
|
|
|
"User-Agent" : "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36"
|
|
|
|
|
}
|
|
|
|
|
headers={"User-Agent" : "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36"}
|
|
|
|
|
image_url = product['images'][0]['src']
|
|
|
|
|
response = requests.get(image_url, stream=True, headers=headers)
|
|
|
|
|
response.raw.decode_content = True
|
|
|
|
|
@@ -121,13 +119,18 @@ def migrate_shop_products(url, key, secret, version="wc/v3"):
|
|
|
|
|
except Exception as e:
|
|
|
|
|
logging.error(f"Could not add image to product: {str(e)}")
|
|
|
|
|
else:
|
|
|
|
|
import ipdb; ipdb.set_trace()
|
|
|
|
|
logging.error(f"{serializer.errors}")
|
|
|
|
|
continue
|
|
|
|
|
|
|
|
|
|
products_created.append(new)
|
|
|
|
|
counter += 1
|
|
|
|
|
logging.info(f"Product {instance_data.get('name')} created")
|
|
|
|
|
print(f"Product {instance_data.get('name')} created")
|
|
|
|
|
logging.info(f"Product '{instance_data.get('name')}' created")
|
|
|
|
|
print(f"Product '{instance_data.get('name')}' created")
|
|
|
|
|
|
|
|
|
|
# update history.quantity
|
|
|
|
|
history.quantity = counter
|
|
|
|
|
history.save()
|
|
|
|
|
|
|
|
|
|
print(f"Products created: {counter}")
|
|
|
|
|
return products_created
|
|
|
|
|
|