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-parseror locally if you want to use it from your code
npm i mongoose-schema-parser --saveIf 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.jsonScript 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"
}
}
}
}
*/