Implement macro recording for gpio (#65)

This commit is contained in:
Shantur Rathore 2021-09-20 01:22:48 +01:00 committed by GitHub
parent e38c65f181
commit f160fb561f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 51 additions and 12 deletions

View File

@ -19,9 +19,11 @@
# # # #
# ========================================================================== # # ========================================================================== #
from typing import Dict
from aiohttp.web import Request from aiohttp.web import Request
from aiohttp.web import Response from aiohttp.web import Response
from aiohttp.web import WebSocketResponse
from ....validators.basic import valid_bool from ....validators.basic import valid_bool
from ....validators.basic import valid_float_f0 from ....validators.basic import valid_float_f0
@ -30,6 +32,7 @@ from ....validators.ugpio import valid_ugpio_channel
from ..ugpio import UserGpio from ..ugpio import UserGpio
from ..http import exposed_http from ..http import exposed_http
from ..http import exposed_ws
from ..http import make_json_response from ..http import make_json_response
@ -38,7 +41,7 @@ class UserGpioApi:
def __init__(self, user_gpio: UserGpio) -> None: def __init__(self, user_gpio: UserGpio) -> None:
self.__user_gpio = user_gpio self.__user_gpio = user_gpio
# ===== # ===== Http
@exposed_http("GET", "/gpio") @exposed_http("GET", "/gpio")
async def __state_handler(self, _: Request) -> Response: async def __state_handler(self, _: Request) -> Response:
@ -62,3 +65,25 @@ class UserGpioApi:
wait = valid_bool(request.query.get("wait", "0")) wait = valid_bool(request.query.get("wait", "0"))
await self.__user_gpio.pulse(channel, delay, wait) await self.__user_gpio.pulse(channel, delay, wait)
return make_json_response() return make_json_response()
# ===== Websocket
@exposed_ws("gpio_switch")
async def __ws_gpio_switch_handler(self, _: WebSocketResponse, event: Dict) -> None:
try:
channel = valid_ugpio_channel(event["channel"])
state = valid_bool(event["state"])
wait = valid_bool(event["wait"])
except Exception:
return
await self.__user_gpio.switch(channel, state, wait)
@exposed_ws("gpio_pulse")
async def __ws_gpio_pulse_handler(self, _: WebSocketResponse, event: Dict) -> None:
try:
channel = valid_ugpio_channel(event["channel"])
delay = valid_float_f0(event["delay"])
wait = valid_bool(event["wait"])
except Exception:
return
await self.__user_gpio.pulse(channel, delay, wait)

View File

@ -27,7 +27,7 @@ import {tools, $, $$$} from "../tools.js";
import {wm} from "../wm.js"; import {wm} from "../wm.js";
export function Gpio() { export function Gpio(__recordWsEvent) {
var self = this; var self = this;
/************************************************************************/ /************************************************************************/
@ -167,7 +167,14 @@ export function Gpio() {
if (to === "0" && el.hasAttribute("data-confirm-off")) { if (to === "0" && el.hasAttribute("data-confirm-off")) {
confirm = el.getAttribute("data-confirm-off"); confirm = el.getAttribute("data-confirm-off");
} }
let act = () => __sendPost(`/api/gpio/switch?channel=${channel}&state=${to}`); let event = {
"event_type": "gpio_switch",
"event": {"channel": channel, "state": to, "wait": 0},
};
let act = () => {
__sendPost(`/api/gpio/switch?channel=${channel}&state=${to}`);
__recordWsEvent(event);
};
if (confirm) { if (confirm) {
wm.confirm(confirm).then(function(ok) { wm.confirm(confirm).then(function(ok) {
if (ok) { if (ok) {
@ -184,7 +191,14 @@ export function Gpio() {
var __pulseChannel = function(el) { var __pulseChannel = function(el) {
let channel = el.getAttribute("data-channel"); let channel = el.getAttribute("data-channel");
let confirm = el.getAttribute("data-confirm"); let confirm = el.getAttribute("data-confirm");
let act = () => __sendPost(`/api/gpio/pulse?channel=${channel}`); let event = {
"event_type": "gpio_pulse",
"event": {"channel": channel, "delay": 0, "wait": 0},
};
let act = () => {
__sendPost(`/api/gpio/pulse?channel=${channel}`);
__recordWsEvent(event);
};
if (confirm) { if (confirm) {
wm.confirm(confirm).then(function(ok) { if (ok) act(); }); wm.confirm(confirm).then(function(ok) { if (ok) act(); });
} else { } else {

View File

@ -26,22 +26,19 @@
import {tools, $, $$$} from "../tools.js"; import {tools, $, $$$} from "../tools.js";
import {wm} from "../wm.js"; import {wm} from "../wm.js";
import {Recorder} from "./recorder.js";
import {Keyboard} from "./keyboard.js"; import {Keyboard} from "./keyboard.js";
import {Mouse} from "./mouse.js"; import {Mouse} from "./mouse.js";
export function Hid(__getResolution) { export function Hid(__getResolution, __recorder) {
var self = this; var self = this;
/************************************************************************/ /************************************************************************/
var __recorder = null;
var __keyboard = null; var __keyboard = null;
var __mouse = null; var __mouse = null;
var __init__ = function() { var __init__ = function() {
__recorder = new Recorder();
__keyboard = new Keyboard(__recorder.recordWsEvent); __keyboard = new Keyboard(__recorder.recordWsEvent);
__mouse = new Mouse(__getResolution, __recorder.recordWsEvent); __mouse = new Mouse(__getResolution, __recorder.recordWsEvent);
@ -98,7 +95,6 @@ export function Hid(__getResolution) {
if (!ws) { if (!ws) {
self.setState(null); self.setState(null);
} }
__recorder.setSocket(ws);
__keyboard.setSocket(ws); __keyboard.setSocket(ws);
__mouse.setSocket(ws); __mouse.setSocket(ws);
}; };

View File

@ -217,7 +217,7 @@ export function Recorder() {
} }
}, event.event.text, "text/plain"); }, event.event.text, "text/plain");
return; return;
} else if (["key", "mouse_button", "mouse_move", "mouse_wheel"].includes(event.event_type)) { } else if (["key", "mouse_button", "mouse_move", "mouse_wheel", "gpio_switch", "gpio_pulse"].includes(event.event_type)) {
__ws.send(JSON.stringify(event)); __ws.send(JSON.stringify(event));
} }
index += 1; index += 1;

View File

@ -26,6 +26,7 @@
import {tools, $} from "../tools.js"; import {tools, $} from "../tools.js";
import {wm} from "../wm.js"; import {wm} from "../wm.js";
import {Recorder} from "./recorder.js";
import {Hid} from "./hid.js"; import {Hid} from "./hid.js";
import {Atx} from "./atx.js"; import {Atx} from "./atx.js";
import {Msd} from "./msd.js"; import {Msd} from "./msd.js";
@ -44,10 +45,11 @@ export function Session() {
var __missed_heartbeats = 0; var __missed_heartbeats = 0;
var __streamer = new Streamer(); var __streamer = new Streamer();
var __hid = new Hid(__streamer.getResolution); var __recorder = new Recorder();
var __hid = new Hid(__streamer.getResolution, __recorder);
var __atx = new Atx(); var __atx = new Atx();
var __msd = new Msd(); var __msd = new Msd();
var __gpio = new Gpio(); var __gpio = new Gpio(__recorder.recordWsEvent);
var __init__ = function() { var __init__ = function() {
__startSession(); __startSession();
@ -227,6 +229,7 @@ export function Session() {
tools.debug("Session: socket opened:", event); tools.debug("Session: socket opened:", event);
$("link-led").className = "led-green"; $("link-led").className = "led-green";
$("link-led").title = "Connected"; $("link-led").title = "Connected";
__recorder.setSocket(__ws);
__hid.setSocket(__ws); __hid.setSocket(__ws);
__missed_heartbeats = 0; __missed_heartbeats = 0;
__ping_timer = setInterval(__pingServer, 1000); __ping_timer = setInterval(__pingServer, 1000);
@ -272,6 +275,7 @@ export function Session() {
__gpio.setState(null); __gpio.setState(null);
__hid.setSocket(null); __hid.setSocket(null);
__recorder.setSocket(null);
__atx.setState(null); __atx.setState(null);
__msd.setState(null); __msd.setState(null);
__streamer.setState(null); __streamer.setState(null);