7.1.2.8. Access-rest

7.1.2.8.1. Présentation

API REST appelées par le client access interne. Il y a un controle des paramètres (SanityChecker.checkJsonAll) transmis avec ESAPI.

7.1.2.8.2. Packages:

fr.gouv.vitam.access.external.config : contient les paramètres de configurations du service web d’application.

fr.gouv.vitam.access.external.model : classes métiers, classes implémentant le pattern DTO… .

fr.gouv.vitam.access.external.rest : classes de lancement du serveur d’application et du controlleur REST.

7.1.2.9. -AccessApplication.java

classe de démarrage du serveur d’application.

// démarrage
public static void main(String[] args) {
    try {
        startApplication(args);
        server.join();
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
}

Dans le startApplication on effectue le start de VitamServer. Le join permet de lancer les tests unitaires et d’arreter le serveur. Dans le fichier de configuration, le paramètre jettyConfig est à paramétrer avec le nom du fichier de configuration de jetty.

7.1.2.10. -AccessResourceImpl.java

classe controlleur REST La classe contient actuellement 9 méthodes :

  1. getUnits()

    NB : the post X-Http-Method-Override header

@POST
@Path("/units")
public Response getUnits(String requestDsl,
@HeaderParam("X-Http-Method-Override") String xhttpOverride) {
...
try {
if (xhttpOverride != null && "GET".equalsIgnoreCase(xhttpOverride)) {
    queryJson = JsonHandler.getFromString(requestDsl);
    result = accessModule.selectUnit(queryJson.toString());
} else {
    throw new AccessExecutionException("There is no 'X-Http-Method-Override:GET' as a header");
}
....
  1. createOrSelectUnits()

    Récupère la liste des units avec la filtre

    NB : La méthode HTTP GET n’est pas compatible, on utilisera une méthode HTTP POST dont l’entête contiendra « X-HTTP-Method-GET »

    méthode createOrSelectUnits() va appeler méthode getUnits()

    @POST
@Path("/units")
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
public Response createOrSelectUnits(JsonNode queryJson,
    @HeaderParam(GlobalDataRest.X_HTTP_METHOD_OVERRIDE) String xhttpOverride)
 ...
  1. getUnitById()

    récupère un unit avec son id

    NB : the post X-Http-Method-Override header

@POST
@Path("/units/{id_unit}")
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
public Response getUnitById(String queryDsl,
    @HeaderParam(GlobalDataRest.X_HTTP_METHOD_OVERRIDE) String xhttpOverride,
    @PathParam("id_unit") String id_unit) {
...
  1. createOrSelectUnitById()

Note

La méthode HTTP GET n’est pas compatible, on utilisera une méthode HTTP POST dont l’entête contiendra « X-HTTP-Method-GET »

méthode createOrSelectUnitById() va appeler méthode getUnitById()

      @POST
@Path("/units/{idu}")
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
public Response createOrSelectUnitById(JsonNode queryJson,
    @HeaderParam(GlobalDataRest.X_HTTP_METHOD_OVERRIDE) String xhttpOverride,
    @PathParam("idu") String idUnit) {
 ...
  1. updateUnitById()
mise à jour d’un unit par son id avec une requête json
@PUT
  @Path("/units/{id_unit}")
  @Consumes(MediaType.APPLICATION_JSON)
  @Produces(MediaType.APPLICATION_JSON)
  public Response updateUnitById(String queryDsl,
                                 @PathParam("id_unit") String id_unit) {
  ...
  1. getObjectGroup()

    récupérer une groupe d’objet avec la filtre

Note

the post X-Http-Method-Override header

    @GET
@Path("/objects/{ido}")
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
public Response getObjectGroup(@PathParam("ido") String idObjectGroup, JsonNode queryJson)
 ...
  1. getObjectGroupPost()

Note

La méthode HTTP GET n’est pas compatible, on utilisera une méthode HTTP POST dont l’entête contiendra « X-HTTP-Method-GET »

méthode getObjectGroupPost() va appeler méthode getObjectGroup()

    @POST
@Path("/objects/{ido}")
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
public Response getObjectGroupPost(@Context HttpHeaders headers,
    @PathParam("ido") String idObjectGroup, JsonNode queryJson)
 ...
  1. getObject()

    récupérer le group d’objet par un unit

Note

the post X-Http-Method-Override header

    @GET
@Path("/units/{ido}/objects")
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_OCTET_STREAM)
public void getObject(@Context HttpHeaders headers, @PathParam("ido") String idObjectGroup,
    JsonNode query, @Suspended final AsyncResponse asyncResponse) {
 ...
  1. getObjectPost()

Note

La méthode HTTP GET n’est pas compatible, on utilisera une méthode HTTP POST dont l’entête contiendra « X-HTTP-Method-GET »

méthode getObjectPost() va appeler méthode getObject()

    @POST
@Path("/units/{ido}/objects")
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_OCTET_STREAM)
public void getObjectPost(@Context HttpHeaders headers, @PathParam("ido") String idObjectGroup,
    JsonNode query, @Suspended final AsyncResponse asyncResponse) {
 ...

7.1.2.11. -LogbookExternalResourceImpl.java

classe controlleur REST

la classe contient actuellement 6 méthodes :

  1. getOperationById()

    récupère l’opération avec son id NB : the post X-Http-Method-Override header

    @GET
@Path("/logbookoperations/{id_op}")
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
public Response getOperationById(@PathParam("id_op") String operationId) {
 ...
  1. selectOperationByPost()

Note

La méthode HTTP GET n’est pas compatible, on utilisera une méthode HTTP POST dont l’entête contiendra « X-HTTP-Method-GET »

méthode selectOperationByPost() va appeler méthode getOperationById()

    @POST
@Path("/operations/{id_op}")
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
public Response selectOperationByPost(@PathParam("id_op") String operationId,
    @HeaderParam("X-HTTP-Method-Override") String xhttpOverride)
 ...
  1. selectOperation()

    récupérer tous les journaux de l’opéraion NB : the post X-Http-Method-Override header

    @GET
@Path("/operations")
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
public Response selectOperation(JsonNode query)
 ...
  1. selectOperationWithPostOverride()

Note

La méthode HTTP GET n’est pas compatible, on utilisera une méthode HTTP POST dont l’entête contiendra « X-HTTP-Method-GET »

méthode selectOperationWithPostOverride() va appeler méthode selectOperation()

    @POST
@Path("/operations")
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
public Response selectOperationWithPostOverride(JsonNode query,
    @HeaderParam("X-HTTP-Method-Override") String xhttpOverride)
 ...
  1. getUnitLifeCycle()

    récupère le journal sur le cycle de vie d’un unit avec son id

    @GET
@Path("/logbookunitlifecycles/{id_lc}")
@Produces(MediaType.APPLICATION_JSON)
public Response getUnitLifeCycle(@PathParam("id_lc") String unitLifeCycleId)
 ...
  1. getObjectGroupLifeCycle()

    récupère le journal sur le cycle de vie d’un groupe d’objet avec son id

    @GET
@Path("/logbookobjectslifecycles/{id_lc}")
@Produces(MediaType.APPLICATION_JSON)
public Response getObjectGroupLifeCycle(@PathParam("id_lc") String objectGroupLifeCycleId)
 ...

7.1.2.12. -AdminManagementExternalResourceImpl.java

classe controlleur REST

la classe contient actuellement 10 méthodes :

  1. checkDocument()

    vérifier le format ou la règle

    @Path("/{collection}")
@PUT
@Consumes(MediaType.APPLICATION_OCTET_STREAM)
@Produces(MediaType.APPLICATION_JSON)
public Response checkDocument(@PathParam("collection") String collection, InputStream document) {
 ...
  1. importDocument()

    Importer le fichier du format ou de la règle

    @Path("/{collection}")
@POST
@Consumes(MediaType.APPLICATION_OCTET_STREAM)
@Produces(MediaType.APPLICATION_JSON)
public Response importDocument(@PathParam("collection") String collection, InputStream document) {
 ...
  1. importProfileFile()
Importer un fichier au format xsd ou rng et l’attacher à un profile métadata déjà existant.
    @Path("/{collection}/{id}")
@PUT
@Consumes(MediaType.APPLICATION_OCTET_STREAM)
@Produces(MediaType.APPLICATION_JSON)
public Response importProfileFile(@Context UriInfo uriInfo, @PathParam("collection") String collection, @PathParam("id") String profileMetadataId,
    InputStream profileFile) {
 ...
  1. downloadProfileFileOrTraceabilityFile()
Télécharger un fichier d’un profile métadata existant au format xsd ou rng Ou télécharger un fichier d’opération de traçabilité
    @GET
@Path("/{collection}/{id}")
@Produces(MediaType.APPLICATION_OCTET_STREAM)
public void downloadProfileFileOrTraceabilityFile(@PathParam("collection") String collection, @PathParam("id") String profileMetadataId,
    @Suspended final AsyncResponse asyncResponse) {
 ...
  1. findDocuments()
Récupérer le format, la règle, le contrat (entrée ou accès), le profile.
    @Path("/{collection}")
@GET
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
public Response findDocuments(@PathParam("collection") String collection, JsonNode select) {
 ...
  1. createOrfindDocuments()
Si la valeur de xhttpOverride est rensigné et égale à GET alors, c’est un find, donc redirection vers la méthode findDocuments ci-dessus. Sinon, c’est créate. Cette méthode est utilisé pour créer des profiles au format json. On peut noter que dans ce cas de figure, ça ressemble à la méthode importDocument, sauf que le Consumes qui change.
    @Path("/{collection}")
@POST
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
public Response createOrfindDocuments(@PathParam("collection") String collection, JsonNode select, @HeaderParam(GlobalDataRest.X_HTTP_METHOD_OVERRIDE) String xhttpOverride) {
 ...
  1. findDocumentByID()
En utilisant la méthode POST avec un paramètre xhttpOverride, ce méthode permets de récupérer avec un id en entrée, le format, la règle, les contrats (accès, entrée), les profiles.
    @Path("/{collection}/{id_document}")
@POST
@Produces(MediaType.APPLICATION_JSON)
public Response findDocumentByID(@PathParam("collection") String collection, @PathParam("id_document") String documentId, @HeaderParam(GlobalDataRest.X_HTTP_METHOD_OVERRIDE) String xhttpOverride) {
 ...
  1. findDocumentByID()
En utilisant la méthode GET, ce méthode permets derécupérer avec un id en entrée, le format, la règle, les contrats (accès, entrée), les profiles.
    @Path("/{collection}/{id_document}")
@GET
@Produces(MediaType.APPLICATION_JSON)
public Response findDocumentByID(@PathParam("collection") String collection,
    @PathParam("id_document") String documentId) {
 ...
  1. updateAccessContract()
Mise à jour du contrat d’accès
@PUT
  @Path("/accesscontract")
  @Consumes(MediaType.APPLICATION_JSON)
  @Produces(MediaType.APPLICATION_JSON)
   public Response updateAccessContract(JsonNode queryDsl) {
   ...
  1. updateIngestContract()
Mise à jour du contrat d’entrée
@PUT
  @Path("/contract")
  @Consumes(MediaType.APPLICATION_JSON)
  @Produces(MediaType.APPLICATION_JSON)
   public Response updateIngestContract(JsonNode queryDsl) {
   ...