diff --git a/sf_base/__manifest__.py b/sf_base/__manifest__.py index 60255021..d6f8a88a 100644 --- a/sf_base/__manifest__.py +++ b/sf_base/__manifest__.py @@ -16,12 +16,11 @@ 'security/ir.model.access.csv', 'views/base_view.xml', 'views/common_view.xml', - "views/menu_view.xml", + 'views/fixture_view.xml', + 'views/functional_fixture_view.xml', + 'views/menu_view.xml', "views/tool_views.xml", "views/tool_menu.xml", - # "views/tool_base_views.xml", - # "views/tool_base_menu.xml", - 'views/fixture_base_view.xml', 'views/menu_fixture_view.xml', ], @@ -32,7 +31,7 @@ 'web.assets_qweb': [ ], 'web.assets_backend': [ - 'sf_base/static/src/scss/*.scss', + 'sf_base/static/src/scss/*.scss', ], }, diff --git a/sf_base/models/__init__.py b/sf_base/models/__init__.py index e9b767fd..cc906ab8 100644 --- a/sf_base/models/__init__.py +++ b/sf_base/models/__init__.py @@ -1,7 +1,9 @@ from . import base from . import common -# from . import tool_base from . import tool_base_new -from . import fixture_base +from . import fixture +from . import functional_fixture + + diff --git a/sf_base/models/fixture.py b/sf_base/models/fixture.py new file mode 100644 index 00000000..033ac181 --- /dev/null +++ b/sf_base/models/fixture.py @@ -0,0 +1,52 @@ +from odoo import models, fields, api + + +class FixtureMaterial(models.Model): + _name = 'sf.fixture.material' + _description = "夹具物料" + + code = fields.Char(string='编码') + name = fields.Char(string="名称", size=15) + remark = fields.Char(string="备注") + + +class Multi_MountingType(models.Model): + _name = 'sf.multi_mounting.type' + _description = "联装类型" + + code = fields.Char(string='编码') + name = fields.Char(string="名称", size=15) + remark = fields.Char(string="备注") + + +class FixtureModel(models.Model): + _name = 'sf.fixture.model' + _description = "夹具型号" + + code = fields.Char(string='编码') + name = fields.Char(string="名称", size=15) + fixture_material_id = fields.Many2one('sf.fixture.material', string="夹具物料", ) + fixture_material_type = fields.Char(string="夹具物料类型", related='fixture_material_id.name') + multi_mounting_type_id = fields.Many2one('sf.multi_mounting.type', string="联装类型") + brand_id = fields.Many2one('sf.machine.brand', string="品牌") + clamping_way = fields.Char(string="装夹方式") + port_type = fields.Char(string="接口类型") + model_file = fields.Binary(string="3D模型图") + length = fields.Char(string="长度[mm]") + width = fields.Char(string="宽度[mm]") + height = fields.Char(string="高度[mm]") + weight = fields.Char(string="重量[kg]") + clamp_workpiece_length_max = fields.Char(string="夹持工件长度MAX[mm]") + clamp_workpiece_width_max = fields.Char(string="夹持工件宽度MAX[mm]") + clamp_workpiece_height_max = fields.Char(string="夹持工件高度MAX[mm]") + clamp_workpiece_diameter_max = fields.Char(string="夹持工件直径MAX[mm]") + maximum_carrying_weight = fields.Char(string="最大承载重量[kg]") + maximum_clamping_force = fields.Char(string="最大夹持力[n]") + materials_model_id = fields.Many2one('sf.materials.model', string="材料型号") + driving_way = fields.Char(string="驱动方式") + apply_machine_tool_type = fields.Char(string="适用机床型号") + through_hole_size = fields.Integer(string="过孔大小[mm]", size=6) + screw_size = fields.Integer(string="螺牙大小[mm]", size=6) + + + diff --git a/sf_base/models/functional_fixture.py b/sf_base/models/functional_fixture.py new file mode 100644 index 00000000..f8acaab2 --- /dev/null +++ b/sf_base/models/functional_fixture.py @@ -0,0 +1,42 @@ +from odoo import models, fields, api + + +class FunctionalFixtureType(models.Model): + _name = 'sf.functional.fixture.type' + _description = "功能夹具类型" + + code = fields.Char(string='编码', readonly=True) + name = fields.Char(string="名称", size=15) + remark = fields.Char(string="备注") + + +class FunctionalFixture(models.Model): + _name = 'sf.functional.fixture' + _description = "功能夹具" + + code = fields.Char(string='编码', readonly=True) + name = fields.Char(string="名称", size=15, required=True) + functional_fixture_type_id = fields.Many2one('sf.functional.fixture.type', string="功能夹具类型", required=True) + zero_chuck_model_ids = fields.Many2many('sf.fixture.model', 'rel_fixture_model_zero_chuck', string="零点卡盘型号", + required=True, + domain=[('fixture_material_type', '=', '零点卡盘')]) + transfer_tray_model_ids = fields.Many2many('sf.fixture.model', 'rel_fixture_model_transfer_tray', + string="转接板(锁板)托盘型号", + domain=[('fixture_material_type', '=', '转接板(锁板)托盘')]) + pneumatic_tray_model_ids = fields.Many2many('sf.fixture.model', 'rel_fixture_model_pneumatic_tray', + string="气动托盘型号", + domain=[('fixture_material_type', '=', '气动托盘')]) + magnetic_tray_model_ids = fields.Many2many('sf.fixture.model', 'rel_fixture_model_magnetic_tray', + string="磁吸托盘型号", + domain=[('fixture_material_type', '=', '磁吸托盘')]) + vice_tray_model_ids = fields.Many2many('sf.fixture.model', 'rel_fixture_model_vice_tray', string="虎钳托盘型号", + domain=[('fixture_material_type', '=', '虎钳托盘')]) + + def _get_fixture_model_ids(self, fixture_model_code): + fixture_model_ids = [] + for item in fixture_model_code: + fixture_model = self.env['sf.fixture.model'].search([('code', '=', item)]) + fixture_model_ids.append(fixture_model.id) + return [(6, 0, fixture_model_ids)] + + diff --git a/sf_base/security/ir.model.access.csv b/sf_base/security/ir.model.access.csv index b68a00ca..175e4589 100644 --- a/sf_base/security/ir.model.access.csv +++ b/sf_base/security/ir.model.access.csv @@ -21,18 +21,13 @@ access_sf_cutting_tool_model,sf_cutting_tool_model,model_sf_cutting_tool_model,b 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_fixture_setting_element,sf_fixture_setting_element,model_sf_fixture_setting_element,base.group_user,1,1,1,1 -access_sf_setting_element_type,sf_setting_element_type,model_sf_setting_element_type,base.group_user,1,1,1,1 -access_sf_fixture_clamping_element,sf_fixture_clamping_element,model_sf_fixture_clamping_element,base.group_user,1,1,1,1 -access_sf_clamping_element_type,sf_clamping_element_type,model_sf_clamping_element_type,base.group_user,1,1,1,1 -access_sf_fixture_tool_setting,sf_fixture_tool_setting,model_sf_fixture_tool_setting,base.group_user,1,1,1,1 -access_sf_tool_setting_type,sf_tool_setting_type,model_sf_tool_setting_type,base.group_user,1,1,1,1 -access_sf_fixture_locating_device,sf_fixture_locating_device,model_sf_fixture_locating_device,base.group_user,1,1,1,1 -access_sf_locating_device_type,sf_locating_device_type,model_sf_locating_device_type,base.group_user,1,1,1,1 -access_sf_locating_device_locate_mode,sf_locating_device_locate_mode,model_sf_locating_device_locate_mode,base.group_user,1,1,1,1 -access_sf_fixture_guide_element,sf_fixture_guide_element,model_sf_fixture_guide_element,base.group_user,1,1,1,1 -access_sf_guide_element_type,sf_guide_element_type,model_sf_guide_element_type,base.group_user,1,1,1,1 -access_sf_guide_element_guide_mode,sf_guide_element_guide_mode,model_sf_guide_element_guide_mode,base.group_user,1,1,1,1 -access_sf_guide_element_way_to_install,sf_guide_element_way_to_install,model_sf_guide_element_way_to_install,base.group_user,1,1,1,1 + + +access_sf_fixture_material,sf_fixture_material,model_sf_fixture_material,base.group_user,1,1,1,1 +access_sf_multi_mounting_type,sf_multi_mounting_type,model_sf_multi_mounting_type,base.group_user,1,1,1,1 +access_sf_fixture_model,sf_fixture_model,model_sf_fixture_model,base.group_user,1,1,1,1 +access_sf_functional_fixture_type,sf_functional_fixture_type,model_sf_functional_fixture_type,base.group_user,1,1,1,1 +access_sf_functional_fixture,sf_functional_fixture,model_sf_functional_fixture,base.group_user,1,1,1,1 + diff --git a/sf_base/views/fixture_view.xml b/sf_base/views/fixture_view.xml new file mode 100644 index 00000000..de9134aa --- /dev/null +++ b/sf_base/views/fixture_view.xml @@ -0,0 +1,257 @@ + + + + + + search.sf.fixture.material + sf.fixture.material + + + + + + + + + + + 夹具物料 + sf.fixture.material + + + + + + + + + + + 夹具物料 + sf.fixture.material + +
+ + + + + + + + + + + + + + + +
+
+
+ + + 夹具物料 + ir.actions.act_window + sf.fixture.material + tree,form + + + + + + + search.sf.multi_mounting.type + sf.multi_mounting.type + + + + + + + + + + + + 联装类型 + sf.multi_mounting.type + + + + + + + + + + + 联装类型 + sf.multi_mounting.type + +
+ + + + + + + + + + + + + +
+
+
+ + + 联装类型 + ir.actions.act_window + sf.multi_mounting.type + tree,form + + + + + + search.sf.fixture.model + sf.fixture.model + + + + + + + + + + + + + + + + + + 夹具型号 + sf.fixture.model + + + + + + + + + + + + + + + 夹具型号 + sf.fixture.model + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+ + + 夹具型号 + ir.actions.act_window + sf.fixture.model + tree,form + +
\ No newline at end of file diff --git a/sf_base/views/functional_fixture_view.xml b/sf_base/views/functional_fixture_view.xml new file mode 100644 index 00000000..799c6351 --- /dev/null +++ b/sf_base/views/functional_fixture_view.xml @@ -0,0 +1,120 @@ + + + + + + + search.sf.functional.fixture.type + sf.functional.fixture.type + + + + + + + + + + + 功能夹具类型 + sf.functional.fixture.type + + + + + + + + + + + 功能夹具类型 + sf.functional.fixture.type + +
+ + + + + + + + + + + + + +
+
+
+ + + 功能夹具类型 + ir.actions.act_window + sf.functional.fixture.type + tree,form + + + + + + + search.sf.functional.fixture + sf.functional.fixture + + + + + + + + + + 功能夹具 + sf.functional.fixture + + + + + + + + + + + + 功能夹具 + sf.functional.fixture + +
+ + + + + + + + + + + + + + +
+
+
+ + + 功能夹具 + ir.actions.act_window + sf.functional.fixture + tree,form + +
\ No newline at end of file diff --git a/sf_base/views/ir_cron_mrs.xml b/sf_base/views/ir_cron_mrs.xml new file mode 100644 index 00000000..a1e88354 --- /dev/null +++ b/sf_base/views/ir_cron_mrs.xml @@ -0,0 +1,505 @@ + + + + + 基础信息同步:品牌类别 + + code + model._cron_machine_brand_tags_func() + 1 + days + -1 + + + + + + 基础信息同步:工序 + + code + model._cron_processing_order_func() + 1 + days + -1 + + + + + 基础信息同步:品牌 + + code + model._cron_machine_brand_func() + 1 + days + -1 + + + + + 基础信息同步:机床型号 + + code + model._cron_machine_tool_type_func() + 1 + days + -1 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 基础信息同步:材料 + + code + model._cron_production_materials_func() + 1 + days + -1 + + + + + 基础信息同步:材料型号 + + code + model._cron_materials_model_func() + 1 + days + -1 + + + + + 基础信息同步:表面工艺类别 + + code + model._cron_production_process_category_func() + 1 + days + -1 + + + + + + 基础信息同步:表面工艺 + + code + model._cron_production_process_func() + 1 + days + -1 + + + + + + + + + + + + + + + + 基础信息同步:数控系统 + + code + model._cron_machine_control_system_func() + 1 + days + -1 + + + + + 基础信息同步:模型类型 + + code + model._cron_model_type_func() + 1 + days + -1 + + + + + 基础信息同步:可选参数 + + code + model._cron_mrs_production_process_parameter() + 1 + days + -1 + + + + + 基础信息同步:机床类型 + + code + model._cron_machine_tool_category_func() + 1 + days + -1 + + + + + 基础信息同步:功能刀具型号 + + code + model._cron_mrs_functional_cutting_tool_func() + 1 + days + -1 + + + + + 基础信息同步:功能刀具类型 + + code + model._cron_mrs_functional_cutting_tool_model_func() + 1 + days + -1 + + + + + 基础信息同步:整体式刀具 + + code + model._cron_mrs_integral_cutting_tool_func() + 1 + days + -1 + + + + + 基础信息同步:整体式刀具类型 + + code + model._cron_mrs_integral_cutting_tool_model_func() + 1 + days + -1 + + + + + 基础信息同步:刀片型号 + + code + model._cron_mrs_blade_func() + 1 + days + -1 + + + + + 基础信息同步:刀片类型 + + code + model._cron_mrs_blade_model_func() + 1 + days + -1 + + + + + 基础信息同步:刀杆型号 + + code + model._cron_mrs_cutter_bar_func() + 1 + days + -1 + + + + + 基础信息同步:刀杆类型 + + code + model._cron_mrs_cutter_bar_model_func() + 1 + days + -1 + + + + + 基础信息同步:刀盘型号 + + code + model._cron_mrs_cutter_pad_func() + 1 + days + -1 + + + + + 基础信息同步:刀盘类型 + + code + model._cron_mrs_cutter_pad_model_func() + 1 + days + -1 + + + + + + 基础信息同步:刀柄型号 + + code + model._cron_mrs_handle_func() + 1 + days + -1 + + + + + 基础信息同步:刀柄类型 + + code + model._cron_mrs_handle_model_func() + 1 + days + -1 + + + + + 基础信息同步:夹具物料 + + code + model._cron_fixture_material_func() + 1 + days + -1 + + + + + 基础信息同步:联装类型 + + code + model._cron_multi_mounting_type_func() + 1 + days + -1 + + + + + 基础信息同步:夹具型号 + + code + model._cron_fixture_model_func() + 1 + days + -1 + + + + + 基础信息同步:功能夹具类型 + + code + model._cron_functional_fixture_type_func() + 1 + days + -1 + + + + + 基础信息同步:功能夹具 + + code + model._cron_functional_fixture_func() + 1 + days + -1 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/sf_base/views/menu_fixture_view.xml b/sf_base/views/menu_fixture_view.xml index 4a5e1283..7186fe35 100644 --- a/sf_base/views/menu_fixture_view.xml +++ b/sf_base/views/menu_fixture_view.xml @@ -1,106 +1,41 @@ - - - - - - + sequence="5" + /> - - - - - - - - + /> - - - + - + /> - - + - - - - - - - - - - - + /> \ No newline at end of file diff --git a/sf_base/views/menu_view.xml b/sf_base/views/menu_view.xml index c9b8f1c1..cd32e960 100644 --- a/sf_base/views/menu_view.xml +++ b/sf_base/views/menu_view.xml @@ -16,18 +16,39 @@ action="action_mrp_configuration" groups="base.group_system"/>--> + + + + + + @@ -43,7 +64,7 @@ id="menu_sf_production_materials_1" name="原材料" parent="mrp.menu_mrp_configuration" - sequence="3" + sequence="6" /> @@ -51,7 +72,7 @@ id="menu_sf_production_process_1" name="工艺" parent="mrp.menu_mrp_configuration" - sequence="4" + sequence="7" /> @@ -98,13 +119,13 @@ sequence="3" action="sf_processing_technology"/> - - - - - - - + + + + + + + - - diff --git a/sf_manufacturing/views/model_type_view.xml b/sf_manufacturing/views/model_type_view.xml index 7c3f18de..8b1218a4 100644 --- a/sf_manufacturing/views/model_type_view.xml +++ b/sf_manufacturing/views/model_type_view.xml @@ -88,7 +88,7 @@ id="menu_sf_model_type" name="模型类型" parent="mrp.menu_mrp_configuration" - sequence="10" + sequence="9" action="action_sf_model_type" /> diff --git a/sf_mrs_connect/data/ir_cron_data.xml b/sf_mrs_connect/data/ir_cron_data.xml index 9ea7dd78..ba94180d 100644 --- a/sf_mrs_connect/data/ir_cron_data.xml +++ b/sf_mrs_connect/data/ir_cron_data.xml @@ -154,176 +154,55 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 同步资源库夹紧元件型号 - + + 同步夹具物料 + code - model.sync_fixture_clamping_element() + model.sync_fixture_material() 1 days -1 - - 同步资源库夹紧元件类型 - + + 同步联装类型列表 + code - model.sync_clamping_element_type() + model.sync_multi_mounting_type() 1 days -1 - - 同步资源库导向元件类型 - + + 同步夹具型号 + code - model.sync_guide_element_type() + model.sync_fixture_model() 1 days -1 - - 同步资源库导向元件导向方式 - + + 同步功能夹具类型 + code - model.sync_guide_element_guide_mode() + model.sync_functional_fixture_type() + 1 + days + -1 + + + + + 同步功能夹具 + + code + model.sync_functional_fixture() 1 days -1 diff --git a/sf_mrs_connect/models/res_config_setting.py b/sf_mrs_connect/models/res_config_setting.py index e1c65d3e..3196f68d 100644 --- a/sf_mrs_connect/models/res_config_setting.py +++ b/sf_mrs_connect/models/res_config_setting.py @@ -68,21 +68,16 @@ class ResConfigSettings(models.TransientModel): 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("同步所有功能刀具列表完成") - - # self.env['sf.fixture.clamping.element'].sync_all_fixture_clamping_element() - # _logger.info("同步资源库夹紧元件型号") - # self.env['sf.clamping.element.type'].sync_all_clamping_element_type() - # _logger.info("同步资源库夹紧元件类型") - # self.env['sf.guide.element.type'].sync_all_guide_element_type() - # _logger.info("同步资源库导向元件类型") - # self.env['sf.guide.element.guide.mode'].sync_all_guide_element_guide_mode() - # _logger.info("同步资源库导向元件导向方式") - + self.env['sf.fixture.material'].sync_all_fixture_material() + _logger.info("同步夹具物料") + self.env['sf.multi_mounting.type'].sync_all_multi_mounting_type() + _logger.info("同步联装类型") + self.env['sf.fixture.model'].sync_all_fixture_model() + _logger.info("同步夹具型号") + self.env['sf.functional.fixture.type'].sync_all_functional_fixture_type() + _logger.info("同步功能夹具类型") + self.env['sf.functional.fixture'].sync_all_functional_fixture() + _logger.info("同步功能夹具") except Exception as e: _logger.info("捕获错误信息:%s" % e) raise ValidationError("数据错误导致同步失败,请联系管理员") diff --git a/sf_mrs_connect/models/sync_common.py b/sf_mrs_connect/models/sync_common.py index 67548349..2413e914 100644 --- a/sf_mrs_connect/models/sync_common.py +++ b/sf_mrs_connect/models/sync_common.py @@ -1369,1586 +1369,45 @@ class SyncFunctionalCuttingToolModel(models.Model): 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("认证未通过") +class SyncFixtureMaterial(models.Model): + _inherit = 'sf.fixture.material' + _description = '同步夹具物料列表' + url = '/api/fixture_material/list' -'''=========================================夹紧元件类型===============================================''' - - -class sfClampingElementType(models.Model): - _inherit = 'sf.clamping.element.type' - _description = '夹紧元件类型' - url = '/api/mrs_clamping_element_type/list' - - # 定时同步每日夹紧元件类型 - def sync_clamping_element_type(self): + # 定时同步夹具物料列表 + def sync_fixture_material(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) + # print('result:%s' % result) if result['status'] == 1: - for item in result['mrs_clamping_element_type_yesterday_list']: - if item: - brand = self.env['sf.clamping.element.type'].search( - [("code", '=', item['code'])]) - if brand: - brand.name = item['name'], - brand.code = item['code'], - brand.comment = item['comment'] - else: - self.env['sf.clamping.element.type'].create({ - "name": item['name'], - "code": item['code'], - "comment": item['comment'] - }) + if result.get('fixture_material_yesterday_list'): + for item in result['fixture_material_yesterday_list']: + if item: + fixture_material = self.env['sf.fixture.material'].search( + [("code", '=', item['code'])]) + if not fixture_material: + self.env['sf.fixture.material'].create({ + "name": item['name'], + "code": item['code'], + "remark": item['remark'], + }) + else: + fixture_material.write({ + "name": item['name'], + "remark": item['remark'], + }) else: raise ValidationError("认证未通过") - # 同步所有夹紧元件类型 - def sync_all_clamping_element_type(self): + # 定时同步所有夹具物料列表 + def sync_all_fixture_material(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'] @@ -2958,98 +1417,67 @@ class sfClampingElementType(models.Model): 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: - _logger.info('result:%s' % result) - for item in result['mrs_clamping_element_type_all_list']: - if item: - brand = self.env['sf.clamping.element.type'].search( - [("code", '=', item['code'])]) - if not brand: - self.env['sf.clamping.element.type'].create({ - "name": item['name'], - "code": item['code'], - "comment": item['comment'] - }) + if result.get('fixture_material_all_list'): + for item in result['fixture_material_all_list']: + if item: + fixture_material = self.env['sf.fixture.material'].search( + [("code", '=', item['code'])]) + if not fixture_material: + self.env['sf.fixture.material'].create({ + "name": item['name'], + "code": item['code'], + "remark": item['remark'], + }) + else: + fixture_material.write({ + "name": item['name'], + "remark": item['remark'], + }) else: raise ValidationError("认证未通过") -'''=================================夹紧元件型号=============================================''' +class SyncMulti_Mounting_Type(models.Model): + _inherit = 'sf.multi_mounting.type' + _description = '同步联装类型列表' + url = '/api/multi_mounting_type/list' -class sfFixtureClampingElement(models.Model): - _inherit = 'sf.fixture.clamping.element' - _description = '夹紧元件型号' - url = '/api/mrs_fixture_clamping_element/list' - - # 定时同步夹紧元件型号 - def sync_fixture_clamping_element(self): + # 定时同步夹具物料列表 + def sync_multi_mounting_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']) + # print('result:%s' % 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, - }) + if result.get('multi_mounting_type_yesterday_list'): + for item in result['multi_mounting_type_yesterday_list']: + if item: + multi_mounting_type = self.env['sf.multi_mounting.type'].search( + [("code", '=', item['code'])]) + if not multi_mounting_type: + self.env['sf.multi_mounting.type'].create({ + "name": item['name'], + "code": item['code'], + "remark": item['remark'], + }) + else: + multi_mounting_type.write({ + "name": item['name'], + "remark": item['remark'], + }) else: raise ValidationError("认证未通过") - # 同步所有夹紧元件型号 - def sync_all_fixture_clamping_element(self): + # 定时同步所有夹具物料列表 + def sync_all_multi_mounting_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'] @@ -3059,82 +1487,113 @@ class sfFixtureClampingElement(models.Model): r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) - print(result) + # print('result:%s' % 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, - }) - - + if result.get('multi_mounting_type_all_list'): + for item in result['multi_mounting_type_all_list']: + if item: + multi_mounting_type = self.env['sf.multi_mounting.type'].search( + [("code", '=', item['code'])]) + if not multi_mounting_type: + self.env['sf.multi_mounting.type'].create({ + "name": item['name'], + "code": item['code'], + "remark": item['remark'], + }) + else: + multi_mounting_type.write({ + "name": item['name'], + "remark": item['remark'], + }) else: raise ValidationError("认证未通过") -'''===================================导向元件类型==========================================''' +class SyncFixtureModel(models.Model): + _inherit = 'sf.fixture.model' + _description = '同步夹具型号列表' + url = '/api/fixture_model/list' -class sfGuideElementType(models.Model): - _inherit = 'sf.guide.element.type' - _description = '导向元件类型' - url = '/api/mrs_guide_element_type/list' - - # 定时同步每日导向元件类型 - def sync_guide_element_type(self): + # 定时同步夹具型号列表 + def sync_fixture_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: - _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'] - }) + if result.get('fixture_model_yesterday_list'): + for item in result['fixture_model_yesterday_list']: + if item: + fixture_model = self.env['sf.fixture.model'].search( + [("code", '=', item['code'])]) + if not fixture_model: + self.env['sf.fixture.model'].create({ + "name": item['name'], + "code": item['code'], + "fixture_material_id": self.env['sf.fixture.material'].search( + [('code', '=', item['fixture_material_code'])]).id, + "multi_mounting_type_id": self.env['sf.multi_mounting.type'].search( + [('code', '=', item['multi_mounting_type_code'])]).id, + "brand_id": self.env['sf.machine.brand'].search([('code', '=', item['brand_code'])]).id, + "clamping_way": item['clamping_way'], + "port_type": item['port_type'], + "model_file": '' if not item['model_file'] else base64.b64decode(item['model_file']), + "length": item['length'], + "width": item['width'], + "height": item['height'], + "weight": item['weight'], + "clamp_workpiece_length_max": item['clamp_workpiece_length_max'], + "clamp_workpiece_width_max": item['clamp_workpiece_width_max'], + "clamp_workpiece_height_max": item['clamp_workpiece_height_max'], + "clamp_workpiece_diameter_max": item['clamp_workpiece_diameter_max'], + "maximum_carrying_weight": item['maximum_carrying_weight'], + "maximum_clamping_force": item['maximum_clamping_force'], + "materials_model_id": self.env['sf.materials.model'].search( + [('materials_no', '=', item['materials_model_code'])]).id, + "driving_way": item['driving_way'], + "apply_machine_tool_type": item['apply_machine_tool_type'], + "through_hole_size": item['through_hole_size'], + "screw_size": item['screw_size'], + }) + else: + fixture_model.write({ + "name": item['name'], + "fixture_material_id": self.env['sf.fixture.material'].search( + [('code', '=', item['fixture_material_code'])]).id, + "multi_mounting_type_id": self.env['sf.multi_mounting.type'].search( + [('code', '=', item['multi_mounting_type_code'])]).id, + "brand_id": self.env['sf.machine.brand'].search([('code', '=', item['brand_code'])]).id, + "clamping_way": item['clamping_way'], + "port_type": item['port_type'], + "model_file": '' if not item['model_file'] else base64.b64decode(item['model_file']), + "length": item['length'], + "width": item['width'], + "height": item['height'], + "weight": item['weight'], + "clamp_workpiece_length_max": item['clamp_workpiece_length_max'], + "clamp_workpiece_width_max": item['clamp_workpiece_width_max'], + "clamp_workpiece_height_max": item['clamp_workpiece_height_max'], + "clamp_workpiece_diameter_max": item['clamp_workpiece_diameter_max'], + "maximum_carrying_weight": item['maximum_carrying_weight'], + "maximum_clamping_force": item['maximum_clamping_force'], + "materials_model_id": self.env['sf.materials.model'].search( + [('materials_no', '=', item['materials_model_code'])]).id, + "driving_way": item['driving_way'], + "apply_machine_tool_type": item['apply_machine_tool_type'], + "through_hole_size": item['through_hole_size'], + "screw_size": item['screw_size'], + }) else: raise ValidationError("认证未通过") - # 同步所有导向元件类型 - def sync_all_guide_element_type(self): + # 定时同步所有夹具型号列表 + def sync_all_fixture_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'] @@ -3144,73 +1603,113 @@ class sfGuideElementType(models.Model): 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: - _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)]}) + if result.get('fixture_model_all_list'): + for item in result['fixture_model_all_list']: + if item: + fixture_model = self.env['sf.fixture.model'].search( + [("code", '=', item['code'])]) + if not fixture_model: + self.env['sf.fixture.model'].create({ + "name": item['name'], + "code": item['code'], + "fixture_material_id": self.env['sf.fixture.material'].search( + [('code', '=', item['fixture_material_code'])]).id, + "multi_mounting_type_id": self.env['sf.multi_mounting.type'].search( + [('code', '=', item['multi_mounting_type_code'])]).id, + "brand_id": self.env['sf.machine.brand'].search([('code', '=', item['brand_code'])]).id, + "clamping_way": item['clamping_way'], + "port_type": item['port_type'], + "model_file": '' if not item['model_file'] else base64.b64decode(item['model_file']), + "length": item['length'], + "width": item['width'], + "height": item['height'], + "weight": item['weight'], + "clamp_workpiece_length_max": item['clamp_workpiece_length_max'], + "clamp_workpiece_width_max": item['clamp_workpiece_width_max'], + "clamp_workpiece_height_max": item['clamp_workpiece_height_max'], + "clamp_workpiece_diameter_max": item['clamp_workpiece_diameter_max'], + "maximum_carrying_weight": item['maximum_carrying_weight'], + "maximum_clamping_force": item['maximum_clamping_force'], + "materials_model_id": self.env['sf.materials.model'].search( + [('materials_no', '=', item['materials_model_code'])]).id, + "driving_way": item['driving_way'], + "apply_machine_tool_type": item['apply_machine_tool_type'], + "through_hole_size": item['through_hole_size'], + "screw_size": item['screw_size'], + }) + else: + fixture_model.write({ + "name": item['name'], + "fixture_material_id": self.env['sf.fixture.material'].search( + [('code', '=', item['fixture_material_code'])]).id, + "multi_mounting_type_id": self.env['sf.multi_mounting.type'].search( + [('code', '=', item['multi_mounting_type_code'])]).id, + "brand_id": self.env['sf.machine.brand'].search([('code', '=', item['brand_code'])]).id, + "clamping_way": item['clamping_way'], + "port_type": item['port_type'], + "model_file": '' if not item['model_file'] else base64.b64decode(item['model_file']), + "length": item['length'], + "width": item['width'], + "height": item['height'], + "weight": item['weight'], + "clamp_workpiece_length_max": item['clamp_workpiece_length_max'], + "clamp_workpiece_width_max": item['clamp_workpiece_width_max'], + "clamp_workpiece_height_max": item['clamp_workpiece_height_max'], + "clamp_workpiece_diameter_max": item['clamp_workpiece_diameter_max'], + "maximum_carrying_weight": item['maximum_carrying_weight'], + "maximum_clamping_force": item['maximum_clamping_force'], + "materials_model_id": self.env['sf.materials.model'].search( + [('materials_no', '=', item['materials_model_code'])]).id, + "driving_way": item['driving_way'], + "apply_machine_tool_type": item['apply_machine_tool_type'], + "through_hole_size": item['through_hole_size'], + "screw_size": item['screw_size'], + }) else: raise ValidationError("认证未通过") -'''===================================导向元件导向方式==========================================''' +class SyncFunctionalFixtureType(models.Model): + _inherit = 'sf.functional.fixture.type' + _description = '同步功能夹具类型列表' + url = '/api/functional_fixture_type/list' -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): + # 定时同步功能夹具类型列表 + def sync_functional_fixture_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']) + # print('result:%s' % 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 - }) + if result.get('functional_fixture_type_yesterday_list'): + for item in result['functional_fixture_type_yesterday_list']: + if item: + functional_fixture_type = self.env['sf.functional.fixture.type'].search( + [("code", '=', item['code'])]) + if not functional_fixture_type: + self.env['sf.functional.fixture.type'].create({ + "name": item['name'], + "code": item['code'], + "remark": item['remark'], + }) + else: + functional_fixture_type.write({ + "name": item['name'], + "remark": item['remark'], + }) else: raise ValidationError("认证未通过") - # 同步所有导向元件导向方式 - def sync_all_guide_element_guide_mode(self): + # 定时同步所有功能夹具类型列表 + def sync_all_functional_fixture_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'] @@ -3220,24 +1719,128 @@ class sfGuideElementGuideMode(models.Model): 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: - _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 - }) + if result.get('functional_fixture_type_all_list'): + for item in result['functional_fixture_type_all_list']: + if item: + functional_fixture_type = self.env['sf.functional.fixture.type'].search( + [("code", '=', item['code'])]) + if not functional_fixture_type: + self.env['sf.functional.fixture.type'].create({ + "name": item['name'], + "code": item['code'], + }) + else: + functional_fixture_type.write({ + "name": item['name'], + "remark": item['remark'], + }) + else: + raise ValidationError("认证未通过") + + +class SyncFunctionalFixture(models.Model): + _inherit = 'sf.functional.fixture' + _description = '同步功能夹具列表' + + url = '/api/functional_fixture/list' + + # 定时同步每日功能夹具列表 + def sync_functional_fixture(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('functional_fixture_yesterday_list'): + for item in result['functional_fixture_yesterday_list']: + if item: + functional_fixture = self.env['sf.functional.fixture'].search( + [("code", '=', item['code'])]) + if not functional_fixture: + self.env['sf.functional.fixture'].create({ + "name": item['name'], + "code": item['code'], + "functional_fixture_type_id": self.env['sf.functional.fixture.type'].search( + [("code", '=', item['functional_fixture_type_code'])]).id, + "zero_chuck_model_ids": self._get_fixture_model_ids(item['zero_chuck_model_codes']), + "transfer_tray_model_ids": self._get_fixture_model_ids( + item['transfer_tray_model_codes']), + "pneumatic_tray_model_ids": self._get_fixture_model_ids( + item['pneumatic_tray_model_codes']), + "magnetic_tray_model_ids": self._get_fixture_model_ids( + item['magnetic_tray_model_codes']), + "vice_tray_model_ids": self._get_fixture_model_ids(item['vice_tray_model_codes']), + }) + else: + functional_fixture.write({ + "name": item['name'], + "functional_fixture_type_id": self.env['sf.functional.fixture.type'].search( + [("code", '=', item['functional_fixture_type_code'])]).id, + "zero_chuck_model_ids": self._get_fixture_model_ids(item['zero_chuck_model_codes']), + "transfer_tray_model_ids": self._get_fixture_model_ids( + item['transfer_tray_model_codes']), + "pneumatic_tray_model_ids": self._get_fixture_model_ids( + item['pneumatic_tray_model_codes']), + "magnetic_tray_model_ids": self._get_fixture_model_ids( + item['magnetic_tray_model_codes']), + "vice_tray_model_ids": self._get_fixture_model_ids(item['vice_tray_model_codes']), + }) + else: + raise ValidationError("认证未通过") + + # 定时同步所有功能夹具列表 + def sync_all_functional_fixture(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('functional_fixture_all_list'): + for item in result['functional_fixture_all_list']: + if item: + functional_fixture = self.env['sf.functional.fixture'].search( + [("code", '=', item['code'])]) + if not functional_fixture: + self.env['sf.functional.fixture'].create({ + "name": item['name'], + "code": item['code'], + "functional_fixture_type_id": self.env['sf.functional.fixture.type'].search( + [("code", '=', item['functional_fixture_type_code'])]).id, + "zero_chuck_model_ids": self._get_fixture_model_ids(item['zero_chuck_model_codes']), + "transfer_tray_model_ids": self._get_fixture_model_ids( + item['transfer_tray_model_codes']), + "pneumatic_tray_model_ids": self._get_fixture_model_ids( + item['pneumatic_tray_model_codes']), + "magnetic_tray_model_ids": self._get_fixture_model_ids( + item['magnetic_tray_model_codes']), + "vice_tray_model_ids": self._get_fixture_model_ids(item['vice_tray_model_codes']), + }) + else: + functional_fixture.write({ + "name": item['name'], + "functional_fixture_type_id": self.env['sf.functional.fixture.type'].search( + [("code", '=', item['functional_fixture_type_code'])]).id, + "zero_chuck_model_ids": self._get_fixture_model_ids(item['zero_chuck_model_codes']), + "transfer_tray_model_ids": self._get_fixture_model_ids( + item['transfer_tray_model_codes']), + "pneumatic_tray_model_ids": self._get_fixture_model_ids( + item['pneumatic_tray_model_codes']), + "magnetic_tray_model_ids": self._get_fixture_model_ids( + item['magnetic_tray_model_codes']), + "vice_tray_model_ids": self._get_fixture_model_ids(item['vice_tray_model_codes']), + }) else: raise ValidationError("认证未通过") @@ -3402,7 +2005,8 @@ class SfToolModel(models.Model): [("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']: + 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) @@ -3487,7 +2091,8 @@ class SfToolModel(models.Model): "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)], + "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'], @@ -3593,7 +2198,8 @@ class SfToolModel(models.Model): "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)], + "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'], @@ -3865,7 +2471,8 @@ class SfToolModel(models.Model): "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)], + "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'],