diff --git a/biblio-tools/v1/conditor/works/expandByHalid.ini b/biblio-tools/v1/conditor/works/expandByHalid.ini new file mode 100644 index 0000000..da59181 --- /dev/null +++ b/biblio-tools/v1/conditor/works/expandByHalid.ini @@ -0,0 +1,93 @@ +# OpenAPI Documentation - JSON format (dot notation) +mimeType = application/json + +post.operationId = post-v1-conditor-works-expandByHalid +post.description = Récupération des métadonnées associées à un HALid dans Conditor +post.summary = Récupération à partir d'un tableau d'objets avec à minima un champ value contenant le HALid +post.tags.0 = biblio-tools +post.requestBody.content.application/json.example.0.id = 1 +post.requestBody.content.application/json.example.0.value = hal-03008165 +post.requestBody.content.application/json.schema.$ref = #/components/schemas/JSONStream +post.requestBody.required = true +post.responses.default.content.application/json.example.0.id = 1 +post.responses.default.content.application/json.example.0.value = { ... } +post.responses.default.content.application/json.schema.$ref = #/components/schemas/JSONStream +post.responses.default.description = Les documents Conditor en version JSON flat +post.parameters.0.description = Indenter le JSON résultant +post.parameters.0.in = query +post.parameters.0.name = indent +post.parameters.0.schema.type = boolean + +# Necessary plugins +[use] +plugin = basics + +# Flow configuration +[JSONParse] +separator = * + +# Quelques paramètres modifiables si besoin +[env] +path = size +value = 10 + +path = indent +value = true + +# Début du traitement par lot +[group] +size = env('size') + +# Création d'une requete avec une liste d'identifiants +[replace] +path = output.0.q +value = self().map('value').filter(Boolean).map(JSON.stringify).join(' ').thru(allIdentifiers => `halid:(${allIdentifiers})`) + +path = output.0.size +value = env('size') + +path = output.0.envelope +value = false + +path = input +value = self() + +[map] +path = output + +# Envoi de la requete +[map/URLStream] +url = https://corhal-api.inist.fr/mergedDocuments +json = true +path = .* +timeout = 30000 +retries = 3 +noerror = false + +[map/OBJFlatten] + +# Création d'un objet réponse +[map/replace] +path = id +value = get('halId').toLower() +path = value +value = self() + +# Croisements des resultats et des dois +[exchange] +value = get('input').map((i) => ({ ...i, value:_.get(_.find(self.output, {id:i.value}), 'value') })) + +# Fin du traitement par lot +[ungroup] + +# On marque les réponses qui n'ont pas abouti +[swing] +test = has('value.sourceUids') +reverse = true + +[swing/assign] +path = value +value = fix('n/a') + +[dump] +indent = env('indent', false)