Accept Merge Request #831: (feature/刀具组接口18-19优化 -> develop)

Merge Request: 刀具组接口优化

Created By: @禹翔辉
Reviewed By: @马广威
Approved By: @马广威 
Accepted By: @禹翔辉
URL: https://jikimo-hn.coding.net/p/jikimo_sfs/d/jikimo_sf/git/merge/831?initial=true
This commit is contained in:
禹翔辉
2024-02-22 18:16:51 +08:00
committed by Coding
6 changed files with 79 additions and 52 deletions

View File

@@ -22,7 +22,7 @@ class Manufacturing_Connect(http.Controller):
ret = json.loads(datas) ret = json.loads(datas)
# ret = json.loads(ret['result']) # ret = json.loads(ret['result'])
logging.info('DeviceId:%s' % ret) logging.info('DeviceId:%s' % ret)
tool_groups = request.env['sf.tool.groups'].sudo().search([('active', '=', True)]) tool_groups = request.env['sf.tool.groups'].sudo().search([])
res = {'Succeed': True, 'Datas': []} res = {'Succeed': True, 'Datas': []}
if tool_groups: if tool_groups:

View File

@@ -8,53 +8,53 @@ from odoo.http import request
class Manufacturing_Connect(http.Controller): class Manufacturing_Connect(http.Controller):
@http.route('/AutoDeviceApi/GetToolInfo', type='json', auth='none', methods=['GET', 'POST'], csrf=False, # @http.route('/AutoDeviceApi/GetToolInfo', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
cors="*") # cors="*")
def get_equipment_tool_Info(self, **kw): # def get_equipment_tool_Info(self, **kw):
""" # """
机床刀库实时信息 # 机床刀库实时信息
:param kw: # :param kw:
:return: # :return:
""" # """
logging.info('get_equipment_tool_Info:%s' % kw) # logging.info('get_equipment_tool_Info:%s' % kw)
try: # try:
datas = request.httprequest.data # datas = request.httprequest.data
ret = json.loads(datas) # ret = json.loads(datas)
ret = json.loads(ret.get('result')) # ret = json.loads(ret.get('result'))
logging.info('DeviceId:%s' % ret) # logging.info('DeviceId:%s' % ret)
equipment = request.env['maintenance.equipment'].sudo().search([('name', '=', ret['DeviceId'])]) # equipment = request.env['maintenance.equipment'].sudo().search([('name', '=', ret['DeviceId'])])
#
res = {'Succeed': True, 'Datas': []} # res = {'Succeed': True, 'Datas': []}
if equipment: # if equipment:
for item in equipment: # for item in equipment:
data = [] # data = []
for equipment_tool_id in item.product_template_ids: # for equipment_tool_id in item.product_template_ids:
functional_tool_id = self.env['sf.functional.cutting.tool.entity'].sudo().search( # functional_tool_id = self.env['sf.functional.cutting.tool.entity'].sudo().search(
[('code', '=', equipment_tool_id.tool_code)]) # [('code', '=', equipment_tool_id.tool_code)])
#
alarm_time = None # alarm_time = None
if functional_tool_id.functional_tool_status == '报警': # if functional_tool_id.functional_tool_status == '报警':
alarm_time = self.env['sf.functional.tool.warning'].sudo().search( # alarm_time = self.env['sf.functional.tool.warning'].sudo().search(
[('code', '=', equipment_tool_id.tool_code)]).alarm_time # [('code', '=', equipment_tool_id.tool_code)]).alarm_time
equipment_tool = { # equipment_tool = {
'RfidCode': None, # 'RfidCode': None,
'ToolId': equipment_tool_id.code, # 'ToolId': equipment_tool_id.code,
'ToolName': equipment_tool_id.functional_tool_name_id.name, # 'ToolName': equipment_tool_id.functional_tool_name_id.name,
'MaxLife': equipment_tool_id.life_value_max, # 'MaxLife': equipment_tool_id.life_value_max,
'UseLife': equipment_tool_id.used_value, # 'UseLife': equipment_tool_id.used_value,
'AddDatetime': equipment_tool_id.tool_install_time, # 'AddDatetime': equipment_tool_id.tool_install_time,
'State': functional_tool_id.functional_tool_status, # 'State': functional_tool_id.functional_tool_status,
'WarnDate': alarm_time if alarm_time else False # 'WarnDate': alarm_time if alarm_time else False
} # }
data.append(equipment_tool) # data.append(equipment_tool)
res['Datas'].append({ # res['Datas'].append({
'DeviceId': item.name, # 'DeviceId': item.name,
'Data': data # 'Data': data
}) # })
except Exception as e: # except Exception as e:
res = {'Succeed': False, 'ErrorCode': 202, 'Error': e} # res = {'Succeed': False, 'ErrorCode': 202, 'Error': e}
logging.info('get_equipment_tool_Info error:%s' % e) # logging.info('get_equipment_tool_Info error:%s' % e)
return json.JSONEncoder().encode(res) # return json.JSONEncoder().encode(res)
@http.route('/AutoDeviceApi/ToolGroup', type='json', auth='none', methods=['GET', 'POST'], csrf=False, @http.route('/AutoDeviceApi/ToolGroup', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
cors="*") cors="*")
@@ -70,7 +70,7 @@ class Manufacturing_Connect(http.Controller):
ret = json.loads(datas) ret = json.loads(datas)
# ret = json.loads(ret['result']) # ret = json.loads(ret['result'])
logging.info('DeviceId:%s' % ret) logging.info('DeviceId:%s' % ret)
functional_tools = request.env['sf.functional.cutting.tool.entity'].sudo().search([('active', '=', True)]) functional_tools = request.env['sf.functional.cutting.tool.entity'].sudo().search([])
res = {'Succeed': True, 'Datas': []} res = {'Succeed': True, 'Datas': []}
if functional_tools: if functional_tools:

