Skip to content
/ koi-cli Public

A simple CLI made to generate base files and migration files.

License

Notifications You must be signed in to change notification settings

98labs/koi-cli

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Koi-cli (KOA Typescript API - Command Line Interface)

A simple CLI made to generate base files and migration files.


Prerequisite:

Clone the Koi project here:


Install:

npm i -g koi-cli

Usage:

1. Run to generate JSON file for structuring table attributes.

   koi-generate:config $tableName
      example: koi-generate:config user

2. Modify the JSON file in /src/db/config.

  • Config:
# /src/db/config/user.json
# Sample table configuration only

{
    "schema": "public", 
    "table": {
        "tableName": "user",
        "attributes" :{
            "id": {
              "primaryKey": true,
              "dataType": "INTEGER", # Or "integer"
              "allowNull": false,
            },
            "name": {
              "dataType": "STRING",
              "allowNull": false,
            },
            "password": {
              "dataType": "STRING",
              "allowNull": false,
            },
            "createdAt": {
              "dataType": "DATE",
              "allowNull": false,
            },
            "updatedAt": {
              "dataType": "DATE",
              "allowNull": false,
            },
        }
    }
}

3. Run to generate migration files from config/ .json for sequelize to use.

   koi-generate:migration
     example: koi-generate:migration

4. Modify the migration file that just have been created.

  • Migrations:
# /src/db/migrations/create-migration-user.js
# Sample migration only

 "use strict";

module.exports = {
  up: (queryInterface, Sequelize) => {
    const DataTypes = Sequelize;

    return queryInterface.createSchema("public")
    .then(() => {
      const tableConfig = {
        schema: "public",
        tableName: "user"
      };

      const tableProps = {
        id: {
          primaryKey: true,
          type: DataTypes.INTEGER,
          allowNull: false,
        },
        name: {
          type: DataTypes.STRING,
          allowNull: false,
        },
        password: {
          type: DataTypes.STRING,
          allowNull: false,
        },
        createdAt: {
          type: DataTypes.DATE,
          allowNull: false,
        },
        updatedAt: {
          type: DataTypes.DATE,
          allowNull: false,
        },
      };

      return queryInterface.createTable(tableConfig, tableProps);
    });
  },

  down: (queryInterface, Sequelize) => {
    const tableConfig = {
      schema: "public",
      tableName: "user"
    };

    return queryInterface.dropTable(tableConfig).then(() => {
      return queryInterface.dropTable(tableConfig);
    });
  }
};

5. Run to generate base files (models, controllers, routes, transformers and services).

   koi-generate:base $tableName
     example: koi-generate:base user 

6. Modify the recently created base files.

  • Models:
# /src/models/user.ts
# Sample model only

import {
  DataTypes,
  ModelAttributes,
} from 'sequelize';

import { BaseModel, ITableConfig } from '../baseModel';

export interface IUser {
  id?: number;
  name: string;
  password: string;
}

export class User extends BaseModel implements IUser {
  public id: number;
  public name: string;
  public password: string;

  static getAttributes(): ModelAttributes {
    return {
      id: {
        primaryKey: true,
        type: DataTypes.INTEGER,
        allowNull: false,
      },
      name: {
        type: DataTypes.STRING,
        allowNull: false,
      },
      password: {
        type: DataTypes.STRING,
        allowNull: false,
      },
      createdAt: {
        type: DataTypes.DATE,
        allowNull: false,
      },
      updatedAt: {
        type: DataTypes.DATE,
        allowNull: false,
      },
    };
  }

  public static getValidationRules(): any {
    # Guide for validation Rules https://validatejs.org
    return {};
  }

  static getTableNameConfig(): ITableConfig {
    return {
      schema: 'public',
      tableName: 'users',
    };
  }

  public static initAssociations(): void {
    # Define your model association here
  }
}
  • Controllers:
# /src/controllers/v1/userController.ts
# Sample controller only

import { Context } from 'koa';
import { ICustomAppContext } from './../../typings';
import { User } from './../../models/core';
import { BaseBreadController } from '../baseBreadController';
import { UserTransformer } from './../../transformers';
import { UserService } from './../../services/dbService';
import { ValidationService } from './../../services';

# type alias for shortcut to trigger intellisense
type CustomContext = Context & ICustomAppContext;

export class UserController extends BaseBreadController {

  constructor() {
    super(
    new UserTransformer(),
    new UserService,
    new ValidationService(User)
    );

    # set any of these variables to false as needed

    this.hasBrowse = false;
    this.hasRead = true;
    this.hasEdit = true;
    this.hasAdd = true;
    this.hasDelete = true;
  }
}
  • Routes:
# /src/routes/v1/user.ts
# Sample route only

import * as Router from 'koa-router';
import { UserController } from '../../controllers/v1';

const route = new Router({ prefix: '/user' });
const userCtrl = new UserController();

route.get('/', userCtrl.browse);
route.get('/:id', userCtrl.read);
route.patch('/:id', userCtrl.edit);
route.post('/', userCtrl.add);
route.delete('/:id', userCtrl.delete);

export { route as userRoute };
  • Transformers:
# /src/transformers/userTransformer.ts
# Sample transformer only

import { TransformableObjectAbstract } from './transformableObjectAbstract';

export class UserTransformer extends TransformableObjectAbstract {

  protected objectType = 'user';
  protected visibleFields = [
    'username',
    'firstName',
    'middleName',
    'lastName',
    'phone',
    'mobile',
  ];

}

License:

  • MIT
  • Copyright 2019 © 98Labs, Inc

About

A simple CLI made to generate base files and migration files.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •