Skip to content

InseeFr/Kraftwerk

Repository files navigation

Coverage Status

Kraftwerk logo

Kraftwerk

🇬🇧

Kraftwerk is a Java Spring application designed to validate and process data from multimode surveys, to generate data tables ready-to-use for statistical purposes. It heavily relies on metadata described using the DDI standard. The automated processes can be enriched with specification written in VTL, thanks to Trevas implementation.

Developer documentation can be found in the wiki.

User documentation and functional tests are still in an inhouse project.

Requirements

  • JDK 21 +
  • Maven 3.6 +

Kraftwerk uses Lombok.

Launch

If no argument is specified in the java -jar command, Kraftwerk will launch as a REST API. Otherwise, it will launch on batch mode and apply treatments on one campaign with the specified arguments. The required arguments for batch mode are as follows (in order) :

  1. Service to use (MAIN,FILEBYFILE,GENESIS,LUNATIC_ONLY)
  2. Archive at end of execution (false or true)
  3. Integrate all reporting datas (false or true)
  4. Campaign name

🇫🇷

Kraftwerk est une application Java Spring conçue pour valider et traiter des données provenant d'enquêtes multimodes, afin de générer des tableaux de données prêts à être utilisés à des fins statistiques. Elle s'appuie fortement sur les métadonnées décrites à l'aide de la norme DDI. Les processus automatisés peuvent être enrichis par des spécifications écrites en VTL, grâce à l'implémentation de Trevas.

La documentation destinée aux développeurs est disponible sur le wiki.

La documentation utilisateur et les tests fonctionnels sont encore dans un projet interne.

Configuration requise

  • JDK 21 +
  • Maven 3.6 +

Kraftwerk utilise Lombok.

Lancement

Si aucun paramètre n'est spécifié dans la commande java -jar, Kraftwerk se lancera en tant qu'API REST. Sinon, il va se lancer en mode batch et appliquer les traitements sur une campagne avec les paramètres spécifiés. Les paramètres requis pour le mode batch sont les suivants (dans l'ordre) :

  1. Service à utiliser (MAIN,FILEBYFILE,GENESIS,LUNATIC_ONLY)
  2. Archiver à la fin de l'exécution (false ou true)
  3. Integrate all reporting datas (false ou true)
  4. Nom de la campagne