diff --git a/sf_base/__manifest__.py b/sf_base/__manifest__.py index 085b8f6f..8013a7e8 100644 --- a/sf_base/__manifest__.py +++ b/sf_base/__manifest__.py @@ -23,6 +23,10 @@ # "views/tool_base_views.xml", # "views/tool_base_menu.xml", # 'views/fixture_base_view.xml', + "views/tool_views.xml", + "views/tool_menu.xml", + # "views/tool_base_views.xml", + # "views/tool_base_menu.xml", 'views/menu_fixture_view.xml', ], diff --git a/sf_base/models/__init__.py b/sf_base/models/__init__.py index dee7cab3..400f3093 100644 --- a/sf_base/models/__init__.py +++ b/sf_base/models/__init__.py @@ -1,8 +1,11 @@ from . import base from . import common -from . import tool_base +#from . import tool_base #from . import fixture_base from . import fixture from . import functional_fixture +# from . import tool_base +from . import tool_base_new +#from . import fixture_base diff --git a/sf_base/models/tool_base.py b/sf_base/models/tool_base.py index e396d82c..08452e69 100644 --- a/sf_base/models/tool_base.py +++ b/sf_base/models/tool_base.py @@ -2,9 +2,9 @@ import logging from odoo import fields, models, api -from odoo.exceptions import UserError -# from odoo.addons import sf_base, sf_common -from datetime import datetime +# from odoo.exceptions import UserError +# # from odoo.addons import sf_base, sf_common +# from datetime import datetime # 功能刀具物料 @@ -24,7 +24,6 @@ class FunctionalCuttingTool(models.Model): code = fields.Char('编码') name = fields.Char('名称') - # 增加功能刀具类型、整体式刀具型号、刀片型号、刀杆型号、刀盘型号、刀柄型号、夹头型号、直径(mm)、刀具等级、加工精度(mm)、装刀长、刃数、整体刃长(mm)、有效刃长(mm)、最大寿命值、是否标准刀、适用范围 functional_model_number = fields.Many2one('sf.functional.cutting.tool.model', string='功能刀具类型') integral_model_number = fields.Many2one('sf.integral.cutting.tool', string='整体式刀具型号') blade_model_number = fields.Many2one('sf.blade', string='刀片型号') diff --git a/sf_base/models/tool_base_new.py b/sf_base/models/tool_base_new.py new file mode 100644 index 00000000..65d2e4cb --- /dev/null +++ b/sf_base/models/tool_base_new.py @@ -0,0 +1,267 @@ +# -*- coding: utf-8 -*- +from odoo import fields, models, api +# from datetime import datetime +# from odoo.exceptions import ValidationError + + +# 刀具物料 +class CuttingToolMaterial(models.Model): + _name = 'sf.cutting.tool.material' + _description = '刀具物料' + + code = fields.Char('编码') + name = fields.Char('名称') + remark = fields.Char('备注') + + +# 功能刀具 +class FunctionalCuttingTool(models.Model): + _name = 'sf.functional.cutting.tool' + _description = '功能刀具' + + code = fields.Char('编码') + name = fields.Char('名称') + mrs_cutting_tool_type_id = fields.Many2one('sf.cutting.tool.type', string='功能刀具类型') + mrs_cutting_tool_model_id = fields.Many2one('sf.cutting.tool.model', string='刀具型号') + diameter = fields.Float('直径(mm)') + tool_grade = fields.Selection([('1', 'P1'), ('2', 'P2'), ('3', 'P3'), ('4', 'P4'), ('5', 'P5'), ('6', 'P6')], + string='刀具等级') + machining_accuracy = fields.Float('加工精度(mm)') + tool_length = fields.Float('装刀长') + blade_number = fields.Integer('刃数') + integral_blade_length = fields.Float('整体刃长(mm)') + effective_blade_length = fields.Float('有效刃长(mm)') + max_life = fields.Float('最大寿命值') + is_standard = fields.Boolean('是否标准刀') + applicable_range = fields.Char('适用范围') + image = fields.Binary('图片') + + +# 功能刀具类型 +class FunctionalCuttingToolModel(models.Model): + _name = 'sf.functional.cutting.tool.model' + _description = '功能刀具类型' + + name = fields.Char('名称', required=True) + code = fields.Char('编码', required=True) + remark = fields.Char('备注') + + +# 刀具型号 +class CuttingToolModel(models.Model): + _name = 'sf.cutting.tool.model' + _description = '刀具型号' + + name = fields.Char('名称') + code = fields.Char('编码') + mrs_machine_brand_id = fields.Many2one('sf.machine.brand', '品牌') + mrs_materials_model_id = fields.Many2one('sf.materials.model', '材料型号') + # 关联刀具物料 + mrs_cutting_tool_material_id = fields.Many2one('sf.cutting.tool.material', '刀具物料', required=True) + # 关联刀具物料名称 + mrs_cutting_tool_material_name = fields.Char(related='mrs_cutting_tool_material_id.name', string='刀具物料名称', + store=True) + # 关联刀具类型 + mrs_cutting_tool_type_id = fields.Many2one( + 'sf.cutting.tool.type', '刀具类型', + domain="[('mrs_cutting_tool_material_id.name', '=', mrs_cutting_tool_material_name)]", required=True) + + # 整体式刀具特有字段 + integral_code = fields.Char('整体式刀具编码') + integral_total_length = fields.Float('总长度(mm)') + integral_shank_length = fields.Float('柄部长度(mm)') + integral_blade_length = fields.Float('刃部长度(mm)') + integral_diameter = fields.Float('直径(mm)') + integral_blade_number = fields.Integer('刃数') + integral_front_angle = fields.Float('前角(°)') + integral_rear_angle = fields.Float('后角(°)') + integral_main_included_angle = fields.Float('主偏角(°)') + integral_nut = fields.Float('配对螺母(mm)') + integral_scope = fields.Char('适用范围') + + # 刀片特有字段 + blade_code = fields.Char('刀片编码') + blade_length = fields.Float('长度L(mm)') + blade_width = fields.Float('宽度D(mm)') + blade_height = fields.Float('高度T(mm)') + blade_top_angle = fields.Float('顶角(°)') + blade_front_angle = fields.Float('前角(°)') + blade_rear_angle = fields.Float('后角(°)') + blade_main_included_angle = fields.Float('主偏角(°)') + blade_r_angle = fields.Float('R角(°)') + blade_hardness = fields.Char('加工硬度') + blade_radius = fields.Float('刀尖半径(mm)') + blade_nut = fields.Float('配对螺母(mm)') + mrs_cutting_tool_model_blade_cutter_bar_ids = fields.Many2many( + 'sf.cutting.tool.model', + relation='sf_cutting_tool_model_blade_cutter_bar_rel', + column1='model_id_1', + column2='model_id_2', + domain="[('mrs_cutting_tool_material_id.name', '=', '刀杆')]", + string='适用刀杆型号', + default=lambda self: [], # 使用空列表作为默认值 + ) + mrs_cutting_tool_model_blade_cutter_pad_ids = fields.Many2many( + 'sf.cutting.tool.model', + relation='sf_cutting_tool_model_blade_cutter_pad_rel', + column1='model_id_1', + column2='model_id_2', + domain="[('mrs_cutting_tool_material_id.name', '=', '刀盘')]", + string='适用刀盘型号', + default=lambda self: [], # 使用空列表作为默认值 + ) + + # 刀杆特有字段 + bar_code = fields.Char('刀杆编码', readonly=True) + bar_c_diameter = fields.Float('C柄径(mm)') + bar_total_length = fields.Float('L总长(mm)') + bar_blade_number = fields.Integer('刃数') + bar_d_diameter = fields.Float('D刃径(mm)') + mrs_cutting_tool_model_bar_blade_ids = fields.Many2many( + 'sf.cutting.tool.model', + relation='sf_cutting_tool_model_bar_blade_rel', + column1='model_id_1', + column2='model_id_2', + domain="[('mrs_cutting_tool_material_id.name', '=', '刀片')]", + string='适用刀片型号', + default=lambda self: [], # 使用空列表作为默认值 + ) + bar_wrench = fields.Float('配对扳手(mm)') + bar_screw = fields.Float('配备螺丝(mm)') + bar_radius = fields.Float('刀尖圆角半径') + bar_accuracy = fields.Char('精度等级') + bar_hardness = fields.Char('硬度(°)') + bar_scope = fields.Char('适用范围') + + # 刀盘特有字段 + pad_code = fields.Char('刀盘编码', readonly=True) + pad_c_diameter = fields.Float('C柄径(mm)') + pad_total_length = fields.Float('L总长(mm)') + pad_blade_number = fields.Integer('刃数') + pad_d_diameter = fields.Float('D刃径(mm)') + mrs_cutting_tool_model_pad_blade_ids = fields.Many2many( + 'sf.cutting.tool.model', + relation='sf_cutting_tool_model_pad_blade_rel', + column1='model_id_1', + column2='model_id_2', + domain="[('mrs_cutting_tool_material_id.name', '=', '刀片')]", + string='适用刀片型号', + default=lambda self: [], # 使用空列表作为默认值 + ) + pad_wrench = fields.Float('配对扳手(mm)') + pad_screw = fields.Float('配备螺丝(mm)') + pad_radius = fields.Float('刀尖圆角半径') + pad_accuracy = fields.Char('精度等级') + pad_hardness = fields.Char('硬度(°)') + pad_scope = fields.Char('适用范围') + + # 刀柄特有字段 + handle_code = fields.Char('刀柄编码', readonly=True) + handle_length = fields.Float('L(mm)') + handle_length1 = fields.Float('L1(mm)') + handle_diameter1 = fields.Float('D1(mm)') + handle_weight = fields.Float('重量(kg)') + handle_body_accuracy = fields.Float('本体精度(mm)') + handle_nut = fields.Float('配对螺母(mm)') + mrs_cutting_tool_model_handle_chuck_model_ids = fields.Many2many( + 'sf.cutting.tool.model', + relation='sf_cutting_tool_model_handle_chuck_rel', + column1='model_id_1', + column2='model_id_2', + domain="[('mrs_cutting_tool_material_id.name', '=', '夹头')]", + string='适用夹头型号', + + ) + handle_clamping_range = fields.Float('夹持范围(mm)') + handle_detection_accuracy = fields.Float('检测精度') + handle_detection_hardness = fields.Char('检测硬度') + handle_standard_speed = fields.Float('标准转速') + + # 夹头特有字段 + chuck_code = fields.Char('夹头编码', readonly=True) + chuck_accuracy = fields.Float('精度(mm)') + chuck_diameter = fields.Float('外径(mm)') + chuck_inner_diameter = fields.Float('内径(mm)') + chuck_height = fields.Float('高度(mm)') + chuck_nut = fields.Float('配对螺母(mm)') + mrs_cutting_tool_model_chuck_handle_model_ids = fields.Many2many( + 'sf.cutting.tool.model', + relation='sf_cutting_tool_model_chuck_handle_rel', + column1='model_id_1', + column2='model_id_2', + domain="[('mrs_cutting_tool_material_id.name', '=', '刀柄')]", + string='适用刀柄型号', + default=lambda self: [], # 使用空列表作为默认值 + ) + chuck_clamping_range = fields.Float('夹持范围(mm)') + chuck_feature = fields.Char('特性') + + image = fields.Binary('图片') + + hide_integral = fields.Boolean(compute='_compute_hide_model_number', default=False, string='隐藏整体式刀具') + hide_blade = fields.Boolean(compute='_compute_hide_model_number', default=False, string='隐藏刀片') + hide_cutter_bar = fields.Boolean(compute='_compute_hide_model_number', default=False, string='隐藏刀杆') + hide_cutter_pad = fields.Boolean(compute='_compute_hide_model_number', default=False, string='隐藏刀盘') + hide_handler = fields.Boolean(compute='_compute_hide_model_number', default=False, string='隐藏刀柄') + hide_chuck = fields.Boolean(compute='_compute_hide_model_number', default=False, string='隐藏夹头') + hide_model = fields.Boolean(compute='_compute_hide_model_number', default=True, string='隐藏型号') + + @api.depends('mrs_cutting_tool_material_id') + def _compute_hide_model_number(self): + """ + 根据刀具物料类型,显示不同的字段 + """ + for record in self: + record.hide_integral = False + record.hide_blade = False + record.hide_cutter_bar = False + record.hide_cutter_pad = False + record.hide_handler = False + record.hide_chuck = False + record.hide_model = True + + if record.mrs_cutting_tool_material_id and record.mrs_cutting_tool_material_id.name == '整体式刀具': + record.hide_model = False + record.hide_integral = True + elif record.mrs_cutting_tool_material_id and record.mrs_cutting_tool_material_id.name == '刀片': + record.hide_model = False + record.hide_blade = True + elif record.mrs_cutting_tool_material_id and record.mrs_cutting_tool_material_id.name == '刀杆': + record.hide_model = False + record.hide_cutter_bar = True + elif record.mrs_cutting_tool_material_id and record.mrs_cutting_tool_material_id.name == '刀盘': + record.hide_model = False + record.hide_cutter_pad = True + elif record.mrs_cutting_tool_material_id and record.mrs_cutting_tool_material_id.name == '刀柄': + record.hide_model = False + record.hide_handler = True + elif record.mrs_cutting_tool_material_id and record.mrs_cutting_tool_material_id.name == '夹头': + record.hide_model = False + record.hide_chuck = True + else: + record.hide_model = True + + +# 刀具类型 +class CuttingToolType(models.Model): + _name = 'sf.cutting.tool.type' + _description = '刀具类型' + + code = fields.Char('编码') + name = fields.Char('名称') + # 关联刀具物料 + mrs_cutting_tool_material_id = fields.Many2one('sf.cutting.tool.material', '刀具物料') + # 整体式刀具类型特有字段 + integral_tool_type_code = fields.Char('整体式刀具类型编码') + # 刀片类型特有字段 + blade_type_code = fields.Char('刀片类型编码') + # 刀杆类型特有字段 + bar_type_code = fields.Char('刀杆类型编码') + # 刀盘类型特有字段 + pad_type_code = fields.Char('刀盘类型编码') + # 刀柄类型特有字段 + handle_type_code = fields.Char('刀柄类型编码') + # 夹头类型特有字段 + chuck_type_code = fields.Char('夹头类型编码') + + remark = fields.Char('备注') diff --git a/sf_base/security/ir.model.access.csv b/sf_base/security/ir.model.access.csv index beabc3f7..175e4589 100644 --- a/sf_base/security/ir.model.access.csv +++ b/sf_base/security/ir.model.access.csv @@ -15,21 +15,11 @@ access_sf_production_process_parameter,sf_production_process_parameter,model_sf_ access_sf_production_process_category,sf_production_process_category,model_sf_production_process_category,base.group_user,1,1,1,1 access_sf_machine_tool_category,sf_machine_tool_category,model_sf_machine_tool_category,base.group_user,1,1,1,1 -access_sf_functional_cutting_tool,sf.functional.cutting.tool,model_sf_functional_cutting_tool,base.group_user,1,1,1,1 -access_sf_functional_cutting_tool_model,sf.functional.cutting.tool.model,model_sf_functional_cutting_tool_model,base.group_user,1,1,1,1 -access_sf_integral_cutting_tool,sf.integral.cutting.tool,model_sf_integral_cutting_tool,base.group_user,1,1,1,1 -access_sf_integral_cutting_tool_model,sf.integral.cutting.tool.model,model_sf_integral_cutting_tool_model,base.group_user,1,1,1,1 -access_sf_blade,sf.blade,model_sf_blade,base.group_user,1,1,1,1 -access_sf_blade_model,sf.blade.model,model_sf_blade_model,base.group_user,1,1,1,1 -access_sf_cutter_bar,sf.cutter.bar,model_sf_cutter_bar,base.group_user,1,1,1,1 -access_sf_cutter_bar_model,sf.cutter.bar.model,model_sf_cutter_bar_model,base.group_user,1,1,1,1 -access_sf_cutter_pad,sf.cutter.pad,model_sf_cutter_pad,base.group_user,1,1,1,1 -access_sf_cutter_pad_model,sf.cutter.pad.model,model_sf_cutter_pad_model,base.group_user,1,1,1,1 -access_sf_handle,sf.handle,model_sf_handle,base.group_user,1,1,1,1 -access_sf_handle_model,sf.handle.model,model_sf_handle_model,base.group_user,1,1,1,1 -access_sf_chuck,sf.chuck,model_sf_chuck,base.group_user,1,1,1,1 -access_sf_chuck_model,sf.chuck.model,model_sf_chuck_model,base.group_user,1,1,1,1 -access_sf_cutting_tool_material,sf.cutting.tool.material,model_sf_cutting_tool_material,base.group_user,1,1,1,1 +access_sf_cutting_tool_material,sf_cutting_tool_material,model_sf_cutting_tool_material,base.group_user,1,1,1,1 +access_sf_cutting_tool_type,sf_cutting_tool_type,model_sf_cutting_tool_type,base.group_user,1,1,1,1 +access_sf_cutting_tool_model,sf_cutting_tool_model,model_sf_cutting_tool_model,base.group_user,1,1,1,1 +access_sf_functional_cutting_tool,sf_functional_cutting_tool,model_sf_functional_cutting_tool,base.group_user,1,1,1,1 +access_sf_functional_cutting_tool_model,sf_functional_cutting_tool_model,model_sf_functional_cutting_tool_model,base.group_user,1,1,1,1 diff --git a/sf_base/views/tool_base_views.xml b/sf_base/views/tool_base_views.xml index 382c4647..473a9134 100644 --- a/sf_base/views/tool_base_views.xml +++ b/sf_base/views/tool_base_views.xml @@ -35,7 +35,9 @@ - + + + sf.cutting.tool.material.search sf.cutting.tool.material diff --git a/sf_base/views/tool_menu.xml b/sf_base/views/tool_menu.xml new file mode 100644 index 00000000..ef11c145 --- /dev/null +++ b/sf_base/views/tool_menu.xml @@ -0,0 +1,89 @@ + + + + + + + 刀具物料 + ir.actions.act_window + sf.cutting.tool.material + tree,form + + + + 刀具类型 + ir.actions.act_window + sf.cutting.tool.type + tree,form + + + + 刀具型号 + ir.actions.act_window + sf.cutting.tool.model + tree,form + + + + 功能刀具 + ir.actions.act_window + sf.functional.cutting.tool + tree,form + + + + 功能刀具类型 + ir.actions.act_window + sf.functional.cutting.tool.model + tree,form + + + + + + + + + + + + + + + + diff --git a/sf_base/views/tool_views.xml b/sf_base/views/tool_views.xml new file mode 100644 index 00000000..6909519a --- /dev/null +++ b/sf_base/views/tool_views.xml @@ -0,0 +1,376 @@ + + + + + + sf.cutting.tool.material.tree + sf.cutting.tool.material + + + + + + + + + + + sf.cutting.tool.material.form + sf.cutting.tool.material + +
+ + + + + + + + + + + + + + +
+
+
+ + + sf.cutting.tool.material.search + sf.cutting.tool.material + + + + + + + + + + + + sf.functional.cutting.tool.tree + sf.functional.cutting.tool + + + + + + + + + + + + sf.functional.cutting.tool.form + sf.functional.cutting.tool + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+ + + sf.functional.cutting.tool.search + sf.functional.cutting.tool + + + + + + + + + + + + sf.cutter.function.tree + sf.functional.cutting.tool.model + + + + + + + + + + sf.cutter.function.form + sf.functional.cutting.tool.model + +
+ + + + + + + + + + + +
+
+
+ + + + sf.cutter.function.search + sf.functional.cutting.tool.model + + + + + + + + + + + sf.cutting.tool.model.tree + sf.cutting.tool.model + + + + + + + + + + + + sf.cutting.tool.model.form + sf.cutting.tool.model + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+ + + + sf.cutting.tool.model.search + sf.cutting.tool.model + + + + + + + + + + + + + sf.cutting.tool.type.tree + sf.cutting.tool.type + + + + + + + + + + + + sf.cutting.tool.type.form + sf.cutting.tool.type + +
+ + + + + + + + + + + + +
+
+
+ + + + sf.cutting.tool.type.search + sf.cutting.tool.type + + + + + + + + + +
+
diff --git a/sf_mrs_connect/data/ir_cron_data.xml b/sf_mrs_connect/data/ir_cron_data.xml index 7c74d5c4..4b9d2060 100644 --- a/sf_mrs_connect/data/ir_cron_data.xml +++ b/sf_mrs_connect/data/ir_cron_data.xml @@ -154,115 +154,115 @@
- - 同步整体式刀具型号 - - code - model.sync_integral_cutting_tool() - 1 - days - -1 - - + + + + + + + + + + - - 同步整体式刀具类型 - - code - model.sync_integral_cutting_tool_model() - 1 - days - -1 - - + + + + + + + + + + - - 同步刀片型号 - - code - model.sync_blade() - 1 - days - -1 - - + + + + + + + + + + - - 同步刀片类型 - - code - model.sync_blade_model() - 1 - days - -1 - - + + + + + + + + + + - - 同步刀杆型号 - - code - model.sync_cutter_bar() - 1 - days - -1 - - + + + + + + + + + + - - 同步刀杆类型 - - code - model.sync_cutter_bar_model() - 1 - days - -1 - - + + + + + + + + + + - - 同步刀盘型号 - - code - model.sync_cutter_pad() - 1 - days - -1 - - + + + + + + + + + + - - 同步刀盘类型 - - code - model.sync_cutter_pad_model() - 1 - days - -1 - - + + + + + + + + + + - - 同步刀柄型号 - - code - model.sync_handle() - 1 - days - -1 - - + + + + + + + + + + - - 同步刀柄类型 - - code - model.sync_handle_model() - 1 - days - -1 - - + + + + + + + + + + 同步夹具物料 @@ -318,71 +318,4 @@ -1 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/sf_mrs_connect/models/res_config_setting.py b/sf_mrs_connect/models/res_config_setting.py index 032a1b20..9fe3b5d5 100644 --- a/sf_mrs_connect/models/res_config_setting.py +++ b/sf_mrs_connect/models/res_config_setting.py @@ -42,96 +42,33 @@ class ResConfigSettings(models.TransientModel): _logger.info("同步资源库机床类型") # self.env['sf.production.process.parameter'].sync_all_production_process_parameter() # _logger.info("同步表面工艺参数") - # _logger.info("定时同步每日功能刀具类型列表...") - # # self.env['sf.functional.cutting.tool.model'].sync_functional_cutting_tool_model() - # _logger.info("同步每日功能刀具类型完成") + _logger.info("定时同步每日功能刀具类型列表...") + # self.env['sf.functional.cutting.tool.model'].sync_functional_cutting_tool_model() + _logger.info("同步每日功能刀具类型完成") _logger.info("同步所有功能刀具类型...") self.env['sf.functional.cutting.tool.model'].sync_all_functional_cutting_tool_model() _logger.info("同步所有功能刀具类型完成") - # _logger.info("定时同步每日整体式刀具类型列表...") - # # self.env['sf.integral.cutting.tool'].sync_integral_cutting_tool() - # _logger.info("同步整体式刀具类型完成") - # _logger.info("同步每日刀具物料...") - # self.env['sf.cutting.tool.material'].sync_cutting_tool_material() - # _logger.info("同步每日刀具物料完成") + _logger.info("同步每日刀具物料...") + self.env['sf.cutting.tool.material'].sync_cutting_tool_material() + _logger.info("同步每日刀具物料完成") _logger.info("同步所有刀具物料...") self.env['sf.cutting.tool.material'].sync_all_cutting_tool_material() _logger.info("同步所有刀具物料完成") - # _logger.info("同步每日刀片类型列表...") - # self.env['sf.blade.model'].sync_blade_model() - # _logger.info("同步每日刀片类型完成") - _logger.info("同步所有刀片类型列表...") - self.env['sf.blade.model'].sync_all_blade_model() - _logger.info("同步所有刀片类型完成") - # _logger.info("同步每日刀杆类型...") - # self.env['sf.cutter.bar.model'].sync_cutter_bar_model() - # _logger.info("同步每日刀杆类型完成") - _logger.info("同步所有刀杆类型...") - self.env['sf.cutter.bar.model'].sync_all_cutter_bar_model() - _logger.info("同步所有刀杆类型完成") - # _logger.info("同步每日刀盘类型...") - # self.env['sf.cutter.pad.model'].sync_cutter_pad_model() - # _logger.info("同步每日刀盘类型完成") - _logger.info("同步所有刀盘类型...") - self.env['sf.cutter.pad.model'].sync_all_cutter_pad_model() - _logger.info("同步所有刀盘类型完成") - # _logger.info("同步每日刀柄类型...") - # self.env['sf.handle.model'].sync_handle_model() - # _logger.info("同步每日刀柄类型完成") - _logger.info("同步所有刀柄类型...") - self.env['sf.handle.model'].sync_all_handle_model() - _logger.info("同步所有刀柄类型完成") - # _logger.info("同步每日夹头类型...") - # self.env['sf.chuck.model'].sync_chuck_model() - # _logger.info("同步每日夹头类型完成") - _logger.info("同步所有夹头类型...") - self.env['sf.chuck.model'].sync_all_chuck_model() - _logger.info("同步所有夹头类型完成") - # _logger.info("同步每日整体式刀具类型...") - # self.env['sf.integral.cutting.tool.model'].sync_integral_cutting_tool_model() - # _logger.info("同步每日整体式刀具类型完成") - _logger.info("同步所有整体式刀具类型...") - self.env['sf.integral.cutting.tool.model'].sync_all_integral_cutting_tool_model() - _logger.info("同步所有整体式刀具类型完成") - # _logger.info("同步每日刀片列表...") - # self.env['sf.blade'].sync_blade() - # _logger.info("同步每日刀片完成") - _logger.info("同步所有刀片列表...") - self.env['sf.blade'].sync_all_blade() - _logger.info("同步所有刀片完成") - # _logger.info("同步每日刀杆列表...") - # self.env['sf.cutter.bar'].sync_cutter_bar() - # _logger.info("同步每日刀杆完成") - _logger.info("同步所有刀杆列表...") - self.env['sf.cutter.bar'].sync_all_cutter_bar() - _logger.info("同步所有刀杆完成") - # _logger.info("同步每日刀盘列表...") - # self.env['sf.cutter.pad'].sync_cutter_pad() - # _logger.info("同步每日刀盘完成") - _logger.info("同步所有刀盘列表...") - self.env['sf.cutter.pad'].sync_all_cutter_pad() - _logger.info("同步所有刀盘完成") - # _logger.info("同步每日刀柄列表...") - # self.env['sf.handle'].sync_handle() - # _logger.info("同步每日刀柄完成") - _logger.info("同步所有刀柄列表...") - self.env['sf.handle'].sync_all_handle() - _logger.info("同步所有刀柄完成") - # _logger.info("同步每日夹头列表...") - # self.env['sf.chuck'].sync_chuck() - # _logger.info("同步每日夹头完成") - _logger.info("同步所有夹头列表...") - self.env['sf.chuck'].sync_all_chuck() - _logger.info("同步所有夹头完成") - # _logger.info("同步每日整体式刀具列表...") - # self.env['sf.integral.cutting.tool'].sync_integral_cutting_tool() - # _logger.info("同步每日整体式刀具完成") - _logger.info("同步所有整体式刀具列表...") - self.env['sf.integral.cutting.tool'].sync_all_integral_cutting_tool() - _logger.info("同步所有整体式刀具完成") - # _logger.info("同步每日同步功能刀具列表...") - # self.env['sf.functional.cutting.tool'].sync_functional_cutting_tool() - # _logger.info("同步每日功能刀具列表完成") + _logger.info("同步每日刀具类型...") + self.env['sf.cutting.tool.type'].sync_tool_type() + _logger.info("同步每日刀具类型完成") + _logger.info("同步所有刀具类型...") + self.env['sf.cutting.tool.type'].sync_all_tool_type() + _logger.info("同步所有刀具类型完成") + _logger.info("同步每日刀具型号...") + self.env['sf.cutting.tool.model'].sync_tool_model() + _logger.info("同步每日刀具型号完成") + _logger.info("同步所有刀具型号...") + self.env['sf.cutting.tool.model'].sync_all_tool_model() + _logger.info("同步所有刀具型号完成") + _logger.info("同步每日同步功能刀具列表...") + self.env['sf.functional.cutting.tool'].sync_functional_cutting_tool() + _logger.info("同步每日功能刀具列表完成") _logger.info("同步所有功能刀具列表...") self.env['sf.functional.cutting.tool'].sync_all_functional_cutting_tool() _logger.info("同步所有功能刀具列表完成") @@ -159,7 +96,6 @@ class ResConfigSettings(models.TransientModel): _logger.info("捕获错误信息:%s" % e) raise ValidationError("数据错误导致同步失败,请联系管理员") - @api.model def get_values(self): """ diff --git a/sf_mrs_connect/models/sync_common.py b/sf_mrs_connect/models/sync_common.py index 0cd13cf6..5f9f6ede 100644 --- a/sf_mrs_connect/models/sync_common.py +++ b/sf_mrs_connect/models/sync_common.py @@ -1180,26 +1180,11 @@ class sfSyncFunctional_cutting_tool(models.Model): "name": item['name'], "code": item['code'], # 功能刀具类型 - "functional_model_number": self.env['sf.functional.cutting.tool.model'].search( - [('code', '=', item['functional_model_number'])]).id, - # 整体刀具型号 - "integral_model_number": self.env['sf.integral.cutting.tool'].search( - [('code', '=', item['integral_model_number'])]).id, - # 刀片型号 - "blade_model_number": self.env['sf.blade'].search( - [('code', '=', item['blade_model_number'])]).id, - # 刀杆型号 - "cutterbar_model_number": self.env['sf.cutter.bar'].search( - [('code', '=', item['cutterbar_model_number'])]).id, - # 刀盘型号 - "cutterpad_model_number": self.env['sf.cutter.pad'].search( - [('code', '=', item['cutterpad_model_number'])]).id, - # 刀柄型号 - "handle_model_number": self.env['sf.handle'].search( - [('code', '=', item['handle_model_number'])]).id, - # 夹头型号 - "chuck_model_number": self.env['sf.chuck'].search( - [('code', '=', item['chuck_model_number'])]).id, + "mrs_cutting_tool_type_id": self.env['sf.cutting.tool.type'].search( + [('code', '=', item['mrs_cutting_tool_type_id'])]).id, + # 刀具型号 + "mrs_cutting_tool_model_id": self.env['sf.cutting.tool.model'].search( + [('code', '=', item['mrs_cutting_tool_model_id'])]).id, "diameter": item['diameter'], "tool_grade": item['tool_grade'], "machining_accuracy": item['machining_accuracy'], @@ -1218,26 +1203,11 @@ class sfSyncFunctional_cutting_tool(models.Model): "name": item['name'], "code": item['code'], # 功能刀具类型 - "functional_model_number": self.env['sf.functional.cutting.tool.model'].search( - [('code', '=', item['functional_model_number'])]).id, - # 整体刀具型号 - "integral_model_number": self.env['sf.integral.cutting.tool'].search( - [('code', '=', item['integral_model_number'])]).id, - # 刀片型号 - "blade_model_number": self.env['sf.blade'].search( - [('code', '=', item['blade_model_number'])]).id, - # 刀杆型号 - "cutterbar_model_number": self.env['sf.cutter.bar'].search( - [('code', '=', item['cutterbar_model_number'])]).id, - # 刀盘型号 - "cutterpad_model_number": self.env['sf.cutter.pad'].search( - [('code', '=', item['cutterpad_model_number'])]).id, - # 刀柄型号 - "handle_model_number": self.env['sf.handle'].search( - [('code', '=', item['handle_model_number'])]).id, - # 夹头型号 - "chuck_model_number": self.env['sf.chuck'].search( - [('code', '=', item['chuck_model_number'])]).id, + "mrs_cutting_tool_type_id": self.env['sf.cutting.tool.type'].search( + [('code', '=', item['mrs_cutting_tool_type_id'])]).id, + # 刀具型号 + "mrs_cutting_tool_model_id": self.env['sf.cutting.tool.model'].search( + [('code', '=', item['mrs_cutting_tool_model_id'])]).id, "diameter": item['diameter'], "tool_grade": item['tool_grade'], "machining_accuracy": item['machining_accuracy'], @@ -1281,26 +1251,11 @@ class sfSyncFunctional_cutting_tool(models.Model): "name": item['name'], "code": item['code'], # 功能刀具类型 - "functional_model_number": self.env['sf.functional.cutting.tool.model'].search( - [('code', '=', item['functional_model_number'])]).id, - # 整体刀具型号 - "integral_model_number": self.env['sf.integral.cutting.tool'].search( - [('code', '=', item['integral_model_number'])]).id, - # 刀片型号 - "blade_model_number": self.env['sf.blade'].search( - [('code', '=', item['blade_model_number'])]).id, - # 刀杆型号 - "cutterbar_model_number": self.env['sf.cutter.bar'].search( - [('code', '=', item['cutterbar_model_number'])]).id, - # 刀盘型号 - "cutterpad_model_number": self.env['sf.cutter.pad'].search( - [('code', '=', item['cutterpad_model_number'])]).id, - # 刀柄型号 - "handle_model_number": self.env['sf.handle'].search( - [('code', '=', item['handle_model_number'])]).id, - # 夹头型号 - "chuck_model_number": self.env['sf.chuck'].search( - [('code', '=', item['chuck_model_number'])]).id, + "mrs_cutting_tool_type_id": self.env['sf.cutting.tool.type'].search( + [('code', '=', item['mrs_cutting_tool_type_id'])]).id, + # 刀具型号 + "mrs_cutting_tool_model_id": self.env['sf.cutting.tool.model'].search( + [('code', '=', item['mrs_cutting_tool_model_id'])]).id, "diameter": item['diameter'], "tool_grade": item['tool_grade'], "machining_accuracy": item['machining_accuracy'], @@ -1319,26 +1274,11 @@ class sfSyncFunctional_cutting_tool(models.Model): "name": item['name'], "code": item['code'], # 功能刀具类型 - "functional_model_number": self.env['sf.functional.cutting.tool.model'].search( - [('code', '=', item['functional_model_number'])]).id, - # 整体刀具型号 - "integral_model_number": self.env['sf.integral.cutting.tool'].search( - [('code', '=', item['integral_model_number'])]).id, - # 刀片型号 - "blade_model_number": self.env['sf.blade'].search( - [('code', '=', item['blade_model_number'])]).id, - # 刀杆型号 - "cutterbar_model_number": self.env['sf.cutter.bar'].search( - [('code', '=', item['cutterbar_model_number'])]).id, - # 刀盘型号 - "cutterpad_model_number": self.env['sf.cutter.pad'].search( - [('code', '=', item['cutterpad_model_number'])]).id, - # 刀柄型号 - "handle_model_number": self.env['sf.handle'].search( - [('code', '=', item['handle_model_number'])]).id, - # 夹头型号 - "chuck_model_number": self.env['sf.chuck'].search( - [('code', '=', item['chuck_model_number'])]).id, + "mrs_cutting_tool_type_id": self.env['sf.cutting.tool.type'].search( + [('code', '=', item['mrs_cutting_tool_type_id'])]).id, + # 刀具型号 + "mrs_cutting_tool_model_id": self.env['sf.cutting.tool.model'].search( + [('code', '=', item['mrs_cutting_tool_model_id'])]).id, "diameter": item['diameter'], "tool_grade": item['tool_grade'], "machining_accuracy": item['machining_accuracy'], @@ -3132,6 +3072,1545 @@ class SyncFunctionalFixture(models.Model): else: raise ValidationError("认证未通过") + # # 同步整体式刀具列表 + # class SyncIntegralCuttingTool(models.Model): + # _inherit = 'sf.integral.cutting.tool' + # _description = '同步整体式刀具列表' + # url = '/api/mrs_integral_cutting_tool/list' + # + # # 定时同步每日整体式刀具列表 + # def sync_integral_cutting_tool(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_integral_cutting_tool_yesterday_list'): + # for item in result['mrs_integral_cutting_tool_yesterday_list']: + # chuck_list = [] + # if item.get('chuck_model'): + # for chuck in item.get('chuck_model'): + # chuck_list.append(self.env['sf.chuck'].search( + # [("code", '=', chuck)]).id) + # if item: + # brand = self.env['sf.integral.cutting.tool'].search( + # [("code", '=', item['code'])]) + # if item.get('image'): + # image = base64.b64decode(item['image']) + # else: + # image = '' + # if not brand: + # self.env['sf.integral.cutting.tool'].create({ + # # code, name, integral_model_number, brand, total_length, shank_length, blade_length, diameter, blade_number, front_angle, rear_angle, main_included_angle, material_model, nut, chuck_model, scope, image, create_uid, create_date + # "name": item['name'], + # "code": item['code'], + # "integral_model_number": self.env['sf.integral.cutting.tool.model'].search( + # [("code", '=', item['integral_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "total_length": item['total_length'], + # "shank_length": item['shank_length'], + # "blade_length": item['blade_length'], + # "diameter": item['diameter'], + # "blade_number": item['blade_number'], + # "front_angle": item['front_angle'], + # "rear_angle": item['rear_angle'], + # "main_included_angle": item['main_included_angle'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "nut": item['nut'], + # "chuck_model": chuck_list, + # "scope": item['scope'], + # "image": image, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "code": item['code'], + # "integral_model_number": self.env['sf.integral.cutting.tool.model'].search( + # [("code", '=', item['integral_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "total_length": item['total_length'], + # "shank_length": item['shank_length'], + # "blade_length": item['blade_length'], + # "diameter": item['diameter'], + # "blade_number": item['blade_number'], + # "front_angle": item['front_angle'], + # "rear_angle": item['rear_angle'], + # "main_included_angle": item['main_included_angle'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "nut": item['nut'], + # "chuck_model": chuck_list, + # "scope": item['scope'], + # "image": image, + # }) + # else: + # raise ValidationError("认证未通过") + # + # # 同步所有整体式刀具列表 + # def sync_all_integral_cutting_tool(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_integral_cutting_tool_all_list'): + # for item in result['mrs_integral_cutting_tool_all_list']: + # chuck_list = [] + # if item.get('chuck_model'): + # for chuck in item.get('chuck_model'): + # chuck_list.append(self.env['sf.chuck'].search( + # [("code", '=', chuck)]).id) + # if item: + # brand = self.env['sf.integral.cutting.tool'].search( + # [("code", '=', item['code'])]) + # if item.get('image'): + # image = base64.b64decode(item['image']) + # else: + # image = '' + # if not brand: + # self.env['sf.integral.cutting.tool'].create({ + # # code, name, integral_model_number, brand, total_length, shank_length, blade_length, diameter, blade_number, front_angle, rear_angle, main_included_angle, material_model, nut, chuck_model, scope, image, create_uid, create_date + # "name": item['name'], + # "code": item['code'], + # "integral_model_number": self.env['sf.integral.cutting.tool.model'].search( + # [("code", '=', item['integral_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "total_length": item['total_length'], + # "shank_length": item['shank_length'], + # "blade_length": item['blade_length'], + # "diameter": item['diameter'], + # "blade_number": item['blade_number'], + # "front_angle": item['front_angle'], + # "rear_angle": item['rear_angle'], + # "main_included_angle": item['main_included_angle'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "nut": item['nut'], + # "chuck_model": chuck_list, + # "scope": item['scope'], + # "image": image, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "code": item['code'], + # "integral_model_number": self.env['sf.integral.cutting.tool.model'].search( + # [("code", '=', item['integral_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "total_length": item['total_length'], + # "shank_length": item['shank_length'], + # "blade_length": item['blade_length'], + # "diameter": item['diameter'], + # "blade_number": item['blade_number'], + # "front_angle": item['front_angle'], + # "rear_angle": item['rear_angle'], + # "main_included_angle": item['main_included_angle'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "nut": item['nut'], + # "chuck_model": chuck_list, + # "scope": item['scope'], + # "image": image, + # }) + # else: + # raise ValidationError("认证未通过") + # + # + # # 同步整体式刀具类型列表 + # class SyncIntegralCuttingToolModel(models.Model): + # _inherit = 'sf.integral.cutting.tool.model' + # _description = '同步整体式刀具类型列表' + # + # url = '/api/mrs_integral_cutting_tool_model/list' + # + # # 定时同步整体式刀具类型列表 + # def sync_integral_cutting_tool_model(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_integral_cutting_tool_model_list'): + # for item in result['mrs_integral_cutting_tool_model_list']: + # if item: + # brand = self.env['sf.integral.cutting.tool.model'].search( + # [("code", '=', item['code'])]) + # if not brand: + # self.env['sf.integral.cutting.tool.model'].create({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # else: + # raise ValidationError("认证未通过") + # + # # 同步所有整体式刀具类型列表 + # def sync_all_integral_cutting_tool_model(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_integral_cutting_tool_model_all_list'): + # for item in result['mrs_integral_cutting_tool_model_all_list']: + # if item: + # brand = self.env['sf.integral.cutting.tool.model'].search( + # [("code", '=', item['code'])]) + # if not brand: + # self.env['sf.integral.cutting.tool.model'].create({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # else: + # raise ValidationError("认证未通过") + # + # + # # 同步刀片列表 + # class SyncBlade(models.Model): + # _inherit = 'sf.blade' + # _description = '同步刀片列表' + # url = '/api/mrs_blade/list' + # + # # 定时同步每日刀片列表 + # def sync_blade(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_blade_yesterday_list'): + # for item in result['mrs_blade_yesterday_list']: + # bar_list = [] + # pad_list = [] + # if item.get('cutter_bar'): + # for i in item.get('cutter_bar'): + # bar_list.append(self.env['sf.cutter.bar'].search( + # [("code", '=', i)]).id) + # if item.get('cutter_pad'): + # for j in item.get('cutter_pad'): + # pad_list.append(self.env['sf.cutter.pad'].search( + # [("code", '=', j)]).id) + # if item: + # # code, name, blade_model_number, brand, length, width, height, top_angle, front_angle, rear_angle, main_included_angle, r_angle, material_model, hardness, nut, cutter_bar, cutter_pad, radius, image, create_uid, create_date + # brand = self.env['sf.blade'].search( + # [("code", '=', item['code'])]) + # if item.get('image'): + # image = base64.b64decode(item['image']) + # else: + # image = '' + # if not brand: + # self.env['sf.blade'].create({ + # "name": item['name'], + # "code": item['code'], + # "blade_model_number": self.env['sf.blade.model'].search( + # [("code", '=', item['blade_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "length": item['length'], + # "width": item['width'], + # "height": item['height'], + # "top_angle": item['top_angle'], + # "front_angle": item['front_angle'], + # "rear_angle": item['rear_angle'], + # "main_included_angle": item['main_included_angle'], + # "r_angle": item['r_angle'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "hardness": item['hardness'], + # "nut": item['nut'], + # "cutter_bar": bar_list, + # "cutter_pad": pad_list, + # "radius": item['radius'], + # "image": image, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "blade_model_number": self.env['sf.blade.model'].search( + # [("code", '=', item['blade_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "length": item['length'], + # "width": item['width'], + # "height": item['height'], + # "top_angle": item['top_angle'], + # "front_angle": item['front_angle'], + # "rear_angle": item['rear_angle'], + # "main_included_angle": item['main_included_angle'], + # "r_angle": item['r_angle'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "hardness": item['hardness'], + # "nut": item['nut'], + # "cutter_bar": bar_list, + # "cutter_pad": pad_list, + # "radius": item['radius'], + # "image": image, + # }) + # else: + # raise ValidationError("认证未通过") + # + # # 同步所有刀片列表 + # def sync_all_blade(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_blade_all_list'): + # for item in result['mrs_blade_all_list']: + # bar_list = [] + # pad_list = [] + # if item.get('cutter_bar'): + # for i in item.get('cutter_bar'): + # bar_list.append(self.env['sf.cutter.bar'].search( + # [("code", '=', i)]).id) + # if item.get('cutter_pad'): + # for j in item.get('cutter_pad'): + # pad_list.append(self.env['sf.cutter.pad'].search( + # [("code", '=', j)]).id) + # + # if item: + # brand = self.env['sf.blade'].search( + # [("code", '=', item['code'])]) + # if item.get('image'): + # image = base64.b64decode(item['image']) + # else: + # image = '' + # if not brand: + # self.env['sf.blade'].create({ + # "name": item['name'], + # "code": item['code'], + # "blade_model_number": self.env['sf.blade.model'].search( + # [("code", '=', item['blade_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "length": item['length'], + # "width": item['width'], + # "height": item['height'], + # "top_angle": item['top_angle'], + # "front_angle": item['front_angle'], + # "rear_angle": item['rear_angle'], + # "main_included_angle": item['main_included_angle'], + # "r_angle": item['r_angle'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "hardness": item['hardness'], + # "nut": item['nut'], + # "cutter_bar": bar_list, + # "cutter_pad": pad_list, + # "radius": item['radius'], + # "image": image, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "blade_model_number": self.env['sf.blade.model'].search( + # [("code", '=', item['blade_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "length": item['length'], + # "width": item['width'], + # "height": item['height'], + # "top_angle": item['top_angle'], + # "front_angle": item['front_angle'], + # "rear_angle": item['rear_angle'], + # "main_included_angle": item['main_included_angle'], + # "r_angle": item['r_angle'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "hardness": item['hardness'], + # "nut": item['nut'], + # "cutter_bar": bar_list, + # "cutter_pad": pad_list, + # "radius": item['radius'], + # "image": image, + # }) + # else: + # raise ValidationError("认证未通过") + # + # + # # 同步刀片类型列表 + # class SyncBladeModel(models.Model): + # _inherit = 'sf.blade.model' + # _description = '同步刀片类型列表' + # + # url = '/api/mrs_blade_model/list' + # + # # 定时同步每日刀片列表 + # def sync_blade_model(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_blade_model_yesterday_list'): + # for item in result['mrs_blade_model_yesterday_list']: + # if item: + # brand = self.env['sf.blade.model'].search( + # [("code", '=', item['code'])]) + # if not brand: + # self.env['sf.blade.model'].create({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # print('同步每日刀片类型列表成功') + # else: + # raise ValidationError("认证未通过") + # + # # 定时同步所有刀片列表 + # def sync_all_blade_model(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_blade_model_all_list'): + # for item in result['mrs_blade_model_all_list']: + # if item: + # brand = self.env['sf.blade.model'].search( + # [("code", '=', item['code'])]) + # if not brand: + # self.env['sf.blade.model'].create({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # print('同步刀片类型列表成功') + # else: + # raise ValidationError("认证未通过") + # + # + # # 同步刀杆列表 + # class SyncCutterBar(models.Model): + # _inherit = 'sf.cutter.bar' + # _description = '同步刀杆列表' + # + # url = '/api/mrs_cutter_bar/list' + # + # # 定时同步每日刀杆列表 + # def sync_cutter_bar(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_cutter_bar_yesterday_list'): + # for item in result['mrs_cutter_bar_yesterday_list']: + # blade_list = [] + # if item.get('blade'): + # for i in item.get('blade'): + # blade_list.append(self.env['sf.blade'].search( + # [("code", '=', i)]).id) + # if item: + # brand = self.env['sf.cutter.bar'].search( + # [("code", '=', item['code'])]) + # if item.get('image'): + # image = base64.b64decode(item['image']) + # else: + # image = '' + # if not brand: + # # code, name, cutter_bar_model_number, brand, c_diameter, total_length, material_model, blade_number, d_diameter, blade, wrench, screw, radius, accuracy, hardness, scope, image + # self.env['sf.cutter.bar'].create({ + # "code": item['code'], + # "name": item['name'], + # "cutter_bar_model_number": self.env['sf.cutter.bar.model'].search( + # [("code", '=', item['cutter_bar_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "c_diameter": item['c_diameter'], + # "total_length": item['total_length'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "blade_number": item['blade_number'], + # "d_diameter": item['d_diameter'], + # "blade": blade_list, + # "wrench": item['wrench'], + # "screw": item['screw'], + # "radius": item['radius'], + # "accuracy": item['accuracy'], + # "hardness": item['hardness'], + # "scope": item['scope'], + # "image": image, + # }) + # else: + # brand.write({ + # "code": item['code'], + # "name": item['name'], + # "cutter_bar_model_number": self.env['sf.cutter.bar.model'].search( + # [("code", '=', item['cutter_bar_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "c_diameter": item['c_diameter'], + # "total_length": item['total_length'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "blade_number": item['blade_number'], + # "d_diameter": item['d_diameter'], + # "blade": blade_list, + # "wrench": item['wrench'], + # "screw": item['screw'], + # "radius": item['radius'], + # "accuracy": item['accuracy'], + # "hardness": item['hardness'], + # "scope": item['scope'], + # "image": image, + # }) + # print('同步昨日刀杆列表成功') + # else: + # raise ValidationError("认证未通过") + # + # # 同步所有刀杆列表 + # def sync_all_cutter_bar(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_cutter_bar_all_list'): + # for item in result['mrs_cutter_bar_all_list']: + # blade_list = [] + # if item.get('blade'): + # for i in item.get('blade'): + # blade_list.append(self.env['sf.blade'].search( + # [("code", '=', i)]).id) + # if item: + # brand = self.env['sf.cutter.bar'].search( + # [("code", '=', item['code'])]) + # if item.get('image'): + # image = base64.b64decode(item['image']) + # else: + # image = '' + # if not brand: + # # code, name, cutter_bar_model_number, brand, c_diameter, total_length, material_model, blade_number, d_diameter, blade, wrench, screw, radius, accuracy, hardness, scope, image + # self.env['sf.cutter.bar'].create({ + # "code": item['code'], + # "name": item['name'], + # "cutter_bar_model_number": self.env['sf.cutter.bar.model'].search( + # [("code", '=', item['cutter_bar_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "c_diameter": item['c_diameter'], + # "total_length": item['total_length'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "blade_number": item['blade_number'], + # "d_diameter": item['d_diameter'], + # "blade": blade_list, + # "wrench": item['wrench'], + # "screw": item['screw'], + # "radius": item['radius'], + # "accuracy": item['accuracy'], + # "hardness": item['hardness'], + # "scope": item['scope'], + # "image": image, + # }) + # else: + # brand.write({ + # "code": item['code'], + # "name": item['name'], + # "cutter_bar_model_number": self.env['sf.cutter.bar.model'].search( + # [("code", '=', item['cutter_bar_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "c_diameter": item['c_diameter'], + # "total_length": item['total_length'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "blade_number": item['blade_number'], + # "d_diameter": item['d_diameter'], + # "blade": blade_list, + # "wrench": item['wrench'], + # "screw": item['screw'], + # "radius": item['radius'], + # "accuracy": item['accuracy'], + # "hardness": item['hardness'], + # "scope": item['scope'], + # "image": image, + # }) + # print('同步所有刀杆列表成功') + # else: + # raise ValidationError("认证未通过") + # + # + # # 同步刀杆类型列表 + # class SyncCutterBarModel(models.Model): + # _inherit = 'sf.cutter.bar.model' + # _description = '同步刀杆类型列表' + # + # url = '/api/mrs_cutter_bar_model/list' + # + # # 定时同步每日刀杆类型列表 + # def sync_cutter_bar_model(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_cutter_bar_model_yesterday_list'): + # for item in result['mrs_cutter_bar_model_yesterday_list']: + # if item: + # brand = self.env['sf.cutter.bar.model'].search( + # [("code", '=', item['code'])]) + # if not brand: + # self.env['sf.cutter.bar.model'].create({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # print('同步每日刀片类型列表成功') + # else: + # raise ValidationError("认证未通过") + # + # # 同步所有刀杆类型列表 + # def sync_all_cutter_bar_model(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_cutter_bar_model_all_list'): + # for item in result['mrs_cutter_bar_model_all_list']: + # if item: + # brand = self.env['sf.cutter.bar.model'].search( + # [("code", '=', item['code'])]) + # if not brand: + # self.env['sf.cutter.bar.model'].create({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # print('同步刀杆类型列表成功') + # else: + # raise ValidationError("认证未通过") + # + # + # # 同步刀盘列表 + # class SyncCutterPad(models.Model): + # _inherit = 'sf.cutter.pad' + # _description = '同步刀盘列表' + # + # url = '/api/mrs_cutter_pad/list' + # + # # 定时同步每日刀盘列表 + # def sync_cutter_pad(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_cutter_pad_yesterday_list'): + # for item in result['mrs_cutter_pad_yesterday_list']: + # blade_list = [] + # if item.get('blade'): + # for i in item.get('blade'): + # blade_list.append(self.env['sf.blade'].search( + # [("code", '=', i)]).id) + # if item: + # brand = self.env['sf.cutter.pad'].search( + # [("code", '=', item['code'])]) + # if item.get('image'): + # image = base64.b64decode(item['image']) + # else: + # image = '' + # if not brand: + # # 'code', 'name', 'cutter_pad_model_number', 'brand', 'c_diameter', 'total_length', 'material_model', 'blade_number', 'd_diameter', 'blade', 'wrench', 'screw', 'radius', 'accuracy', 'hardness', 'scope', 'image' + # self.env['sf.cutter.pad'].create({ + # "name": item['name'], + # "code": item['code'], + # "cutter_pad_model_number": self.env['sf.cutter.pad.model'].search( + # [("code", '=', item['cutter_pad_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "c_diameter": item['c_diameter'], + # "total_length": item['total_length'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "blade_number": item['blade_number'], + # "d_diameter": item['d_diameter'], + # # "blade": [(6, 0, blade_list)], + # "blade": blade_list, + # "wrench": item['wrench'], + # "screw": item['screw'], + # "radius": item['radius'], + # "accuracy": item['accuracy'], + # "hardness": item['hardness'], + # "scope": item['scope'], + # "image": image, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "code": item['code'], + # "cutter_pad_model_number": self.env['sf.cutter.pad.model'].search( + # [("code", '=', item['cutter_pad_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "c_diameter": item['c_diameter'], + # "total_length": item['total_length'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "blade_number": item['blade_number'], + # "d_diameter": item['d_diameter'], + # # "blade": [(6, 0, blade_list)], + # "blade": blade_list, + # "wrench": item['wrench'], + # "screw": item['screw'], + # "radius": item['radius'], + # "accuracy": item['accuracy'], + # "hardness": item['hardness'], + # "scope": item['scope'], + # "image": image, + # }) + # print('同步每日刀盘列表成功') + # else: + # raise ValidationError("认证未通过") + # + # # 定时同步所有刀盘列表 + # def sync_all_cutter_pad(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_cutter_pad_all_list'): + # for item in result['mrs_cutter_pad_all_list']: + # blade_list = [] + # if item.get('blade'): + # for i in item.get('blade'): + # blade_list.append(self.env['sf.blade'].search( + # [("code", '=', i)]).id) + # if item: + # brand = self.env['sf.cutter.pad'].search( + # [("code", '=', item['code'])]) + # if item.get('image'): + # image = base64.b64decode(item['image']) + # else: + # image = '' + # if not brand: + # # 'code', 'name', 'cutter_pad_model_number', 'brand', 'c_diameter', 'total_length', 'material_model', 'blade_number', 'd_diameter', 'blade', 'wrench', 'screw', 'radius', 'accuracy', 'hardness', 'scope', 'image' + # self.env['sf.cutter.pad'].create({ + # "name": item['name'], + # "code": item['code'], + # "cutter_pad_model_number": self.env['sf.cutter.pad.model'].search( + # [("code", '=', item['cutter_pad_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "c_diameter": item['c_diameter'], + # "total_length": item['total_length'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "blade_number": item['blade_number'], + # "d_diameter": item['d_diameter'], + # # "blade": [(6, 0, blade_list)], + # "blade": blade_list, + # "wrench": item['wrench'], + # "screw": item['screw'], + # "radius": item['radius'], + # "accuracy": item['accuracy'], + # "hardness": item['hardness'], + # "scope": item['scope'], + # "image": image, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "code": item['code'], + # "cutter_pad_model_number": self.env['sf.cutter.pad.model'].search( + # [("code", '=', item['cutter_pad_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "c_diameter": item['c_diameter'], + # "total_length": item['total_length'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "blade_number": item['blade_number'], + # "d_diameter": item['d_diameter'], + # # "blade": [(6, 0, blade_list)], + # "blade": blade_list, + # "wrench": item['wrench'], + # "screw": item['screw'], + # "radius": item['radius'], + # "accuracy": item['accuracy'], + # "hardness": item['hardness'], + # "scope": item['scope'], + # "image": image, + # }) + # print('同步所有刀盘列表成功') + # else: + # raise ValidationError("认证未通过") + # + # + # # 同步刀盘类型列表 + # class SyncCutterPadModel(models.Model): + # _inherit = 'sf.cutter.pad.model' + # _description = '同步刀盘类型列表' + # + # url = '/api/mrs_cutter_pad_model/list' + # + # # 定时同步每日刀盘类型列表 + # def sync_cutter_pad_model(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_cutter_pad_model_yesterday_list'): + # for item in result['mrs_cutter_pad_model_yesterday_list']: + # if item: + # brand = self.env['sf.cutter.pad.model'].search( + # [("code", '=', item['code'])]) + # if not brand: + # self.env['sf.cutter.pad.model'].create({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # print('同步每日刀盘类型列表成功') + # else: + # raise ValidationError("认证未通过") + # + # # 定时同步所有刀盘类型列表 + # def sync_all_cutter_pad_model(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_cutter_pad_model_all_list'): + # for item in result['mrs_cutter_pad_model_all_list']: + # if item: + # brand = self.env['sf.cutter.pad.model'].search( + # [("code", '=', item['code'])]) + # if not brand: + # self.env['sf.cutter.pad.model'].create({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # print('同步刀盘类型列表成功') + # else: + # raise ValidationError("认证未通过") + # + # + # # 同步刀柄列表 + # class SyncHandle(models.Model): + # _inherit = 'sf.handle' + # _description = '同步刀柄列表' + # + # url = '/api/mrs_handle/list' + # + # # 定时同步每日刀柄列表 + # def sync_handle(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_handle_yesterday_list'): + # for item in result['mrs_handle_yesterday_list']: + # chuck_list = [] + # if item.get('chuck_model'): + # for chuck in item.get('chuck_model'): + # chuck_list.append(self.env['sf.chuck'].search( + # [("code", '=', chuck)]).id) + # if item: + # brand = self.env['sf.handle'].search( + # [("code", '=', item['code'])]) + # if item.get('image'): + # image = base64.b64decode(item['image']) + # else: + # image = '' + # if not brand: + # # code, name, handle_model_number, brand, length, length1, diameter1, weight, material_model, body_accuracy, nut, chuck_model, clamping_range, detection_accuracy, detection_hardness, standard_speed, image + # self.env['sf.handle'].create({ + # "name": item['name'], + # "code": item['code'], + # "handle_model_number": self.env['sf.handle.model'].search( + # [("code", '=', item['handle_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "length": item['length'], + # "length1": item['length1'], + # "diameter1": item['diameter1'], + # "weight": item['weight'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "body_accuracy": item['body_accuracy'], + # "nut": item['nut'], + # # "chuck_model": [(6, 0, chuck_list)], + # "chuck_model": chuck_list, + # "clamping_range": item['clamping_range'], + # "detection_accuracy": item['detection_accuracy'], + # "detection_hardness": item['detection_hardness'], + # "standard_speed": item['standard_speed'], + # "image": image, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "code": item['code'], + # "handle_model_number": self.env['sf.handle.model'].search( + # [("code", '=', item['handle_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "length": item['length'], + # "length1": item['length1'], + # "diameter1": item['diameter1'], + # "weight": item['weight'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "body_accuracy": item['body_accuracy'], + # "nut": item['nut'], + # # "chuck_model": [(6, 0, chuck_list)], + # "chuck_model": chuck_list, + # "clamping_range": item['clamping_range'], + # "detection_accuracy": item['detection_accuracy'], + # "detection_hardness": item['detection_hardness'], + # "standard_speed": item['standard_speed'], + # "image": image, + # }) + # print('同步昨日刀柄列表成功') + # else: + # raise ValidationError("认证未通过") + # + # # 同步所有刀柄列表 + # def sync_all_handle(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_handle_all_list'): + # for item in result['mrs_handle_all_list']: + # chuck_list = [] + # if item.get('chuck_model'): + # for chuck in item.get('chuck_model'): + # chuck_list.append(self.env['sf.chuck'].search( + # [("code", '=', chuck)]).id) + # if item: + # brand = self.env['sf.handle'].search( + # [("code", '=', item['code'])]) + # if item.get('image'): + # image = base64.b64decode(item['image']) + # else: + # image = '' + # if not brand: + # # code, name, handle_model_number, brand, length, length1, diameter1, weight, material_model, body_accuracy, nut, chuck_model, clamping_range, detection_accuracy, detection_hardness, standard_speed, image + # self.env['sf.handle'].create({ + # "name": item['name'], + # "code": item['code'], + # "handle_model_number": self.env['sf.handle.model'].search( + # [("code", '=', item['handle_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "length": item['length'], + # "length1": item['length1'], + # "diameter1": item['diameter1'], + # "weight": item['weight'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "body_accuracy": item['body_accuracy'], + # "nut": item['nut'], + # # "chuck_model": [(6, 0, chuck_list)], + # "chuck_model": chuck_list, + # "clamping_range": item['clamping_range'], + # "detection_accuracy": item['detection_accuracy'], + # "detection_hardness": item['detection_hardness'], + # "standard_speed": item['standard_speed'], + # "image": image, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "code": item['code'], + # "handle_model_number": self.env['sf.handle.model'].search( + # [("code", '=', item['handle_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "length": item['length'], + # "length1": item['length1'], + # "diameter1": item['diameter1'], + # "weight": item['weight'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "body_accuracy": item['body_accuracy'], + # "nut": item['nut'], + # # "chuck_model": [(6, 0, chuck_list)], + # "chuck_model": chuck_list, + # "clamping_range": item['clamping_range'], + # "detection_accuracy": item['detection_accuracy'], + # "detection_hardness": item['detection_hardness'], + # "standard_speed": item['standard_speed'], + # "image": image, + # }) + # print('同步所有刀柄列表成功') + # else: + # raise ValidationError("认证未通过") + # + # + # # 同步刀柄类型列表 + # class SyncHandleModel(models.Model): + # _inherit = 'sf.handle.model' + # _description = '同步刀柄类型列表' + # + # url = '/api/mrs_handle_model/list' + # + # # 定时同步每日刀柄类型列表 + # def sync_handle_model(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_handle_model_yesterday_list'): + # for item in result['mrs_handle_model_yesterday_list']: + # if item: + # brand = self.env['sf.handle.model'].search( + # [("code", '=', item['code'])]) + # if not brand: + # self.env['sf.handle.model'].create({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # print('同步每日刀柄类型列表成功') + # else: + # raise ValidationError("认证未通过") + # + # # 定时同步所有刀柄类型列表 + # def sync_all_handle_model(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_handle_model_all_list'): + # for item in result['mrs_handle_model_all_list']: + # if item: + # brand = self.env['sf.handle.model'].search( + # [("code", '=', item['code'])]) + # if not brand: + # self.env['sf.handle.model'].create({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # print('同步刀柄类型列表成功') + # else: + # raise ValidationError("认证未通过") + # + # + # # 同步夹头型号列表 + # class SyncChuck(models.Model): + # _inherit = 'sf.chuck' + # _description = '同步夹头型号列表' + # + # url = '/api/mrs_chuck/list' + # + # # 定时同步每日夹头型号列表 + # def sync_chuck(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_chuck_yesterday_list'): + # for item in result['mrs_chuck_yesterday_list']: + # handle_model_list = [] + # if item.get('handle_model'): + # for handle_model in item['handle_model']: + # handle_model_list.append(self.env['sf.handle.model'].search( + # [("code", '=', handle_model)]).id) + # if item: + # brand = self.env['sf.chuck'].search( + # [("code", '=', item['code'])]) + # if item.get('image'): + # image = base64.b64decode(item['image']) + # else: + # image = '' + # if not brand: + # # code, name, chuck_model_number, brand, accuracy, diameter, inner_diameter, height, material_model, nut, handle_model, clamping_range, feature, image + # self.env['sf.chuck'].create({ + # "code": item['code'], + # "name": item['name'], + # "chuck_model_number": self.env['sf.chuck.model'].search( + # [("code", '=', item['chuck_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "accuracy": item['accuracy'], + # "diameter": item['diameter'], + # "inner_diameter": item['inner_diameter'], + # "height": item['height'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "nut": item['nut'], + # "handle_model": handle_model_list, + # "clamping_range": item['clamping_range'], + # "feature": item['feature'], + # "image": image, + # }) + # else: + # brand.write({ + # "code": item['code'], + # "name": item['name'], + # "chuck_model_number": self.env['sf.chuck.model'].search( + # [("code", '=', item['chuck_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "accuracy": item['accuracy'], + # "diameter": item['diameter'], + # "inner_diameter": item['inner_diameter'], + # "height": item['height'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "nut": item['nut'], + # "handle_model": handle_model_list, + # "clamping_range": item['clamping_range'], + # "feature": item['feature'], + # "image": image, + # }) + # print('同步每日夹头型号列表成功') + # else: + # raise ValidationError("认证未通过") + # + # # 同步所有夹头型号列表 + # def sync_all_chuck(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_chuck_all_list'): + # for item in result['mrs_chuck_all_list']: + # handle_model_list = [] + # if item.get('handle_model'): + # for handle_model in item['handle_model']: + # handle_model_list.append(self.env['sf.handle.model'].search( + # [("code", '=', handle_model)]).id) + # if item: + # brand = self.env['sf.chuck'].search( + # [("code", '=', item['code'])]) + # if item.get('image'): + # image = base64.b64decode(item['image']) + # else: + # image = '' + # if not brand: + # # code, name, chuck_model_number, brand, accuracy, diameter, inner_diameter, height, material_model, nut, handle_model, clamping_range, feature, image + # self.env['sf.chuck'].create({ + # "code": item['code'], + # "name": item['name'], + # "chuck_model_number": self.env['sf.chuck.model'].search( + # [("code", '=', item['chuck_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "accuracy": item['accuracy'], + # "diameter": item['diameter'], + # "inner_diameter": item['inner_diameter'], + # "height": item['height'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "nut": item['nut'], + # "handle_model": handle_model_list, + # "clamping_range": item['clamping_range'], + # "feature": item['feature'], + # "image": image, + # }) + # else: + # brand.write({ + # "code": item['code'], + # "name": item['name'], + # "chuck_model_number": self.env['sf.chuck.model'].search( + # [("code", '=', item['chuck_model_number'])]).id, + # "brand": self.env['sf.machine.brand'].search( + # [("code", '=', item['brand'])]).id, + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # "accuracy": item['accuracy'], + # "diameter": item['diameter'], + # "inner_diameter": item['inner_diameter'], + # "height": item['height'], + # "material_model": self.env['sf.materials.model'].search( + # [("materials_no", '=', item['material_model'])]).id, + # "nut": item['nut'], + # "handle_model": handle_model_list, + # "clamping_range": item['clamping_range'], + # "feature": item['feature'], + # "image": image, + # }) + # print('同步所有夹头型号列表成功') + # else: + # raise ValidationError("认证未通过") + # + # + # # 同步夹头类型列表 + # class SyncChuckModel(models.Model): + # _inherit = 'sf.chuck.model' + # _description = '同步夹头类型列表' + # + # url = '/api/mrs_chuck_model/list' + # + # # 定时同步每日夹头型号列表 + # def sync_chuck_model(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_chuck_model_yesterday_list'): + # for item in result['mrs_chuck_model_yesterday_list']: + # if item: + # brand = self.env['sf.chuck.model'].search( + # [("code", '=', item['code'])]) + # if not brand: + # self.env['sf.chuck.model'].create({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # print('同步每日夹头类型列表成功') + # else: + # raise ValidationError("认证未通过") + # + # # 定时同步所有夹头型号列表 + # def sync_all_chuck_model(self): + # sf_sync_config = self.env['res.config.settings'].get_values() + # token = sf_sync_config['token'] + # sf_secret_key = sf_sync_config['sf_secret_key'] + # headers = Common.get_headers(self, token, sf_secret_key) + # + # strUrl = sf_sync_config['sf_url'] + self.url + # r = requests.post(strUrl, json={}, data=None, headers=headers) + # r = r.json() + # result = json.loads(r['result']) + # # print('result:%s' % result) + # if result['status'] == 1: + # if result.get('mrs_chuck_model_all_list'): + # for item in result['mrs_chuck_model_all_list']: + # if item: + # brand = self.env['sf.chuck.model'].search( + # [("code", '=', item['code'])]) + # if not brand: + # self.env['sf.chuck.model'].create({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # else: + # brand.write({ + # "name": item['name'], + # "code": item['code'], + # "remark": item['remark'], + # "cutting_tool_material": self.env['sf.cutting.tool.material'].search( + # [("code", '=', item['cutting_tool_material'])]).id, + # }) + # print('同步夹头类型列表成功') + # else: + # raise ValidationError("认证未通过") + # 定时同步所有功能夹具列表 def sync_all_functional_fixture(self): sf_sync_config = self.env['res.config.settings'].get_values() @@ -3144,6 +4623,7 @@ class SyncFunctionalFixture(models.Model): r = r.json() result = json.loads(r['result']) # print('result:%s' % result) + print('result:%s' % result) if result['status'] == 1: if result.get('functional_fixture_all_list'): for item in result['functional_fixture_all_list']: @@ -3165,8 +4645,6 @@ class SyncFunctionalFixture(models.Model): raise ValidationError("认证未通过") - - # # # 同步夹头型号列表 # class SyncChuck(models.Model): @@ -3742,3 +5220,911 @@ class SyncFunctionalFixture(models.Model): # }) # else: # raise ValidationError("认证未通过") + +class sfFixtureClampingElement(models.Model): + _inherit = 'sf.fixture.clamping.element' + _description = '夹紧元件型号' + url = '/api/mrs_fixture_clamping_element/list' + + # 定时同步夹紧元件型号 + def sync_fixture_clamping_element(self): + sf_sync_config = self.env['res.config.settings'].get_values() + token = sf_sync_config['token'] + sf_secret_key = sf_sync_config['sf_secret_key'] + headers = Common.get_headers(self, token, sf_secret_key) + + strUrl = sf_sync_config['sf_url'] + self.url + r = requests.post(strUrl, json={}, data=None, headers=headers) + r = r.json() + result = json.loads(r['result']) + if result['status'] == 1: + for item in result['mrs_fixture_clamping_element_yesterday_list']: + brand = self.env['sf.fixture.clamping.element'].search( + [("code", '=', item['code'])]) + if brand: + brand.code = item['code'], + brand.name = item['name'], + + brand.length = item['length'], + brand.width = item['width'], + brand.height = item['height'], + brand.diameter = item['diameter'], + brand.hardness = item['hardness'], + brand.chucking_power = item['chucking_power'], + brand.surface_treatment = item['surface_treatment'], + brand.accuracy_grade = item['accuracy_grade'], + # brand.picture = item['picture'].encode('utf-8'), + brand.picture = base64.b64decode(item['picture']), + brand.comment = item['comment'], + + brand.brand_id = self.env['sf.machine.brand'].search( + [('code', '=', item['brand_id'])]).id, + brand.material_type_id = self.env['sf.materials.model'].search( + [('materials_no', '=', item['material_type_id'])]).id, + brand.clamping_ele_type_id = self.env['sf.clamping.element.type'].search( + [('code', '=', item['clamping_ele_type_id'])]).id + + else: + self.env['sf.fixture.clamping.element'].create({ + "code": item['code'], + "name": item['name'], + + "length": item['length'], + "width": item['width'], + "height": item['height'], + "diameter": item['diameter'], + "hardness": item['hardness'], + "chucking_power": item['chucking_power'], + "surface_treatment": item['surface_treatment'], + "accuracy_grade": item['accuracy_grade'], + + 'picture': base64.b64decode(item['picture']), + # "picture": item['picture'].encode('utf-8'), + "comment": item['comment'], + + 'brand_id': self.env['sf.machine.brand'].search( + [('code', '=', item['brand_id'])]).id, + "material_type_id": self.env['sf.materials.model'].search( + [('materials_no', '=', item['material_type_id'])]).id, + "clamping_ele_type_id": self.env['sf.clamping.element.type'].search( + [('code', '=', item['clamping_ele_type_id'])]).id, + }) + else: + raise ValidationError("认证未通过") + + # 同步所有夹紧元件型号 + def sync_all_fixture_clamping_element(self): + sf_sync_config = self.env['res.config.settings'].get_values() + token = sf_sync_config['token'] + sf_secret_key = sf_sync_config['sf_secret_key'] + headers = Common.get_headers(self, token, sf_secret_key) + + strUrl = sf_sync_config['sf_url'] + self.url + r = requests.post(strUrl, json={}, data=None, headers=headers) + r = r.json() + result = json.loads(r['result']) + print(result) + if result['status'] == 1: + for item in result['mrs_fixture_clamping_element_all_list']: + brand = self.env['sf.fixture.clamping.element'].search( + [("code", '=', item['code'])]) + if not brand: + self.env['sf.fixture.clamping.element'].create({ + "code": item['code'], + "name": item['name'], + + "length": item['length'], + "width": item['width'], + "height": item['height'], + "diameter": item['diameter'], + "hardness": item['hardness'], + "chucking_power": item['chucking_power'], + "surface_treatment": item['surface_treatment'], + "accuracy_grade": item['accuracy_grade'], + + # "picture": item['picture'].encode('utf-8'), + 'picture': base64.b64decode(item['picture']), + "comment": item['comment'], + + 'brand_id': self.env['sf.machine.brand'].search( + [('code', '=', item['brand_id'])]).id, + "material_type_id": self.env['sf.materials.model'].search( + [('materials_no', '=', item['material_type_id'])]).id, + "clamping_ele_type_id": self.env['sf.clamping.element.type'].search( + [('code', '=', item['clamping_ele_type_id'])]).id, + }) + + + else: + raise ValidationError("认证未通过") + + +'''===================================导向元件类型==========================================''' + + +class sfGuideElementType(models.Model): + _inherit = 'sf.guide.element.type' + _description = '导向元件类型' + url = '/api/mrs_guide_element_type/list' + + # 定时同步每日导向元件类型 + def sync_guide_element_type(self): + sf_sync_config = self.env['res.config.settings'].get_values() + token = sf_sync_config['token'] + sf_secret_key = sf_sync_config['sf_secret_key'] + headers = Common.get_headers(self, token, sf_secret_key) + + strUrl = sf_sync_config['sf_url'] + self.url + r = requests.post(strUrl, json={}, data=None, headers=headers) + r = r.json() + result = json.loads(r['result']) + if result['status'] == 1: + _logger.info('result:%s' % result) + for item in result['mrs_guide_element_type_yesterday_list']: + if item: + brand = self.env['sf.guide.element.type'].search( + [("code", '=', item['code'])]) + if brand: + brand.name = item['name'], + brand.code = item['code'], + brand.comment = item['comment'] + else: + self.env['sf.guide.element.type'].create({ + "name": item['name'], + "code": item['code'], + "comment": item['comment'] + }) + else: + raise ValidationError("认证未通过") + + # 同步所有导向元件类型 + def sync_all_guide_element_type(self): + sf_sync_config = self.env['res.config.settings'].get_values() + token = sf_sync_config['token'] + sf_secret_key = sf_sync_config['sf_secret_key'] + headers = Common.get_headers(self, token, sf_secret_key) + + strUrl = sf_sync_config['sf_url'] + self.url + r = requests.post(strUrl, json={}, data=None, headers=headers) + r = r.json() + result = json.loads(r['result']) + if result['status'] == 1: + _logger.info('result:%s' % result) + for item in result['mrs_guide_element_type_all_list']: + if item: + brand = self.env['sf.guide.element.type'].search( + [("code", '=', item['code'])]) + if not brand: + self.env['sf.guide.element.type'].create({ + "name": item['name'], + "code": item['code'], + "comment": item['comment'] + }) + # guide_element_type = self.env['sf.guide.element.type'].search([('code', '=', code)]) + # tags = self.env['sf.tag'].search([('name', '=', 'new_tag_name')]) + # guide_element_type.write({'tag_ids': [(6, 0, tags.ids)]}) + else: + raise ValidationError("认证未通过") + + +'''===================================导向元件导向方式==========================================''' + + +class sfGuideElementGuideMode(models.Model): + _inherit = 'sf.guide.element.guide.mode' + _description = '导向元件导向方式' + url = '/api/mrs_guide_element_guide_mode/list' + + # 定时同步每日导向元件导向方式 + def sync_guide_element_guide_mode(self): + sf_sync_config = self.env['res.config.settings'].get_values() + token = sf_sync_config['token'] + sf_secret_key = sf_sync_config['sf_secret_key'] + headers = Common.get_headers(self, token, sf_secret_key) + + strUrl = sf_sync_config['sf_url'] + self.url + r = requests.post(strUrl, json={}, data=None, headers=headers) + r = r.json() + result = json.loads(r['result']) + if result['status'] == 1: + _logger.info('result:%s' % result) + for item in result['mrs_guide_element_guide_mode_yesterday_list']: + name_id_list = [] + if item.get('guide_ele_guide_mode_id'): + for i in item.get('guide_ele_guide_mode_id'): + name_id_list.append(self.env['sf.fixture.guide.element'].search( + [("code", '=', i)]).id) + if item: + brand = self.env['sf.guide.element.guide.mode'].search( + [("code", '=', item['code'])]) + if brand: + brand.name = item['name'], + brand.code = item['code'], + brand.comment = item['comment'] + brand.name_id = name_id_list + + else: + self.env['sf.guide.element.guide.mode'].create({ + "name": item['name'], + "code": item['code'], + "comment": item['comment'], + "name_id": name_id_list + }) + else: + raise ValidationError("认证未通过") + + # 同步所有导向元件导向方式 + def sync_all_guide_element_guide_mode(self): + sf_sync_config = self.env['res.config.settings'].get_values() + token = sf_sync_config['token'] + sf_secret_key = sf_sync_config['sf_secret_key'] + headers = Common.get_headers(self, token, sf_secret_key) + + strUrl = sf_sync_config['sf_url'] + self.url + r = requests.post(strUrl, json={}, data=None, headers=headers) + r = r.json() + result = json.loads(r['result']) + if result['status'] == 1: + _logger.info('result:%s' % result) + for item in result['mrs_guide_element_guide_mode_all_list']: + name_id_list = [] + if item.get('guide_ele_guide_mode_id'): + for i in item.get('guide_ele_guide_mode_id'): + name_id_list.append(self.env['sf.fixture.guide.element'].search( + [("code", '=', i)]).id) + if item: + brand = self.env['sf.guide.element.guide.mode'].search( + [("code", '=', item['code'])]) + if not brand: + self.env['sf.guide.element.guide.mode'].create({ + "name": item['name'], + "code": item['code'], + "comment": item['comment'], + "name_id": name_id_list + }) + else: + raise ValidationError("认证未通过") + + +# 同步刀具类型 +class SfToolType(models.Model): + _inherit = 'sf.cutting.tool.type' + _description = '同步刀具类型' + + url = '/api/mrs_cutting_tool_type/list' + + # 定时同步每日刀具类型 + def sync_tool_type(self): + sf_sync_config = self.env['res.config.settings'].get_values() + token = sf_sync_config['token'] + sf_secret_key = sf_sync_config['sf_secret_key'] + headers = Common.get_headers(self, token, sf_secret_key) + + strUrl = sf_sync_config['sf_url'] + self.url + r = requests.post(strUrl, json={}, data=None, headers=headers) + r = r.json() + result = json.loads(r['result']) + if result['status'] == 1: + _logger.info('result:%s' % result) + for item in result['mrs_cutting_tool_type_yesterday_list']: + if item: + brand = self.env['sf.cutting.tool.type'].search( + [("code", '=', item['code'])]) + if not brand: + self.env['sf.cutting.tool.type'].create({ + "name": item['name'], + "code": item['code'], + "mrs_cutting_tool_material_id": self.env['sf.cutting.tool.material'].search( + [("code", '=', item['mrs_cutting_tool_material_id'])]).id, + "integral_tool_type_code": item['integral_tool_type_code'], + "blade_type_code": item['blade_type_code'], + "bar_type_code": item['bar_type_code'], + "pad_type_code": item['pad_type_code'], + "handle_type_code": item['handle_type_code'], + "chuck_type_code": item['chuck_type_code'], + "remark": item['remark'], + }) + else: + brand.write({ + "name": item['name'], + "code": item['code'], + "mrs_cutting_tool_material_id": self.env['sf.cutting.tool.material'].search( + [("code", '=', item['mrs_cutting_tool_material_id'])]).id, + "integral_tool_type_code": item['integral_tool_type_code'], + "blade_type_code": item['blade_type_code'], + "bar_type_code": item['bar_type_code'], + "pad_type_code": item['pad_type_code'], + "handle_type_code": item['handle_type_code'], + "chuck_type_code": item['chuck_type_code'], + "remark": item['remark'], + }) + print('同步每日刀柄类型列表成功') + else: + raise ValidationError("认证未通过") + + # 同步所有刀具类型列表 + def sync_all_tool_type(self): + sf_sync_config = self.env['res.config.settings'].get_values() + token = sf_sync_config['token'] + sf_secret_key = sf_sync_config['sf_secret_key'] + headers = Common.get_headers(self, token, sf_secret_key) + + strUrl = sf_sync_config['sf_url'] + self.url + r = requests.post(strUrl, json={}, data=None, headers=headers) + r = r.json() + result = json.loads(r['result']) + if result['status'] == 1: + _logger.info('result:%s' % result) + for item in result['mrs_cutting_tool_type_all_list']: + if item: + brand = self.env['sf.cutting.tool.type'].search( + [("code", '=', item['code'])]) + if not brand: + self.env['sf.cutting.tool.type'].create({ + "name": item['name'], + "code": item['code'], + "mrs_cutting_tool_material_id": self.env['sf.cutting.tool.material'].search( + [("code", '=', item['mrs_cutting_tool_material_id'])]).id, + "integral_tool_type_code": item['integral_tool_type_code'], + "blade_type_code": item['blade_type_code'], + "bar_type_code": item['bar_type_code'], + "pad_type_code": item['pad_type_code'], + "handle_type_code": item['handle_type_code'], + "chuck_type_code": item['chuck_type_code'], + "remark": item['remark'], + }) + else: + brand.write({ + "name": item['name'], + "code": item['code'], + "mrs_cutting_tool_material_id": self.env['sf.cutting.tool.material'].search( + [("code", '=', item['mrs_cutting_tool_material_id'])]).id, + "integral_tool_type_code": item['integral_tool_type_code'], + "blade_type_code": item['blade_type_code'], + "bar_type_code": item['bar_type_code'], + "pad_type_code": item['pad_type_code'], + "handle_type_code": item['handle_type_code'], + "chuck_type_code": item['chuck_type_code'], + "remark": item['remark'], + }) + print('同步所有刀柄类型列表成功') + else: + raise ValidationError("认证未通过") + + +# 同步刀具型号 +class SfToolModel(models.Model): + _inherit = 'sf.cutting.tool.model' + _description = '同步刀具型号' + + url = '/api/mrs_cutting_tool_model/list' + + # 定时同步每日刀具型号 + def sync_tool_model(self): + sf_sync_config = self.env['res.config.settings'].get_values() + token = sf_sync_config['token'] + sf_secret_key = sf_sync_config['sf_secret_key'] + headers = Common.get_headers(self, token, sf_secret_key) + + strUrl = sf_sync_config['sf_url'] + self.url + r = requests.post(strUrl, json={}, data=None, headers=headers) + r = r.json() + result = json.loads(r['result']) + if result['status'] == 1: + _logger.info('result:%s' % result) + for item in result['mrs_cutting_tool_model_yesterday_list']: + mrs_cutting_tool_model_blade_cutter_bar_ids_list = [] + if item.get('mrs_cutting_tool_model_blade_cutter_bar_ids'): + for mrs_cutting_tool_model_blade_cutter_bar_id in item[ + 'mrs_cutting_tool_model_blade_cutter_bar_ids']: + mrs_cutting_tool_model_blade_cutter_bar_ids_list.append( + self.env['sf.cutting.tool.model'].search( + [("code", '=', mrs_cutting_tool_model_blade_cutter_bar_id)]).id) + mrs_cutting_tool_model_blade_cutter_pad_ids_list = [] + if item.get('mrs_cutting_tool_model_blade_cutter_pad_ids'): + for mrs_cutting_tool_model_blade_cutter_pad_id in item[ + 'mrs_cutting_tool_model_blade_cutter_pad_ids']: + mrs_cutting_tool_model_blade_cutter_pad_ids_list.append( + self.env['sf.cutting.tool.model'].search( + [("code", '=', mrs_cutting_tool_model_blade_cutter_pad_id)]).id) + mrs_cutting_tool_model_bar_blade_ids_list = [] + if item.get('mrs_cutting_tool_model_bar_blade_ids'): + for mrs_cutting_tool_model_bar_blade_id in item['mrs_cutting_tool_model_bar_blade_ids']: + mrs_cutting_tool_model_bar_blade_ids_list.append(self.env['sf.cutting.tool.model'].search( + [("code", '=', mrs_cutting_tool_model_bar_blade_id)]).id) + mrs_cutting_tool_model_pad_blade_ids_list = [] + if item.get('mrs_cutting_tool_model_pad_blade_ids'): + for mrs_cutting_tool_model_pad_blade_id in item['mrs_cutting_tool_model_pad_blade_ids']: + mrs_cutting_tool_model_pad_blade_ids_list.append(self.env['sf.cutting.tool.model'].search( + [("code", '=', mrs_cutting_tool_model_pad_blade_id)]).id) + mrs_cutting_tool_model_handle_chuck_model_ids_list = [] + if item.get('mrs_cutting_tool_model_handle_chuck_model_ids'): + for mrs_cutting_tool_model_handle_chuck_model_id in item[ + 'mrs_cutting_tool_model_handle_chuck_model_ids']: + mrs_cutting_tool_model_handle_chuck_model_ids_list.append( + self.env['sf.cutting.tool.model'].search( + [("code", '=', mrs_cutting_tool_model_handle_chuck_model_id)]).id) + mrs_cutting_tool_model_chuck_handle_model_ids_list = [] + if item.get('mrs_cutting_tool_model_chuck_handle_model_ids'): + for mrs_cutting_tool_model_chuck_handle_model_id in item[ + 'mrs_cutting_tool_model_chuck_handle_model_ids']: + mrs_cutting_tool_model_chuck_handle_model_ids_list.append( + self.env['sf.cutting.tool.model'].search( + [("code", '=', mrs_cutting_tool_model_chuck_handle_model_id)]).id) + if item: + brand = self.env['sf.cutting.tool.model'].search( + [("code", '=', item['code'])]) + if item.get('image'): + image = base64.b64decode(item['image']) + else: + image = '' + if not brand: + new_record = self.env['sf.cutting.tool.model'].create({ + "name": item['name'], + "code": item['code'], + "mrs_machine_brand_id": self.env['sf.machine.brand'].search( + [("code", '=', item['mrs_machine_brand_id'])]).id, + "mrs_materials_model_id": self.env['sf.materials.model'].search( + [("materials_no", '=', item['mrs_materials_model_id'])]).id, + "mrs_cutting_tool_material_id": self.env['sf.cutting.tool.material'].search( + [("code", '=', item['mrs_cutting_tool_material_id'])]).id, + "mrs_cutting_tool_material_name": item['mrs_cutting_tool_material_name'], + "mrs_cutting_tool_type_id": self.env['sf.cutting.tool.type'].search( + [("code", '=', item['mrs_cutting_tool_type_id'])]).id, + "integral_code": item['integral_code'], + "integral_total_length": item['integral_total_length'], + "integral_shank_length": item['integral_shank_length'], + "integral_blade_length": item['integral_blade_length'], + "integral_diameter": item['integral_diameter'], + "integral_blade_number": item['integral_blade_number'], + "integral_front_angle": item['integral_front_angle'], + "integral_rear_angle": item['integral_rear_angle'], + "integral_main_included_angle": item['integral_main_included_angle'], + "integral_nut": item['integral_nut'], + "integral_scope": item['integral_scope'], + "blade_code": item['blade_code'], + "blade_length": item['blade_length'], + "blade_width": item['blade_width'], + "blade_height": item['blade_height'], + "blade_top_angle": item['blade_top_angle'], + "blade_front_angle": item['blade_front_angle'], + "blade_rear_angle": item['blade_rear_angle'], + "blade_main_included_angle": item['blade_main_included_angle'], + "blade_r_angle": item['blade_r_angle'], + "blade_hardness": item['blade_hardness'], + "blade_radius": item['blade_radius'], + "blade_nut": item['blade_nut'], + "mrs_cutting_tool_model_blade_cutter_bar_ids": mrs_cutting_tool_model_blade_cutter_bar_ids_list, + "mrs_cutting_tool_model_blade_cutter_pad_ids": mrs_cutting_tool_model_blade_cutter_pad_ids_list, + "bar_code": item['bar_code'], + "bar_c_diameter": item['bar_c_diameter'], + "bar_total_length": item['bar_total_length'], + "bar_blade_number": item['bar_blade_number'], + "bar_d_diameter": item['bar_d_diameter'], + "mrs_cutting_tool_model_bar_blade_ids": mrs_cutting_tool_model_bar_blade_ids_list, + "bar_wrench": item['bar_wrench'], + "bar_screw": item['bar_screw'], + "bar_radius": item['bar_radius'], + "bar_accuracy": item['bar_accuracy'], + "bar_hardness": item['bar_hardness'], + "bar_scope": item['bar_scope'], + "pad_code": item['pad_code'], + "pad_c_diameter": item['pad_c_diameter'], + "pad_total_length": item['pad_total_length'], + "pad_blade_number": item['pad_blade_number'], + "pad_d_diameter": item['pad_d_diameter'], + "mrs_cutting_tool_model_pad_blade_ids": mrs_cutting_tool_model_pad_blade_ids_list, + "pad_wrench": item['pad_wrench'], + "pad_screw": item['pad_screw'], + "pad_radius": item['pad_radius'], + "pad_accuracy": item['pad_accuracy'], + "pad_hardness": item['pad_hardness'], + "pad_scope": item['pad_scope'], + "handle_code": item['handle_code'], + "handle_length": item['handle_length'], + "handle_length1": item['handle_length1'], + "handle_diameter1": item['handle_diameter1'], + "handle_weight": item['handle_weight'], + "handle_body_accuracy": item['handle_body_accuracy'], + "handle_nut": item['handle_nut'], + "mrs_cutting_tool_model_handle_chuck_model_ids": [ + (6, 0, mrs_cutting_tool_model_handle_chuck_model_ids_list)], + "handle_clamping_range": item['handle_clamping_range'], + "handle_detection_accuracy": item['handle_detection_accuracy'], + "handle_detection_hardness": item['handle_detection_hardness'], + "handle_standard_speed": item['handle_standard_speed'], + "chuck_code": item['chuck_code'], + "chuck_accuracy": item['chuck_accuracy'], + "chuck_diameter": item['chuck_diameter'], + "chuck_inner_diameter": item['chuck_inner_diameter'], + "chuck_height": item['chuck_height'], + "chuck_nut": item['chuck_nut'], + "mrs_cutting_tool_model_chuck_handle_model_ids": mrs_cutting_tool_model_chuck_handle_model_ids_list, + "chuck_clamping_range": item['chuck_clamping_range'], + "chuck_feature": item['chuck_feature'], + "image": image, + "hide_integral": item['hide_integral'], + "hide_blade": item['hide_blade'], + "hide_cutter_bar": item['hide_cutter_bar'], + "hide_cutter_pad": item['hide_cutter_pad'], + "hide_handler": item['hide_handler'], + "hide_chuck": item['hide_chuck'], + "hide_model": item['hide_model'], + }) + new_record.write({ + 'mrs_cutting_tool_model_handle_chuck_model_ids': [ + (6, 0, [new_record.id] * len(mrs_cutting_tool_model_handle_chuck_model_ids_list))], + }) + # many2many_commands = [(0, 0, {'model_id_1': new_record.id, 'model_id_2': related_record_id}) for + # related_record_id in mrs_cutting_tool_model_handle_chuck_model_ids_list] + # new_record.write({ + # 'mrs_cutting_tool_model_handle_chuck_model_ids': many2many_commands, + # }) + else: + brand.write({ + "name": item['name'], + "code": item['code'], + "mrs_machine_brand_id": self.env['sf.machine.brand'].search( + [("code", '=', item['mrs_machine_brand_id'])]).id, + "mrs_materials_model_id": self.env['sf.materials.model'].search( + [("materials_no", '=', item['mrs_materials_model_id'])]).id, + "mrs_cutting_tool_material_id": self.env['sf.cutting.tool.material'].search( + [("code", '=', item['mrs_cutting_tool_material_id'])]).id, + "mrs_cutting_tool_material_name": item['mrs_cutting_tool_material_name'], + "mrs_cutting_tool_type_id": self.env['sf.cutting.tool.type'].search( + [("code", '=', item['mrs_cutting_tool_type_id'])]).id, + "integral_code": item['integral_code'], + "integral_total_length": item['integral_total_length'], + "integral_shank_length": item['integral_shank_length'], + "integral_blade_length": item['integral_blade_length'], + "integral_diameter": item['integral_diameter'], + "integral_blade_number": item['integral_blade_number'], + "integral_front_angle": item['integral_front_angle'], + "integral_rear_angle": item['integral_rear_angle'], + "integral_main_included_angle": item['integral_main_included_angle'], + "integral_nut": item['integral_nut'], + "integral_scope": item['integral_scope'], + "blade_code": item['blade_code'], + "blade_length": item['blade_length'], + "blade_width": item['blade_width'], + "blade_height": item['blade_height'], + "blade_top_angle": item['blade_top_angle'], + "blade_front_angle": item['blade_front_angle'], + "blade_rear_angle": item['blade_rear_angle'], + "blade_main_included_angle": item['blade_main_included_angle'], + "blade_r_angle": item['blade_r_angle'], + "blade_hardness": item['blade_hardness'], + "blade_radius": item['blade_radius'], + "blade_nut": item['blade_nut'], + "mrs_cutting_tool_model_blade_cutter_bar_ids": mrs_cutting_tool_model_blade_cutter_bar_ids_list, + "mrs_cutting_tool_model_blade_cutter_pad_ids": mrs_cutting_tool_model_blade_cutter_pad_ids_list, + "bar_code": item['bar_code'], + "bar_c_diameter": item['bar_c_diameter'], + "bar_total_length": item['bar_total_length'], + "bar_blade_number": item['bar_blade_number'], + "bar_d_diameter": item['bar_d_diameter'], + "mrs_cutting_tool_model_bar_blade_ids": mrs_cutting_tool_model_bar_blade_ids_list, + "bar_wrench": item['bar_wrench'], + "bar_screw": item['bar_screw'], + "bar_radius": item['bar_radius'], + "bar_accuracy": item['bar_accuracy'], + "bar_hardness": item['bar_hardness'], + "bar_scope": item['bar_scope'], + "pad_code": item['pad_code'], + "pad_c_diameter": item['pad_c_diameter'], + "pad_total_length": item['pad_total_length'], + "pad_blade_number": item['pad_blade_number'], + "pad_d_diameter": item['pad_d_diameter'], + "mrs_cutting_tool_model_pad_blade_ids": mrs_cutting_tool_model_pad_blade_ids_list, + "pad_wrench": item['pad_wrench'], + "pad_screw": item['pad_screw'], + "pad_radius": item['pad_radius'], + "pad_accuracy": item['pad_accuracy'], + "pad_hardness": item['pad_hardness'], + "pad_scope": item['pad_scope'], + "handle_code": item['handle_code'], + "handle_length": item['handle_length'], + "handle_length1": item['handle_length1'], + "handle_diameter1": item['handle_diameter1'], + "handle_weight": item['handle_weight'], + "handle_body_accuracy": item['handle_body_accuracy'], + "handle_nut": item['handle_nut'], + "mrs_cutting_tool_model_handle_chuck_model_ids": [ + (6, 0, mrs_cutting_tool_model_handle_chuck_model_ids_list)], + "handle_clamping_range": item['handle_clamping_range'], + "handle_detection_accuracy": item['handle_detection_accuracy'], + "handle_detection_hardness": item['handle_detection_hardness'], + "handle_standard_speed": item['handle_standard_speed'], + "chuck_code": item['chuck_code'], + "chuck_accuracy": item['chuck_accuracy'], + "chuck_diameter": item['chuck_diameter'], + "chuck_inner_diameter": item['chuck_inner_diameter'], + "chuck_height": item['chuck_height'], + "chuck_nut": item['chuck_nut'], + "mrs_cutting_tool_model_chuck_handle_model_ids": mrs_cutting_tool_model_chuck_handle_model_ids_list, + "chuck_clamping_range": item['chuck_clamping_range'], + "chuck_feature": item['chuck_feature'], + "image": image, + "hide_integral": item['hide_integral'], + "hide_blade": item['hide_blade'], + "hide_cutter_bar": item['hide_cutter_bar'], + "hide_cutter_pad": item['hide_cutter_pad'], + "hide_handler": item['hide_handler'], + "hide_chuck": item['hide_chuck'], + "hide_model": item['hide_model'], + }) + brand.write({ + 'mrs_cutting_tool_model_handle_chuck_model_ids': [ + (6, 0, [brand.id] * len(mrs_cutting_tool_model_handle_chuck_model_ids_list))], + }) + # many2many_commands = [(0, 0, {'model_id_1': brand.id, 'model_id_2': related_record_id}) for + # related_record_id in mrs_cutting_tool_model_handle_chuck_model_ids_list] + # brand.write({ + # 'mrs_cutting_tool_model_handle_chuck_model_ids': many2many_commands, + # }) + print('同步所有刀柄类型列表成功') + else: + raise ValidationError("认证未通过") + + # 同步所有刀具型号列表 + def sync_all_tool_model(self): + sf_sync_config = self.env['res.config.settings'].get_values() + token = sf_sync_config['token'] + sf_secret_key = sf_sync_config['sf_secret_key'] + headers = Common.get_headers(self, token, sf_secret_key) + + strUrl = sf_sync_config['sf_url'] + self.url + r = requests.post(strUrl, json={}, data=None, headers=headers) + r = r.json() + result = json.loads(r['result']) + print('result', result) + if result['status'] == 1: + _logger.info('result:%s' % result) + for item in result['mrs_cutting_tool_model_all_list']: + mrs_cutting_tool_model_blade_cutter_bar_ids_list = [] + if item.get('mrs_cutting_tool_model_blade_cutter_bar_ids'): + for mrs_cutting_tool_model_blade_cutter_bar_id in item[ + 'mrs_cutting_tool_model_blade_cutter_bar_ids']: + mrs_cutting_tool_model_blade_cutter_bar_ids_list.append( + self.env['sf.cutting.tool.model'].search( + [("code", '=', mrs_cutting_tool_model_blade_cutter_bar_id)]).id) + mrs_cutting_tool_model_blade_cutter_pad_ids_list = [] + if item.get('mrs_cutting_tool_model_blade_cutter_pad_ids'): + for mrs_cutting_tool_model_blade_cutter_pad_id in item[ + 'mrs_cutting_tool_model_blade_cutter_pad_ids']: + mrs_cutting_tool_model_blade_cutter_pad_ids_list.append( + self.env['sf.cutting.tool.model'].search( + [("code", '=', mrs_cutting_tool_model_blade_cutter_pad_id)]).id) + mrs_cutting_tool_model_bar_blade_ids_list = [] + if item.get('mrs_cutting_tool_model_bar_blade_ids'): + for mrs_cutting_tool_model_bar_blade_id in item['mrs_cutting_tool_model_bar_blade_ids']: + mrs_cutting_tool_model_bar_blade_ids_list.append(self.env['sf.cutting.tool.model'].search( + [("code", '=', mrs_cutting_tool_model_bar_blade_id)]).id) + mrs_cutting_tool_model_pad_blade_ids_list = [] + if item.get('mrs_cutting_tool_model_pad_blade_ids'): + for mrs_cutting_tool_model_pad_blade_id in item['mrs_cutting_tool_model_pad_blade_ids']: + mrs_cutting_tool_model_pad_blade_ids_list.append(self.env['sf.cutting.tool.model'].search( + [("code", '=', mrs_cutting_tool_model_pad_blade_id)]).id) + mrs_cutting_tool_model_handle_chuck_model_ids_list = [] + if item.get('mrs_cutting_tool_model_handle_chuck_model_ids'): + for mrs_cutting_tool_model_handle_chuck_model_id in item[ + 'mrs_cutting_tool_model_handle_chuck_model_ids']: + mrs_cutting_tool_model_handle_chuck_model_ids_list.append( + self.env['sf.cutting.tool.model'].search( + [("code", '=', mrs_cutting_tool_model_handle_chuck_model_id)]).id) + mrs_cutting_tool_model_chuck_handle_model_ids_list = [] + if item.get('mrs_cutting_tool_model_chuck_handle_model_ids'): + for mrs_cutting_tool_model_chuck_handle_model_id in item[ + 'mrs_cutting_tool_model_chuck_handle_model_ids']: + mrs_cutting_tool_model_chuck_handle_model_ids_list.append( + self.env['sf.cutting.tool.model'].search( + [("code", '=', mrs_cutting_tool_model_chuck_handle_model_id)]).id) + if item: + brand = self.env['sf.cutting.tool.model'].search( + [("code", '=', item['code'])]) + if item.get('image'): + image = base64.b64decode(item['image']) + else: + image = '' + if not brand: + new_record = self.env['sf.cutting.tool.model'].create({ + "name": item['name'], + "code": item['code'], + "mrs_machine_brand_id": self.env['sf.machine.brand'].search( + [("code", '=', item['mrs_machine_brand_id'])]).id, + "mrs_materials_model_id": self.env['sf.materials.model'].search( + [("materials_no", '=', item['mrs_materials_model_id'])]).id, + "mrs_cutting_tool_material_id": self.env['sf.cutting.tool.material'].search( + [("code", '=', item['mrs_cutting_tool_material_id'])]).id, + "mrs_cutting_tool_material_name": item['mrs_cutting_tool_material_name'], + "mrs_cutting_tool_type_id": self.env['sf.cutting.tool.type'].search( + [("code", '=', item['mrs_cutting_tool_type_id'])]).id, + "integral_code": item['integral_code'], + "integral_total_length": item['integral_total_length'], + "integral_shank_length": item['integral_shank_length'], + "integral_blade_length": item['integral_blade_length'], + "integral_diameter": item['integral_diameter'], + "integral_blade_number": item['integral_blade_number'], + "integral_front_angle": item['integral_front_angle'], + "integral_rear_angle": item['integral_rear_angle'], + "integral_main_included_angle": item['integral_main_included_angle'], + "integral_nut": item['integral_nut'], + "integral_scope": item['integral_scope'], + "blade_code": item['blade_code'], + "blade_length": item['blade_length'], + "blade_width": item['blade_width'], + "blade_height": item['blade_height'], + "blade_top_angle": item['blade_top_angle'], + "blade_front_angle": item['blade_front_angle'], + "blade_rear_angle": item['blade_rear_angle'], + "blade_main_included_angle": item['blade_main_included_angle'], + "blade_r_angle": item['blade_r_angle'], + "blade_hardness": item['blade_hardness'], + "blade_radius": item['blade_radius'], + "blade_nut": item['blade_nut'], + "mrs_cutting_tool_model_blade_cutter_bar_ids": mrs_cutting_tool_model_blade_cutter_bar_ids_list, + "mrs_cutting_tool_model_blade_cutter_pad_ids": mrs_cutting_tool_model_blade_cutter_pad_ids_list, + "bar_code": item['bar_code'], + "bar_c_diameter": item['bar_c_diameter'], + "bar_total_length": item['bar_total_length'], + "bar_blade_number": item['bar_blade_number'], + "bar_d_diameter": item['bar_d_diameter'], + "mrs_cutting_tool_model_bar_blade_ids": mrs_cutting_tool_model_bar_blade_ids_list, + "bar_wrench": item['bar_wrench'], + "bar_screw": item['bar_screw'], + "bar_radius": item['bar_radius'], + "bar_accuracy": item['bar_accuracy'], + "bar_hardness": item['bar_hardness'], + "bar_scope": item['bar_scope'], + "pad_code": item['pad_code'], + "pad_c_diameter": item['pad_c_diameter'], + "pad_total_length": item['pad_total_length'], + "pad_blade_number": item['pad_blade_number'], + "pad_d_diameter": item['pad_d_diameter'], + "mrs_cutting_tool_model_pad_blade_ids": mrs_cutting_tool_model_pad_blade_ids_list, + "pad_wrench": item['pad_wrench'], + "pad_screw": item['pad_screw'], + "pad_radius": item['pad_radius'], + "pad_accuracy": item['pad_accuracy'], + "pad_hardness": item['pad_hardness'], + "pad_scope": item['pad_scope'], + "handle_code": item['handle_code'], + "handle_length": item['handle_length'], + "handle_length1": item['handle_length1'], + "handle_diameter1": item['handle_diameter1'], + "handle_weight": item['handle_weight'], + "handle_body_accuracy": item['handle_body_accuracy'], + "handle_nut": item['handle_nut'], + # "mrs_cutting_tool_model_handle_chuck_model_ids": [(6, 0, mrs_cutting_tool_model_handle_chuck_model_ids_list)], + "handle_clamping_range": item['handle_clamping_range'], + "handle_detection_accuracy": item['handle_detection_accuracy'], + "handle_detection_hardness": item['handle_detection_hardness'], + "handle_standard_speed": item['handle_standard_speed'], + "chuck_code": item['chuck_code'], + "chuck_accuracy": item['chuck_accuracy'], + "chuck_diameter": item['chuck_diameter'], + "chuck_inner_diameter": item['chuck_inner_diameter'], + "chuck_height": item['chuck_height'], + "chuck_nut": item['chuck_nut'], + "mrs_cutting_tool_model_chuck_handle_model_ids": mrs_cutting_tool_model_chuck_handle_model_ids_list, + "chuck_clamping_range": item['chuck_clamping_range'], + "chuck_feature": item['chuck_feature'], + "image": image, + "hide_integral": item['hide_integral'], + "hide_blade": item['hide_blade'], + "hide_cutter_bar": item['hide_cutter_bar'], + "hide_cutter_pad": item['hide_cutter_pad'], + "hide_handler": item['hide_handler'], + "hide_chuck": item['hide_chuck'], + "hide_model": item['hide_model'], + }) + new_record.write({ + 'mrs_cutting_tool_model_handle_chuck_model_ids': [ + (6, 0, [new_record.id] * len(mrs_cutting_tool_model_handle_chuck_model_ids_list))], + }) + + else: + brand.write({ + "name": item['name'], + "code": item['code'], + "mrs_machine_brand_id": self.env['sf.machine.brand'].search( + [("code", '=', item['mrs_machine_brand_id'])]).id, + "mrs_materials_model_id": self.env['sf.materials.model'].search( + [("materials_no", '=', item['mrs_materials_model_id'])]).id, + "mrs_cutting_tool_material_id": self.env['sf.cutting.tool.material'].search( + [("code", '=', item['mrs_cutting_tool_material_id'])]).id, + "mrs_cutting_tool_material_name": item['mrs_cutting_tool_material_name'], + "mrs_cutting_tool_type_id": self.env['sf.cutting.tool.type'].search( + [("code", '=', item['mrs_cutting_tool_type_id'])]).id, + "integral_code": item['integral_code'], + "integral_total_length": item['integral_total_length'], + "integral_shank_length": item['integral_shank_length'], + "integral_blade_length": item['integral_blade_length'], + "integral_diameter": item['integral_diameter'], + "integral_blade_number": item['integral_blade_number'], + "integral_front_angle": item['integral_front_angle'], + "integral_rear_angle": item['integral_rear_angle'], + "integral_main_included_angle": item['integral_main_included_angle'], + "integral_nut": item['integral_nut'], + "integral_scope": item['integral_scope'], + "blade_code": item['blade_code'], + "blade_length": item['blade_length'], + "blade_width": item['blade_width'], + "blade_height": item['blade_height'], + "blade_top_angle": item['blade_top_angle'], + "blade_front_angle": item['blade_front_angle'], + "blade_rear_angle": item['blade_rear_angle'], + "blade_main_included_angle": item['blade_main_included_angle'], + "blade_r_angle": item['blade_r_angle'], + "blade_hardness": item['blade_hardness'], + "blade_radius": item['blade_radius'], + "blade_nut": item['blade_nut'], + "mrs_cutting_tool_model_blade_cutter_bar_ids": mrs_cutting_tool_model_blade_cutter_bar_ids_list, + "mrs_cutting_tool_model_blade_cutter_pad_ids": mrs_cutting_tool_model_blade_cutter_pad_ids_list, + "bar_code": item['bar_code'], + "bar_c_diameter": item['bar_c_diameter'], + "bar_total_length": item['bar_total_length'], + "bar_blade_number": item['bar_blade_number'], + "bar_d_diameter": item['bar_d_diameter'], + "mrs_cutting_tool_model_bar_blade_ids": mrs_cutting_tool_model_bar_blade_ids_list, + "bar_wrench": item['bar_wrench'], + "bar_screw": item['bar_screw'], + "bar_radius": item['bar_radius'], + "bar_accuracy": item['bar_accuracy'], + "bar_hardness": item['bar_hardness'], + "bar_scope": item['bar_scope'], + "pad_code": item['pad_code'], + "pad_c_diameter": item['pad_c_diameter'], + "pad_total_length": item['pad_total_length'], + "pad_blade_number": item['pad_blade_number'], + "pad_d_diameter": item['pad_d_diameter'], + "mrs_cutting_tool_model_pad_blade_ids": mrs_cutting_tool_model_pad_blade_ids_list, + "pad_wrench": item['pad_wrench'], + "pad_screw": item['pad_screw'], + "pad_radius": item['pad_radius'], + "pad_accuracy": item['pad_accuracy'], + "pad_hardness": item['pad_hardness'], + "pad_scope": item['pad_scope'], + "handle_code": item['handle_code'], + "handle_length": item['handle_length'], + "handle_length1": item['handle_length1'], + "handle_diameter1": item['handle_diameter1'], + "handle_weight": item['handle_weight'], + "handle_body_accuracy": item['handle_body_accuracy'], + "handle_nut": item['handle_nut'], + "mrs_cutting_tool_model_handle_chuck_model_ids": [ + (6, 0, mrs_cutting_tool_model_handle_chuck_model_ids_list)], + "handle_clamping_range": item['handle_clamping_range'], + "handle_detection_accuracy": item['handle_detection_accuracy'], + "handle_detection_hardness": item['handle_detection_hardness'], + "handle_standard_speed": item['handle_standard_speed'], + "chuck_code": item['chuck_code'], + "chuck_accuracy": item['chuck_accuracy'], + "chuck_diameter": item['chuck_diameter'], + "chuck_inner_diameter": item['chuck_inner_diameter'], + "chuck_height": item['chuck_height'], + "chuck_nut": item['chuck_nut'], + "mrs_cutting_tool_model_chuck_handle_model_ids": mrs_cutting_tool_model_chuck_handle_model_ids_list, + "chuck_clamping_range": item['chuck_clamping_range'], + "chuck_feature": item['chuck_feature'], + "image": image, + "hide_integral": item['hide_integral'], + "hide_blade": item['hide_blade'], + "hide_cutter_bar": item['hide_cutter_bar'], + "hide_cutter_pad": item['hide_cutter_pad'], + "hide_handler": item['hide_handler'], + "hide_chuck": item['hide_chuck'], + "hide_model": item['hide_model'], + }) + brand.write({ + 'mrs_cutting_tool_model_handle_chuck_model_ids': [ + (6, 0, [brand.id] * len(mrs_cutting_tool_model_handle_chuck_model_ids_list))], + }) + # many2many_commands = [(0, 0, {'model_id_1': brand.id, 'model_id_2': related_record_id}) for + # related_record_id in mrs_cutting_tool_model_handle_chuck_model_ids_list] + # brand.write({ + # 'mrs_cutting_tool_model_handle_chuck_model_ids': many2many_commands, + # }) + print('同步所有刀具型号列表成功') + else: + raise ValidationError("认证未通过")