> For the complete documentation index, see [llms.txt](https://navixy.com/docs/llms.txt). Markdown versions of documentation pages are available by appending `.md` to page URLs; this page is available as [Markdown](https://navixy.com/docs/expert-center/es/faq-and-troubleshooting/iot-logic/how-to-implement-event-driven-scheduling-using-unix-time-in-iot-logic.md).

# Cómo implementar la programación basada en eventos usando la hora Unix en IoT Logic

En esta sección, configuraremos un temporizador en IoT Logic para controlar la activación de salidas en los dispositivos. Esto funcionará como un programador al utilizar la hora Unix para el control basado en tiempo.

<figure><img src="/files/c77c8689ffb41f204fc8add777c7ab9f004fe409" alt=""><figcaption></figcaption></figure>

Primero, la lógica del programador se construyó basándose en la hora Unix, ya que es el único parámetro fiable y consistente en el que siempre podemos confiar. El segundo elemento clave es la marca de tiempo de los paquetes válidos recibidos por la plataforma.\
Es importante señalar que esta lógica requiere que el dispositivo envíe continuamente paquetes de datos válidos a la plataforma. La frecuencia en sí no es crítica; sin embargo, si no se reciben mensajes entrantes, resulta imposible evaluar el tiempo o activar cualquier acción programada.

\
Ahora, pasando al nodo de cálculo del atributo de lógica implementada.\
Este nodo recupera:

* La hora actual del evento (current\_time) del paquete más reciente
* La hora anterior del evento (prev\_time) del paquete anterior

Ambos valores se convierten de milisegundos a segundos.<br>

Es importante señalar que **genTime** se proporciona en hora Unix (milisegundos) y debe dividirse entre 1000 para obtener la hora Unix en segundos, que es el formato que utilizaremos para todos los cálculos.

\
A partir de estos, el sistema calcula:

* current\_sod (segundos del día)
* prev\_sod (segundos del día para el paquete anterior)

Esto se hace utilizando la operación módulo, que extrae la cantidad de segundos transcurridos desde medianoche, convirtiendo de hecho la hora Unix en una referencia de hora del día.

<pre><code><strong>time % 86400
</strong></code></pre>

Puede observarse un desplazamiento horario en estas fórmulas. Este desplazamiento está determinado por la zona horaria UTC en la que se realizan los cálculos.

En el escenario de prueba, los cálculos se realizaron en UTC -6, lo que dio como resultado una diferencia de 6 horas. Al convertirlo a segundos, esto equivale a:\
6 horas × 60 min × 60 seg = 21.600 segundos.

{% code overflow="wrap" %}

```
current_sod = (current_time - offset_time) % 86400
prev_sod = (prev_time - offset_time) % 86400
```

{% endcode %}

\
Usando estos valores, el sistema detecta transiciones de tiempo, no estados continuos.

\
Por ejemplo:

* Condición de encendido (p. ej., 20:00): El sistema comprueba cuándo el tiempo cruza el umbral:

  <pre data-overflow="wrap"><code>prev_sod &#x3C; 72000 AND current_sod >= 72000
  </code></pre>
* Condición de apagado (p. ej., 5:00):

  <pre data-overflow="wrap"><code>prev_sod &#x3C; 18000 AND current_sod >= 18000
  </code></pre>

Esto garantiza que la acción se active solo una vez en el momento de la transición, en lugar de hacerlo continuamente durante toda la ventana de tiempo.

\
Una vez que se cumple la lógica, el nodo de acción activará el comando de salida para cambiar el estado de la salida.\
A lo largo de este flujo pueden surgir algunas limitaciones, y es importante destacarlas para que puedan tenerse en cuenta:<br>

* **Dependiente de los datos entrantes:**

Si el dispositivo deja de enviar datos, no se activará ninguna acción. Por eso se requiere una supervisión continua de la unidad. Si el dispositivo está desconectado, bloqueado o en modo de suspensión sin enviar datos válidos, el cambio de estado nunca se detectará.<br>

* **Sin garantía de ejecución exacta en el tiempo:**

Las acciones se ejecutan cuando llega el siguiente paquete de datos después de que se alcanza el umbral, no exactamente en el momento programado. Por ejemplo, si el dispositivo informa cada 5 minutos y el último paquete se recibió a las 20:58, el siguiente mensaje llegará a las 21:03. En ese momento, la lógica se cumplirá y se activará la acción (p. ej., activación de salida).<br>

* **Se requiere gestión de la zona horaria:**

Como la hora Unix está en UTC, debe aplicarse un desplazamiento para alinearla con la hora local deseada.<br>

* **Sin estado de programación persistente:**

El sistema no almacena tiempos futuros de activación; depende por completo de comparaciones en tiempo real entre paquetes entrantes consecutivos.

Esta solución simula un programador en un sistema basado en eventos mediante el uso de marcas de tiempo Unix y la detección de transiciones de tiempo entre paquetes de datos consecutivos. Aunque no es un verdadero programador, proporciona una forma fiable y escalable de implementar automatización basada en el tiempo sin requerir compatibilidad nativa con la programación.


---

# Agent Instructions
This documentation is published with GitBook. GitBook is the documentation platform designed so that both humans and AI agents can read, navigate, and reason over technical content effectively. Learn more at gitbook.com.

## Querying This Documentation
If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter, and the optional `goal` query parameter:

```
GET https://navixy.com/docs/expert-center/es/faq-and-troubleshooting/iot-logic/how-to-implement-event-driven-scheduling-using-unix-time-in-iot-logic.md?ask=<question>&goal=<endgoal>
```

`ask` is the immediate question: it should be specific, self-contained, and written in natural language.
`goal` is optional and describes the broader end goal you are ultimately trying to accomplish on behalf of the user. GitBook uses it to tailor the answer towards what is most useful for that goal.

The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
