mongoose-schema-ts-infer v0.1.19
What does it do and why?
mongoose has typescript support since v5.11.0.
But until mongoose@>=6.3.1, everytime we create a schema, we must create an interface representing a document in MongoDB.
This library has been made for these people 😁: Create your schema and infer the document type from it!
Install
npm i mongoose-schema-ts-inferUsage
- Create a mongoose schema:
const userSchema = {
name: {
type: String,
required: true as const
},
email: String,
favoriteColor: {
type: String,
required: false as const,
enum: ['white', 'black'] as const
},
}Warning
as constis mandatory forrequiredoption,enumoption andtype(if it's a string like"buffer","Buffer", etc...).
- Infer a document type from it:
import {InferFromSchema} from "mongoose-schema-ts-infer";
type IUser = InferFromSchema<typeof userSchema>;
/**
* `IUser` type is equivalent to:
* {
* _id ?: ObjectId
* name: string,
* email?: string
* favoriteColor?: 'white'|'black
* }
**/
const document: IUser = {
name: 'Nicolas',
favoriteColor: 'white'
}Supported types
We don't support (yet) all the types. They will come! Feel free to create MR to add if you are in the hurry 😁.
| Schema type | typescript type |
|---|---|
String | string |
Number | number |
Date | Date |
Buffer | Buffer |
"buffer" | Buffer |
"Buffer" | Buffer |
mongoose.Schema.Types.Buffer | Buffer |
Boolean | boolean |
mongoose.Schema.Types.Mixed | any |
Object | any |
mongoose.Schema.Typ@es.ObjectId | mongoose.Types.ObjectId |
Array | Array |
mongoose.Schema.Types.Decimal128 | mongoose.Types.Decimal128 |
Map | Map |
Schema | Inferred from the generic given during instantiation |
| Nested | ✅ |
Both shorthand notation ({name: String}) and "classic" notation ({name: {type: String}}) are supported.
For the latter, some options are also taken into account:
| Option name | typescript infer | Example |
|---|---|---|
required | Mark the field as optional or not (default:false) | {name: {type: String, required: false as const} } gives {name?:string} |
enum (only for String type) | Restrict the value to one of the specified item in the list | {accept: {type: String, enum: ['yes','no'] as const} } gives {accept:'yes' / 'no'} |
of (only for Map type) | Restrict values of the Map to a specific type (default: any) | {name: {type: Map, of: Number} } gives {name?: Map<string,number>} |
Examples
All examples are available in the "examples" folder:
Test, transpile and publish on npm
Before publishing, we need to transpile the code into lib and make sure everything works:
npm test && npm run buildFor publishing on npm (make sure to update the version in package.json first):
npm publish