Skip to content
No description, website, or topics provided.
Java JavaScript HTML CSS
Branch: master
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
po
src
.bowerrc
.editorconfig
.eslintignore
.eslintrc
.gitignore
.jshintrc
.yo-rc.json
Gruntfile.js
LICENSE
MAN002 NumaHOP - Administrateur - V1.3.pdf
MAN003 NumaHOP - Utilisateur - V1.3.pdf
MAN004 NumaHOP - Prestataire - V1.1.pdf
README.md
bower.json
index.html
package-lock.json
package.json
pom.xml
sonar-project.properties
yaz4.md

README.md

NumaHop (Plate-forme de gestion de contenus numérisés)

NumaHOP permet de gérer une chaîne de numérisation de documents de l’import des notices et du constat d’état des documents physiques à la diffusion et à l’archivage grâce à un interfaçage largement automatisé entre les différentes étapes de la numérisation impliquant les acteurs concernés (prestataires de numérisation, bibliothèques, diffuseurs, CINES). Le bénéfice de cette réalisation est triple :

  • privilégier l’usage de formats normalisés
  • favoriser la standardisation des méthodes de travail
  • permettre la mutualisation et l’échange des savoir-faire entre les établissements qui utilisent cette plate-forme.

NumaHOP est composé de plusieurs modules fonctionnels permettant :

  • de convertir des notices au format UNIMARC ou EAD dans des formats interopérables : Dublin Core, Dublin Core qualifié
  • de réaliser des constats d’état pour les lots de documents à numériser envoyés vers les prestataires de numérisation
  • de recevoir les lots numérisés par le prestataire (images et métadonnées) et de les contrôler
  • d’utiliser des fonctions de workflow, de contrôle et de structuration des projets
  • de valider les unités documentaires numérisées (images + métadonnées) et de les exporter vers les diffuseurs et les archiveurs
  • de produire des fichiers OCR, METS, images dérivées...

NumaHOP offre la possibilité de disséminer largement et de manière automatisée les contenus numérisés, à la fois sous l’identité des établissements à travers leurs bibliothèques numériques, mais aussi vers des plates-formes externes telles qu’Internet Archive ou OMEKA.

Commencer

NumaHop est une application SpringBoot construite avec Maven.

Vous pouvez cloner le repository.

Les instructions suivantes permettent d'installer NumaHop sur un poste de développement.

Prérequis

Numahop nécessite au préalable l'installation des outils listés ci-dessous.

  • JDK 8
  • MariaDB 10.1
  • elasticsearch 2.4.6
  • tesseract 3.04.01 (leptonica-1.74.1 : libgif 5.1.4 : libjpeg 6b (libjpeg-turbo 1.5.1) : libpng 1.6.28 : libtiff 4.0.8 : zlib 1.2.8 : libwebp 0.5.2 : libopenjp2 2.1.2)
  • ImageMagick 6.9.7-4 Q16 x86_64 20170114 - http://www.imagemagick.org
  • exiftool 10.40
  • compass 1.0.3 (Polaris)

Les versions proposées sont valides dans un environnement Debian Stretch.

Il vous faudra également un user linux dédié disposant d'un repository maven (.m2).

Pour des recherches Z39.50, il faudra également installer la librairie libyaz4 - Voir yaz4.md

Première mise en oeuvre

Configuration minimale : application.yml | application-[PROFILE].yml

Les fichiers de configuration .yml doivent être mis à jour pour se conformer à votre installation.

Le profil "dev" est dédié à la mise en place d'un environnement de developpement.

Pour simplement lancer NumaHop, l'utilisation du profil "prod" est préconisée.

  • MariaDB

Il faut simplement créer une base et un utilisateur autorisé. La structure et les données paramétrées seront créées lors du 1er démarrage de l'application.

spring:
    datasource:
        driverClassName: org.mariadb.jdbc.Driver
        url: jdbc:mariadb://**urlDataBase**
        username: **userName**
        password: **userpassword**
        maximumPoolSize: 20
  • elasticsearch
spring:
    data:
      elasticsearch:
          cluster-nodes: localhost:9300
          cluster-name: **clusterName**
          properties:
              node:
                  name: Transport Client
          repositories:
              enabled: true
              
elasticsearch:
    bulk_size: 1000
    index:
        name: **indexName**              
  • ImageMagick
imageMagick: 
    convert: **imConvertPath**
    identify: **imIdentifyPath**
  • exifTool
exifTool:
    process: **exiftoolPath**
    quot_char: ''
  • tesseract
tesseract:    
    process: **tesseractPath**
  • Autres paramètres obligatoires

Certains paramètres supplémentaires doivent être également renseignés

# lister les bibliotheques utilisatrices comme suit: library_identifier1, library_identifier2, etc..
instance:
    libraries: library_bibliotheque
    
# répertoires de stockage images  
storage:
    binaries: **path to Image Dir repository**
    digest: MD5
    depth: 3

# répertoires de travail **path to workBaseDir**
uploadPath:
    condition_report: **path to workBaseDir**/upload/condition_report
    ead: **path to workBaseDir**/upload/ead
    import: **path to workBaseDir**/upload/import
    library: **path to workBaseDir**/upload/library
    user: **path to workBaseDir**/upload/user
    template: **path to workBaseDir**/upload/templates

export:
    rdf:
        default_uri: http://numahop.fr/
    ssh:
        knownHosts: **path to workBaseDir**/config/known_hosts
        strictHostKeyChecking: yes
# Services externes
services:
    cines:
        aip: **path to workBaseDir**/cines/aip
        cache: **path to workBaseDir**/cines/cache
        facile: https://facile.cines.fr/xml
        xsd:
           sip: **path to workBaseDir**/xsd/sip.xsd
    archive:
        alto: **path to workBaseDir**/archive/alto           
    metaDatas:
        path: **path to workBaseDir**/metadatas
    deliveryreporting:
        path: **path to workBaseDir**/deliveryReporting
    omeka:
        cache: **path to workBaseDir**/omeka/cache
    ftpexport:
        cache: **path to workBaseDir**/ftpexport/cache

Démarrage

Pour démarrer l'application:

  • se connecter avec votre utilisateur dédié disposant d'un repository maven
  • se positionner à la racine du projet
  • exécuter la commande suivante:
$ mvn clean package spring-boot:run -Pprod -Drun.jvmArguments="-Dspring.profiles.active=prod"

En cas de problème, une commande alternative :

$  mvn spring-boot:run -P prod  -Drun.arguments="--spring.profiles.active=prod,--spring.config.location=file:/opt/pgcn/src/main/resources/config/"

En fin de build, l'application est lancée sur le port 8080. Vous pouvez vous logger en admin / admin afin d'effectuer le paramétrage de base, créer des utilisateurs autorisés etc..

Les acteurs du projet

Maîtrise d'ouvrage

  • Bibliothèque Sainte-Geneviève
  • Bibliothèque de Sciences Po
  • BULAC

Maîtrise d'oeuvre

Contribution

Progilone reste responsable de la version principale. Les issues et/ou merge requests doivent nous être adressées.

Progilone étudiera également toute demande d'évolution de l'application.

Licence

Le projet est sous licence AGPLv3 - Voir le fichier LICENSE.md pour plus d'informations.

You can’t perform that action at this time.