Socket
Book a DemoInstallSign in
Socket

@odyssee/imqfe

Package Overview
Dependencies
Maintainers
1
Versions
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@odyssee/imqfe

Flow Engine & In Memory Queue

latest
npmnpm
Version
1.0.0
Version published
Weekly downloads
1
Maintainers
1
Weekly downloads
 
Created
Source

@odyssee-software/imqfe

Flow Engine & In-Memory Queue
Un moteur de workflows JSON et une file d’attente en mémoire pour orchestrer des tâches synchrones et asynchrones avec gestion des dépendances.

Fonctionnalités principales

  • Exécution parallèle et séquentielle de tâches
  • Gestion des dépendances entre tâches (inputs/outputs)
  • Flows JSON paramétrables et réutilisables
  • Résolveurs intégrés (Echo, Noop, ThrowError, Conditional, Wait, etc.)
  • Ajout de tâches dynamiquement
  • Système de plugins et d’actions personnalisées
  • File d’attente en mémoire (MQ) pour la gestion des jobs, résultats, événements et callbacks
  • API simple pour l’intégration et les tests

Installation

npm install @odyssee-software/imqfe

Utilisation rapide

1. Création d’un flow simple

Pour une introduction détaillée à la création et l’utilisation des flows, consultez le guide des flows.

import { FlowProducer } from '@odyssee-software/imqfe';

const flow = new FlowProducer();

flow.add('echoTask', {
  provides: ['output1'],
  requires: [],
  resolver: {
    name: 'flowher::Echo',
    params: { in: 'Hello World!' },
    results: { out: 'output1' }
  }
});

const result = await flow.run(
  {},                // paramètres d’entrée
  ['output1'],       // outputs attendus
  {},                // actions personnalisées (optionnel)
  {}                 // contexte (optionnel)
);

console.log(result); // [{ output1: 'Hello World!' }]

2. Utilisation des résolveurs intégrés

  • flowher::Echo : Retourne la valeur passée en entrée
  • flowher::Noop : Ne fait rien, retourne un objet vide
  • flowher::ThrowError : Lève une erreur personnalisée
  • flowher::Conditional : Retourne un résultat selon une condition
  • flowher::Wait : Attend un délai avant de retourner un résultat

Voir src/resolver-registry.ts pour la liste complète.

File d’attente en mémoire (MQ)

Le module MQ permet de gérer des files de jobs, leur exécution, le suivi d’état, les événements et les résultats, le tout en mémoire.

Pour une explication complète et des exemples avancés, consultez le guide MQ.

Exemple minimal

import { MQ, WorkerController } from '@odyssee-software/imqfe';

const queue = new MQ({ name: 'ma-queue' });

const workerFactory = WorkerController(async ({ value }) => {
  // Traitement asynchrone ici
  return value * 2;
}, { value: 21 });

queue.enqueue(workerFactory);

queue.start(() => {
  // Callback à la fin de la queue
  console.log('Tous les jobs sont terminés');
});

Suivi des jobs et gestion des événements

const [worker] = queue.enqueue(workerFactory);

worker.on('success', (job) => {
  console.log('Job terminé avec succès:', job.data);
});

worker.on('error', (job) => {
  console.error('Erreur dans le job:', job.error);
});

worker.follow((step, error, result) => {
  console.log('Étape:', step, 'Résultat:', result, 'Erreur:', error);
});

Pour plus de détails, voir src/mq.ts.

API Principale

FlowProducer (src/mq-flow.ts)

  • constructor(specs?) : Initialise un flow avec des tâches optionnelles
  • add(taskName, taskSpec) : Ajoute une tâche au flow
  • run(params, expectedOutputs, actions?, context?) : Exécute le flow et retourne les résultats attendus

Pour plus d’informations et d’exemples, consultez le guide des flows.

MQ (src/mq.ts)

  • enqueue(...workers) : Ajoute un ou plusieurs jobs à la file
  • dequeue(jobId) : Retire un job de la file par son identifiant
  • job(jobId) : Récupère un job par son identifiant
  • start(callback?) : Démarre l’exécution de la file
  • Gestion des événements : on('success'|'error'|'start'|'end', callback)
  • Suivi d’un job : worker.follow(callback)

Pour des cas d’usage avancés, voir le guide MQ.

WorkerController (src/mq.ts)

  • Permet de créer des workers personnalisés avec gestion des propriétés, du suivi, des événements et des dépendances.

Tests

Lance tous les tests unitaires :

npm test

Un rapport Markdown est généré dans test-reports/test-report.md.

Documentation

Licence

Distribué sous licence GNU GPL v3. Voir le fichier LICENSE.

Auteur

Keywords

workflow

FAQs

Package last updated on 29 Jun 2025

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts