-- Phase A seed: 32 UPC + 4 ZPO civil deadline rules. -- Ported from /home/m/dev/KanzlAI/backend/seed/seed_upc_timeline.sql, -- adapted to the paliad schema (no tenant_id, table paliad.deadline_rules). DO $$ DECLARE -- Proceeding-type FKs v_inf integer; v_rev integer; v_ccr integer; v_apm integer; v_app integer; v_amd integer; v_zpo integer; -- INF event IDs v_inf_soc uuid; v_inf_prelim uuid; v_inf_sod uuid; v_inf_reply uuid; v_inf_rejoin uuid; v_inf_interim uuid; v_inf_oral uuid; v_inf_decision uuid; -- CCR event IDs v_ccr_root uuid; v_ccr_defence uuid; v_ccr_reply uuid; v_ccr_rejoin uuid; v_ccr_interim uuid; v_ccr_oral uuid; v_ccr_decision uuid; -- REV event IDs v_rev_app uuid; v_rev_defence uuid; v_rev_reply uuid; v_rev_rejoin uuid; v_rev_interim uuid; v_rev_oral uuid; v_rev_decision uuid; -- PI event IDs v_pi_app uuid; v_pi_resp uuid; v_pi_oral uuid; -- APP event IDs v_app_notice uuid; v_app_grounds uuid; v_app_response uuid; v_app_oral uuid; BEGIN SELECT id INTO v_inf FROM paliad.proceeding_types WHERE code = 'INF'; SELECT id INTO v_rev FROM paliad.proceeding_types WHERE code = 'REV'; SELECT id INTO v_ccr FROM paliad.proceeding_types WHERE code = 'CCR'; SELECT id INTO v_apm FROM paliad.proceeding_types WHERE code = 'APM'; SELECT id INTO v_app FROM paliad.proceeding_types WHERE code = 'APP'; SELECT id INTO v_amd FROM paliad.proceeding_types WHERE code = 'AMD'; SELECT id INTO v_zpo FROM paliad.proceeding_types WHERE code = 'ZPO_CIVIL'; -- ======================================================================== -- INFRINGEMENT (INF) — 9 rules -- ======================================================================== v_inf_soc := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_inf_soc, v_inf, NULL, 'inf.soc', 'Statement of Claim', 'Claimant files the statement of claim with the Registry', 'claimant', 'filing', true, 0, 'months', NULL, NULL, false, NULL, 0, true); v_inf_prelim := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_inf_prelim, v_inf, v_inf_soc, 'inf.prelim', 'Preliminary Objection', 'Defendant raises preliminary objection (jurisdiction, admissibility)', 'defendant', 'filing', false, 1, 'months', 'R.19', 'Rarely triggers separate decision; usually decided with main case', false, NULL, 1, true); v_inf_sod := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_inf_sod, v_inf, v_inf_soc, 'inf.sod', 'Statement of Defence', 'Defendant files the statement of defence', 'defendant', 'filing', true, 3, 'months', 'RoP.023', NULL, false, NULL, 2, true); v_inf_reply := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_inf_reply, v_inf, v_inf_sod, 'inf.reply', 'Reply to Defence', 'Claimant''s reply to the statement of defence (includes Defence to Counterclaim if CCR active)', 'claimant', 'filing', true, 2, 'months', 'RoP.029b', NULL, false, NULL, 1, true); v_inf_rejoin := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_inf_rejoin, v_inf, v_inf_reply, 'inf.rejoin', 'Rejoinder', 'Defendant''s rejoinder to the reply', 'defendant', 'filing', true, 1, 'months', 'RoP.029c', NULL, false, NULL, 0, true); v_inf_interim := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_inf_interim, v_inf, v_inf_rejoin, 'inf.interim', 'Interim Conference', 'Interim conference with the judge-rapporteur', 'court', 'hearing', true, 0, 'months', NULL, NULL, false, NULL, 0, true); v_inf_oral := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_inf_oral, v_inf, v_inf_interim, 'inf.oral', 'Oral Hearing', 'Oral hearing before the panel', 'court', 'hearing', true, 0, 'months', NULL, NULL, false, NULL, 0, true); v_inf_decision := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_inf_decision, v_inf, v_inf_oral, 'inf.decision', 'Decision', 'Panel delivers its decision', 'court', 'decision', true, 0, 'months', NULL, NULL, false, NULL, 0, true); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (gen_random_uuid(), v_app, v_inf_decision, 'inf.appeal', 'Appeal', 'Appeal against infringement decision to Court of Appeal', 'both', 'filing', true, 2, 'months', 'RoP.220.1', NULL, true, 'Appeal filed', 0, true); -- ======================================================================== -- COUNTERCLAIM FOR REVOCATION (CCR) — 8 rules -- ======================================================================== v_ccr_root := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_ccr_root, v_ccr, v_inf_sod, 'ccr.counterclaim', 'Counterclaim for Revocation', 'Defendant files counterclaim challenging patent validity (included in SoD)', 'defendant', 'filing', true, 0, 'months', NULL, NULL, true, 'Includes counterclaim for revocation', 0, true); v_ccr_defence := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_ccr_defence, v_ccr, v_ccr_root, 'ccr.defence', 'Defence to Counterclaim', 'Patent proprietor files defence to revocation counterclaim', 'claimant', 'filing', true, 3, 'months', 'RoP.050', NULL, false, NULL, 0, true); v_ccr_reply := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_ccr_reply, v_ccr, v_ccr_defence, 'ccr.reply', 'Reply in CCR', 'Reply in the counterclaim for revocation', 'defendant', 'filing', true, 2, 'months', NULL, 'Timing overlaps with infringement Rejoinder', false, NULL, 1, true); v_ccr_rejoin := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_ccr_rejoin, v_ccr, v_ccr_reply, 'ccr.rejoin', 'Rejoinder in CCR', 'Rejoinder in the counterclaim for revocation', 'claimant', 'filing', true, 2, 'months', NULL, NULL, false, NULL, 0, true); v_ccr_interim := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_ccr_interim, v_ccr, v_ccr_rejoin, 'ccr.interim', 'Interim Conference', 'Interim conference covering revocation issues', 'court', 'hearing', true, 0, 'months', NULL, 'May be combined with infringement IC', false, NULL, 0, true); v_ccr_oral := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_ccr_oral, v_ccr, v_ccr_interim, 'ccr.oral', 'Oral Hearing', 'Oral hearing on validity', 'court', 'hearing', true, 0, 'months', NULL, NULL, false, NULL, 0, true); v_ccr_decision := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_ccr_decision, v_ccr, v_ccr_oral, 'ccr.decision', 'Decision', 'Decision on validity of the patent', 'court', 'decision', true, 0, 'months', NULL, NULL, false, NULL, 0, true); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (gen_random_uuid(), v_app, v_ccr_decision, 'ccr.appeal', 'Appeal', 'Appeal against revocation decision to Court of Appeal', 'both', 'filing', true, 2, 'months', 'RoP.220.1', NULL, true, 'Appeal filed', 0, true); -- AMD spawn from CCR Defence INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (gen_random_uuid(), v_amd, v_ccr_defence, 'ccr.amend', 'Application to Amend Patent', 'Patent proprietor applies to amend the patent during revocation proceedings', 'claimant', 'filing', false, 0, 'months', NULL, NULL, true, 'Includes application to amend patent', 2, true); -- ======================================================================== -- STANDALONE REVOCATION (REV) — 7 rules -- ======================================================================== v_rev_app := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_rev_app, v_rev, NULL, 'rev.app', 'Application for Revocation', 'Applicant files standalone application for revocation of the patent', 'claimant', 'filing', true, 0, 'months', NULL, NULL, false, NULL, 0, true); v_rev_defence := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_rev_defence, v_rev, v_rev_app, 'rev.defence', 'Defence to Revocation', 'Patent proprietor files defence to revocation application', 'defendant', 'filing', true, 3, 'months', NULL, NULL, false, NULL, 0, true); v_rev_reply := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_rev_reply, v_rev, v_rev_defence, 'rev.reply', 'Reply', 'Reply in standalone revocation proceedings', 'claimant', 'filing', true, 2, 'months', NULL, NULL, false, NULL, 1, true); v_rev_rejoin := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_rev_rejoin, v_rev, v_rev_reply, 'rev.rejoin', 'Rejoinder', 'Rejoinder in standalone revocation proceedings', 'defendant', 'filing', true, 2, 'months', NULL, NULL, false, NULL, 0, true); v_rev_interim := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_rev_interim, v_rev, v_rev_rejoin, 'rev.interim', 'Interim Conference', 'Interim conference with the judge-rapporteur', 'court', 'hearing', true, 0, 'months', NULL, NULL, false, NULL, 0, true); v_rev_oral := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_rev_oral, v_rev, v_rev_interim, 'rev.oral', 'Oral Hearing', 'Oral hearing on validity in standalone revocation', 'court', 'hearing', true, 0, 'months', NULL, NULL, false, NULL, 0, true); v_rev_decision := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_rev_decision, v_rev, v_rev_oral, 'rev.decision', 'Decision', 'Decision on patent validity', 'court', 'decision', true, 0, 'months', NULL, NULL, false, NULL, 0, true); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (gen_random_uuid(), v_app, v_rev_decision, 'rev.appeal', 'Appeal', 'Appeal against revocation decision to Court of Appeal', 'both', 'filing', true, 2, 'months', 'RoP.220.1', NULL, true, 'Appeal filed', 0, true); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (gen_random_uuid(), v_amd, v_rev_defence, 'rev.amend', 'Application to Amend Patent', 'Patent proprietor applies to amend the patent', 'claimant', 'filing', false, 0, 'months', NULL, NULL, true, 'Includes application to amend patent', 2, true); -- ======================================================================== -- PROVISIONAL MEASURES (APM) — 4 rules -- ======================================================================== v_pi_app := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_pi_app, v_apm, NULL, 'pi.app', 'Application for Provisional Measures', 'Claimant files application for preliminary injunction', 'claimant', 'filing', true, 0, 'months', NULL, NULL, false, NULL, 0, true); v_pi_resp := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_pi_resp, v_apm, v_pi_app, 'pi.response', 'Response to PI Application', 'Defendant files response to preliminary injunction application', 'defendant', 'filing', true, 0, 'months', NULL, 'Deadline set by court', false, NULL, 0, true); v_pi_oral := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_pi_oral, v_apm, v_pi_resp, 'pi.oral', 'Oral Hearing', 'Oral hearing on provisional measures', 'court', 'hearing', true, 0, 'months', NULL, NULL, false, NULL, 0, true); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (gen_random_uuid(), v_apm, v_pi_oral, 'pi.order', 'Order on Provisional Measures', 'Court issues order on preliminary injunction', 'court', 'decision', true, 0, 'months', NULL, NULL, false, NULL, 0, true); -- ======================================================================== -- APPEAL standalone (APP) — 5 rules -- ======================================================================== v_app_notice := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_app_notice, v_app, NULL, 'app.notice', 'Notice of Appeal', 'Appellant files notice of appeal with the Court of Appeal', 'both', 'filing', true, 0, 'months', NULL, NULL, false, NULL, 0, true); v_app_grounds := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_app_grounds, v_app, v_app_notice, 'app.grounds', 'Statement of Grounds of Appeal', 'Appellant files statement of grounds', 'both', 'filing', true, 2, 'months', 'RoP.220.1', NULL, false, NULL, 0, true); v_app_response := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_app_response, v_app, v_app_grounds, 'app.response', 'Response to Appeal', 'Respondent files response to the appeal', 'both', 'filing', true, 2, 'months', NULL, NULL, false, NULL, 0, true); v_app_oral := gen_random_uuid(); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (v_app_oral, v_app, v_app_response, 'app.oral', 'Oral Hearing', 'Oral hearing before the Court of Appeal', 'court', 'hearing', true, 0, 'months', NULL, NULL, false, NULL, 0, true); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (gen_random_uuid(), v_app, v_app_oral, 'app.decision', 'Decision', 'Court of Appeal delivers its decision', 'court', 'decision', true, 0, 'months', NULL, NULL, false, NULL, 0, true); -- ======================================================================== -- ZPO Civil (ZPO_CIVIL) — 4 rules (LG first-instance skeleton) -- ======================================================================== INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (gen_random_uuid(), v_zpo, NULL, 'zpo.klage', 'Klageschrift', 'Kläger reicht Klageschrift ein', 'claimant', 'filing', true, 0, 'months', '§ 253 ZPO', NULL, false, NULL, 0, true); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (gen_random_uuid(), v_zpo, NULL, 'zpo.vertanz', 'Verteidigungsanzeige', 'Beklagter zeigt Verteidigungsabsicht an (2 Wochen nach Zustellung)', 'defendant', 'filing', true, 2, 'weeks', '§ 276 Abs. 1 S. 1 ZPO', 'Notfrist ab Zustellung der Klageschrift', false, NULL, 1, true); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (gen_random_uuid(), v_zpo, NULL, 'zpo.klageerw', 'Klageerwiderung', 'Beklagter reicht Klageerwiderung ein (mindestens 2 Wochen)', 'defendant', 'filing', true, 2, 'weeks', '§ 276 Abs. 1 S. 2 ZPO', 'Vom Gericht gesetzt, mindestens 2 Wochen', false, NULL, 2, true); INSERT INTO paliad.deadline_rules (id, proceeding_type_id, parent_id, code, name, description, primary_party, event_type, is_mandatory, duration_value, duration_unit, rule_code, deadline_notes, is_spawn, spawn_label, sequence_order, is_active) VALUES (gen_random_uuid(), v_zpo, NULL, 'zpo.berufung', 'Berufung', 'Berufung gegen erstinstanzliches Urteil (1 Monat ab Zustellung)', 'both', 'filing', true, 1, 'months', '§ 517 ZPO', 'Notfrist ab Zustellung des vollständigen Urteils', false, NULL, 3, true); -- ======================================================================== -- Conditional deadlines (from KanzlAI migration 040): -- Reply to Defence: rule code changes when CCR active (029b → 029a) -- Rejoinder: duration changes when CCR active (1 month → 2 months; 029c → 029d) -- ======================================================================== UPDATE paliad.deadline_rules SET condition_rule_id = v_ccr_root, alt_rule_code = 'RoP.029a' WHERE id = v_inf_reply; UPDATE paliad.deadline_rules SET condition_rule_id = v_ccr_root, alt_duration_value = 2, alt_duration_unit = 'months', alt_rule_code = 'RoP.029d' WHERE id = v_inf_rejoin; END $$;