Vidocq MicroProfile

MicroProfile · Java 25 · AI-augmented development · 100% European

Vidocq

A 100% sovereign European stack — zero external dependencies, zero inherited CVEs, full technological independence. Strict JPMS module isolation closes the door on reflection attacks and classpath pollution, making Vidocq the first Java framework that is jlink- and jpackage-ready out of the box.

Six constraints. One runtime.

Every design decision in the Vidocq ecosystem flows from the same set of rules, applied consistently across all fifteen projects.

JPMS-native

Every module ships a module-info.java. Minimal exports, no unjustified opens, no classpath fallback, no split packages.

Virtual threads throughout

All I/O paths run on virtual threads. No platform thread pool without a documented reason.

Static code generation

The Class-File API (JEP 484) and APT produce all metadata at compile time. No reflection, no dynamic proxies, no startup scanning.

Zero runtime deps

Production scope: only the Jakarta or MicroProfile spec artifact. No ASM, no Byte Buddy, no utility libraries.

Independent bricks

Fifteen self-contained projects, each with its own release cycle. Consume only the layers you need.

AOT-ready

GraalVM native and Leyden CDS work out of the box — no reflection config, no dynamic proxies to register.

Innovations

Beyond the core constraints, Vidocq ships capabilities you will not find in any other Java runtime.

Secured JARs (.sjar)

JPMS archives encrypted with AES-256. The exposed surface — public API and SPI packages — stays in the clear so consumers compile and link normally; everything else is ciphered at rest, protecting your intellectual property and shrinking the attack surface.

JAR enrichment plugins

Vauban and Vidocq plugins can enrich external JARs — adding CDI metadata, indexes, and generated glue to third-party libraries that were never built for the ecosystem, without touching their source.

Hot reload

A first-class hot-reload mode reflects code and configuration changes live, keeping the inner development loop tight without restarting the runtime.

Architecture

Four layers. No circular dependencies.

The dependency graph is strictly layered. Foundational bricks carry no inter-dependency. Jakarta layers compose them. MicroProfile implementations sit on top. The orchestrator wires everything through an extension SPI.

Orchestrator
vidocq Extension SPI · packaging · runtime wiring
Persistence
mansart Jakarta Data 1.0 · Transactions 2.0 · JDBC pool · H2 / PostgreSQL
MicroProfile
heisenberg Fault Tolerance 4.1 cervantes JWT 2.1 cyrano Rest Client 4.0 dirac Metrics 5.1 grimm OpenAPI 4.1 humboldt Telemetry 2.1 knock Health 4.0
Jakarta EE
foy Servlet 6.1 cassini REST 4.0
Foundation
chappe HTTP/1.1 · H2 · WS · gRPC vauban CDI 4.1 champollion JSON · Protobuf ravel Config

The people behind Vidocq

Vidocq was initiated by two long-time members of the Java, Jakarta EE and MicroProfile communities.

Yann Blazart

Yann Blazart

Creator & lead · Senior Tech Lead @ SCIAM

In the Java world since the early 2000s and a long-standing advocate of Jakarta EE, MicroProfile and CDI. Co-creator of LangChain4j-CDI. Senior Tech Lead at SCIAM since 2019, with past contributions to TomEE, JAX-WS (Metro) and WicketExtJS.

Antoine Sabot-Durand

Antoine Sabot-Durand

Co-initiator · Java Champion · Consultant @ SCIAM

Java Champion and former CDI specification lead. Member of the Quarkus launch team at Red Hat and contributor to MicroProfile (Fault Tolerance, Health) and Jakarta EE.

From the blog

Engineering notes, release updates, and implementation deep-dives from the Vidocq ecosystem.

All posts

Get involved

Contributions are welcome at every layer — from TCK coverage to implementing a new MicroProfile specification.

The contributing guide covers prerequisites (Java 25, Maven 4, SDKMAN), JPMS conventions, the zero-deps rule, virtual-thread patterns, and the PR workflow.

Contributing guide