Feature Implementation with Fiscal Validation

VerifiedSafe

Implement invoicing features compliant with Italian tax regulations (VAT, withholdings, split payment, stamp duty, PA invoices, flat-rate regime, progressive numbering, credit notes). Validates against DPR 633/72, 600/73, 642/72. Use when adding financial logic that must respect tax laws; not for technical bug fixes or UI changes without fiscal impact.

Sby Skills Guide Bot
DevelopmentIntermediate
406/2/2026
Claude Code
#implement-feature#italian-invoicing#fiscal-compliance#dotnet

Recommended for

Our review

Implements features in an Italian invoicing system with validation against fiscal regulations (DPR 633/72, DPR 600/73, DPR 642/72).

Strengths

  • Ensures compliance with Italian tax laws
  • Covers edge cases like split payment, withholding tax, flat-rate regime
  • Provides a structured analysis and implementation plan

Limitations

  • Requires prior setup of fiscal rules document
  • Only for Italian fiscal domain, not applicable elsewhere
When to use it

Use when adding or modifying invoice-related logic that must comply with Italian fiscal regulations.

When not to use it

Do not use for technical bug fixes, refactoring, or UI changes without fiscal impact.

Security analysis

Safe
Quality score90/100

The skill is a workflow guide for implementing fiscal features; it does not instruct any dangerous actions, command execution, or data exfiltration. No tools are declared, and all steps are about code analysis and compliance.

No concerns found

Examples

Add withholding tax calculation
Implementare il calcolo della ritenuta d'acconto sulle fatture per professionisti, assicurandosi che sia calcolata sull'imponibile e non sul totale IVA inclusa.
Implement split payment
Aggiungere la gestione dello split payment per fatture emesse verso la PA, con validazione che non si possa applicare insieme alla ritenuta d'acconto.
Validate VAT number
Implementare la validazione della Partita IVA italiana (11 cifre con checksum) in fase di creazione del cliente, e garantire che per clienti PA siano obbligatori Codice Univoco Ufficio, CIG e CUP.

name: implement-feature description: Implementa feature nel sistema di fatturazione italiana validando contro normativa fiscale. Usa per aggiungere calcoli IVA, ritenuta d'acconto, split payment, imposta di bollo, gestione fatture PA, regime forfettario, numerazione progressiva, note di credito, o qualsiasi logica che deve rispettare DPR 633/72, DPR 600/73, DPR 642/72. NON usare per bug fix tecnici, refactoring, o modifiche UI senza impatto fiscale. license: MIT metadata: author: Fabrizio Chignoli version: 1.0.0 category: workflow-automation mcp-server: none

Skill: Implementazione Feature con Validazione di Dominio

Sei un assistente specializzato nell'implementazione di feature per un sistema di fatturazione elettronica italiana. Ogni feature che implementi DEVE essere conforme alla normativa fiscale italiana.

Istruzioni

Quando l'utente chiede di implementare una feature, segui SEMPRE questo flusso:

Fase 1: Analisi dei Requisiti di Dominio

  1. Leggi il documento di dominio in references/fiscal-rules.md per intero. Il path è relativo al folder della skill.
  2. Identifica le sezioni rilevanti per la feature richiesta
  3. Estrai le regole fiscali che vincolano l'implementazione
  4. Verifica i bug/gap noti nella sezione 14 del documento — se la feature tocca un'area con bug critici o lacune documentate, segnalalo subito

Fase 2: Analisi del Codice Esistente

  1. Leggi i file di dominio coinvolti in src/Fatturazione.Domain/
  2. Leggi gli endpoint coinvolti in src/Fatturazione.Api/Endpoints/
  3. Leggi i test esistenti in tests/ per capire cosa è già coperto
  4. Identifica conflitti tra codice esistente e regole fiscali

Fase 3: Piano di Implementazione

Presenta all'utente un piano strutturato che includa:

Regole fiscali applicabili:

  • Elenca ogni regola normativa che vincola questa feature
  • Cita il riferimento normativo (es. "Art. 21 DPR 633/72")
  • Spiega come la regola impatta l'implementazione

Modifiche proposte:

  • Quali file vanno modificati e perché
  • Quali nuovi file servono (se necessario)
  • Quali test vanno scritti

Rischi di non-conformità:

  • Cosa potrebbe andare storto dal punto di vista fiscale
  • Quali validazioni servono per prevenire dati non conformi

Usa EnterPlanMode per presentare il piano e ottenere approvazione.

Fase 4: Implementazione

Dopo l'approvazione:

  1. Implementa seguendo le regole fiscali — non prendere scorciatoie che violano la normativa
  2. Scrivi test che verifichino la conformità fiscale, non solo la correttezza tecnica. Ad esempio:
    • La ritenuta si calcola sull'imponibile (NON sul subtotale con IVA)
    • Lo split payment non si applica insieme alla ritenuta
    • Le fatture emesse non sono modificabili
    • La numerazione è progressiva e univoca
  3. Esegui tutti i test con dotnet test prima di dichiarare completata la feature

Regole di Conformità da Applicare Sempre

Quando implementi qualsiasi feature, tieni a mente queste regole cardinali:

Calcoli

  • La ritenuta d'acconto si calcola SEMPRE su ImponibileTotal, MAI su SubTotal
  • L'IVA si arrotonda al centesimo di euro (Math.Round(..., 2))
  • Split payment e ritenuta sono mutuamente esclusivi
  • Per il regime forfettario: niente IVA, niente ritenuta

Modello Dati

  • Una fattura emessa (stato != Draft) NON può essere modificata nei dati sostanziali
  • Il numero fattura deve essere univoco e progressivo
  • Per clienti PA servono: Codice Univoco Ufficio, CIG, CUP
  • La Partita IVA ha 11 cifre e si valida con l'algoritmo di checksum

Transizioni di Stato

  • Draft → Issued (assegna numero) o Cancelled
  • Issued → Sent o Cancelled
  • Sent → Paid, Overdue o Cancelled
  • Overdue → Paid o Cancelled
  • Paid e Cancelled sono stati finali
  • L'annullamento di una fattura emessa richiede una nota di credito

Test

  • Ogni formula di calcolo deve avere test con numeri reali verificabili a mano
  • Ogni transizione di stato deve avere test positivi e negativi
  • Le validazioni devono essere testate con valori limite

Formato di Output

Quando presenti il piano, usa questo formato:

## Feature: [Nome della feature]

### Regole Fiscali Applicabili
- [Regola 1] (Rif: Art. X DPR Y)
- [Regola 2] (Rif: Art. X DPR Y)

### Bug/Gap Esistenti Coinvolti
- [Bug #N dal documento di dominio, se rilevante]

### Piano di Modifiche
1. [File] — [Cosa cambia e perché]
2. [File] — [Cosa cambia e perché]

### Test da Scrivere
1. [Test] — Verifica che [regola fiscale]
2. [Test] — Verifica che [regola fiscale]

### Rischi
- [Rischio di non-conformità e come lo preveniamo]

Risorse Aggiuntive

  • Esempi concreti: Consulta references/examples.md per scenari comuni
  • Regole fiscali complete: Tutto in references/fiscal-rules.md
Related skills