114 lines
6.8 KiB
Python
114 lines
6.8 KiB
Python
# -*- coding: utf-8 -*-
|
||
import logging
|
||
import os
|
||
import json
|
||
import base64
|
||
from odoo import http, fields, models
|
||
from odoo.http import request
|
||
from odoo.addons.sf_base.controllers.controllers import MultiInheritController
|
||
|
||
|
||
class Sf_Mrs_Connect(http.Controller, MultiInheritController):
|
||
|
||
@http.route('/api/cnc_processing/create', type='json', auth='sf_token', methods=['GET', 'POST'], csrf=False,
|
||
cors="*")
|
||
def get_cnc_processing_create(self, **kw):
|
||
"""
|
||
获取mrs下发的编程单
|
||
:param kw:
|
||
:return:
|
||
"""
|
||
logging.info('get_cnc_processing_create:%s' % kw)
|
||
try:
|
||
res = {'status': 1, 'message': '成功'}
|
||
datas = request.httprequest.data
|
||
ret = json.loads(datas)
|
||
ret = json.loads(ret['result'])
|
||
logging.info('下发编程单:%s' % ret)
|
||
domain = [('programming_no', '=', ret['programming_no'])]
|
||
if ret['manufacturing_type'] in ('scrap', 'invalid_tool_rework'):
|
||
domain += [('state', 'not in', ['done', 'scrap', 'cancel'])]
|
||
else:
|
||
domain += [('state', 'in', ['confirmed', 'pending_cam'])]
|
||
productions = request.env['mrp.production'].with_user(
|
||
request.env.ref("base.user_admin")).search(domain)
|
||
if productions:
|
||
# 拉取所有加工面的程序文件
|
||
# for r in ret['processing_panel'].split(','):
|
||
# program_path_tmp_r = os.path.join('/tmp', ret['folder_name'], 'return', r)
|
||
# if os.path.exists(program_path_tmp_r):
|
||
# files_r = os.listdir(program_path_tmp_r)
|
||
# if files_r:
|
||
# for file_name in files_r:
|
||
# file_path = os.path.join(program_path_tmp_r, file_name)
|
||
# os.remove(file_path)
|
||
# download_state = request.env['sf.cnc.processing'].with_user(
|
||
# request.env.ref("base.user_admin")).download_file_tmp(
|
||
# ret['folder_name'], r)
|
||
# if download_state is False:
|
||
# res['status'] = -2
|
||
# res['message'] = '编程单号为%s的CNC程序文件从FTP拉取失败' % (ret['programming_no'])
|
||
# return json.JSONEncoder().encode(res)
|
||
for production in productions:
|
||
for panel in ret['processing_panel'].split(','):
|
||
# 查询状态为进行中且工序类型为CNC加工的工单
|
||
cnc_workorder_has = production.workorder_ids.filtered(
|
||
lambda ach: ach.routing_type == 'CNC加工' and ach.state not in ['progress', 'done',
|
||
'rework',
|
||
'cancel'] and ach.processing_panel == panel)
|
||
if cnc_workorder_has:
|
||
if cnc_workorder_has.cnc_ids:
|
||
cnc_workorder_has.cmm_ids.sudo().unlink()
|
||
cnc_workorder_has.cnc_ids.sudo().unlink()
|
||
# request.env['sf.cam.work.order.program.knife.plan'].sudo().unlink_cam_plan(
|
||
# production)
|
||
cnc_workorder_has.write(
|
||
{'cnc_ids': cnc_workorder_has.cnc_ids.sudo()._json_cnc_processing(panel, ret),
|
||
'cmm_ids': cnc_workorder_has.cmm_ids.sudo()._json_cmm_program(panel, ret)})
|
||
# for panel in ret['processing_panel'].split(','):
|
||
# # 查询状态为进行中且工序类型为CNC加工的工单
|
||
# cnc_workorder = productions.workorder_ids.filtered(
|
||
# lambda ac: ac.routing_type == 'CNC加工' and ac.state not in ['progress', 'done', 'rework'
|
||
# 'cancel'] and ac.processing_panel == panel)
|
||
# if cnc_workorder:
|
||
# # program_path_tmp_panel = os.path.join('C://Users//43484//Desktop//fsdownload//test',
|
||
# # panel)
|
||
# program_path_tmp_panel = os.path.join('/tmp', ret['folder_name'], 'return', panel)
|
||
# files_panel = os.listdir(program_path_tmp_panel)
|
||
# if files_panel:
|
||
# for file in files_panel:
|
||
# file_extension = os.path.splitext(file)[1]
|
||
# if file_extension.lower() == '.pdf':
|
||
# panel_file_path = os.path.join(program_path_tmp_panel, file)
|
||
# logging.info('panel_file_path:%s' % panel_file_path)
|
||
# cnc_workorder.write({'cnc_worksheet': base64.b64encode(open(panel_file_path, 'rb').read())})
|
||
# pre_workorder = productions.workorder_ids.filtered(
|
||
# lambda ap: ap.routing_type == '装夹预调' and ap.state not in ['done', 'rework'
|
||
# 'cancel'] and ap.processing_panel == panel)
|
||
# if pre_workorder:
|
||
# pre_workorder.write(
|
||
# {'processing_drawing': base64.b64encode(open(panel_file_path, 'rb').read())})
|
||
productions.write({'programming_state': '已编程', 'work_state': '已编程'})
|
||
logging.info('已更新制造订单编程状态:%s' % productions.ids)
|
||
res.update({
|
||
'production_ids': productions.ids
|
||
})
|
||
|
||
# 对制造订单所以面的cnc工单的程序用刀进行校验
|
||
try:
|
||
logging.info(f'已更新制造订单:{productions}')
|
||
productions.production_cnc_tool_checkout()
|
||
except Exception as e:
|
||
logging.info(f'对cnc工单的程序用刀进行校验报错:{e}')
|
||
return json.JSONEncoder().encode(res)
|
||
|
||
return json.JSONEncoder().encode(res)
|
||
else:
|
||
res = {'status': 0, 'message': '该制造订单暂未开始'}
|
||
return json.JSONEncoder().encode(res)
|
||
except Exception as e:
|
||
res = {'status': -1, 'message': '系统解析失败'}
|
||
request.cr.rollback()
|
||
logging.info('get_cnc_processing_create error:%s' % e)
|
||
return json.JSONEncoder().encode(res)
|