View File

@@ -734,7 +734,7 @@ class CAMWorkOrderProgramKnifePlan(models.Model):
撤回装刀申请 撤回装刀申请
:return: :return:
""" """
self.env['sf.functional.tool.assembly'].search( self.env['sf.functional.tool.assembly'].sudo().search(
[('assembly_order_code', '=', self.sf_functional_tool_assembly_id.assembly_order_code), [('assembly_order_code', '=', self.sf_functional_tool_assembly_id.assembly_order_code),
('loading_task_source', '=', '0')]).unlink() ('loading_task_source', '=', '0')]).unlink()

View File

@@ -1,5 +1,8 @@
import json
import requests
from odoo import models, api, fields from odoo import models, api, fields
from odoo.exceptions import ValidationError from odoo.exceptions import ValidationError
from odoo.addons.sf_base.commons.common import Common
class SfMaintenanceEquipmentTool(models.Model): class SfMaintenanceEquipmentTool(models.Model):
@@ -29,6 +32,30 @@ class SfMaintenanceEquipmentTool(models.Model):
return tools return tools
class SfMaintenanceEquipment(models.Model):
_inherit = 'maintenance.equipment'
_description = '设备机床刀库'
# ==========机床当前刀库实时信息接口==========
def register_equipment_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 = "https://x24467i973.zicp.fun/AutoDeviceApi/GetToolInfos"
val = {
"DeviceId": self.name
}
kw = json.dumps(val, ensure_ascii=False)
r = requests.get(strurl, json={}, data={'kw': kw, 'token': token}, headers=headers)
ret = r.json()
print(ret)
if r == 200:
return "机床当前刀库实时信息指令发送成功"
else:
raise ValidationError("机床当前刀库实时信息指令发送失败")
class StockLot(models.Model): class StockLot(models.Model):
_inherit = 'stock.lot' _inherit = 'stock.lot'

View File

@@ -11,12 +11,11 @@ class CNCprocessing(models.Model):
# ==========MES装刀指令接口========== # ==========MES装刀指令接口==========
def register_cnc_processing(self, cnc_processing): def register_cnc_processing(self, cnc_processing):
create_url = '/AutoDeviceApi/ToolLoadInstruct'
sf_sync_config = self.env['res.config.settings'].get_values() sf_sync_config = self.env['res.config.settings'].get_values()
token = sf_sync_config['token'] token = sf_sync_config['token']
sf_secret_key = sf_sync_config['sf_secret_key'] sf_secret_key = sf_sync_config['sf_secret_key']
headers = Common.get_headers(self, token, sf_secret_key) headers = Common.get_headers(self, token, sf_secret_key)
strurl = sf_sync_config['sf_url'] + create_url strurl = "https://x24467i973.zicp.fun/AutoDeviceApi/ToolLoadInstruct"
val = { val = {
'DeviceId': cnc_processing.workorder_id.machine_tool_name, 'DeviceId': cnc_processing.workorder_id.machine_tool_name,
'RfidCode': None, 'RfidCode': None,

View File

@@ -9,6 +9,7 @@
<xpath expr="//page[@name='sf_equipment_product_template']" position="replace"> <xpath expr="//page[@name='sf_equipment_product_template']" position="replace">
<page string="标准刀库" name="sf_equipment_product_template" <page string="标准刀库" name="sf_equipment_product_template"
attrs="{'invisible': [('equipment_type', '!=', '机床')]}"> attrs="{'invisible': [('equipment_type', '!=', '机床')]}">
<button string="获取机床刀库信息" name="register_equipment_tool" type="object" class="btn-primary"/>
<field name='product_template_ids'> <field name='product_template_ids'>
<tree editable='bottom'> <tree editable='bottom'>
<field name="code"/> <field name="code"/>