85 lines
3.3 KiB
Python
85 lines
3.3 KiB
Python
|
# -*- coding: utf-8 -*-
|
||
|
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
||
|
|
||
|
from base64 import b64decode
|
||
|
import json
|
||
|
import logging
|
||
|
import os
|
||
|
import subprocess
|
||
|
import time
|
||
|
|
||
|
from odoo import http, tools
|
||
|
|
||
|
from odoo.addons.hw_drivers.event_manager import event_manager
|
||
|
from odoo.addons.hw_drivers.main import iot_devices, manager
|
||
|
from odoo.addons.hw_drivers.tools import helpers
|
||
|
|
||
|
_logger = logging.getLogger(__name__)
|
||
|
|
||
|
|
||
|
class DriverController(http.Controller):
|
||
|
@http.route('/hw_drivers/action', type='json', auth='none', cors='*', csrf=False, save_session=False)
|
||
|
def action(self, session_id, device_identifier, data):
|
||
|
"""
|
||
|
This route is called when we want to make a action with device (take picture, printing,...)
|
||
|
We specify in data from which session_id that action is called
|
||
|
And call the action of specific device
|
||
|
"""
|
||
|
iot_device = iot_devices.get(device_identifier)
|
||
|
if iot_device:
|
||
|
iot_device.data['owner'] = session_id
|
||
|
data = json.loads(data)
|
||
|
|
||
|
# Skip the request if it was already executed (duplicated action calls)
|
||
|
iot_idempotent_id = data.get("iot_idempotent_id")
|
||
|
if iot_idempotent_id:
|
||
|
idempotent_session = iot_device._check_idempotency(iot_idempotent_id, session_id)
|
||
|
if idempotent_session:
|
||
|
_logger.info("Ignored request from %s as iot_idempotent_id %s already received from session %s",
|
||
|
session_id, iot_idempotent_id, idempotent_session)
|
||
|
return False
|
||
|
iot_device.action(data)
|
||
|
return True
|
||
|
return False
|
||
|
|
||
|
@http.route('/hw_drivers/check_certificate', type='http', auth='none', cors='*', csrf=False, save_session=False)
|
||
|
def check_certificate(self):
|
||
|
"""
|
||
|
This route is called when we want to check if certificate is up-to-date
|
||
|
Used in cron.daily
|
||
|
"""
|
||
|
helpers.get_certificate_status()
|
||
|
|
||
|
@http.route('/hw_drivers/event', type='json', auth='none', cors='*', csrf=False, save_session=False)
|
||
|
def event(self, listener):
|
||
|
"""
|
||
|
listener is a dict in witch there are a sessions_id and a dict of device_identifier to listen
|
||
|
"""
|
||
|
req = event_manager.add_request(listener)
|
||
|
|
||
|
# Search for previous events and remove events older than 5 seconds
|
||
|
oldest_time = time.time() - 5
|
||
|
for event in list(event_manager.events):
|
||
|
if event['time'] < oldest_time:
|
||
|
del event_manager.events[0]
|
||
|
continue
|
||
|
if event['device_identifier'] in listener['devices'] and event['time'] > listener['last_event']:
|
||
|
event['session_id'] = req['session_id']
|
||
|
return event
|
||
|
|
||
|
# Wait for new event
|
||
|
if req['event'].wait(50):
|
||
|
req['event'].clear()
|
||
|
req['result']['session_id'] = req['session_id']
|
||
|
return req['result']
|
||
|
|
||
|
@http.route('/hw_drivers/download_logs', type='http', auth='none', cors='*', csrf=False, save_session=False)
|
||
|
def download_logs(self):
|
||
|
"""
|
||
|
Downloads the log file
|
||
|
"""
|
||
|
if tools.config['logfile']:
|
||
|
return http.Stream.from_path(tools.config['logfile']).get_response(
|
||
|
mimetype='text/plain', as_attachment=True
|
||
|
)
|