1.3.2 • Published 1 month ago

cm-idempotencia v1.3.2

Weekly downloads
-
License
UNLICENSED
Repository
-
Last release
1 month ago

cm-idempotencia

Librería para implementar fácilmente el modelo de idempotencia en una api hecha en fastify.

Instalación

yarn add cm-idempotencia

Implementación

Importar el método handler de cm-idempotencia y definir los valores asi:

import { handler } from 'cm-idempotencia';

const exampleRouteHandler = handler({
    serviceName: 'cm-service-example-name',
    keyId: 'process_id',
    isPubsub: true,
});

Implementación de las dependencias de la librería

Buscar la función en nuestro código donde se tenga implementado el servidor (Express, Fastify, etc). Y llamar la función dependenciasIdempotencia(), se puede llamar en cualquier parte de la ejecución del flujo de la aplicación, la idea principal es que se ejecute siempre que inicia nuestro servidor.

Ejemplo Fastify

import { application } from './Application';
import { createDependencyContainer } from '@configuration';
import { dependenciasIdempotencia } from 'cm-idempotencia'; //Importar la funcion desde la libreria
import { ENV } from '@util';

const start = async () => { // Iniciar el servidor
    const port = ENV.PORT;
    try {
        const server = await application.listen(port, '0.0.0.0');
        createDependencyContainer();
        dependenciasIdempotencia(); //Llamar la funcion mencionada despues de iniciar el servidor
        console.log(`Application running on ${server}`);
    } catch (error) {
        console.error(error);
        await application.close();
    } 
};
start(); 

Campos

  • serviceName: Nombre del servicio, esto sera usado como nombre de la colección dentro de la instancia de redis. Se puede pasar cualquier nombre pero se recomienda que sea el nombre del servicio para envitar conflictos en caso de que la instancia de redis sea compartida.
  • keyId: El nombre de la propiedad que contiene el identificador de la petición, el nombre que se le pase tiene que existir en el body de la petición. Siguiendo este ejemplo, en el body tiene que existir un campo process_id que contiene el un identificador único de la petición, de lo contrario habrá un error.
  • isPubsub: En caso que sea por un topic de PubSub.

Después cuando se defina la ruta se utiliza el handler de esta manera:

application.post(`/example-route`, exampleRouteHandler, exampleRoute);

NOTA:

Se debe tener una instancia de redis lista para que la libreria pueda funcionar. Definir como variables de entorno los siguientes valores: REDIS_HOST y REDIS_PORT

REDIS_CONNECTION_LOCAL_ENV

Esta es una variable de entorno que debe ser definida, su valor es boleano y será true cuando el redis a utilizar este definido localmente, ósea dentro del mismo contenedor de docker de la aplicación (docker compose). A continuación un ejemplo:

Archivo docker-compose.yml

version: '3.7'
services:
    redis:
        image: redis:7.0.4
        restart: always
        command: redis-server --bind 0.0.0.0

En este caso el redis esta definido en el docker-compose, en el mismo archivo estará definido el contenedor de nuestra aplicación. REDIS_CONNECTION_LOCAL_ENV tendrá un valor de true y hará referencia al contenedor de redis llamado redis la conexión será automática.

Si el redis es externo y necesitamos el REDIS_HOST y REDIS_PORT entonces REDIS_CONNECTION_LOCAL_ENV tendrá un valor de false

1.3.2

1 month ago

1.3.1

1 month ago

1.2.6

10 months ago

1.2.5

10 months ago

1.3.0

9 months ago

1.2.0

1 year ago

1.2.4

1 year ago

1.2.3

1 year ago

1.2.2

1 year ago

1.2.1

1 year ago

1.1.2

1 year ago

1.1.1

1 year ago

1.1.0

1 year ago

1.0.0

1 year ago