# -*- coding: utf-8 -*- import logging import json from datetime import datetime from odoo import http from odoo.http import request class Workpiece(http.Controller): @http.route('/agvApi/backfeed', type='json', auth='none', methods=['GET', 'POST'], csrf=False, cors="*") def backfeed(self, **kw): """ agv小车反馈工单(工件)结果 :param kw: :return: """ logging.info('backfeed:%s' % kw) try: res = {'Succeed': True} datas = request.httprequest.data ret = json.loads(datas) logging.info('backfeed-ret:%s' % ret) if 'reqCode' in ret: if 'method' in ret: if ret['method'] == 'end': # 找到对应的AGV调度任务 agv_scheduling = request.env['sf.agv.scheduling'].sudo().search( [('name', '=', ret['reqCode']), ('state', '=', '配送中')]) if agv_scheduling: agv_scheduling.finish_scheduling() else: res = {'Succeed': False, 'ErrorCode': 203, 'Error': '该reqCode暂未查到对应的AGV任务记录'} else: res = {'Succeed': False, 'ErrorCode': 204, 'Error': '未传method字段'} else: res = {'Succeed': False, 'ErrorCode': 201, 'Error': '未传reqCode字段'} except Exception as e: res = {'Succeed': False, 'ErrorCode': 202, 'Error': e} logging.info('backfeed error:%s' % e) return json.JSONEncoder().encode(res)