Editorial backlog: seed 279 candidate UPC RoP events into deadline_rules (full catalog gap) #143
Open
opened 2026-05-26 17:30:36 +00:00 by mAi
·
1 comment
No Branch/Tag Specified
main
mai/planck/coder-b5-b6-train-share
mai/archimedes/fixer-port-engine
mai/maxwell/coder-b4-akte-mode
mai/lorenz/coder-b3-event-triggered
mai/euler/fixer-builder-add
mai/brunel/fixer-prod-500s-after-b1
mai/galileo/coder-b1-b2-mvp-train
mai/pasteur/fixer-pkg-litigationplann
mai/newton/coder-b0-scenario-db
mai/edison/inventor-prd-columnar
mai/knuth/coder-workflow-tracker
mai/atlas/inventor-extend-tools
mai/cronus/inventor-unified
mai/atlas/inventor-deadline-system
mai/atlas/inventor-followup-rules
mai/athena/consultant-deadline
mai/brunel/fixer-dark-mode-support
mai/knuth/coder-cronus-fristenrechn
mai/ritchie/coder-mig-153-proceeding
mai/atlas/inventor-proceeding
mai/cronus/inventor-fristenrechner
mai/curie/coder-mig152-clone-dedupe
mai/darwin/researcher-lexy-draft
mai/knuth/coder-dedupe-null
mai/cronus/coder-composer-slice-f
mai/cronus/coder-composer-slice-e
mai/cronus/coder-composer-slice-d
mai/curie/coder-slice-b6-url-rename
mai/curie/coder-slice-b5-go-rename
mai/cronus/coder-composer-slice-c
mai/curie/coder-slice-b4-destructive-drop
mai/cronus/coder-composer-slice-b
mai/cronus/coder-composer-slice-a
mai/cronus/inventor-prd-for
mai/knuth/coder-verfahrensablauf
mai/ritchie/coder-make-backup
mai/diesel/fixer-dark-mode-css
mai/curie/coder-slice-b3-read-cutover
mai/diesel/fixer-verfahrensablauf
mai/curie/coder-slice-b2-dual-write
mai/cronus/coder-slice-d-scenarios
mai/knuth/coder-backfill-applies
mai/hermes/gitster-verfahrensablauf
mai/cronus/coder-berufung-labels-refactor
mai/diesel/hotfix-2-mig-134-missing
mai/curie/coder-slice-b1-procedural-events
mai/cronus/coder-slice-c-upc-snapshot
mai/brunel/hotfix-rename-upc-apl
mai/cronus/coder-slice-b3-primary-party
mai/cronus/coder-slice-b2-catalog-query
mai/cronus/inventor-litigation-slice-b
mai/curie/researcher-slice-b-zero
mai/cronus/inventor-litigation
mai/artemis/gitster-remove-admin
mai/ritchie/coder-sort-post-trigger
mai/knuth/coder-conditional-label
mai/hermes/coder-verfahrensablauf
mai/brunel/rebase-121-conditional
mai/knuth/coder-conditional-rule
mai/hermes/gitster-dark-mode-fix
mai/ritchie/coder-submission-form
mai/artemis/gitster-re-surface
mai/brunel/fixer-views-any-filters
mai/cronus/coder-cicd-slice-a
mai/knuth/coder-wave-1-tier-1-rule
mai/ritchie/coder-upc-damages-add
mai/cronus/inventor-ci-cd-pre
mai/brunel/rebase-108-language
mai/hermes/gitster-admin-rules-list
mai/artemis/gitster-submission
mai/icarus/gitster-verfahrensablauf
mai/orpheus/gitster-search-input
mai/atlas/coder-event-card-choices-slice-ab
mai/hermes/gitster-date-range
mai/demeter/gitster-submission
mai/knuth/coder-hl-patents-style
mai/hermes/gitster-draft-editor
mai/atlas/inventor-per-event-card
mai/knuth/coder-deadline-rule-tier
mai/cronus/coder-procedural-events-slice-a
mai/hermes/gitster-deadline-form
mai/artemis/gitster-add-missing-i18n
mai/demeter/gitster-paliadin-chat
mai/brunel/wave0-tier0-deadline-fixes
mai/artemis/coder-docker-compose-yml
mai/icarus/coder-inbox-overhaul-slice-a
mai/atlas/coder-date-range-picker-slice-a
mai/brunel/fixer-de-inf-lg-cfi
mai/cronus/inventor-procedural
mai/hermes/gitster-event-type-modal
mai/cronus/coder-backup-mode
mai/curie/researcher-bulletproof
mai/hermes/gitster-draft-editor-focus-jump
mai/cronus/inventor-backup-mode
mai/hermes/gitster-submissions
mai/artemis/gitster-deadline-form
mai/brunel/fixer-submission-preview
mai/brunel/fixer-test-data-reset
mai/artemis/gitster-approval-withdraw
mai/demeter/gitster-events
mai/hermes/gitster-sidebar-loses
mai/hermes/gitster-browse-a
mai/brunel/fixer-submissions-demo
mai/icarus/inventor-inbox-overhaul
mai/atlas/inventor-symmetric-date
mai/artemis/gitster-demote-daten
mai/hermes/gitster-team-view-mailto
mai/knuth/coder-global-schriftsatze
mai/knuth/coder-schriftsatze
mai/ritchie/coder-author-demo-docx
mai/knuth/coder-add-schriftsatze
mai/knuth/coder-add-checklist
mai/knuth/coder-anchor-lookup-must
mai/tesla/dashboard-resize-clamp
mai/knuth/coder-demote-projekt
mai/knuth/coder-paliadin-chat
mai/knuth/coder-print-views
mai/knuth/coder-add-proceeding
mai/knuth/coder-submission
mai/ritchie/coder-extend-team-email
mai/knuth/coder-changelog-catch-up
mai/tesla/dashboard-overlap
mai/pasteur/fixercoder-dashboard
mai/newton/inventor-configurable
mai/dirac/inventorcoder-user
mai/gauss/inventorcoder-team-admin
mai/kepler/inventorcoder-project
mai/darwin/roadmap-ccr-en
mai/euler/coder-small-ux-polish
mai/darwin/fristenrechner-cleanup
mai/darwin/fixercoder-priority-bug
mai/leibniz/inventor-caldav-multi
mai/hertz/inventor-unified-modal
mai/archimedes/inventor-excel-data
mai/boltzmann/inventor-gap-tolerant
mai/copernicus/submission-slice-1
mai/fermi/interactive-session
mai/hertz/inventor-suggest-changes
mai/copernicus/inventor-submission
mai/mendel/test-strategy-slice-1
mai/mendel/inventor-test-strategy
mai/ampere/custom-views-improvements
mai/joule/mig-097-apply-huygens-s
mai/ohm/workstream-b-rename
mai/huygens/workstream-a-backfill
mai/kelvin/t-204-phase-2-proceeding
mai/bohr/ingest-t-paliad-203-rule
mai/curie/fristenrechner-gap
mai/maxwell/inbox-grey-out
mai/rutherford/slice-9-follow-up-b-re
mai/dirac/slice-9-follow-up-a
mai/bose/determinator-cascade-slice-3
mai/bose/determinator-cascade-slice-2
mai/bose/determinator-row-cascade
mai/lorenz/fristen-phase-3-slice-9
mai/curie/fristen-phase-3-slice-12
mai/planck/aichat-phase-b-paliad
mai/young/fristen-phase-3-slice-11b
mai/lorenz/fristen-phase-3-slice-11a
mai/lorenz/fristen-phase-3-slice-10
mai/lorenz/fristen-phase-3-slice-8
mai/lorenz/fristen-phase-3-slice-7
mai/lorenz/fristen-phase-3-slice-6
mai/lorenz/fristen-phase-3-slice-5
mai/lorenz/fristen-phase-3-slice-4
mai/lorenz/fristen-phase-3-slice-3
mai/lorenz/fristen-phase-3-slice-2
mai/lorenz/fristen-phase-3-slice-1
mai/pauli/fristen-phase2-design
mai/tesla/project-timeline-chart
mai/pauli/fristen-logic-audit
mai/pauli/determinator-b1-row-by
mai/noether/tools-cleanup-slice-1
mai/kelvin/inventor-tools-surface
mai/planck/paliadin-per-user-rls
mai/maxwell/bug-bundle-filterbar
mai/faraday/project-timeline-chart
mai/schroedinger/smarttimeline-slice-4
mai/bohr/smarttimeline-slice-3
mai/gauss/smarttimeline-slice-2
mai/riemann/filterbar-phase-2-slice
mai/lagrange/smarttimeline-design-the
mai/curie/researcher-determinator
mai/noether/collapse-regel-typ-on
mai/riemann/inventor-universal
mai/minkowski/project-level-our-side
mai/dirac/inventor-inline-paliadin
mai/feynman/fristenrechner
mai/minkowski/navbar-dashboard-reorg
mai/shannon/approval-rework
mai/einstein/consultant-deadline-data
mai/curie/researcher-upc-rop-audit
mai/noether/paliadin-real-claude
mai/noether/inventor-paliadin
mai/hilbert/inventor-approval-policy
mai/shannon/bug-frist-due-date
mai/fritz/bug-fristen-termine
mai/godel/inventor-projects-page
mai/fritz/bug-paliadin-chat
mai/kepler/inventor-profession-vs
mai/noether/inventor-paliadin-in-app
mai/fritz/bulk-team-email-send-to
mai/noether/inventor-local-chat-for
mai/noether/inventor-data-display
mai/fritz/bug-derived-team-members
mai/fritz/bug-sidebar-visibly
mai/noether/inventor-project
mai/shannon/bug-project-team-add
mai/cronus/inventor-dual-control
mai/fritz/bug-edit-mode-on
mai/cronus/inventor-holidays-per
mai/ritchie/phase-h-ai-deadline
No results found.
No Label
Milestone
No items
No Milestone
Projects
Clear projects
No project
Notifications
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: m/paliad#143
Reference in New Issue
Block a user
Blocking a user prevents them from interacting with repositories, such as opening or commenting on pull requests or issues. Learn more about blocking a user.
No description provided.
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Context
Follow-up to issue #142 (which covered just the 6 UPC PI respondent gaps surfaced during HL/mWorkRepo's Schulung prep). m asked: extract every event from the UPC RoP systematically and cross-reference against paliad's catalog.
Researcher (
darwinworker on HL/mWorkRepo) completed the full extraction. Output committed at441a59bon HL/mWorkRepo:UPC RoP Event Catalog 2026-05.md- 319 events from 303 RoP rules, 657 linesUPC RoP - Catalog Gaps 2026-05.md- 580 linesUPC RoP - Event Connection Graph 2026-05.md- 218 lines, mermaid parent->child diagramsScale
is_active=true,lifecycle_state='published'), across 18 proceeding_types + 77 distinct RoP ruleslegal_source)This is roughly 13% RoP coverage in paliad today. The remainder is editorial backlog.
Missing proceeding_type codes (27)
Grouped by category, with the count of new events per type:
Cross-cutting / framework
generalupc.case.mgmtupc.serviceupc.representationupc.partiesupc.feesupc.legalaidupc.languageupc.reestablishmentPre-action / standalone procedures
upc.optout.cfiupc.dni.cfiupc.epo.review.cfiCFI sub-phases (currently bundled into upc.inf.cfi in paliad)
upc.cfi.interimupc.cfi.oralupc.cfi.decisionupc.costs.cfiupc.security.cfiEvidence procedures
upc.evidence.cfiupc.bsv.cfiupc.inspection.cfiupc.freezing.cfiupc.experiments.cfiAppeal-side
upc.rehearing.coaupc.interventionExceptional
upc.defaultupc.specialupc.withdrawalPlus: gaps within existing proceeding_types
The 18 proceeding_types already in paliad also have gaps — events in the RoP that map to those types but aren't yet seeded. The gap report (§1.B) breaks these out. Examples:
upc.inf.cfi: missing Application to Amend Patent timeline events, Defence to amendment, defendant's reply to PA defence, etc.upc.pi.cfi: the 6 from issue #142 + the few above (interim/oral/decision)upc.cfa.coa: appeal-stage interim procedure events, cross-appeal timing variantsRecommended editorial workflow
Don't try to seed all 279 at once. Per the gap report's §5 Open Questions:
Decide naming convention first. Existing paliad codes (
upc.<proc>.<phase>.<action>) work for most, but the 27 new types need stable codes before seeding. The proposed codes above are darwin's suggestions — m / paliad/head review before locking in.Decide proceeding_type granularity. Should
upc.cfi.interim/upc.cfi.oral/upc.cfi.decisionbe standalone, or sub-codes ofupc.inf.cfi/upc.rev.cfi? Affects whether the count is 27 new types or fewer.Prioritize seeding by user impact. Highest-impact first (= what HL PAs actually run into daily):
upc.bsv.cfi(Beweissicherung — 18 events, PA-relevant)upc.optout.cfi(3 events, every patent matter)upc.dni.cfi(6 events, defensive standard)upc.cfi.interim/oral/decision(15 events, every contested matter)upc.epo.review.cfi(17 events, EPO-bridge)general,upc.fees,upc.legalaid)Per proceeding_type, file a separate sub-issue linking back here. Lets editorial work parallelize. Or batch-seed via CSV import if
/admin/rulessupports that.Reconfirm fristen against RoP volltext before publishing. darwin's frist values are extracted verbatim from rule text; paliad's normalization (days/months conversion) may need a second pass.
Out of scope (deferred follow-ups)
Source documents in HL/mWorkRepo
Commit
441a59b(today, 2026-05-26):mainThe three files are the authoritative source. paliad-side seeding decisions go back to those for verification.
Related
3 - areas/UPC/UPC Deadlines - PA Workflow Framework.mdDrafts staged (lifecycle_state=
draft)darwin(researcher, t-paliad-314) seeded the full §1.A + §1.B catalog gap as drafts on the live youpc Supabase paliad schema. All rows areis_active=true,lifecycle_state='draft', so they do NOT show up in the production picker until m reviews + publishes them via/admin/rules.Total drafts staged for #143: 256
Plus 6 PI-respondent drafts for #142 = 262 drafts total across both issues.
Phase 1 — 28 new proceeding_types created
The issue listed 27 missing codes; I created 28 because issue #142 also called for a new
upc.pl.cfi(Protective Letter / Schutzschrift) as its own proceeding_type. All 28 areis_active=true,category='fristenrechner',jurisdiction='UPC',display_orderbetween 921 and 992 (so they sort after the existing UPC types and before the archived placeholder).Naming adaptation for the CHECK constraint
^[a-z]+\.[a-z]+\.[a-z]+$: the proposed 2-segment codes (general,upc.fees,upc.legalaid, etc.) violated the 3-segment shape. I appended a stable third segment:generalupc.general.ropupc.serviceupc.service.ropupc.representationupc.representation.ropupc.partiesupc.parties.changeupc.feesupc.fees.courtupc.legalaidupc.legalaid.cfiupc.languageupc.language.ropupc.reestablishmentupc.reestablishment.ropupc.interventionupc.intervention.ropupc.defaultupc.default.cfiupc.specialupc.special.cfiupc.withdrawalupc.withdrawal.ropupc.epo.review.cfi(4-seg)upc.epo.reviewAll others (
upc.optout.cfi,upc.dni.cfi,upc.cfi.interim/oral/decision,upc.costs.cfi,upc.security.cfi,upc.evidence.cfi,upc.bsv.cfi,upc.inspection.cfi,upc.freezing.cfi,upc.experiments.cfi,upc.rehearing.coa) match the issue's proposal verbatim.m: ratify the renames before publish. If you prefer a different third segment (
.geninstead of.rop,.procfor procedural cross-cuts, etc.), flag them; the proceeding_types table isREAD-writefor admin and a single UPDATE per code rotates them cleanly.Phase 2 — 256 deadline_rules drafts
Distribution by proceeding_type (the 9 existing types in column 2 reflect §1.B "partial proceedings, sub-rows missing" gaps — these add to the published rows rather than replacing them):
upc.epo.reviewupc.apl.unifiedupc.bsv.cfiupc.ccr.cfiupc.evidence.cfiupc.inf.cfiupc.general.ropupc.pi.cfiupc.service.ropupc.dmgs.cfiupc.legalaid.cfiupc.rev.cfiupc.cfi.interimupc.disc.cfiupc.language.ropupc.pl.cfi(new)upc.parties.changeupc.fees.courtupc.case.mgmtupc.dni.cfiupc.cfi.oralupc.rehearing.coaupc.intervention.ropupc.default.cfiupc.representation.ropupc.security.cfiupc.optout.cfiupc.costs.cfiupc.experiments.cfiupc.reestablishment.ropupc.special.cfiupc.inspection.cfiupc.cfi.decisionupc.freezing.cfiupc.withdrawal.ropRepresentative sample (10 of 256)
upc.optout.cfi.rop_5a_3upc.dni.cfi.rop_67upc.epo.review.rop_88_1upc.cfi.interim.rop_101_3upc.cfi.oral.rop_113_1upc.bsv.cfi.rop_197_3upc.bsv.cfi.rop_198_1upc.legalaid.rop_379_2upc.fees.rop_371_4upc.apl.unified.rop_223_1Where to review
upc.bsv.cfi(18 drafts) for a Beweissicherung sweep,upc.legalaid.cfi(10 drafts) for legal-aid coverage.Auto-extraction provenance & known limits
Every draft was generated by parsing the three reference docs in HL/mWorkRepo @
441a59bonmain:UPC RoP Event Catalog 2026-05.mdUPC RoP - Catalog Gaps 2026-05.mdUPC RoP - Event Connection Graph 2026-05.mdThe Python extractor (
/tmp/paliad-t314/gen_inserts.py, kept for re-runs) maps the catalog's "Rule | Party | Frist | Trigger | Prio | Source" tables todeadline_rulesrows. It is heuristic, and m should treat every draft as a candidate to ratify, edit, or reject — NOT as a publication-ready rule. Specifically:Names are auto-generated — German + English event labels were synthesised from RoP source-text keywords. ~60% read cleanly ("Klageerwiderung (UPC.RoP.67)", "Vorladung zur mündlichen Verhandlung (UPC.RoP.108)"); the rest are placeholder ("Ereignis UPC.RoP.93.3" / "Event UPC.RoP.93.3") for rules whose source text didn't trigger a heuristic. m should rename these before publish — the placeholder is intentionally ugly so it stands out in the editor.
Primary_party is NULL on ~30 rows where the catalog flagged
?(ambiguous in the RoP itself, often referring to the operative actor by reference to a different rule). m must set these explicitly toclaimant/defendant/court/bothbefore publish — the picker won't show party badges otherwise.Frist values are extracted verbatim from rule text. R.198.1 carries the awkward "20 working_dayss (working)" string from the catalog because the source RoP rule combines "31 calendar days OR 20 working days". The extractor picked 20 working_days; m may want both as alt_duration_value + combine_op='max'.
rule_code style: I used
RoP.X.Y.z(e.g.RoP.197.3) — matches the existing paliad convention (cf.RoP.220.1.aon the publishedupc.pi.cfi.appeal_spawnrow).legal_source style: full
UPC.RoP.X.Y.zform — also matches existing rows.No
parent_idortrigger_event_idlinkages set. The Event Connection Graph has parent→child relationships, but resolving them to specific draftids programmatically would require a second pass. m can wire them in/admin/rulesper rule, or I can extend the extractor in a follow-up.Dual-write side-tables (
legal_sources/procedural_events/sequencing_rules). The bulk INSERT bypassed the Go service layer'ssyncDualWriteFromDeadlineRulecall (it ran as direct SQL). If the B.2 read-cutover is still scheduled, m may want to either (a) run a one-shot dual-write projection script after publishing, or (b) hold publish until B.3 closes the dual-write window.Ambiguous calls for m to ratify legally before publish
darwinran the legal-judgement pass withmai-lexyheuristics. These five rows deviate from what a strict RoP read would suggest:upc.cfi.interim,upc.cfi.oral,upc.cfi.decision— open question §5 from the gap report asks whether these should be standalone proceeding_types or sub-codes ofupc.inf.cfi/upc.rev.cfi. I seeded them as standalone (matches the issue's recommended structure). If m prefers a flatupc.inf.cfi.*namespace instead, mark the 15 drafts (9+5+1) for delete and reassign — single UPDATE onproceeding_type_idwill move them.upc.protective.letterrename →upc.pl.cfi— the gap report referenced the proceeding asupc.protective.letter(24-char, 3-segment-but-long). I usedupc.pl.cfifor compactness and to mirrorupc.pi.cfi/upc.rev.cfi/upc.inf.cfi. The CHECK constraint accepts both shapes; m's preference between brevity (pl) and clarity (protective.letter) governs.upc.epo.review(3-seg) vs.upc.epo.review.cfi(4-seg) — issue proposed 4-segment; constraint allows max 3. I dropped.cfi. EPO reviews are ex-parte CFI procedures, so the.cfiwas just a tag, not a discriminator. m: confirm.§2.A "paliad rows without legal_source" — the gap report flags 18 existing rules (e.g.
upc.pi.cfi.app,upc.dmgs.cfi.oral) as missing UPC.RoP citations. I did NOT touch these because they're already published; the task explicitly said "READ-ONLY on existing rules". m may want a follow-up issue to backfill their legal_source values once the new drafts land.R.220.1 cross-proceeding appeal_spawn — open question §5.4 asks whether DNI / books-laying / ex-parte BSV decisions need their own
*.appeal_spawnrows. I did NOT seed these because the catalog gap doc doesn't list R.220.1 as a row in §1.A or §1.B (it's already in paliad under*.appeal_spawnfor the 5 mainstream proceedings). m: if you want the DNI/BSV/PI-extra appeal_spawn rows added, file a follow-up — they'd be a one-INSERT-per-proceeding pattern.Open editorial-workflow items (from §5 of the gap report)
reply/ 4rejoinevents that could symmetric-rename (e.g.upc.inf.cfi.reply→upc.inf.cfi.reply_sod). I did NOT rename existing rows. Decide first, then a renaming pass can run separately.Files preserved for review / re-run
/tmp/paliad-t314/gen_inserts.py— extractor (Python 3)/tmp/paliad-t314/inserts.sql— 256-row SQL bundle, no schema-rewrite/tmp/paliad-t314/bulk2.go— Go runner that issued the transaction/tmp/paliad-t314/chunks/— 7 chunked variants (40-row each) if you want to re-execute viamcp__supabase__execute_sqlstep-wiseCross-context
441a59bonmain(2026-05-26, darwin)proceeding_types: ids 161–188 inpaliad.proceeding_types— darwin (researcher) · t-paliad-314 · 2026-05-26