Mongoose Schema Parser tool parses Mongoose schemas defined in project and returns data in JSON format.
Script uses mongoose instance to parse registered schemas. You can use it from CLI or inside your application code.
Install globally if you want to use it from cli
npm i -g mongoose-schema-parser
or locally if you want to use it from your code
npm i mongoose-schema-parser --save
If you install package globally, you can run it from anywhere in your system. Script returns file with parsed schema in JSON format.
mongoose-schema-parser -c /path/to/project -p "**/*.model.js" -o output-schema.json
Script options:
-c, --cwd Current working directory [string] [default: "/your/project/dir"]
-p, --pattern Search file pattern [string] [required] [default: "**/*.model.js"]
-o, --output Output file path [string] [required]
--help, -h Show help [boolean]
Output example:
{
"Category": {
"schema": {
"_id": {
"type": "ObjectId"
},
"name": {
"type": "String",
"details": {
"required": true,
"maxlength": 150
}
},
"enabled": {
"type": "Boolean",
"details": {
"default": true
}
}
}
},
"Item": {
"schema": {
"_id": {
"type": "ObjectId"
},
"name": {
"type": "String"
},
"category": {
"type": "ObjectId",
"details": {
"ref": "Category"
}
},
"sizes": {
"type": "Schema",
"schema": {
"size": {
"type": "Number"
}
}
},
"created": {
"type": "Date",
"details": {}
}
}
}
}
This example shows, how to use parseSchemaFromMongoose
function to parse schema in your application. Function returns schema as JS object.
const mongoose = require('mongoose')
const { parseSchemaFromMongoose } = require('mongoose-schema-parser')
// content of ./models/example-01.model
/*
const ExampleSchema = new mongoose.Schema({
name: 'string'
})
mongoose.model('ExampleModel', ExampleSchema)
*/
require('./models/example-01.model')
const exportedSchema = parseSchemaFromMongoose(mongoose)
console.log(JSON.stringify(exportedSchema, null, 2))
/* outputs:
{
"ExampleModel": {
"schema": {
"name": {
"type": "String"
},
"_id": {
"type": "ObjectId"
}
}
}
}
*/