Differences between revisions 60 and 61
Revision 60 as of 2018-04-12 10:00:26
Size: 25406
Editor: a.santurbano
Comment:
Revision 61 as of 2018-04-12 10:27:32
Size: 26075
Editor: a.santurbano
Comment:
Deletions are marked like this. Additions are marked like this.
Line 247: Line 247:
=== Servizio '''search/byNumeroAndPin''' === === Servizio search/byNumeroAndPin ===
Line 259: Line 259:
>* http://demo.izs.it/demo_farmaco_test/lov/ricettafornitura/ws/search/byNumeroAndPin/?numero=1515868293927&pin=5055

=== Servizio '''search/noPrivacy''' ===
 * http://demo.izs.it/demo_farmaco_test/lov/ricettafornitura/ws/search/byNumeroAndPin/?numero=1515868293927&pin=5055

=== Servizio search/noPrivacy/farmaci/ ===

Il servizio torna tutte le ricette contenenti solo farmaci per coloro che hanno espressamente richiesto di non avere una gestione forte (attraverso numero e pin) della privacy.
Line 265: Line 267:
 * '''<url_server>/lov/ricettafornitura/ws/search/noPrivacy/''' (dove <url_server> varia in base all'ambiente: test o produzione).  * '''<url_server>/lov/ricettafornitura/ws/search/noPrivacy/farmaci/''' (dove <url_server> varia in base all'ambiente: test o produzione).
Line 275: Line 277:
>* http://demo.izs.it/demo_farmaco_test/lov/ricettafornitura/ws/search/noPrivacy/?aziendaCodice=001BG093  * http://demo.izs.it/demo_farmaco_test/lov/ricettafornitura/ws/search/noPrivacy/farmaci/?aziendaCodice=001BG093

=== Servizio search/noPrivacy/mangimi/ ===

E' identico al servizio '''search/noPrivacy/farmaci/''' tranne per il fatto che torna tutte le ricette contenenti solo mangimi medicati per coloro che hanno espressamente richiesto di non avere una gestione forte (attraverso numero e pin) della privacy.

Esempio di chiamata del servizio di interrogazione:

 * http://demo.izs.it/demo_farmaco_test/lov/ricettafornitura/ws/search/noPrivacy/mangimi/?aziendaCodice=001BG093

Regole generali

Per la fornitura dei medicinali attraverso la ricetta elettronica valgono le seguenti regole generali, applicabili alle funzionalità disponibili tramite le maschere online e alle funzionalità disponibili tramite servizi web esposti:

  1. per l’erogazione dei medicinali veterinari la ricetta elettronica potrà essere recuperata tramite il numero identificativo e pin della stessa;
  2. i medicinali sono identificati in maniera univoca tramite il loro AIC;
  3. nella fornitura dei medicinali vanno riportati il codice di lotto e la data di scadenza dei medicinali movimentati;
  4. a seguito di evasione parziale, utilizzando sempre lo stesso numero identificativo di prescrizione e PIN è possibile completare la fornitura (farmaci mancanti).

Flusso di fornitura dei medicinali

Quanto di seguito va a descrivere il seguente flusso operativo relativamente alle operazioni effettuabili da un utente con profilo Farmacista:

farmacia-fornitura-flow.PNG

La fornitura di una ricetta avviene selezionando dal bottone Menu la voce Fornitura ricetta.

farmacia-menu.PNG

Fornitura mediante applicativo

Il sistema permette di effettuare la ricerca della ricetta sulla base di numero e pin o per quelle aziende che hanno effettuato espressa richiesta di rendere visibile a chiunque le proprie ricette. Di seguito sono evidenziate le due modalita operative nel caso si operi direttamente dal sistema informativo.

Ricerca ricetta mediante numero e pin

Una volta ottenuti:

  • Il NUMERO della ricetta

  • Il PIN della ricetta

E' possibile procedere alla fornitura dei farmaci inserendo nella maschera di ricerca della ricetta facendo attenzione alla scrittura del numero della ricetta affinché non contenga caratteri sporchi tipo ad esempio spazio che potrebbero impedire la corretta ricerca. Una volta inserito il numero è possibile procedere con la ricerca cliccando sul relativo bottone. Se la ricerca avrà esito positivo la tabella sottostante la form di ricerca restituirà un risultato, come nell'immagine di seguito

fornitura-ricerca-semplice.PNG

A questo punto è possibile accedere al dettaglio della fornitura in due modi:

  1. Doppio click sulla riga
  2. Selezione della riga e click sul bottone Visualizza Dettaglio

Verremo dunque spostati su una nuova maschera dove verrà richiesto l'inserimento del PIN della ricetta

fornitura-pin.PNG

Una volta inserito il PIN, se questo risulta corretto, avremo accesso alla maschera di dettaglio della fornitura

Ricerca ricetta per azienda con deroga sulla privacy

Le aziende zootecniche possono far richiesta di andare in deroga sulla gestione della privacy delle proprie ricette e rendere quindi queste visibili a chiunque; in questo caso se si sta effettuando una fornitura per un'azienda del genere bisogna cambiare il flag Deroga fornitura farmaci da No a Si, di conguenza la maschera cambierà come nell'immagine di sotto e sarà necessario inserire semplicemente il codice dell'azienda zootecnica in modo da aver accesso all'elenco delle ricette che è possibile fornire.

fornitura-ricerca-deroga.PNG

Dopo aver cliccato su ricerca è possiible selezionare un ricetta per la fornitura nel seguente modo:

  1. Doppio click sulla riga
  2. Selezione della riga e click sul bottone Visualizza Dettaglio

Maschera fornitura ricetta

fornitura-maschera.PNG

Com'è possibile evidenziare dall'immagine precedente possiamo suddividere l'area di lavoro in tre zone:

  1. Area blu: zona di riepilogo della ricetta
  2. Area verde: zona di vendita dei farmaci, dov'è inoltre possibile avere il dettaglio da ricetta
  3. Area rossa: zona relativa al dettaglio della vendita in caso siano state effettuate forniture parziali, utile nel caso ci si accorga che si è appena sbagliato ad effettuare la fornitura. Nel caso siano gia presenti forniture parziali effettuate dalla vostra farmacia, alla selezione del farmaco queste appariranno nella tabella evidenziata, come nella figura di seguito

Con il pulsante "Visualizza ricetta" è possibile aprire il PDF della ricetta emessa.

fornitura-parziale.PNG

E' possibile che la ricetta sia stata parzialmente fornita anche da altre farmacie. In tal caso non sarà possibile visualizzare il dettaglio di tali forniture. E' possibile pero' notare che una ricetta è stata parzialmente fornita, confrontando la quantità del prodotto da fornire con la richiesta iniziale della ricetta (visibile tramite il pulsante "Visualizza ricetta")

Fornitura di un farmaco

Per procedere con la fornitura di un farmaco è necessario selezionare il farmaco di interesse facendo:

  1. Doppio click sulla riga
  2. Selezione della riga e click sul bottone Vendita

Tale azione comporterà l'apertura di una popup come nell'immagine di seguito

fornitura-vendita.PNG

Com'è possibile evidenziare dall'immagine precedente possiamo suddividere l'area di lavoro in due zone:

  1. Area viola: zona di riepilogo della prescrizione relativa al farmaco che ci accingiamo a vendere
  2. Area gialla: zona di vendita dei farmaco

Una volta inseriti i campi obbligatori contraddistinti da un asterisco (*) rosso è possibile procedere alla fornitura del farmaco

Caso particolare: Sostituzione di un farmaco

Nel caso il farmaco richiesto dalla fornitura non risulti disponibile e si vuole procedere con una sostituzione è possibile:

  1. Procedere alla ricerca di eventuali Farmaci compatibili. Eventualmente facendo click sul bottone Vai al prontuario, verrete spostati nel Prontuario Farmaceutico Veterinario gestito dal Ministero della Salute, dal quale è possibile effettuare delle ricerche avanzate (es. Ricerca per principio attivo, ecc...). La ricerca sul prontuario è facoltativa, nel caso si è già a conoscenza della denominazione del farmaco da sostituire passare direttamente al punto 2;

  2. Una volta scelto il farmaco tornate sulla popup di vendita del farmaco, facendo click sul bottone evidenziato dal cerchio azzurro nell'immagine di sopra procedete alla cancellazione del farmaco prescritto dal Veterinario e inserite il nuovo farmaco da voi scelto digitandone il nome.

Per concludere la fornitura del farmaco è possibile far click sul bottone Vendi in basso a destra nella popup.

A parità di Farmaco, identificato dalle prime sei cifre dell'AIC, è possibile effettuare una maggiorazione relativamente al numero di scatole fornite. Il sistema prima richiederà se siete sicuri di effettuare la sostituzione:

fornitura-conferma-sostituzione.png

Dopo di che chiederà una seconda conferma come nella popup seguente:

fornitura-conferma-maggiorazione.png

Fornitura massiva mediante CSV

Oltre alle funzionalità online per la fornitura manuale delle ricette elettroniche (vendita dei medicinali), il sistema informativo permette di effettuare la registrazione “massiva” dei medicinali forniti tramite un file in formato CSV.

Tracciato del file CSV

Il file CSV deve avere la seguente struttura:

numero

pin

prodAic

flTipomedicinale

galenico

fornProdAic

numConfezioni

dtScadenza

numLotto

gtinCodice

tipodocumentoCodice

numDocumento

dtFornitura

1456923503953

4186

104862127

N

1

21/12/2030

testimportRidotto

E' obbligatorio passare l'intestazione delle colonne

Descrizione dei campi del tracciato

Vengono di seguito riportate le descrizioni dei campi obbligatori:

  • numero: numero della ricetta;

  • pin: pin della ricetta;

  • prodAic: AIC del medicinale veterinario da fornire (è il prodotto prescritto dal veterinario); NB: nel caso di sostituzione del medicinale bisogna inserire l’AIC del farmaco effettivamente fornito nel campo fornProdAic e questo campo non deve essere modificato, ma deve essere lasciato l’AIC del farmaco prescritto dal veterinario;

  • flTipomedicinale: flag che indica il tipo di medicinale fornito, i cui possibili valori sono:

    • "N": medicinale veterinario (prodotto autorizzato non galenico);
    • "S": galenico;
    • "C": mangime completo;
    • "X": mangime complementare;
    • "I": prodotto intermedio;
  • galenico: nel caso in cui il flTipomedicinale = ‘S’ questo campo deve essere popolato con la descrizione del galenico;

  • fornProdAic: AIC del prodotto fornito in sostituzione del medicinale prescritto; NB: da valorizzare solo se si stà effettuando una sostituzione del medicinale prescritto;

  • numConfezioni: numero confezioni fornite;

  • dtScadenza: data di scadenza. Se si forniscono medicinali con differenti lotti e con differenti date di scadenza è sufficiente compilare due distinte righe per lo stesso medicinale;

  • numLotto: numero di lotto.

Vengono di seguito riportate le descrizioni dei campi non obbligatori:

  • gtinCodice: codice GTIN del medicinale venduto;

  • tipodocumentoCodice: tipologia di documento collegato alla fornitura; i possibili valori di questo campo sono i seguenti:

    • R: Ricetta;

    • F: Fattura;

    • A: Altro documento;

    • D: Documento di trasporto;

  • dtFornitura: la data di fornitura (se non inserita il sistema considera la data odierna) (per ora disponibile solo in ambiente di test, entro fine Aprile 2018 sarà in ambiente reale)

Invio del file CSV

Per procedere all'import massivo delle forniture è sufficienete cliccare sul bottone “Import CSV forniture” nella maschera di fornitura dei medicinali. Verrà quindi aperta una popup come nell'immagine:

fornitura-popup-import-massivo.png

Nella popup si potrà scegliere il file da importare. Spuntare il flag “Consenti fornitura maggiorata” se nel csv che si va ad importare sono presenti delle sostituzioni dei medicinali prescritti, con numero di confezioni fornite maggiorate rispetto al numero di confezioni originariamente prescritte.

Logica di elaborazione

ATTENZIONE: la logica di elaborazione del file CSV inviato è di tipo “transazionale”, e prevede quindi che in caso di errori tutti i dati inviati vengano scartati.

Fornitura massiva mediante XML NSIS (Ambiente di TEST, DRAFT può esser soggetto a cambiamenti)

Il sistema è in grado recepire gli XML relativi alle comunicazioni che vengono mandate ad NSIS sulle forniture. Il tracciato risulta leggermente modificato rispetto a quanto necessario per NSIS in quanto è stata aggiunta una informazione aggiuntiva relativamente alla sostituzione dei farmaci. Di seguito è possibile scaricare l XSD necessario per generare XML compatibili con il nostro sistema informativo, dove si evidenzia (rispetto a quello "standard" NSIS) il campo aggiuntivo cod_orig che specifica il farmaco che originariamente era stato specificato dal Veterinario nella ricetta.

   1 <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" elementFormDefault="qualified" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
   2     <xs:element name="dataroot">
   3         <xs:complexType>
   4             <xs:sequence>
   5                 <xs:element ref="MITT" minOccurs="1" maxOccurs="unbounded" />
   6             </xs:sequence>
   7         </xs:complexType>
   8     </xs:element>
   9     <xs:element name="MITT">
  10         <xs:complexType>
  11             <xs:sequence>
  12                 <xs:element ref="DEST" minOccurs="1" maxOccurs="unbounded" />
  13             </xs:sequence>
  14             <xs:attribute name="id_mitt" use="required">
  15                 <xs:simpleType>
  16                     <xs:restriction base="xs:string">
  17                         <xs:pattern value="[0-9]{6}" />
  18                     </xs:restriction>
  19                 </xs:simpleType>
  20             </xs:attribute>
  21             <xs:attribute name="tipo_m" use="required">
  22                 <xs:simpleType>
  23                     <xs:restriction base="xs:string">
  24                         <xs:enumeration value="D" />
  25                         <xs:enumeration value="F" />
  26                     </xs:restriction>
  27                 </xs:simpleType>
  28             </xs:attribute>
  29         </xs:complexType>
  30     </xs:element>
  31     <xs:element name="DEST">
  32         <xs:complexType>
  33             <xs:sequence>
  34                 <xs:element ref="MOV" minOccurs="1" maxOccurs="unbounded" />
  35             </xs:sequence>
  36             <xs:attribute name="id_dest" use="optional">
  37                 <xs:simpleType>
  38                     <xs:restriction base="xs:string">
  39                         <xs:pattern value="[0-9]{6}|[0-9]{11}|[*]{0}" />
  40                     </xs:restriction>
  41                 </xs:simpleType>
  42             </xs:attribute>
  43             <xs:attribute name="tipo_d" use="required">
  44                 <xs:simpleType>
  45                     <xs:restriction base="xs:string">
  46                         <xs:enumeration value="W" />
  47                         <xs:enumeration value="K" />
  48                         <xs:enumeration value="Y" />
  49                         <xs:enumeration value="Z" />
  50                     </xs:restriction>
  51                 </xs:simpleType>
  52             </xs:attribute>
  53         </xs:complexType>
  54     </xs:element>
  55     <xs:element name="MOV">
  56         <xs:complexType>
  57             <xs:sequence>
  58                 <xs:element ref="DDT" minOccurs="1" maxOccurs="unbounded" />
  59             </xs:sequence>
  60             <xs:attribute name="tipo_mov" use="required">
  61                 <xs:simpleType>
  62                     <xs:restriction base="xs:string">
  63                         <xs:enumeration value="CM" />
  64                     </xs:restriction>
  65                 </xs:simpleType>
  66             </xs:attribute>
  67             <xs:attribute name="tipo_tr" use="required">
  68                 <xs:simpleType>
  69                     <xs:restriction base="xs:string">
  70                         <xs:enumeration value="T" />
  71                         <xs:enumeration value="E" />
  72                     </xs:restriction>
  73                 </xs:simpleType>
  74             </xs:attribute>
  75         </xs:complexType>
  76     </xs:element>
  77     <xs:element name="DDT">
  78         <xs:complexType>
  79             <xs:sequence>
  80                 <xs:element ref="RICETTA" minOccurs="1" maxOccurs="unbounded" />
  81             </xs:sequence>
  82             <xs:attribute name="d_tr" use="required">
  83                 <xs:simpleType>
  84                     <xs:restriction base="xs:date">
  85                         <xs:pattern value="20[0-9]{2}-[0-9]{2}-[0-9]{2}" />
  86                     </xs:restriction>
  87                 </xs:simpleType>
  88             </xs:attribute>
  89             <xs:attribute name="h_tr" use="optional">
  90                 <xs:simpleType>
  91                     <xs:restriction base="xs:string">
  92                         <xs:pattern value="[0-9]{2}:[0-9]{2}:[0-5]{1}[0-9]{1}|[*]{0}" />
  93                     </xs:restriction>
  94                 </xs:simpleType>
  95             </xs:attribute>
  96             <xs:attribute name="id_doc" use="required">
  97                 <xs:simpleType>
  98                     <xs:restriction base="xs:string">
  99                         <xs:pattern value="[0-9a-zA-Z \w _]{1,20}" />
 100                     </xs:restriction>
 101                 </xs:simpleType>
 102             </xs:attribute>
 103             <xs:attribute name="tipo_doc" use="required">
 104                 <xs:simpleType>
 105                     <xs:restriction base="xs:string">
 106                         <xs:enumeration value="D" />
 107                         <xs:enumeration value="F" />
 108                         <xs:enumeration value="A" />
 109                     </xs:restriction>
 110                 </xs:simpleType>
 111             </xs:attribute>
 112         </xs:complexType>
 113     </xs:element>
 114     <xs:element name="RICETTA">
 115         <xs:complexType>
 116             <xs:sequence>
 117                 <xs:element maxOccurs="unbounded" ref="AIC" />
 118             </xs:sequence>
 119             <xs:attribute name="cf_med_prs" use="required">
 120                 <xs:simpleType>
 121                     <xs:restriction base="xs:string">
 122                         <xs:pattern value="[a-zA-Z]{6}\d{2}[abcdehlmprstABCDEHLMPRST]\d{2}[a-zAZ]\d{3}[a-zA-Z]" />
 123                     </xs:restriction>
 124                 </xs:simpleType>
 125             </xs:attribute>
 126             <xs:attribute name="dat_ric" use="required">
 127                 <xs:simpleType>
 128                     <xs:restriction base="xs:date">
 129                         <xs:pattern value="20[0-9]{2}-[0-9]{2}-[0-9]{2}" />
 130                     </xs:restriction>
 131                 </xs:simpleType>
 132             </xs:attribute>
 133             <xs:attribute name="num_ric" use="required">
 134                 <xs:simpleType>
 135                     <xs:restriction base="xs:integer">
 136                         <xs:maxInclusive value="1000000" />
 137                     </xs:restriction>
 138                 </xs:simpleType>
 139             </xs:attribute>
 140             <xs:attribute name="tipo_ric" use="required">
 141                 <xs:simpleType>
 142                     <xs:restriction base="xs:string">
 143                         <xs:enumeration value="1" />
 144                     </xs:restriction>
 145                 </xs:simpleType>
 146             </xs:attribute>
 147         </xs:complexType>
 148     </xs:element>
 149     <xs:element name="AIC">
 150         <xs:complexType>
 151             <xs:attribute name="t_prod" use="required">
 152                 <xs:simpleType>
 153                     <xs:restriction base="xs:string">
 154                         <xs:enumeration value="1" />
 155                         <xs:enumeration value="8" />
 156                         <xs:enumeration value="9" />
 157                     </xs:restriction>
 158                 </xs:simpleType>
 159             </xs:attribute>
 160             <xs:attribute name="cod" use="required">
 161                 <xs:simpleType>
 162                     <xs:restriction base="xs:string">
 163                         <xs:pattern value="[0-9]{9}|[0-9]{14}" />
 164                     </xs:restriction>
 165                 </xs:simpleType>
 166             </xs:attribute>
 167             <xs:attribute name="d_scad" use="optional">
 168                 <xs:simpleType>
 169                     <xs:restriction base="xs:date">
 170                         <xs:pattern value="20[0-9]{2}-[0-9]{2}-[0-9]{2}" />
 171                     </xs:restriction>
 172                 </xs:simpleType>
 173             </xs:attribute>
 174             <xs:attribute name="lot" use="required">
 175                 <xs:simpleType>
 176                     <xs:restriction base="xs:string">
 177                         <xs:maxLength value="40" />
 178                         <xs:minLength value="1" />
 179                         <xs:pattern value="[!-~ ]{0,}" />
 180                     </xs:restriction>
 181                 </xs:simpleType>
 182             </xs:attribute>
 183             <xs:attribute name="qta" use="required">
 184                 <xs:simpleType>
 185                     <xs:restriction base="xs:int">
 186                         <xs:minInclusive value="0" />
 187                         <xs:maxInclusive value="999999999" />
 188                     </xs:restriction>
 189                 </xs:simpleType>
 190             </xs:attribute>
 191             <xs:attribute name="cod_orig" use="optional">
 192                 <xs:simpleType>
 193                     <xs:restriction base="xs:string">
 194                         <xs:pattern value="[0-9]{9}|[0-9]{14}" />
 195                     </xs:restriction>
 196                 </xs:simpleType>
 197             </xs:attribute>
 198         </xs:complexType>
 199     </xs:element>
 200 </xs:schema>

fornitura-izs-nsis.xsd

Per quanto riguarda il flusso di import, è identico a quanto specificato sopra per il csv a parte che per iniziare bisogna cliccare sul bottone Import XML forniture

Fornitura massiva mediante servizio web REST JSON

Attenzione: versione DRAFT che può essere soggetta a cambiamenti.

Il sistema informativo permette di effettuare la registrazione “massiva” della fornitura di medicinali tramite l’invocazione di un servizio web REST JSON.

URL del servizio REST

Il servizio REST JSON è esposto al seguente URL (endpoint):

  • <url_server>/fornitura/ws/insert/ (dove <url_server> varia in base all'ambiente: test o produzione)

Tracciato JSON di INPUT

E’ possibile invocare il web service REST attraverso un tracciato JSON così formattato:

   1 [{
   2     "numero": "1479111882578",
   3     "pin": "3468",
   4     "prodAic": "105025011",
   5     "flTipomedicinale": "N",
   6     "galenico": "",
   7     "fornProdAic": "",
   8     "numConfezioni": "3",
   9     "dtScadenza": "14-11-2019",
  10     "numLotto": "XSS 123 A",
  11     "gtinCodice": "",
  12     "tipodocumentoCodice": "",
  13     "numDocumento": "",
  14     "farmacId": 12534
  15 }, {
  16     "numero": "1479117689369",
  17     "pin": "9657",
  18     "prodAic": "104807058",
  19     "flTipomedicinale": "N",
  20     "galenico": "",
  21     "fornProdAic": "",
  22     "numConfezioni": "7",
  23     "dtScadenza": "14-11-2019",
  24     "numLotto": "AB 34 A 3",
  25     "gtinCodice": "",
  26     "tipodocumentoCodice": "",
  27     "numDocumento": "",
  28     "farmacId": 12534
  29 }]

La semantica dei campi del tracciato JSON è la stessa dei corrispondenti campi utilizzati nella fornitura massiva mediante CSV. Per la loro descrizione fare quindi riferimento al relativo paragrafo. In aggiunta il tracciato JSON prevede i seguenti campi (per ora disponibile solo in ambiente di test, entro fine Aprile 2018 sarà in ambiente reale):

  • farmacId: identificativo della farmacia che sta effettuando la vendita del farmaco; è obbligatorio se nella propria lista dei profili si ha più di una farmacia, altrimenti il sistema considera automaticamente l'unico presente;

L’invocazione del servizio WEB REST deve avere i seguenti headers:

   1     Content-Type: application/json
   2     Accept: application/json

Tracciato JSON di OUTPUT

Il servizio REST risponderà con un JSON con il seguente formato:

   1 {
   2     "result": [...]
   3 }

Viene di seguito riportata la descrizione dei due campi del JSON restituito:

  • result: in questo campo, di tipo array, verranno collezionati i vari errori contenuti nei singoli elementi dell'array di importazione:

  • tale item è “null” se non si sono verificati errori;
  • nel caso in cui nel corso dell'elaborazione si fossero verificati errori, viene restituito un array che ha tanti elementi quanti gli elementi elaborati, e ad uno specifico indice dell’array corrisponde un errore rispetto allo specifico elemento inviato (l'elemento i-esimo dell'array in formato JSON inviato).

Autenticazione

Le modalità di autenticazione per l'invocazione dei servizi REST sono descritte nell'apposito paragrafo della sezione del manuale con le informazioni base e tecnologie adottate dal Sistema Informativo Nazionale della Farmacosorveglianza per l'integrazione con i sistemi esterni, accedibile tramite il seguente URL: farmaco/help/integrazione

Logica di elaborazione

ATTENZIONE: La logica di elaborazione del tracciato JSON inviato al servizio REST è di tipo “transazionale”, e prevede quindi che in caso di errori tutti i dati inviati vengano scartati.

Servizi Web di Interrogazione (ricerca e dati di dettaglio della ricetta)

Sono disponibili due differenti servizi REST JSON per la ricerca delle ricette e il recupero delle informazioni di dettaglio delle ricette stesse

  1. search/byNumeroAndPin: accesso alla ricetta tramite numero ricetta e PIN:

    • metodo da utilizzare per l'accesso ai dati della ricetta quando si conoscono il numero della ricetta e il suo PIN;
  2. search/noPrivacy: ricerca della ricetta tramite i dati identificativi dell'intestatario della ricetta:

    • utilizzabile solo quando l'intestatario della ricetta ha rinunciato alla privacy sulle ricette, e ha quindi reso possibile la ricerca ed accesso alle ricette ancora da "fornire" senza PIN;
    • se l'intestatario della ricetta non ha rinunciato alla privacy sulle sue ricette, l'invocazione di tale servizio non restituirà alcun dato.

Servizio search/byNumeroAndPin

Il servizio REST JSON è esposto al seguente URL (endpoint):

  • <url_server>/lov/ricettafornitura/ws/search/byNumeroAndPin/ (dove <url_server> varia in base all'ambiente: test o produzione).

In query string vanno passati obbligatoriamente i due seguenti parametri:

  • numero: numero della ricetta;

  • pin: pin della ricetta;

Esempio di chiamata del servizio di interrogazione:

Servizio search/noPrivacy/farmaci/

Il servizio torna tutte le ricette contenenti solo farmaci per coloro che hanno espressamente richiesto di non avere una gestione forte (attraverso numero e pin) della privacy.

Il servizio REST JSON è esposto al seguente URL (endpoint):

  • <url_server>/lov/ricettafornitura/ws/search/noPrivacy/farmaci/ (dove <url_server> varia in base all'ambiente: test o produzione).

In query string vanno passati alternativamente (solo uno dei parametri di input deve essere valorizzato) i seguenti parametri:

  • aziendaCodice: codice dell'azienda zootecnica, in questo caso il sistema ritorna tutte le ricette di tipo Prescrizione Veterinaria o Prescrizione per scorta struttura zootecnica relative al codice immesso;

  • propIdFiscale: codice fiscale o partita iva dell'intestatario della ricetta per Prescrizione Veterinaria PET (animali d'affezione);

  • strutturaCodice: codice della struttura non zootecnica intestataria della ricetta per Scorta struttura non zootecnica;

  • vetPersIdFiscale: codice fiscale o partita iva del veterinario intestatario della ricetta per Scorta propria;

Esempio di chiamata del servizio di interrogazione:

Servizio search/noPrivacy/mangimi/

E' identico al servizio search/noPrivacy/farmaci/ tranne per il fatto che torna tutte le ricette contenenti solo mangimi medicati per coloro che hanno espressamente richiesto di non avere una gestione forte (attraverso numero e pin) della privacy.

Esempio di chiamata del servizio di interrogazione:

Tracciato di output

Entrambi i servizi condividono un unico tracciato JSON di output.

Nel caso di ricerca tramite numero ricetta e PIN il servizio restituirà una sola ricetta, se in essa ci sono ancora dei medicinali da fornire. Nel caso di ricerca tramite l'intestatario della ricetta, il servizio restituirà l'elenco delle ricette per le quali è ancora possibile effettuare la fornitura (ricette da evadere o parzialmente evase).

L'output restituito è un JSON cosi formattato:

   1 [{
   2         "numero": "1515868293927",
   3         "pin": "5055",
   4         "presDtPrescrizione": "13-01-2018 00:00:00.000",
   5         "aziendaCodice": "001BG093",
   6         "propCognNome": "SASSELLA CATERINA BIONDO",
   7         "propIdFiscale": "SSSCRN34R62E200B",
   8         "detenCognNome": "SASSELLA CLAUDIO",
   9         "vetPersIdFiscale": "BRSGNN52L24C469G",
  10         "vetPersCognNome": "BORIOSI GIANNI",
  11         "tipoprescrizioneDescrizione": "Prescrizione Veterinaria",
  12         "tipoprescrizioneCodice": "PRESVET",
  13         "statoricettaDescrizione": "Emessa",
  14         "statoricettaCodice": "CONFERMATO",
  15         "medicinali": [{
  16                 "presrigaId": 1190624,
  17                 "quantitativo": 1,
  18                 "posologia": "POSOLOGIA",
  19                 "durataTrt": 1,
  20                 "flDeroga": "N",
  21                 "flTipomedicinale": "N",
  22                 "famAic": "102519",
  23                 "prodAic": "102519028",
  24                 "prodDenominazione": "AMMINOFARMA L 20%",
  25                 "prodConfezione": "FLACONE DA 1 LITRO",
  26                 "unimisCodice": "SCAT"
  27         },
  28         {
  29                 "presrigaId": 1190625,
  30                 "quantitativo": 2,
  31                 "posologia": "POSOLOGIA",
  32                 "durataTrt": 1,
  33                 "flDeroga": "N",
  34                 "flTipomedicinale": "N",
  35                 "famAic": "105026",
  36                 "prodAic": "105026013",
  37                 "prodDenominazione": "SUIVAC APP",
  38                 "prodConfezione": "FLACONE DA 50 ML (25 DOSI) DI SOLUZIONE INIETTABILE PER SUINI",
  39                 "unimisCodice": "SCAT"
  40         }]
  41 }]

ATTENZIONE: il campo quantitativo all'interno del JSON indica il numero di confezioni ancora da fornire e non la quantità prescritta (in caso di evasione parziale già effettuata il numero delle confezioni da fornire è inferiore al numero delle confezioni prescritte).

Nel caso di ricetta per mangimi medicati il json di output è il seguente:

   1 [{
   2     "numero": "1523524711100",
   3     "pin": "8373",
   4     "detenId": null,
   5     "presDtPrescrizione": "12-04-2018 00:00:00.000",
   6     "aziendaCodice": "041TE865",
   7     "propCognNome": "FILOCAMO MAURIZIO",
   8     "propIdFiscale": "FLCMRZ80B16H224C",
   9     "detenIdFiscale": null,
  10     "detenCognNome": null,
  11     "vetPersIdFiscale": "BRSGNN52L24C469G",
  12     "vetPersCognNome": "BORIOSI GIANNI",
  13     "tipoprescrizioneDescrizione": "Prescrizione Veterinaria",
  14     "tipoprescrizioneCodice": "PRESVET",
  15     "statoricettaDescrizione": "Emessa",
  16     "statoricettaCodice": "CONFERMATO",
  17     "vetNumAutorizzazione": null,
  18     "presFlDeroga": "N",
  19     "presNote": null,
  20     "strutturaId": null,
  21     "strutturaCodice": null,
  22     "strutturaDenominazione": null,
  23     "medicinali": [
  24         {
  25             "presrigaId": 1912859,
  26             "quantitativo": 1000,
  27             "posologia": "100",
  28             "note": null,
  29             "flDeroga": "N",
  30             "flTipomedicinale": "C",
  31             "unimisCodice": "Kg",
  32             "mangmedMangDenominazione": "MANGIME RICETTA n° 1523524711100-C",
  33             "premiscele": [
  34                 {
  35                     "famAic": "101988",
  36                     "famDenominazione": "SULFACHINOSSALINA 200 PREMIX",
  37                     "quantitativo": 1000
  38                 }
  39             ]
  40         }
  41     ]
  42 }]

Attenzione la sottostruttura premiscele contiene l'elenco delle premiscele specificate dal veterinario, mentre il campo mangmedMangDenominazione rappresenta la denominazione del mangime commerciale utilizzato, non essendo un campo richiesto obbligatoriamente all'utente, nel caso quest'ultimo non lo specifichi il sistema genererà una denominazione con la seguente codifica MANGIME RICETTA N° <NUMERO_RICETTA>-<CODICE_TIPO_MANGIME>

Descrizione dei campi del tracciato JSON di output

Vengono di seguito riportate le descrizioni dei campi obbligatori:

  • numero: numero della ricetta;

  • pin: pin della ricetta;

  • prodAic: AIC del medicinale veterinario da fornire (è il prodotto prescritto dal veterinario); NB: nel caso di sostituzione del medicinale bisogna inserire l’AIC del farmaco effettivamente fornito nel campo fornProdAic e questo campo non deve essere modificato, ma deve essere lasciato l’AIC del farmaco prescritto dal veterinario;

  • flTipomedicinale: flag che indica il tipo di medicinale fornito, i cui possibili valori sono:

    • "N": medicinale veterinario (prodotto autorizzato non galenico);
    • "S": galenico;
    • "C": mangime completo;
    • "X": mangime complementare;
    • "I": prodotto intermedio;
  • galenico: nel caso in cui il flTipomedicinale = ‘S’ questo campo deve essere popolato con la descrizione del galenico;

  • fornProdAic: AIC del prodotto fornito in sostituzione del medicinale prescritto; NB: da valorizzare solo se si stà effettuando una sostituzione del medicinale prescritto;

  • numConfezioni: numero confezioni fornite;

  • dtScadenza: data di scadenza. Se si forniscono medicinali con differenti lotti e con differenti date di scadenza è sufficiente compilare due distinte righe per lo stesso medicinale;

  • numLotto: numero di lotto.

Vengono di seguito riportate le descrizioni dei campi non obbligatori:

  • gtinCodice: codice GTIN del medicinale venduto;

  • tipodocumentoCodice: tipologia di documento collegato alla fornitura; i possibili valori di questo campo sono i seguenti:

    • R: Ricetta;

    • F: Fattura;

    • A: Altro documento;

    • D: Documento di trasporto;

  • dtFornitura: la data di fornitura (se non inserita il sistema considera la data odierna) (per ora disponibile solo in ambiente di test, entro fine Aprile 2018 sarà in ambiente reale)

Registro dei prodotti forniti

Il registro dei prodotti forniti è raggiungibile dall'apposita voce di menu. Qui è possibile visualizzare lo storico di tutte le forniture ed è inoltre possibile eventualmente effettuare delle azioni correttive sulle stesse.

Correzione dei dati della fornitura

E' possibile correggere i dati relativi ai campi Data di scadenza e Numero di Lotto, dopo aver effettuato una ricerca sulla tabellina è necessario far doppio click sulla riga di fornitura da modificare, si aprirà un pop-up dove è possibile modificare i campi, una volta conclusa la modifica per salvare i dati è sufficiente cliccare su bottone Aggiorna

Cancellazione dei dati in caso di errata fornitura

Se al momento della fornitura è stato inserito un quantitativo errato l'unico modo per procedere alla correzione del dato è cancellare la fornitura associata e poi ripetere l'azione. Una volta effettuata la ricerca dalla tabellina selezionare una o più righe da cancellare dopo di che premere il bottone Cancella selezionati in basso a destro.

Tabella dei prodotti ed esportazione in excel

Una volta effettuata la ricerca dalla tabellina dei risultati è possibile esportare in Excel il risultato come spiegato alla seguente pagine di manuale

farmaco/help/fornitura (last edited 2023-02-28 11:25:19 by r.sciamanna)