Extraire les métadonnées des ArchiveUnit et DataObject ###################################################### Général ******* L'extraction du bordereau SEDA tranforme le fichier manifest.xml en plusieurs fichiers contenant les informations du manifest, les définitions des Archives Units et des Groupes d'Objets Techniques, ainsi que la structure des objets. Dans des étapes utlérieures, les fichiers OG et Unit extraits sont indexés en base lors de l'indexation. Workspace avant extraction : ============================ containerId/SIP containerId/SIP/Content/ containerId/SIP/manifest.xml Workspace après extraction : ============================ containerId/SIP containerId/SIP/Content/ containerId/SIP/manifest.xml containerId/Units containerId/Units/AU_GUID.json containerId/Uits/... containerId/ObjectGroup containerId/ObjectGroup/GOT_GUID.json containerId/ObjectGroup/... containerId/Maps/ containerId/Maps/ARCHIVE_ID_TO_GUID_MAP.json containerId/Maps/DATA_OBJECT_TO_OBJECT_GROUP_ID_MAP.json containerId/Maps/DATA_OBJECT_ID_TO_DATA_OBJECT_DETAIL_MAP.json containerId/Maps/DATA_OBJECT_ID_TO_GUID_MAP.json containerId/Maps/OBJECT_GROUP_ID_TO_GUID_MAP.json containerId/UnitsLevel/ containerId/UnitsLevel/ingestLevelStack.json containerId/ATR/ containerId/ATR/globalSEDAParameters.json Algorithme ********** 1. Récupération du GUID/objects/SIP/manifest.xml * Voir RAML WEB/Internal_Workspace.html#containers__cid__objects__id_object__get 2. Extraction SEDA 1. Extraction des DataObject (Physical et Binary) dans workspace depuis manifest.xml (GUID/DataObject/GUID) (SedaUtils->extractSEDA) * En lisant le fichier XML, extraire les DataObject depuis xml (SedaUtils->writeDataObjectInLocal et extractArchiveUnitToLocalFile) * Mettre en place des MAP utiles * Liaisons DataObject -> object (MAP) * Liaisons DataObject <-> ObjectGroup (MAP et MAP>) * Liaisons Unit -> Unit (MAP>) * Liaisons Unit <-> ObjectGroup (MAP avec x et y à décider) 2. Construction des ObjectGroup depuis les DataObject (SedaUtils->saveObjectGroupsToWorkspace) * A partir le map ObjectGroup -> DataObject: construire l'objet ObjectGroup en Json * Sauvegarde ces ObjectGroups dans workspace 3. Sauvegarde des ArchiveUnit dans workspace depuis manifest.xml (GUID/Units/GUID) (SedaUtils->writeArchiveUnitToWorkspace) 3. Journalisation de fin de l'action extraction SEDA (fait par le Distributeur) 4. Indexation 1. Lors de l'indexation des OGs, le worker va chercher les ObjectGroups dans workspace puis le worker se charge d'indexer dans metadata (SedaUtils->indexObjectGroup) 2. Lors de l'indexation des Units, le worker va chercher dans le workspace, et le handler se charge de nettoyer et préparer les Units puis indexer dans metadata (SedaUtils->indexArchiveUnit) 5. Journalisation de fin de l'action d'indexation (fait par le Distributeur) Algorithme d'update pour l'extract SEDA ======================================= Après la création de l'Archives Unit temporaire extraite du manifest.xml si une balise *EXISTING_GUID* a été rencontrée les traitement suivant sont fait : * l'Archive Unit existant est récupéré en base à partir du EXISTING_GUID fourni dans le fichier, si il n'est pas trouvé l'extraction est arrêtée * un nouveau fichier d'archive temporaire *EXISTING_GUID.json* est créé à partir du fichier extrait (*GUID.json*) en changeant modifiant d'id l'objet *"ArchiveUnit":{ "_id":"GUID", ...}* * l'ancien fichier *GUID.json* est supprimé * le nouveau guid *EXISTING_GUID* remplace l'ancien *GUID* dans la données temporaires d'extraction (correspondance des Id VITAM/SEDA, liste des GUID de unit extrait) et ajouté dans la liste des GUID existants * préparation du lifecycle de l'archive unit spécifique à la mise à jour (*message à définir*) Lors de la finalisation de l'extraction des units, si le unit est déclaré comme pré-existant on ajoute : * on ajoute une valeur *"existing":true* dans l'objet *_work: {...}* pour indiquer aux prochaines étapes que l'archive unit manipulé est une mise à jour