Product | Validator API Endpoints |
---|---|
Description | Node.JS app that provides API end points to validate IATI XML files, is used by https://validator.iatistandard.org/ |
Website | https://developer.iatistandard.org/ |
Related | IATI/validator-services, IATI/validator-web |
Documentation | https://developer.iatistandard.org/ |
Technical Issues | https://github.com/IATI/js-validator-api/issues |
Support | https://iatistandard.org/en/guidance/get-support/ |
See OpenAPI specification postman/schemas/index.yaml
. To view locally in Swagger UI, you can use the 42crunch.vscode-openapi
VSCode extension.
- nvm - nvm - Node version manager
- Node LTS
- once you've installed nvm run
nvm use
which will look at.nvmrc
for the node version, if it's not installed then it will prompt you to install it withnvm install <version>
- once you've installed nvm run
- Azure Functions Core Tools v4
- Azure CLI version 2.4 or later.
- Docker Engine
- Docker Compose
xmllint
- There are two ways to run this locally: directly, or using the
docker compose
setup. The docker build includes thexmllint
tool. If you run it directly, you may need to install this tool.- On Ubuntu it is in
libxml2-utils
, so you'll need something likesudo apt install libxml2-utils
.
- On Ubuntu it is in
- There are two ways to run this locally: directly, or using the
- Clone this repository
- Follow instructions for nvm/node prerequisties above
- Setup the environment variables using the
.env
file (instructions below)- If running directly (option 1), this will mean setting up a
redis
database.
- If running directly (option 1), this will mean setting up a
- Run
npm i
to install dependencies - Run
npm start
to run the Function locally using the Azure Functions Core Tools - The API end points will be available on
localhost:7071
- Run
npm run docker:start
to run the Function inside a Docker container using docker-compose.yml to create a Redis instance. - The API end points will be available on
localhost:8080
To test the basic setup, you can run the following command:
curl http://localhost:8080/api/pub/version
This should return a version number (change port if running directly instead of via docker).
To test the validation is working, obtain an IATI XML file, and run the following command (this is if running via the docker setup; change port to 7071
if running directly):
curl -X POST --data-binary @PATH_TO_IATI_XML http://localhost:8080/api/pub/validate
You should see something like (if the file is a valid IATI file):
{
"valid": true,
"fileType": "iati-activities",
"iatiVersion": "2.03",
"rulesetCommitSha": "2cd1a14f6c584000ae6d76e708c73ddcc12b6c40",
"codelistCommitSha": "cf571799b909eb894c071dc364cd2a4dfbcd5d7c",
"orgIdPrefixFileName": "org-id-fa56731af7.json",
"apiVersion": "2.3.2",
"summary": {
"critical": 0,
"error": 0,
"warning": 0
},
"errors": []
}
If it has warnings or errors, you'll see them listed.
cp .env.example .env
APPLICATIONINSIGHTS_CONNECTION_STRING
- Needs to be set for running locally, but will not actually report telemetry to the AppInsights instance in my experience
BASIC_GITHUB_TOKEN
- GitHub personal access token. This is needed to pull in the Codelists from the
IATI/IATI-Validator-Codelists
repository. Note that you cannot use a "Personal Access Token (Classic)"; you must generate a fine-grained access token.
REDIS_PORT=6379
REDIS_HOSTNAME=redis
- Redis connection, configured for
docker compose use
. If you develop outside docker, change these settings as appropriate.
VALIDATOR_SERVICES_URL=https://func-validator-services-dev.azurewebsites.net/api
VALIDATOR_SERVICES_KEY_NAME=x-functions-key
VALIDATOR_SERVICES_KEY_VALUE=
- URL and API Key for Validator Services, used to get list of Publisher Identifiers
DATASTORE_SERVICES_URL=https://dev-func-datastore-services.azurewebsites.net/api DATASTORE_SERVICES_AUTH_HTTP_HEADER_NAME=x-functions-key DATASTORE_SERVICES_AUTH_HTTP_HEADER_VALUE= DATASTORE_SERVICES_IATI_IDENTIFIERS_EXIST_MAX_NUMBER_OF_IDS=5000
- URL and API Key for datastore services, used by the advisory system to check for the existence of IATI Identifiers in the Datastore
`APP_NAME`: IATI Validator API
`VERSION`: process.env.npm_package_version
`NODE_ENV`: process.env.NODE_ENV
`APPLICATIONINSIGHTS_CONNECTION_STRING`: process.env.APPLICATIONINSIGHTS_CONNECTION_STRING
`NS_PER_SEC`: 1e9
`VERSIONS`: process.env.VERSIONS || ['2.01', '2.02', '2.03']
`MAX_FILESIZE`: process.env.MAX_FILESIZE || 60
Add in:
- .env.example
- .env
/config/config.js
Import
import config from "./config.js";
let myEnvVariable = config.ENV_VAR
- To show linting inline install ESLint for VSCode
- This is done with eslint following the airbnb-base style and using Prettier. Implemented with this guide.
- If you use VSCode the formatting will happen automagically on save due to the
.vscode/settings.json
>"editor.formatOnSave": true
setting
func new --name <routename> --template "HTTP trigger" --authlevel "Function"
- An example of using the
config/appInsights.js
utility is available in thepvt-get/index.js
where execution time of the function is measured and then logged in 2 ways to the AppInsights Telemetry.
npm run rules:test
There is a large set of Mocha unit tests for the Rulesets logic in ruleset-unit-tests
.
Locally
- Install newman globally
npm i -g newman
- Start function
npm start
- Run Tests
npm int:test
In Docker container
- Install newman globally
npm i -g newman
- Edit
function.json
files to set"authLevel": "anonymous"
, don't forget to change back! - Start function
npm run docker:start
- Run Tests
npm docker:int:test
Integration tests are written in Postman v2.1 format and run with newman
Import the integration-tests/dev-func-validator.postman_collection.json
into Postman and write additional tests there
Then once you are happy, export the collection and overwrite the file, then check into git.
Using files:
- You must reference the file in the Postman file directory when working in the Postman GUI e.g.
~/Postman/files
- When ready to export tests to the repo don't forget to copy file to
integration-tests/test-files
--working-dir
cli parameter tellsnewman
where to look
https://github.com/IATI/IATI-Internal-Wiki#development-process
- Fork IATI/xpath - v0.0.34
- Sent a performance improvement PR that hasn't been merged into the original project: goto100/xpath#107
- If that is ever merged, then we could get rid of this custom dependency.
- Also merged this performance PR from another dev to our fork (also hasn't been merged into the original project): goto100/xpath#108
- If that is ever merged, then we could get rid of this custom dependency.
- Sent a performance improvement PR that hasn't been merged into the original project: goto100/xpath#107
Schemas are stored statically in the application source code as they are versioned and rarely change.
./schemas/2.0X/*
The source is IATI-Schemas
This repo provides the "Codelist Rules" for evaluating whether the codelists used by an IATI file being validated are correct. This application dynamically loads the codelist_rules.json
file from this repo for each version-2.0X
branch. This is also stored in Redis for caching.
This repo provides the "Rulesets" for various conditional and restraint rules for IATI data. This application dynamically loads the rulsets/standard.json
file from this repo for each version-2.0X
branch. This is also stored in Redis for caching.
The rulesets contain rules that require evaluation against a list of Publisher organisation identifiers, and valid organisation identifier prefixes. link
These are sourced from the following locations:
-
Organisation Identifier Prefixes (Registration Agencies) - https://org-id.guide/download.json
response.lists[].code
- The validator expects the response header from the URL to contain:
Content-Disposition: attachment; filename="<filename>"
-
Published Organisation Identifiers - https://func-validator-services-dev.azurewebsites.net/api/pvt/publishers
response[].iati_id
Due to a known limitation in the core library libxml2
used to perform schema validation, if an activity has a schema error at a line greater than 65535, the value will not be accurate in the context.
If this is the case for your validation report, a message like so will be displayed in the context of the schema error:
At line greater than: 65537. Note: The validator cannot display accurate line numbers for schema errors located at a line greater than 65537 for this activity.