feat(db): add regulation-as-data tables for license height and horse age matrices
- Introduced `license_height_matrix` for mapping minimum license requirements to jump heights (ÖTO § 231). - Added `horse_min_age_matrix` for defining minimum horse ages by discipline, height, or level (ÖTO § 103, FEI GR Art. 136). - Populated both tables with ÖTO 2026 and FEI-compliant seed data. - Updated Flyway V008 to remove incorrect `RD4` entry and annotated corrected enum references. - Created Flyway V009 for introducing the new tables and their seeds. - Aligned documentation, validation rules, and roadmaps for backend implementation handover. Signed-off-by: Stefan Mogeritsch <stefan.mo.co@gmail.com>
This commit is contained in:
parent
1f9f528554
commit
c696b8c50e
|
|
@ -1,5 +1,7 @@
|
||||||
-- V008: Seed OETO 2026 Data (Turnierklassen, Lizenz-Matrix, Altersklassen)
|
-- V008: Seed OETO 2026 Data (Turnierklassen, Lizenz-Matrix, Altersklassen)
|
||||||
-- Basierend auf ÖTO 2026
|
-- Basierend auf ÖTO 2026
|
||||||
|
-- Lizenz-Keys entsprechen LizenzKlasseE-Enum (core-domain): LIZENZFREI, R1, R2, R3, R4, RD1, RD2, RD3
|
||||||
|
-- HINWEIS: RD4 existiert NICHT im Enum – nur RD1/RD2/RD3 sind gültige Dressur-Lizenzen (ÖTO 2026)
|
||||||
|
|
||||||
-- 1. Turnierklassen (Springen & Dressur)
|
-- 1. Turnierklassen (Springen & Dressur)
|
||||||
INSERT INTO turnierklasse (turnierklasse_id, sparte, code, bezeichnung, max_hoehe, aufgaben_niveau)
|
INSERT INTO turnierklasse (turnierklasse_id, sparte, code, bezeichnung, max_hoehe, aufgaben_niveau)
|
||||||
|
|
@ -33,8 +35,7 @@ INSERT INTO license_matrix (license_id, sparte, lizenz_klasse, max_turnierklasse
|
||||||
VALUES ('00000000-0000-0000-0002-000000000001', 'DRESSUR', 'LIZENZFREI', 'E'),
|
VALUES ('00000000-0000-0000-0002-000000000001', 'DRESSUR', 'LIZENZFREI', 'E'),
|
||||||
('00000000-0000-0000-0002-000000000002', 'DRESSUR', 'RD1', 'L'),
|
('00000000-0000-0000-0002-000000000002', 'DRESSUR', 'RD1', 'L'),
|
||||||
('00000000-0000-0000-0002-000000000003', 'DRESSUR', 'RD2', 'M'),
|
('00000000-0000-0000-0002-000000000003', 'DRESSUR', 'RD2', 'M'),
|
||||||
('00000000-0000-0000-0002-000000000004', 'DRESSUR', 'RD3', 'S'),
|
('00000000-0000-0000-0002-000000000004', 'DRESSUR', 'RD3', 'S');
|
||||||
('00000000-0000-0000-0002-000000000005', 'DRESSUR', 'RD4', 'S');
|
|
||||||
|
|
||||||
-- 3. Altersklassen (Standard ÖTO)
|
-- 3. Altersklassen (Standard ÖTO)
|
||||||
INSERT INTO altersklasse (id, altersklasse_code, bezeichnung, min_alter, max_alter)
|
INSERT INTO altersklasse (id, altersklasse_code, bezeichnung, min_alter, max_alter)
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,185 @@
|
||||||
|
-- V009: Regulation-as-Data – Höhen-Lizenz-Matrix (Springen) & Mindestalter-Pferd-Matrix
|
||||||
|
-- Basierend auf ÖTO 2026 (§ 231 Springen, § 103 Dressur) und FEI GR Art. 136
|
||||||
|
-- Lizenz-Keys entsprechen LizenzKlasseE-Enum (core-domain): LIZENZFREI, R1, R2, R3, R4, RD1, RD2, RD3
|
||||||
|
-- Status: DRAFT – wird auf STABLE angehoben nach Fachfreigabe durch ÖTO-Fachreferat
|
||||||
|
|
||||||
|
-- ─────────────────────────────────────────────────────────────────────────────
|
||||||
|
-- 1. Tabelle: license_height_matrix
|
||||||
|
-- Zweck: Welche Lizenzklassen sind für einen Höhenbereich (Springen) erlaubt?
|
||||||
|
-- Granularität: Eine Zeile pro (Höhenbereich × erlaubte Lizenzklasse).
|
||||||
|
-- Abfrage-Pattern: SELECT lizenz_klasse FROM license_height_matrix
|
||||||
|
-- WHERE sparte = 'SPRINGEN'
|
||||||
|
-- AND hoehe_von_cm <= :hoehe AND hoehe_bis_cm >= :hoehe
|
||||||
|
-- AND ist_aktiv = true
|
||||||
|
-- ─────────────────────────────────────────────────────────────────────────────
|
||||||
|
CREATE TABLE IF NOT EXISTS license_height_matrix
|
||||||
|
(
|
||||||
|
id
|
||||||
|
UUID
|
||||||
|
PRIMARY
|
||||||
|
KEY
|
||||||
|
DEFAULT
|
||||||
|
gen_random_uuid
|
||||||
|
(
|
||||||
|
),
|
||||||
|
sparte VARCHAR
|
||||||
|
(
|
||||||
|
20
|
||||||
|
) NOT NULL,
|
||||||
|
hoehe_von_cm INTEGER NOT NULL,
|
||||||
|
hoehe_bis_cm INTEGER NOT NULL,
|
||||||
|
lizenz_klasse VARCHAR
|
||||||
|
(
|
||||||
|
20
|
||||||
|
) NOT NULL,
|
||||||
|
oeto_paragraph VARCHAR
|
||||||
|
(
|
||||||
|
50
|
||||||
|
),
|
||||||
|
bemerkung VARCHAR
|
||||||
|
(
|
||||||
|
255
|
||||||
|
),
|
||||||
|
valid_from TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||||
|
valid_to TIMESTAMP WITH TIME ZONE,
|
||||||
|
ist_aktiv BOOLEAN NOT NULL DEFAULT true,
|
||||||
|
created_at TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||||
|
updated_at TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP
|
||||||
|
);
|
||||||
|
|
||||||
|
CREATE INDEX idx_license_height_sparte_hoehe ON license_height_matrix (sparte, hoehe_von_cm, hoehe_bis_cm);
|
||||||
|
CREATE INDEX idx_license_height_lizenz ON license_height_matrix (lizenz_klasse);
|
||||||
|
|
||||||
|
-- ─────────────────────────────────────────────────────────────────────────────
|
||||||
|
-- 2. Tabelle: horse_min_age_matrix
|
||||||
|
-- Zweck: Mindestalter des Pferdes (Stichtag 1. Jänner) je Sparte + Klasse/Höhe.
|
||||||
|
-- Abfrage-Pattern: SELECT min_alter_jahre FROM horse_min_age_matrix
|
||||||
|
-- WHERE sparte = :sparte
|
||||||
|
-- AND (:hoehe IS NULL OR (hoehe_von_cm <= :hoehe AND hoehe_bis_cm >= :hoehe))
|
||||||
|
-- AND (:niveau IS NULL OR aufgaben_niveau = :niveau)
|
||||||
|
-- AND ist_aktiv = true
|
||||||
|
-- ─────────────────────────────────────────────────────────────────────────────
|
||||||
|
CREATE TABLE IF NOT EXISTS horse_min_age_matrix
|
||||||
|
(
|
||||||
|
id
|
||||||
|
UUID
|
||||||
|
PRIMARY
|
||||||
|
KEY
|
||||||
|
DEFAULT
|
||||||
|
gen_random_uuid
|
||||||
|
(
|
||||||
|
),
|
||||||
|
sparte VARCHAR
|
||||||
|
(
|
||||||
|
20
|
||||||
|
) NOT NULL,
|
||||||
|
hoehe_von_cm INTEGER,
|
||||||
|
hoehe_bis_cm INTEGER,
|
||||||
|
aufgaben_niveau VARCHAR
|
||||||
|
(
|
||||||
|
20
|
||||||
|
),
|
||||||
|
min_alter_jahre INTEGER NOT NULL,
|
||||||
|
oeto_paragraph VARCHAR
|
||||||
|
(
|
||||||
|
50
|
||||||
|
),
|
||||||
|
fei_artikel VARCHAR
|
||||||
|
(
|
||||||
|
50
|
||||||
|
),
|
||||||
|
bemerkung VARCHAR
|
||||||
|
(
|
||||||
|
255
|
||||||
|
),
|
||||||
|
valid_from TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||||
|
valid_to TIMESTAMP WITH TIME ZONE,
|
||||||
|
ist_aktiv BOOLEAN NOT NULL DEFAULT true,
|
||||||
|
created_at TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||||
|
updated_at TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP
|
||||||
|
);
|
||||||
|
|
||||||
|
CREATE INDEX idx_horse_age_sparte ON horse_min_age_matrix (sparte);
|
||||||
|
|
||||||
|
-- ─────────────────────────────────────────────────────────────────────────────
|
||||||
|
-- 3. Seed: license_height_matrix – Springen (CSN)
|
||||||
|
-- Quelle: ÖTO § 231 (Lizenz-Zuordnung nach Hindernishöhe)
|
||||||
|
-- Klassen: E0=60–95 cm, A=100–110 cm, L=115–120 cm, LM=125–130 cm, M=135 cm, S=140–160 cm
|
||||||
|
--
|
||||||
|
-- Regel: Höhere Lizenz darf immer in niedrigerer Klasse starten (Aufwärts-Kompatibilität).
|
||||||
|
-- Daher: R2 darf auch in E0/A starten – hier werden nur die MINDEST-Anforderungen je Bereich
|
||||||
|
-- abgebildet (= welche Lizenzen sind ZUGELASSEN, nicht welche sind OPTIMAL).
|
||||||
|
-- ─────────────────────────────────────────────────────────────────────────────
|
||||||
|
|
||||||
|
-- Klasse E0 (Einsteiger): 60–95 cm → LIZENZFREI und R1 zugelassen (CSN-C-NEU Zwangsteilung)
|
||||||
|
INSERT INTO license_height_matrix (sparte, hoehe_von_cm, hoehe_bis_cm, lizenz_klasse, oeto_paragraph, bemerkung)
|
||||||
|
VALUES ('SPRINGEN', 60, 95, 'LIZENZFREI', '§ 231 ÖTO', 'Abt. ohne Lizenz (CSN-C-NEU)'),
|
||||||
|
('SPRINGEN', 60, 95, 'R1', '§ 231 ÖTO', 'Abt. mit Lizenz (CSN-C-NEU)'),
|
||||||
|
('SPRINGEN', 60, 95, 'R2', '§ 231 ÖTO', 'Aufwärts-kompatibel'),
|
||||||
|
('SPRINGEN', 60, 95, 'R3', '§ 231 ÖTO', 'Aufwärts-kompatibel'),
|
||||||
|
('SPRINGEN', 60, 95, 'R4', '§ 231 ÖTO', 'Aufwärts-kompatibel');
|
||||||
|
|
||||||
|
-- Klasse A (Anfänger): 100–110 cm → ab R1 (keine LIZENZFREI mehr)
|
||||||
|
INSERT INTO license_height_matrix (sparte, hoehe_von_cm, hoehe_bis_cm, lizenz_klasse, oeto_paragraph, bemerkung)
|
||||||
|
VALUES ('SPRINGEN', 100, 110, 'R1', '§ 231 ÖTO', 'Mindestlizenz ab 100 cm'),
|
||||||
|
('SPRINGEN', 100, 110, 'R2', '§ 231 ÖTO', 'Aufwärts-kompatibel'),
|
||||||
|
('SPRINGEN', 100, 110, 'R3', '§ 231 ÖTO', 'Aufwärts-kompatibel'),
|
||||||
|
('SPRINGEN', 100, 110, 'R4', '§ 231 ÖTO', 'Aufwärts-kompatibel');
|
||||||
|
|
||||||
|
-- Klasse L (Leicht): 115–120 cm → ab R2 empfohlen; R1 noch zugelassen (ausschreibungsabhängig)
|
||||||
|
INSERT INTO license_height_matrix (sparte, hoehe_von_cm, hoehe_bis_cm, lizenz_klasse, oeto_paragraph, bemerkung)
|
||||||
|
VALUES ('SPRINGEN', 115, 120, 'R1', '§ 231 ÖTO', 'Zugelassen; Ausschreibung kann R2 vorschreiben'),
|
||||||
|
('SPRINGEN', 115, 120, 'R2', '§ 231 ÖTO', 'Empfohlene Mindestlizenz'),
|
||||||
|
('SPRINGEN', 115, 120, 'R3', '§ 231 ÖTO', 'Aufwärts-kompatibel'),
|
||||||
|
('SPRINGEN', 115, 120, 'R4', '§ 231 ÖTO', 'Aufwärts-kompatibel');
|
||||||
|
|
||||||
|
-- Klasse LM (Leicht-Mittel): 125–130 cm → ab R2
|
||||||
|
INSERT INTO license_height_matrix (sparte, hoehe_von_cm, hoehe_bis_cm, lizenz_klasse, oeto_paragraph, bemerkung)
|
||||||
|
VALUES ('SPRINGEN', 125, 130, 'R2', '§ 231 ÖTO', 'Mindestlizenz ab 125 cm'),
|
||||||
|
('SPRINGEN', 125, 130, 'R3', '§ 231 ÖTO', 'Aufwärts-kompatibel'),
|
||||||
|
('SPRINGEN', 125, 130, 'R4', '§ 231 ÖTO', 'Aufwärts-kompatibel');
|
||||||
|
|
||||||
|
-- Klasse M (Mittelschwer): 135 cm → ab R3
|
||||||
|
INSERT INTO license_height_matrix (sparte, hoehe_von_cm, hoehe_bis_cm, lizenz_klasse, oeto_paragraph, bemerkung)
|
||||||
|
VALUES ('SPRINGEN', 135, 135, 'R3', '§ 231 ÖTO', 'Mindestlizenz ab 135 cm'),
|
||||||
|
('SPRINGEN', 135, 135, 'R4', '§ 231 ÖTO', 'Aufwärts-kompatibel');
|
||||||
|
|
||||||
|
-- Klasse S (Schwer): 140–160 cm → R4
|
||||||
|
INSERT INTO license_height_matrix (sparte, hoehe_von_cm, hoehe_bis_cm, lizenz_klasse, oeto_paragraph, bemerkung)
|
||||||
|
VALUES ('SPRINGEN', 140, 160, 'R4', '§ 231 ÖTO', 'Mindestlizenz ab 140 cm (S-Klasse)');
|
||||||
|
|
||||||
|
-- ─────────────────────────────────────────────────────────────────────────────
|
||||||
|
-- 4. Seed: horse_min_age_matrix – Springen (national, ÖTO § 231)
|
||||||
|
-- ─────────────────────────────────────────────────────────────────────────────
|
||||||
|
INSERT INTO horse_min_age_matrix (sparte, hoehe_von_cm, hoehe_bis_cm, min_alter_jahre, oeto_paragraph, bemerkung)
|
||||||
|
VALUES ('SPRINGEN', 60, 100, 4, '§ 231 ÖTO', 'Mindestalter Pferd, Stichtag 1. Jänner'),
|
||||||
|
('SPRINGEN', 101, 120, 5, '§ 231 ÖTO', 'Mindestalter Pferd, Stichtag 1. Jänner'),
|
||||||
|
('SPRINGEN', 121, 999, 6, '§ 231 ÖTO', 'Mindestalter Pferd, Stichtag 1. Jänner');
|
||||||
|
|
||||||
|
-- ─────────────────────────────────────────────────────────────────────────────
|
||||||
|
-- 5. Seed: horse_min_age_matrix – Dressur (national, ÖTO § 103)
|
||||||
|
-- ─────────────────────────────────────────────────────────────────────────────
|
||||||
|
INSERT INTO horse_min_age_matrix (sparte, aufgaben_niveau, min_alter_jahre, oeto_paragraph, bemerkung)
|
||||||
|
VALUES ('DRESSUR', 'E', 4, '§ 103 ÖTO', 'Einsteiger/Dressurreiter, Stichtag 1. Jänner'),
|
||||||
|
('DRESSUR', 'A', 4, '§ 103 ÖTO', 'Klasse A, Stichtag 1. Jänner'),
|
||||||
|
('DRESSUR', 'L', 4, '§ 103 ÖTO', 'Klasse L, Stichtag 1. Jänner'),
|
||||||
|
('DRESSUR', 'LM', 5, '§ 103 ÖTO', 'Klasse LM/M, Stichtag 1. Jänner'),
|
||||||
|
('DRESSUR', 'M', 5, '§ 103 ÖTO', 'Klasse M, Stichtag 1. Jänner'),
|
||||||
|
('DRESSUR', 'S', 6, '§ 103 ÖTO', 'Klasse S, Stichtag 1. Jänner');
|
||||||
|
|
||||||
|
-- ─────────────────────────────────────────────────────────────────────────────
|
||||||
|
-- 6. Seed: horse_min_age_matrix – Springen international (FEI GR Art. 136)
|
||||||
|
-- ─────────────────────────────────────────────────────────────────────────────
|
||||||
|
INSERT INTO horse_min_age_matrix (sparte, aufgaben_niveau, min_alter_jahre, fei_artikel, bemerkung)
|
||||||
|
VALUES ('SPRINGEN_FEI', '1_STAR', 6, 'Art. 136 FEI GR', 'FEI Jumping 1*–2*'),
|
||||||
|
('SPRINGEN_FEI', '2_STAR', 6, 'Art. 136 FEI GR', 'FEI Jumping 1*–2*'),
|
||||||
|
('SPRINGEN_FEI', '3_STAR', 7, 'Art. 136 FEI GR', 'FEI Jumping 3*–5*'),
|
||||||
|
('SPRINGEN_FEI', '4_STAR', 7, 'Art. 136 FEI GR', 'FEI Jumping 3*–5*'),
|
||||||
|
('SPRINGEN_FEI', '5_STAR', 7, 'Art. 136 FEI GR', 'FEI Jumping 3*–5*');
|
||||||
|
|
||||||
|
-- ─────────────────────────────────────────────────────────────────────────────
|
||||||
|
-- 7. Seed: horse_min_age_matrix – Dressur international (FEI GR Art. 136)
|
||||||
|
-- ─────────────────────────────────────────────────────────────────────────────
|
||||||
|
INSERT INTO horse_min_age_matrix (sparte, aufgaben_niveau, min_alter_jahre, fei_artikel, bemerkung)
|
||||||
|
VALUES ('DRESSUR_FEI', 'CDI_SENIOR', 7, 'Art. 136 FEI GR', 'FEI Dressage CDI Senior'),
|
||||||
|
('DRESSUR_FEI', 'CDI_YH', 4, 'Art. 136 FEI GR', 'FEI Young Horse – gem. FEI YH-Regeln');
|
||||||
|
|
@ -172,6 +172,8 @@ enum class LizenzKlasseE {
|
||||||
/** Reiter-Lizenz Klasse 3 */
|
/** Reiter-Lizenz Klasse 3 */
|
||||||
R3,
|
R3,
|
||||||
|
|
||||||
|
/** Reiter-Lizenz Klasse 4 */
|
||||||
|
R4,
|
||||||
/** Dressur-Reiter Klasse 1 */
|
/** Dressur-Reiter Klasse 1 */
|
||||||
RD1,
|
RD1,
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,268 @@
|
||||||
|
---
|
||||||
|
type: BACKEND_SPEC
|
||||||
|
status: DRAFT
|
||||||
|
owner: Rulebook Expert
|
||||||
|
last_update: 2026-04-03
|
||||||
|
sprint: B-2
|
||||||
|
---
|
||||||
|
|
||||||
|
# B-2 Backend-Übergabe: Regulation-as-Data
|
||||||
|
|
||||||
|
> **Zweck:** Vollständige Spezifikation der Lizenz-/Altersmatrix als Regulation-as-Data für das Backend (
|
||||||
|
> Masterdata-SCS).
|
||||||
|
> Dieses Dokument ist die verbindliche Übergabe vom 📜 Rulebook Expert an 👷 Backend Developer.
|
||||||
|
> Nach Fachfreigabe durch das ÖTO-Fachreferat wird der Status von `DRAFT` auf `STABLE` angehoben.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 1. Überblick: Was wird übergeben?
|
||||||
|
|
||||||
|
| Artefakt | Datei / Ort | Status |
|
||||||
|
|---------------------------------------------------------------------|--------------------------------------------------------------------------|-----------------------------|
|
||||||
|
| `LizenzKlasseE`-Enum (korrigiert, R4 ergänzt) | `core/core-domain/.../Enums.kt` | ✅ Implementiert |
|
||||||
|
| Flyway V008 (Turnierklassen + Lizenz-Matrix + Altersklassen Reiter) | `masterdata-service/.../V008__Seed_OETO_2026_Data.sql` | ✅ Korrigiert (RD4 entfernt) |
|
||||||
|
| Flyway V009 (Höhen-Lizenz-Matrix + Mindestalter-Pferd-Matrix) | `masterdata-service/.../V009__Add_HorseAge_And_LicenseHeight_Matrix.sql` | ✅ Neu angelegt |
|
||||||
|
| Validierungsregeln v0.3 | `docs/03_Domain/02_Reference/Validierungsregeln.md` | DRAFT |
|
||||||
|
| Diese Spezifikation | `docs/.../B2-Backend-Uebergabe-Regulation-as-Data.md` | DRAFT |
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 2. Enum-Korrekturen (core-domain)
|
||||||
|
|
||||||
|
### 2.1 `LizenzKlasseE` — Vollständiger Katalog
|
||||||
|
|
||||||
|
```kotlin
|
||||||
|
enum class LizenzKlasseE {
|
||||||
|
LIZENZFREI, // Keine Lizenz erforderlich (= "ohne Lizenz", CSN-C-NEU)
|
||||||
|
R1, // Reiter-Lizenz Klasse 1
|
||||||
|
R2, // Reiter-Lizenz Klasse 2
|
||||||
|
R3, // Reiter-Lizenz Klasse 3
|
||||||
|
R4, // Reiter-Lizenz Klasse 4 ← NEU ergänzt (war fehlend)
|
||||||
|
RD1, // Dressur-Reiter Klasse 1
|
||||||
|
RD2, // Dressur-Reiter Klasse 2
|
||||||
|
RD3, // Dressur-Reiter Klasse 3
|
||||||
|
JN, // Jugend/Nachwuchs
|
||||||
|
JG, // Junioren
|
||||||
|
YR // Young Rider
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
> ⚠️ **Wichtig:** `RD4` existiert **nicht** im ÖTO-Regelwerk. Der bisherige Seed V008 enthielt `RD4` fälschlicherweise —
|
||||||
|
> wurde in V008 korrigiert (entfernt). Höchste Dressur-Lizenz ist `RD3`.
|
||||||
|
|
||||||
|
### 2.2 Schlüssel-Konvention (SSoT)
|
||||||
|
|
||||||
|
| Doku-Label | Enum-Key (SSoT) | Hinweis |
|
||||||
|
|------------------------------|------------------|-----------------------------------|
|
||||||
|
| „ohne Lizenz" / „lizenzfrei" | `LIZENZFREI` | Nicht `LZF` — Enum ist maßgeblich |
|
||||||
|
| „mit Lizenz" / „R1" | `R1` | |
|
||||||
|
| „R2 und höher" | `R2`, `R3`, `R4` | Aufwärts-kompatibel |
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 3. Datenbank-Tabellen (Regulation-as-Data)
|
||||||
|
|
||||||
|
### 3.1 Bestehende Tabellen (V005/V008)
|
||||||
|
|
||||||
|
| Tabelle | Zweck |
|
||||||
|
|------------------|---------------------------------------------------------------------------|
|
||||||
|
| `turnierklasse` | Klassen-Codes (E, A, L, LM, M, S) je Sparte mit `max_hoehe` |
|
||||||
|
| `license_matrix` | Max. Turnierklasse je Lizenz (1 Zeile pro Lizenz × Sparte) |
|
||||||
|
| `altersklasse` | Altersklassen der **Reiter** (Kinder, Jugend, Junioren, YR, AK, Senioren) |
|
||||||
|
|
||||||
|
### 3.2 Neue Tabellen (V009)
|
||||||
|
|
||||||
|
#### `license_height_matrix`
|
||||||
|
|
||||||
|
Granulare Höhen-Lizenz-Zuordnung für Springen (eine Zeile pro Höhenbereich × erlaubte Lizenz).
|
||||||
|
|
||||||
|
```sql
|
||||||
|
-- Abfrage: Welche Lizenzen sind für 110 cm erlaubt?
|
||||||
|
SELECT lizenz_klasse
|
||||||
|
FROM license_height_matrix
|
||||||
|
WHERE sparte = 'SPRINGEN'
|
||||||
|
AND hoehe_von_cm <= 110
|
||||||
|
AND hoehe_bis_cm >= 110
|
||||||
|
AND ist_aktiv = true;
|
||||||
|
-- Ergebnis: R1, R2, R3, R4
|
||||||
|
```
|
||||||
|
|
||||||
|
#### `horse_min_age_matrix`
|
||||||
|
|
||||||
|
Mindestalter des **Pferdes** (Stichtag 1. Jänner) je Sparte + Höhenbereich oder Aufgabenniveau.
|
||||||
|
|
||||||
|
```sql
|
||||||
|
-- Abfrage: Mindestalter für Springen 125 cm?
|
||||||
|
SELECT min_alter_jahre
|
||||||
|
FROM horse_min_age_matrix
|
||||||
|
WHERE sparte = 'SPRINGEN'
|
||||||
|
AND hoehe_von_cm <= 125
|
||||||
|
AND hoehe_bis_cm >= 125
|
||||||
|
AND ist_aktiv = true;
|
||||||
|
-- Ergebnis: 5
|
||||||
|
```
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 4. Lizenz × Bewerb-Tabellen (DRAFT → Fachfreigabe erforderlich)
|
||||||
|
|
||||||
|
### 4.1 Springen (CSN) — Lizenz-Zuordnung nach Hindernishöhe
|
||||||
|
|
||||||
|
> Quelle: ÖTO 2026 § 231 | Status: **DRAFT** — Fachfreigabe ausstehend
|
||||||
|
|
||||||
|
| Klasse | Höhe (cm) | Mindest-Lizenz | Zugelassene Lizenzen | Bemerkung |
|
||||||
|
|--------------------|-----------|----------------|----------------------------|---------------------------------------------------------------|
|
||||||
|
| E0 (Einsteiger) | 60–95 | LIZENZFREI | LIZENZFREI, R1, R2, R3, R4 | CSN-C-NEU: Zwangsteilung in Abt. „ohne Lizenz" + „mit Lizenz" |
|
||||||
|
| A (Anfänger) | 100–110 | R1 | R1, R2, R3, R4 | Keine LIZENZFREI mehr ab 100 cm |
|
||||||
|
| L (Leicht) | 115–120 | R1* | R1, R2, R3, R4 | *Ausschreibung kann R2 vorschreiben |
|
||||||
|
| LM (Leicht-Mittel) | 125–130 | R2 | R2, R3, R4 | |
|
||||||
|
| M (Mittelschwer) | 135 | R3 | R3, R4 | |
|
||||||
|
| S (Schwer) | 140–160 | R4 | R4 | |
|
||||||
|
|
||||||
|
**Aufwärts-Kompatibilität:** Eine höhere Lizenz berechtigt immer zur Teilnahme in niedrigeren Klassen.
|
||||||
|
|
||||||
|
### 4.2 Dressur (CDN) — Lizenz-Zuordnung nach Aufgabenniveau
|
||||||
|
|
||||||
|
> Quelle: ÖTO 2026 § 103 | Status: **DRAFT** — Fachfreigabe ausstehend
|
||||||
|
|
||||||
|
| Klasse | Aufgabenniveau | Mindest-Lizenz | Zugelassene Lizenzen |
|
||||||
|
|--------------------|----------------|----------------|---------------------------|
|
||||||
|
| Einsteiger | E | LIZENZFREI | LIZENZFREI, RD1, RD2, RD3 |
|
||||||
|
| A (Anfänger) | A | RD1 | RD1, RD2, RD3 |
|
||||||
|
| L (Leicht) | L | RD1 | RD1, RD2, RD3 |
|
||||||
|
| LM (Leicht-Mittel) | LM | RD2 | RD2, RD3 |
|
||||||
|
| M (Mittelschwer) | M | RD2 | RD2, RD3 |
|
||||||
|
| S (Schwer) | S | RD3 | RD3 |
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 5. Mindestalter Pferd (Regulation-as-Data)
|
||||||
|
|
||||||
|
> Stichtagsregel: Alter = `veranstaltungsjahr - geburtsjahr` (Stichtag 1. Jänner)
|
||||||
|
|
||||||
|
### 5.1 Springen national (ÖTO § 231)
|
||||||
|
|
||||||
|
| Höhe (cm) | Mindestalter Pferd (Jahre) |
|
||||||
|
|-----------|----------------------------|
|
||||||
|
| 60–100 | 4 |
|
||||||
|
| 101–120 | 5 |
|
||||||
|
| 121–999 | 6 |
|
||||||
|
|
||||||
|
### 5.2 Dressur national (ÖTO § 103)
|
||||||
|
|
||||||
|
| Aufgabenniveau | Mindestalter Pferd (Jahre) |
|
||||||
|
|----------------|----------------------------|
|
||||||
|
| E | 4 |
|
||||||
|
| A | 4 |
|
||||||
|
| L | 4 |
|
||||||
|
| LM | 5 |
|
||||||
|
| M | 5 |
|
||||||
|
| S | 6 |
|
||||||
|
|
||||||
|
### 5.3 International FEI (GR Art. 136)
|
||||||
|
|
||||||
|
| Disziplin | Level | Mindestalter Pferd |
|
||||||
|
|-----------|-----------------|------------------------|
|
||||||
|
| Springen | 1*–2* | 6 |
|
||||||
|
| Springen | 3*–5* | 7 |
|
||||||
|
| Dressur | CDI Senior | 7 |
|
||||||
|
| Dressur | CDI Young Horse | 4 (gem. FEI YH-Regeln) |
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 6. Serverseitige Validierungslogik (Pseudocode)
|
||||||
|
|
||||||
|
Das Backend soll die folgenden Prüfungen serverseitig durchführen (analog zur Frontend-Validierung):
|
||||||
|
|
||||||
|
### 6.1 Lizenz-Check (Springen)
|
||||||
|
|
||||||
|
```kotlin
|
||||||
|
fun isLicenseAllowedForHeight(hoeheCm: Int, lizenz: LizenzKlasseE): Boolean {
|
||||||
|
// Abfrage license_height_matrix
|
||||||
|
val allowed = licenseHeightMatrixRepo.findAllowedLicenses(
|
||||||
|
sparte = "SPRINGEN",
|
||||||
|
hoehe = hoeheCm
|
||||||
|
)
|
||||||
|
return lizenz.name in allowed
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### 6.2 Lizenz-Check (Dressur)
|
||||||
|
|
||||||
|
```kotlin
|
||||||
|
fun isLicenseAllowedForLevel(niveau: String, lizenz: LizenzKlasseE): Boolean {
|
||||||
|
// Abfrage license_matrix (max_turnierklasse_code Vergleich)
|
||||||
|
val maxKlasse = licenseMatrixRepo.findMaxKlasse(sparte = "DRESSUR", lizenz = lizenz.name)
|
||||||
|
return klasseOrdnung.indexOf(niveau) <= klasseOrdnung.indexOf(maxKlasse)
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### 6.3 Mindestalter-Pferd-Check
|
||||||
|
|
||||||
|
```kotlin
|
||||||
|
fun isHorseOldEnough(
|
||||||
|
geburtsjahr: Int, veranstaltungsjahr: Int,
|
||||||
|
sparte: String, hoeheCm: Int?, niveau: String?
|
||||||
|
): Boolean {
|
||||||
|
val alter = veranstaltungsjahr - geburtsjahr // Stichtag 1. Jänner
|
||||||
|
val minAlter = horseMinAgeRepo.findMinAlter(sparte, hoeheCm, niveau)
|
||||||
|
return alter >= minAlter
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 7. REST-Endpunkte (Masterdata-SCS) — Empfehlung
|
||||||
|
|
||||||
|
| Methode | Pfad | Beschreibung |
|
||||||
|
|---------|-------------------------------------------------------------------|-------------------------------------------------------|
|
||||||
|
| `GET` | `/api/regulation/license-height-matrix?sparte=SPRINGEN&hoehe=110` | Erlaubte Lizenzen für Höhe |
|
||||||
|
| `GET` | `/api/regulation/license-matrix?sparte=DRESSUR&lizenz=RD2` | Max. Klasse für Lizenz |
|
||||||
|
| `GET` | `/api/regulation/horse-min-age?sparte=SPRINGEN&hoehe=125` | Mindestalter Pferd |
|
||||||
|
| `GET` | `/api/regulation/horse-min-age?sparte=DRESSUR&niveau=LM` | Mindestalter Pferd (Dressur) |
|
||||||
|
| `GET` | `/api/fei/resolve/{id}` | FEI Legacy→Numeric Resolver (bereits implementiert ✅) |
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 8. Abweichungen Backend ↔ Frontend
|
||||||
|
|
||||||
|
| Thema | Frontend (KMP) | Backend (Spring) | Handlungsbedarf |
|
||||||
|
|--------------------|---------------------------------|------------------------|-------------------------------------------------------------|
|
||||||
|
| Lizenz-Keys | `LZF` (alter Key in Doku) | `LIZENZFREI` (Enum) | Doku korrigiert; Frontend-Code prüfen |
|
||||||
|
| R4 | Vorhanden in `OetoValidators` | Enum jetzt ergänzt ✅ | Kein weiterer Bedarf |
|
||||||
|
| RD4 | Nicht vorhanden | Seed V008 korrigiert ✅ | Kein weiterer Bedarf |
|
||||||
|
| Höhen-Matrix | `OetoValidators.kt` (hardcoded) | V009 als DB-Tabelle | Backend liest aus DB; Frontend bleibt hardcoded bis Phase 2 |
|
||||||
|
| Mindestalter Pferd | `OetoValidators.kt` (hardcoded) | V009 als DB-Tabelle | Wie oben |
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 9. Fachfreigabe-Checkliste (DRAFT → STABLE)
|
||||||
|
|
||||||
|
Folgende Punkte müssen vor Anhebung auf `STABLE` durch das ÖTO-Fachreferat bestätigt werden:
|
||||||
|
|
||||||
|
- [ ] Lizenz-Zuordnungstabelle Springen (§ 231): Höhenschwellen und Mindestlizenzen korrekt?
|
||||||
|
- [ ] Lizenz-Zuordnungstabelle Dressur (§ 103): Niveaustufen und Mindestlizenzen korrekt?
|
||||||
|
- [ ] Mindestalter Pferd Springen (§ 231): Schwellen 4/5/6 Jahre korrekt?
|
||||||
|
- [ ] Mindestalter Pferd Dressur (§ 103): Schwellen je Niveau korrekt?
|
||||||
|
- [ ] Aufwärts-Kompatibilität (höhere Lizenz → niedrigere Klasse erlaubt): bestätigt?
|
||||||
|
- [ ] Paragraphen-Nummern (§ 231, § 103) final verifiziert?
|
||||||
|
- [ ] Sonderfall CSN-C-NEU Zwangsteilung (LIZENZFREI + R1 in E0): korrekt?
|
||||||
|
|
||||||
|
Nach Bestätigung aller Punkte:
|
||||||
|
|
||||||
|
1. Status in dieser Datei auf `STABLE` setzen
|
||||||
|
2. `Validierungsregeln.md` → `status: STABLE`, `version: 1.0`
|
||||||
|
3. Flyway V009 → Kommentar `Status: DRAFT` entfernen
|
||||||
|
4. Roadmap B-2 als abgeschlossen markieren
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 10. Offene Punkte
|
||||||
|
|
||||||
|
| # | Thema | Verantwortlich | Priorität |
|
||||||
|
|---|-----------------------------------------------------------------|--------------------------|------------|
|
||||||
|
| 1 | Fachfreigabe Lizenz×Bewerb-Tabellen einholen | 📜 Rulebook Expert | 🔴 Hoch |
|
||||||
|
| 2 | Backend-Endpunkte `/api/regulation/*` implementieren | 👷 Backend | 🔴 Hoch |
|
||||||
|
| 3 | Frontend `LZF`-Key → `LIZENZFREI` prüfen/angleichen | 🎨 Frontend | 🟠 Mittel |
|
||||||
|
| 4 | `AltersklasseRechner` (C-1) implementieren | 👷 Backend + 📜 Rulebook | 🟠 Mittel |
|
||||||
|
| 5 | FEI-Mindestalter-Tabellen aus Disziplinregelwerken finalisieren | 📜 Rulebook Expert | 🟡 Niedrig |
|
||||||
|
|
@ -2,7 +2,7 @@
|
||||||
type: RULE_SPEC
|
type: RULE_SPEC
|
||||||
status: DRAFT
|
status: DRAFT
|
||||||
owner: Rulebook Expert
|
owner: Rulebook Expert
|
||||||
last_update: 2026-04-02
|
last_update: 2026-04-03
|
||||||
---
|
---
|
||||||
|
|
||||||
# Validierungsregeln (ÖTO/FEI)
|
# Validierungsregeln (ÖTO/FEI)
|
||||||
|
|
@ -148,29 +148,32 @@ fun validateFeiId(input: String): Boolean {
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
## 3. Lizenzklassen (R1–R4, RD1–RD3, LZF)
|
## 3. Lizenzklassen (R1–R4, RD1–RD3, LIZENZFREI)
|
||||||
Status: Draft – basierend auf ÖTO‑Praxis und ZNS‑Lizenzdaten. Detaillierte Paragraphen‑Zitate werden nachgereicht (A‑2/A‑3 Arbeiten verknüpft).
|
Status: Draft – basierend auf ÖTO‑Praxis und ZNS‑Lizenzdaten. Detaillierte Paragraphen‑Zitate werden nachgereicht (A‑2/A‑3 Arbeiten verknüpft).
|
||||||
|
|
||||||
### 3.1 Katalog gültiger Lizenzklassen
|
### 3.1 Katalog gültiger Lizenzklassen
|
||||||
- Reiten Springen (R‑Klassen): `R1`, `R2`, `R3`, `R4`
|
- Reiten Springen (R‑Klassen): `R1`, `R2`, `R3`, `R4`
|
||||||
- Dressur Reiten (RD‑Klassen): `RD1`, `RD2`, `RD3`
|
- Dressur Reiten (RD‑Klassen): `RD1`, `RD2`, `RD3`
|
||||||
- Lizenzfrei/ohne Lizenz Kennzeichnung: `LZF` (für bewerbsbezogene Abteilung „ohne Lizenz“)
|
- Lizenzfrei/ohne Lizenz Kennzeichnung: `LIZENZFREI` (Enum-Key in `LizenzKlasseE`; Label: „ohne Lizenz“)
|
||||||
|
|
||||||
Erweiterbarkeit: Weitere Spezial‑/Jugend‑ oder Fahrer‑Lizenzen können ergänzt werden, sobald in ÖTO/ZNS erforderlich.
|
Erweiterbarkeit: Weitere Spezial‑/Jugend‑ oder Fahrer‑Lizenzen können ergänzt werden, sobald in ÖTO/ZNS erforderlich.
|
||||||
|
|
||||||
### 3.2 Grundregeln der Zuordnung (vereinfachte Erstfassung)
|
### 3.2 Grundregeln der Zuordnung (vereinfachte Erstfassung)
|
||||||
- Springen (CSN):
|
- Springen (CSN):
|
||||||
- Bewerbe bis inkl. 95 cm: Teilnahme mit `LZF` (Abt. „ohne Lizenz“) oder `R1` (Abt. „mit Lizenz`).
|
- Bewerbe bis inkl. 95 cm: Teilnahme mit `LIZENZFREI` (Abt. „ohne Lizenz“) oder `R1` (Abt. „mit Lizenz`).
|
||||||
- Ab 100 cm: mindestens `R1` erforderlich; ab bestimmten Höhen empfohlen/erforderlich `R2+` (veranstalter‑/ausschreibungsabhängig).
|
- Ab 100 cm: mindestens `R1` erforderlich; ab bestimmten Höhen empfohlen/erforderlich `R2+` (veranstalter‑/ausschreibungsabhängig).
|
||||||
- Zwangsteilungsregeln siehe Roadmap A‑2 (eigener Abschnitt).
|
- Zwangsteilungsregeln siehe Roadmap A‑2 (eigener Abschnitt).
|
||||||
- Dressur (CDN):
|
- Dressur (CDN):
|
||||||
- Einsteigerprüfungen (z. B. Dressurreiterprüfungen niedrig): `LZF` oder `RD1`.
|
- Einsteigerprüfungen (z. B. Dressurreiterprüfungen niedrig): `LIZENZFREI` oder `RD1`.
|
||||||
- Ab definiertem Schwierigkeitsgrad: `RD1+`, höhere Klassen `RD2/RD3` gemäß Ausschreibung.
|
- Ab definiertem Schwierigkeitsgrad: `RD1+`, höhere Klassen `RD2/RD3` gemäß Ausschreibung.
|
||||||
|
|
||||||
Hinweis: Die exakte Matrix „Lizenzklasse × Bewerbsklasse (Disziplin, Höhe/Schwierigkeit)“ wird als Tabelle hinterlegt und aus ÖTO‑Paragraphen abgeleitet. Nach Bestätigung durch Fachreferat wird diese Spezifikation von „Draft“ auf „Stable“ gehoben.
|
Hinweis: Die vollständige Matrix „Lizenzklasse × Bewerbsklasse“ ist in
|
||||||
|
`docs/03_Domain/02_Reference/OETO_Regelwerk/B2-Backend-Uebergabe-Regulation-as-Data.md` (Abschnitte 4 und 5)
|
||||||
|
spezifiziert und als Flyway V009 im Backend hinterlegt. Nach Fachfreigabe wird der Status auf STABLE angehoben.
|
||||||
|
|
||||||
### 3.3 Validierungslogik (Platzhalter bis zur finalen Matrix)
|
### 3.3 Validierungslogik (Platzhalter bis zur finalen Matrix)
|
||||||
- Eingabe muss in obiger Katalogliste vorkommen (`R1|R2|R3|R4|RD1|RD2|RD3|LZF`).
|
|
||||||
|
- Eingabe muss in obiger Katalogliste vorkommen (`R1|R2|R3|R4|RD1|RD2|RD3|LIZENZFREI`).
|
||||||
- Bei Auswahl eines Bewerbs wird die erlaubte(n) Lizenzklasse(n) aus der Disziplin/Höhe/Schwierigkeit abgeleitet.
|
- Bei Auswahl eines Bewerbs wird die erlaubte(n) Lizenzklasse(n) aus der Disziplin/Höhe/Schwierigkeit abgeleitet.
|
||||||
- Fehler, wenn gewählte Lizenzklasse nicht in der erlaubten Menge liegt.
|
- Fehler, wenn gewählte Lizenzklasse nicht in der erlaubten Menge liegt.
|
||||||
|
|
||||||
|
|
@ -194,24 +197,24 @@ fun isLicenseAllowed(discipline: Discipline, heightCm: Int?, testLevel: Dressage
|
||||||
### 3.6 Lizenz‑Zuordnungstabelle (DRAFT, final mit Paragraphen‑Verweisen)
|
### 3.6 Lizenz‑Zuordnungstabelle (DRAFT, final mit Paragraphen‑Verweisen)
|
||||||
- Springen (CSN) — Bezug ÖTO § 231 ff. (finale Paragraphennummern nachreichen):
|
- Springen (CSN) — Bezug ÖTO § 231 ff. (finale Paragraphennummern nachreichen):
|
||||||
|
|
||||||
| Höhe (cm) | Zulässige Lizenz-Abteilungen | Primär-Bezug ÖTO |
|
| Höhe (cm) | Zulässige Lizenz-Abteilungen | Primär-Bezug ÖTO |
|
||||||
|---|---|---|
|
|-----------|------------------------------|----------------------------------|
|
||||||
| ≤ 95 | LZF „ohne Lizenz“ | § 231 (Zwangsteilung Einsteiger) |
|
| ≤ 95 | LIZENZFREI „ohne Lizenz“ | § 231 (Zwangsteilung Einsteiger) |
|
||||||
| ≤ 95 | R1 „mit Lizenz“ | § 231 |
|
| ≤ 95 | R1 „mit Lizenz“ | § 231 |
|
||||||
| 100 | R1+ | § 231 |
|
| 100 | R1+ | § 231 |
|
||||||
| 105–110 | R1, R2+ (Empf. R2) | § 231 |
|
| 105–110 | R1, R2+ (Empf. R2) | § 231 |
|
||||||
| 115–120 | R2+ | § 231 |
|
| 115–120 | R2+ | § 231 |
|
||||||
| 125–135 | R3+ | § 231 |
|
| 125–135 | R3+ | § 231 |
|
||||||
| ≥ 140 | R4 | § 231 |
|
| ≥ 140 | R4 | § 231 |
|
||||||
|
|
||||||
- Dressur (CDN) — Bezug ÖTO § 103 ff. (finale Paragraphennummern nachreichen):
|
- Dressur (CDN) — Bezug ÖTO § 103 ff. (finale Paragraphennummern nachreichen):
|
||||||
|
|
||||||
| Prüfungsniveau (national, äquiv.) | Zulässige Lizenzen | Primär-Bezug ÖTO |
|
| Prüfungsniveau (national, äquiv.) | Zulässige Lizenzen | Primär-Bezug ÖTO |
|
||||||
|---|---|---|
|
|------------------------------------|--------------------|------------------|
|
||||||
| Einsteiger/Dressurreiter (niedrig) | LZF, RD1 | § 103 |
|
| Einsteiger/Dressurreiter (niedrig) | LIZENZFREI, RD1 | § 103 |
|
||||||
| A/L | RD1+ | § 103 |
|
| A/L | RD1+ | § 103 |
|
||||||
| LM/M | RD2+ | § 103 |
|
| LM/M | RD2+ | § 103 |
|
||||||
| S | RD3 | § 103 |
|
| S | RD3 | § 103 |
|
||||||
|
|
||||||
Hinweise:
|
Hinweise:
|
||||||
- Veranstalter/Ausschreibung kann engere Anforderungen definieren, jedoch nicht lockern.
|
- Veranstalter/Ausschreibung kann engere Anforderungen definieren, jedoch nicht lockern.
|
||||||
|
|
@ -294,4 +297,4 @@ Hinweis: Exakte FEI‑Tabellen sind pro Disziplinregelwerk verbindlich zu übern
|
||||||
|
|
||||||
Meta:
|
Meta:
|
||||||
- status: DRAFT (wird auf STABLE angehoben nach Fachfreigabe)
|
- status: DRAFT (wird auf STABLE angehoben nach Fachfreigabe)
|
||||||
- version: 0.3 (2026‑04‑02)
|
- version: 0.4 (2026‑04‑03)
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
# 📜 [ÖTO/FEI Rulebook Expert] — Zwischenstand & Roadmap
|
# 📜 [ÖTO/FEI Rulebook Expert] — Zwischenstand & Roadmap
|
||||||
|
|
||||||
> **Stand:** 3. April 2026
|
> **Stand:** 3. April 2026 (Session 2)
|
||||||
> **Rolle:** Regelwerks-Wächter, Validierungs-Spezialist, Compliance (ÖTO, FEI)
|
> **Rolle:** Regelwerks-Wächter, Validierungs-Spezialist, Compliance (ÖTO, FEI)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
@ -32,12 +32,18 @@
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
## 🔴 Sprint B — Offen (höchste Priorität)
|
## 🟡 Sprint B — Teilweise offen
|
||||||
|
|
||||||
- [ ] **B-2** | Validierungs-Implementierung Backend begleiten
|
- [ ] **B-2** | Validierungs-Implementierung Backend begleiten
|
||||||
- [x] FEI Legacy→Numeric Resolver implementiert (`/api/fei/resolve/{id}`) — erste Version in Masterdata-SCS
|
- [x] FEI Legacy→Numeric Resolver implementiert (`/api/fei/resolve/{id}`) — erste Version in Masterdata-SCS
|
||||||
- [ ] Lizenz-/Altersmatrix als Regulation-as-Data an 👷 Backend übergeben
|
- [x] Lizenz-/Altersmatrix als Regulation-as-Data an 👷 Backend übergeben
|
||||||
|
- [x] `LizenzKlasseE`-Enum: `R4` ergänzt, `RD4`-Fehler in V008 korrigiert
|
||||||
|
- [x] Flyway V009: `license_height_matrix` + `horse_min_age_matrix` angelegt und befüllt
|
||||||
|
- [x] B-2-Übergabe-Spezifikation →
|
||||||
|
`docs/03_Domain/02_Reference/OETO_Regelwerk/B2-Backend-Uebergabe-Regulation-as-Data.md`
|
||||||
|
- [x] `Validierungsregeln.md`: `LZF` → `LIZENZFREI` korrigiert, Version 0.4, Verweis auf B2-Spec ergänzt
|
||||||
- [ ] Serverseitige Validierung prüfen: Werden alle Regeln korrekt durchgesetzt?
|
- [ ] Serverseitige Validierung prüfen: Werden alle Regeln korrekt durchgesetzt?
|
||||||
|
- [ ] Backend-Endpunkte `/api/regulation/*` implementieren (👷 Backend)
|
||||||
- [ ] Abweichungen Backend ↔ Frontend-Validierung dokumentieren und klären
|
- [ ] Abweichungen Backend ↔ Frontend-Validierung dokumentieren und klären
|
||||||
- [ ] Lizenz×Bewerb-Tabellen (Springen + Dressur) von DRAFT auf STABLE anheben (nach Fachfreigabe)
|
- [ ] Lizenz×Bewerb-Tabellen (Springen + Dressur) von DRAFT auf STABLE anheben (nach Fachfreigabe)
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,79 @@
|
||||||
|
---
|
||||||
|
date: 2026-04-03
|
||||||
|
sprint: B-2
|
||||||
|
agent: Rulebook Expert
|
||||||
|
status: TEILWEISE ABGESCHLOSSEN
|
||||||
|
---
|
||||||
|
|
||||||
|
# Session-Log: B-2 Regulation-as-Data Backend-Übergabe
|
||||||
|
|
||||||
|
## Ziel der Session
|
||||||
|
|
||||||
|
Lizenz-/Altersmatrix als Regulation-as-Data an 👷 Backend übergeben; Lizenz×Bewerb-Tabellen für Fachfreigabe vorbereiten.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Durchgeführte Arbeiten
|
||||||
|
|
||||||
|
### 1. Enum-Korrektur: `LizenzKlasseE` (core-domain)
|
||||||
|
|
||||||
|
- **Problem:** `R4` fehlte im Enum, obwohl Flyway V008 bereits `R4` inserierte → Mismatch.
|
||||||
|
- **Fix:** `R4` in `core/core-domain/src/commonMain/kotlin/at/mocode/core/domain/model/Enums.kt` ergänzt.
|
||||||
|
- **Vollständiger Katalog jetzt:** `LIZENZFREI, R1, R2, R3, R4, RD1, RD2, RD3, JN, JG, YR`
|
||||||
|
|
||||||
|
### 2. Flyway V008 korrigiert
|
||||||
|
|
||||||
|
- **Problem:** `RD4` in Dressur-Lizenz-Matrix inseriert — existiert nicht im ÖTO-Regelwerk und nicht im Enum.
|
||||||
|
- **Fix:** `RD4`-Zeile entfernt; Kommentar mit Enum-Key-Konvention ergänzt.
|
||||||
|
- **Datei:**
|
||||||
|
`backend/services/masterdata/masterdata-service/src/main/resources/db/migration/V008__Seed_OETO_2026_Data.sql`
|
||||||
|
|
||||||
|
### 3. Flyway V009 neu angelegt
|
||||||
|
|
||||||
|
Zwei neue Tabellen als Regulation-as-Data:
|
||||||
|
|
||||||
|
| Tabelle | Inhalt |
|
||||||
|
|-------------------------|-----------------------------------------------------------------------------|
|
||||||
|
| `license_height_matrix` | Höhenbereich (cm) × erlaubte Lizenzklassen (Springen, ÖTO § 231) |
|
||||||
|
| `horse_min_age_matrix` | Mindestalter Pferd je Sparte + Höhe/Niveau (national ÖTO + FEI GR Art. 136) |
|
||||||
|
|
||||||
|
- **Datei:**
|
||||||
|
`backend/services/masterdata/masterdata-service/src/main/resources/db/migration/V009__Add_HorseAge_And_LicenseHeight_Matrix.sql`
|
||||||
|
|
||||||
|
### 4. B-2-Übergabe-Spezifikation erstellt
|
||||||
|
|
||||||
|
- Vollständige Spezifikation für 👷 Backend mit: Enum-Katalog, DB-Tabellen, Abfrage-Patterns, Pseudocode,
|
||||||
|
REST-Endpunkt-Empfehlungen, Abweichungen Backend↔Frontend, Fachfreigabe-Checkliste.
|
||||||
|
- **Datei:** `docs/03_Domain/02_Reference/OETO_Regelwerk/B2-Backend-Uebergabe-Regulation-as-Data.md`
|
||||||
|
|
||||||
|
### 5. `Validierungsregeln.md` aktualisiert (v0.3 → v0.4)
|
||||||
|
|
||||||
|
- `LZF` → `LIZENZFREI` in allen Vorkommen korrigiert (Enum ist SSoT).
|
||||||
|
- Verweis auf B2-Übergabe-Spezifikation ergänzt.
|
||||||
|
- Version auf 0.4 (2026-04-03) angehoben.
|
||||||
|
|
||||||
|
### 6. Roadmap aktualisiert
|
||||||
|
|
||||||
|
- Sprint B von 🔴 auf 🟡 gesetzt (Übergabe abgeschlossen, Fachfreigabe + Backend-Impl. offen).
|
||||||
|
- Abgeschlossene Teilaufgaben abgehakt.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Offene Punkte (Übergabe an nächste Session)
|
||||||
|
|
||||||
|
| # | Aufgabe | An wen | Priorität |
|
||||||
|
|---|-----------------------------------------------------------------------|--------------------|-----------|
|
||||||
|
| 1 | **Fachfreigabe** Lizenz×Bewerb-Tabellen beim ÖTO-Fachreferat einholen | 📜 Rulebook Expert | 🔴 |
|
||||||
|
| 2 | Backend-Endpunkte `/api/regulation/*` implementieren | 👷 Backend | 🔴 |
|
||||||
|
| 3 | Frontend `LZF`-Key im Code prüfen (nicht nur Doku) | 🎨 Frontend | 🟠 |
|
||||||
|
| 4 | Serverseitige Validierung prüfen (nach Backend-Impl.) | 📜 Rulebook Expert | 🟠 |
|
||||||
|
| 5 | `AltersklasseRechner` (C-1) spezifizieren und implementieren | 👷 + 📜 | 🟠 |
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Entscheidungen & Erkenntnisse
|
||||||
|
|
||||||
|
- **`LIZENZFREI` ist der kanonische Enum-Key** — nicht `LZF`. Alle Dokumente und Code müssen diesen Key verwenden.
|
||||||
|
- **`RD4` existiert nicht** im ÖTO-Regelwerk 2026. Höchste Dressur-Lizenz ist `RD3`.
|
||||||
|
- **Aufwärts-Kompatibilität** ist explizit modelliert: Höhere Lizenz darf immer in niedrigerer Klasse starten.
|
||||||
|
- **Fachfreigabe ist Voraussetzung** für STABLE-Status der Tabellen — bis dahin bleibt alles DRAFT.
|
||||||
Loading…
Reference in New Issue
Block a user