1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
|
from odoo import fields, models, api, tools, _
import logging
import re
import pysolr
_logger = logging.getLogger(__name__)
_cat_brand_solr = pysolr.Solr('http://10.148.0.5:8983/solr/url_category_brand/', always_commit=True, timeout=30)
# _cat_brand_solr_dev = pysolr.Solr('http://127.0.0.1:8983/solr/url_category_brand/', always_commit=True, timeout=30)
class BrandProductCategory(models.Model):
_name = 'v.brand.product.category'
_auto = False
_rec_name = 'brand_id'
brand_id = fields.Many2one('x_manufactures', string='Brand')
category_id = fields.Many2one('product.public.category', string='Category')
def init(self):
tools.drop_view_if_exists(self.env.cr, self._table)
self.env.cr.execute("""
CREATE OR REPLACE VIEW %s
AS select row_number() over(order by pt.x_manufacture) as id,
pt.x_manufacture as brand_id,
ppcptr.product_public_category_id as category_id
from product_template pt
join product_public_category_product_template_rel ppcptr on ppcptr.product_template_id = pt.id
join x_manufactures xm on xm.id = pt.x_manufacture
group by x_manufacture, ppcptr.product_public_category_id
""" % self._table)
class FindPage(models.Model):
_name = 'web.find.page'
_inherit = ['mail.thread']
_rec_name = 'url'
brand_id = fields.Many2one('x_manufactures', string='Brand')
category_id = fields.Many2one('product.public.category', string='Category', help='Bisa semua level Category')
url = fields.Char(string='Url')
def _sync_to_solr(self, limit=10000):
urls = self.env['web.find.page'].search([])
documents = []
catch = {}
for url in urls:
try:
document = {
'id': url.id,
'category_id_i': url.category_id.id,
'brand_id_i': url.brand_id.id,
'url_s': url.url
}
documents.append(document)
catch = document
except Exception as e:
_logger.error('Failed to add document to Solr URL Category Brand: %s', e)
_logger.error('Document Data: %s', catch)
_cat_brand_solr.add(documents)
return True
def _get_category_hierarchy(self, category):
categories = []
current_category = category
while current_category:
categories.insert(0, current_category)
current_category = current_category.parent_id
return categories
def _generate_url(self):
categories = self.env['v.brand.product.category'].search([])
list_url = []
for category in categories:
category_hierarchy = self._get_category_hierarchy(category.category_id)
for level, cat in enumerate(reversed(category_hierarchy), start=1):
list_url.append(self._generate_mod_url(cat, category.brand_id))
# print(f"Level {level}: {cat.name} {category.brand_id.x_name}")
unique_list = []
for item in list_url:
if item not in unique_list:
unique_list.append(item)
count = 0
for item in unique_list:
self._create_find_page(item['url'], item['category_id'], item['brand_id'])
count += 1
print(f"Total categories processed: {count}")
def _create_find_page(self, url, category_id, brand_id):
param = {
'url': url,
'category_id': category_id,
'brand_id': brand_id,
}
find_page = self.env['web.find.page'].create(param)
_logger.info('Created Web Find Page %s' % find_page.id)
def _generate_mod_url(self, category, brand):
# generate_url = 'https://indoteknik.com/shop/find/category-brand' example
cleaned_category = re.sub(r'[^\w\s]', '', category.name)
cleaned_brand = re.sub(r'[^\w\s]', '', brand.x_name)
cleaned_combined = cleaned_category+' '+cleaned_brand
cleaned_combined = cleaned_combined.replace(' ', '-')
cleaned_combined = cleaned_combined.replace('--', '-')
url = 'https://indoteknik.com/shop/find/'+cleaned_combined
url = url.lower()
result = {
'url': url,
'category_id': category.id,
'brand_id': brand.id
}
# print(url)
# param = {
# 'brand_id': brand.id,
# 'category_id': category.id,
# 'url':''
# }
# self.env['web.find.page'].create()
# print(1)
return result
|