Migration 4.7 vers la 5.0

Guide de migration vers la nouvelle version 5.0

La version 5.0 apporte son lot de nouveautés, et tend vers une intégration la plus souple avec le DMP mais aussi les autres téléservices de santé.

Cette version supporte encore les anciennes requêtes mais déprecient certaines notions.

Une nouvelle collection postman est disponible dans l’espace public Postman : https://www.postman.com/universal-satellite-657415/workspace/devbox-sante-exemples

Note et Historique de vaccination

Tout d’abord, nous avons ajouté le support de la note et historique de vaccinations, pour plus d’information consulter la documentation à ce sujet : /5.x/dmp/cda/vaccination

Gestion de l’INS améliorée

Pour être en conformité avec l’INSi et simplifier l’intégration entre les deux composants DMP et INSi, dans tous les objets faisant référence à un INS, le couple identifiant/autorité est dorénavant utilisé au lieu de spécifier cette autorité dans le contexte de la requête.

Par exemple, une requête (td0.2 test d’existence) en version 4.7 :

td0.2_4.7.png

devient en 5.0 :

td0.2_5.0.png

Bien sur, l’ancienne forme est encore supporté sur cette version mais il est fortement conseillé d’adopter la nouvelle forme.

Le même exemple en java, un test d’existence en 4.7 :

context.setInsNirAutorite(DMPCContext.DMPCInsNirAutorite.TEST);
TD02Response response = client.td02Exist(context, new TD02Request("277076322082910"));

devient en 5.0

var response = client.td02Exist(
                    context,  
                    TD02Request.builder()
                        .matriculeINS(Identifiant.builder()
                            .valeur("277076322082910")
                            .identifiantSysteme(Oids.ANS_1_2_250_1_213._1_4_10_INS_NIR_TEST.val())
                            .build())
                        .build()
                    );

Validation

Les messages de validation ont été améliorés en contextualisant la plupart des validations (en soumission, en récupération). Mais aussi plus finement, comme par exemple, la vérification qu’un code d’un document est bien dans son jeu de valeurs spécifique.

Quelques exemples de validations effectuées sur un DMPCDocument :

public class DMPCDocument {
...
    @CodeValid(jeuValeurs = DMPCCode.JeuxValeursDMP.FORMAT_CODE, groups = {OnSubmit.class})
    private DMPCCode formatCode;
...
    @NotNull(groups = {BinaryRequired.class})
    private byte[] content;
    
    @NotNull(groups = {OnRetrieve.class})
    private String entryUuid;

Exemple de message obtenu dorénavant pour un classCode erronné dans le document :

 "message": "Code 55 inexistant dans la nomenclature JDV_J57-ClassCode-DMP.tabs"

Par conséquent, certains contrôles sont plus sévères, et donc certains cas passant peuvent ne plus l’être. Par exemple, il n’est plus possible d’identifier un Personnel de santé avec un internalId sans préciser son identifiant de structure. Ou encore, une vérification du format des RPPS est effectué dans les documents envoyés.

Consulter, les sources pour visualiser les contrôles possibles : https://bitbucket.org/devbox-sante/devbox-sante-apis/src/master/dmpc-api

Ajout de la TD0.4

La documentation sur cette nouvelle transaction est ici

Autres évolutions

  • Suppression de la TD0.0

  • Meilleur gestion des cartes CPF (en formation)

  • Gestion multicertificats

  • Suppression de la transaction TD1.5

  • Suppression du statut Médecint Traitant (TD0.3)

  • Contrôle des formats d’identifiant (RPPS, FINESS …)

  • … et d’autres encore cf. le release note