Institutional Bridge: Compiling TNO FLINT (Regels als Code) into ODGS Executable Rules.
Project description
ODGS FLINT Bridge
The ODGS FLINT Bridge is an open-source institutional connector that translates TNO FLINT (Formal Language for the Interpretation of Normative Texts) Linked Data into ODGS Executable Enforcement Rules.
It bridges the semantic legal ontology layer with the ODGS enforcement engine — connecting "Rules as Code" (Regels als Code) ecosystems to live data pipelines.
Install
pip install odgs-flint-bridge
CLI
After install, the odgs-flint command is available:
# Compile a FLINT JSON-LD file and print the rule
odgs-flint sample_flint.json
# Compile and save to a file
odgs-flint sample_flint.json --output my_rule.json
# Compact output (no indentation)
odgs-flint sample_flint.json --compact
On file save, the CLI prints a summary:
Rule written to my_rule.json
semantic_hash: a3f8c2d1...
urn: urn:odgs:rule:flint:zorgtoeslag_art5_p1
effective_from: 2026-01-01 (if declared in flint:period)
Python API
from odgs_flint_bridge.parser import FlintParser
from odgs_flint_bridge.compiler import OdgsCompiler
# Load your FLINT JSON-LD payload
flint_payload = {
"@type": "flint:Fact",
"flint:identifier": "urn:flint:fact:zorgtoeslag:art5:p1",
"flint:name": "Zorgtoeslag Threshold",
"flint:sourceReference": "https://wetten.overheid.nl/BWBR0018988/",
"flint:expression": {
"flint:subject": "inkomen",
"flint:operator": "LESS_THAN_OR_EQUAL",
"flint:targetValue": 35000
}
}
# Parse → Compile (FlintParser.parse() auto-routes by @type)
parsed = FlintParser.parse(flint_payload)
rule = OdgsCompiler.compile_rule(parsed)
print(rule["semantic_hash"]) # SHA-256 of the source FLINT JSON-LD
print(rule["urn"]) # urn:odgs:rule:flint:zorgtoeslag_art5_p1
The compiled rule is ready to load directly into the ODGS enforcement engine:
from odgs.executive.interceptor import OdgsInterceptor
engine = OdgsInterceptor(rules=[rule])
engine.intercept("urn:odgs:custom:myprocess", {"inkomen": 40000})
What It Does
- Parses all six FLINT types —
flint:Fact,flint:Duty,flint:Act,flint:Source,flint:Reference,flint:Violationfrom any TNO FLINT source (wetten.overheid.nl, Choppr, EUR-Lex, etc.) - Computes
semantic_hash— Auto-generates a SHA-256 of the verbatim source payload, logged on every enforcement event — a tamper-evident link from decision back to law. - Extracts rule lifecycle —
flint:Dutypayloads with aflint:periodproduceeffective_from/effective_tobounds, enforced by the ODGS engine. - Type-specific rule shapes — Each FLINT type compiles to the right ODGS severity:
HARD_STOPfor facts/duties/violations,ACT_CONSTRAINTfor acts,METADATA_ONLYfor sources,LOG_ONLYfor references. - Human-readable audit fields —
plain_english_description(fromflint:description) andnon_conformance_message(fromflint:salvageClause) surface directly in S-Cert audit logs.
The Architecture
flowchart LR
subgraph legislative["⚖️ Legislative Plane"]
A["wetten.overheid.nl\nChoppr / TNO FLINT Tools"]
B["FLINT JSON-LD\nflint:Fact · flint:Duty · flint:Act\nflint:Source · flint:Reference · flint:Violation"]
A --> B
end
subgraph bridge["🔗 ODGS FLINT Bridge ← you are here"]
C["FlintParser\nDeserialise JSON-LD"]
D["OdgsCompiler\nCompute semantic_hash\nExtract temporal bounds"]
B --> C --> D
end
subgraph engine["⚙️ ODGS Enforcement Engine"]
E["OdgsInterceptor\npip install odgs"]
F["S-Cert Audit Log\nevent_id · semantic_hash\npayload_hash · verdict"]
D --> E --> F
end
subgraph exec["🗄️ Live Data Pipeline"]
G["Databricks"]
H["Snowflake"]
I["AI Agent / API"]
E --> G & H & I
end
style legislative fill:#E8F4FD,stroke:#2196F3,color:#000
style bridge fill:#FFF3E0,stroke:#FF9800,color:#000
style engine fill:#E8F5E9,stroke:#4CAF50,color:#000
style exec fill:#F3E5F5,stroke:#9C27B0,color:#000
Enterprise
This package emits rules with semantic_hash: "auto-computed" — the SHA-256 is derived locally from the source payload. For Registry-attested hashing with sovereign Ed25519 signing (required for EU AI Act liability indemnification), upgrade to the Metric Provenance enterprise tier.
👉 Sovereign Registry & Enterprise Law Packs
Licensed under the Apache License 2.0.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file odgs_flint_bridge-0.3.0.tar.gz.
File metadata
- Download URL: odgs_flint_bridge-0.3.0.tar.gz
- Upload date:
- Size: 16.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b66edf162612aca1940a9cb1f87644adc6041e3c4cb5959191534fe378ee68cc
|
|
| MD5 |
02083e0b64ca52de57dd3c82f96a6e77
|
|
| BLAKE2b-256 |
db622e4d0d53122773f30477772832bb78ca24a320963e28451eb41c149bcc54
|
File details
Details for the file odgs_flint_bridge-0.3.0-py3-none-any.whl.
File metadata
- Download URL: odgs_flint_bridge-0.3.0-py3-none-any.whl
- Upload date:
- Size: 11.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f0f9b4433174f0ecc5d74792c60d7f07fbf4313ba7242892b711ede10c772027
|
|
| MD5 |
6e6684f3f10b1ca1567f66642bddf341
|
|
| BLAKE2b-256 |
0fc1844b41d760de460987e86ce0b9b7af3daa9698f1edf8a9ede8949a318efc
|