A delicious TypeScript/TypeORM file parser (for the extraction of decorators and properties of an entity)
This package has been created to parse TypeORM file and return informations on a given Entity (decorators, columns and properties). The main idea is to be able to retrieve information for a CLI or documentation.
- Node.js version 14 or higher
This package is available in the Node Package Repository and can be easily installed with npm or yarn.
$ npm i @myunisoft/typeorm-file-parser
# or
$ yarn add @myunisoft/typeorm-file-parser
import { fileURLToPath } from "url";
import path from "path";
import * as TypeORMFileParser from "@myunisoft/typeorm-file-parser";
// CONSTANTS
const __dirname = path.dirname(fileURLToPath(import.meta.url));
const result = await TypeORMFileParser.readFile(
path.join(__dirname, "EntityFile.ts")
);
console.log(result);
It will return an Object like the following one
{
"properties": {
"id": {
"type": "number",
"decorators": {
"PrimaryGeneratedColumn": {
"name": "PrimaryGeneratedColumn"
}
}
},
"note": {
"type": "string",
"decorators": {
"Column": {
"name": "Column",
"type": "text",
"properties": {
"nullable": true
}
}
}
},
"billed": {
"type": "boolean",
"decorators": {
"Column": {
"name": "Column",
"type": "boolean",
"properties": {
"default": "false"
}
}
}
}
},
"unique": {
"constraintName": "GiArticle_reference",
"columns": [
"reference"
]
}
}
The response of the readFile method is described by the following interfaces:
export interface TypeORMProperty {
/** TypeScript/JavaScript type */
type: string;
/** TypeScript (TypeORM) decorators attached to the property */
decorators: Record<string, TypeORMDecoratorBase>;
}
export interface ParsedTypeORMResult {
/** Entity Unique decorator (without root name property) */
unique?: DecoratorExWithoutName;
/** Entity properties as a plainObject */
properties: Record<string, TypeORMProperty>;
}
TypeORMDecoratorBase
is a composition of multiple types
export type TypeORMDecoratorExtended =
UniqueDecorator |
RelationDecorator |
ColumnDecorator |
JoinDecorator;
export type TypeORMDecoratorBase =
{ name: "Entity" | "PrimaryGeneratedColumn" } |
TypeORMDecoratorExtended;
Each of them can be found in ./src/decorator/parsers
UniqueDecorator
export interface UniqueDecorator {
name: "Unique";
constraintName: string | null;
columns: string[];
}
RelationDecorator
export interface RelationDecorator {
name: RelationKind;
table: string;
tableColumn: string;
properties: Properties;
}
ColumnDecorator
export type ColumnKind = "PrimaryColumn" | "Column" | "Generated";
export interface ColumnDecorator {
name: ColumnKind;
type: string;
properties: Properties;
}
JoinDecorator
export type JoinKind = "JoinTable" | "JoinColumn";
export interface JoinDecorator {
name: JoinKind;
properties: Properties;
}
Thanks goes to these wonderful people (emoji key):
Gentilhomme 💻 🐛 📖 🛡️ |
MIT