1 vim: set ts=4 sw=4 tw=80:
4 Propuesta de servidor v0.1:
6 El servidor estará dividido en 2 módulos que provean 2 servicios diferentes:
8 El módulo de control se basa en el protocolo TCP y se encarga de listar
9 los archivos de planta disponibles en el servidor, permitiendo cambiar
10 las propiedades de cada uno y conocer su estado en términos generales
11 (si se está simulando o no). Todo lo que sean comandos (abrir una
12 exclusa, parar una bomba, etc) se realizan a través de este módulo.
13 El protocolo que maneja es un HTTP simplificado. Se aceptan comandos
14 simples (en un principio solo GET) a través de URLs.
16 Obtiene lista de archivos:
18 Cierra la <exclusa1> de la planta <archivo>:
19 GET /<archivo>/set/<exclusa1>?cerrar HTTP/1.0
20 Pone el <caudal> de <canio1> en 3 l/s:
21 GET /<archivo>/set/<canio1>?caudal=3 HTTP/1.0
22 Comienza la simulación de la planta <archivo>:
23 GET /<archivo>/start HTTP/1.0
24 Empieza a transmitir a host:port la simulación de la planta <archivo>:
25 GET /<archivo>/connect?host=localhost&port=1234 HTTP/1.0
26 Deja de transmitir a host:port la simulación de la planta <archivo>:
27 GET /<archivo>/disconnect?host=localhost&port=1234 HTTP/1.0
29 Los datos que envía este módulo están en formato XML, preferentemente con
30 un archivo de transformación XSLT (o como se llame :) para que pueda ser
31 visto en un browser cualquiera (que soporte esto, como Mozilla).
33 2) Módulo de transmisión:
34 Este módulo se encarga de transmitir la simulación en tiempo real por UDP
35 (como si fuera un video). Comienza luego de que el módulo de control recibe
36 una petición de transmisión (con connect) y continúa transmitiendo (en un
37 thread propio) hasta que recibe un disconnect. Envía un archivo XML con el
38 estado de la planta. En este caso no tiene sentido la XSLT porque no hay
39 browsers HTTP que usen UDP :).
40 El cliente debe validar lo recibido y mostrar todos los 'frames' válidos.
41 Mientras que no se reciban 'frames' válidos se debe mostrar el último
42 válido. Si no se recibiece durante una cantidad de tiempo determinada ningún
43 'frame' válido, se asume un error en la red.
44 Si por casualidad los datos recibidos son incorrectos pero válidos (por
45 ejemplo, se recibe el comienzo de un 'frame' y el final del siguente), el
46 cliente lo mostrará igual porque no tiene forma de darse cuenta. Esto no es
47 problema si consideramos que en pocos milisegundos se recibirá un nuevo
48 'frame' válido y correcto (similar a lo que pasa en transmisiones de audio o
49 video en tiempo real).
51 Opcionalmente se puede hacer un Módulo de transmición sobre TCP, que sólo envíe
52 el estado actual de la planta en ese instante y se desconecte, o directamente
53 implementarlo como un comando del módulo de control para poder verlo en un
54 browser. Aunque esto ya sería más un cliente que un servidor :)