Security News
Bun 1.2 Released with 90% Node.js Compatibility and Built-in S3 Object Support
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
data-models
Advanced tools
Validation for standard data models
This repository provides examples and validators for data models that we want to share through different eHealth projects
JSON schema docs: http://json-schema.org
This is open software. If you need realistic data for your tests you can either forge them or generate them automatically with the command line tool (see below). Improving the generator is also a way to improve the data model.
Until such a time upon which we decide on something better, the current schema domain is schema.ehealthafrica.org
and the current stable version is 1.0
. e.g:
https://schema.ehealthafrica.org/1.0/Image.json#
validate
Add the dependency from the module, then use the provided validate
method. For example if you want to validate a Person
object:
var dataModel = require('data-models');
var person = { ... };
var errors = dataModel.validate(person);
If the object is valid, errors should be null
.
generate
Given an optional list of model names (and count), generate an instance with pre-filled pseudo data:
var dataModel = require('data-models');
dataModel.generate('driver', 1);
// =>
// { driver:
// [ { doc_type: 'driver',
// version: '1.0.0',
// forename: 'Wade',
// surname: 'Jacobi',
// email: 'Lexi_Mosciski95@gmail.com',
// phone: '1-264-961-1978' } ] }
A command line interface to the generate function (stringified as JSON) can be useful for generating fixtures, for example:
data-models --model driver --count 1
Yields:
{
"driver": [
{
"doc_type": "driver",
"version": "1.0.0",
"forename": "Jeremie",
"surname": "Bayer",
"email": "epiwam@gmail.com",
"phone": "(958) 420-7636 x656"
}
]
}
See data-model --help
for further usage.
A bundled version is available in the dist/
folder. The files there
have been built with Browserify using the --standalone
option, so
they will expose a global dataModel
object.
Remember to run npm run build
before tagging a new release of this
code in order to update the distribution files.
Copyright 2015 eHealth Africa
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License here.
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
1.21.0 - 2015-07-10
ward
as property of an addressward
as property of a patient and contactFAQs
Validation for standard data models
We found that data-models demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 3 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.