This package has been deprecated

Author message:

This generator no longer supported

generator-astro

4.2.3 • Public • Published

Astro Generator

Yeoman generator for building RESTful APIs and microservices using Node.js, ExpressJS and Docker support, and fullstack service with ReactJS, Redux, and Redux Observable. Astro Generator was designed to be scalable on containerized environment like Kubernetes, and designed to be enterprise ready. The principle of the project structure is isolation, so multiple developers can work on the same project without high dependency.

Technology Stack Supported

  • ExpressJS project, with vanilla javascript, this is suitable for creating service only project.
  • ReactJS Fullstack Project, this is for creating web app using Server Side Rendering.

Client Features (Only for Fullstack)

Server Features

  • No transpilers, just vanilla javascript
  • ES2017 latest features like Async/Await
  • CORS enabled
  • Uses yarn
  • Express
  • Consistent coding styles with editorconfig
  • Docker support
  • Uses helmet to set some HTTP headers for security
  • Load environment variables from .env files with dotenv
  • Request validation with joi
  • Gzip compression with compression
  • Linting with eslint with eslint-config-astro
  • Tests with jest along with coverage
  • Git hooks with husky
  • Logging with winston, and winston-cloudwatch for production log stream
  • API documentation geratorion with apidoc
  • Monitoring with pm2
  • Startup boot tasks that can be used for data migrations or pre startup task runner.
  • ORM using Sequelize (optional) sequelize with docker-compose migrations
  • HTTP using axios with retry axios

Requirements

Getting Started

Install:

npm install -g yo generator-astro

Generate a new project:

yo astro

Choose your project, either service or fullstack

Client Side Generator

Generate a new component

yo astro:component

Upon creation on a component, a new component folder will be created on src/components, and entries will be injected on the following files:

  • src/client/ducks/routers.js
  • src/client/ducks/epics.js
  • src/client/ducks/reducers.js

Server Side Generator

Generate a new API:

yo astro:api

Generate a new middleware:

yo astro:middleware

Generate a new service:

yo astro:service

Generate a new utility:

yo astro:util

Generate a new boot task:

yo astro:boot

Set environment variables:

cp .env.example .env

Running Locally

yarn dev

Running in Production

yarn start

Lint

# lint code with ESLint 
yarn lint
 
# try to fix ESLint errors 
yarn lint:fix
 
# lint and watch for changes 
yarn lint:watch

Sequelize Migrations (optional)

yarn db:migrate
 
# to undo the migration 
 
yarn db:migrate:undo

Test

# run all tests with Jest with coverage 
yarn test
 
# run unit tests 
yarn test:unit
 
# run integration tests 
yarn test:integration
 
# run all tests and watch for changes 
yarn test:watch

Validate

# run lint and tests 
yarn validate

Logs

# show logs in production 
pm2 logs

Documentation

# generate and open api documentation 
yarn docs

Docker

# run container locally 
yarn docker:dev
or
docker-compose -f docker-compose.yml -f docker-compose.dev.yml up
 
# run container in production 
yarn docker:prod
or
docker-compose -f docker-compose.yml -f docker-compose.prod.yml up
 
# run tests 
yarn docker:test
or
docker-compose -f docker-compose.yml -f docker-compose.test.yml up

License

MIT License - Suhendra Ahmad

Package Sidebar

Install

npm i generator-astro

Weekly Downloads

1

Version

4.2.3

License

MIT

Unpacked Size

198 kB

Total Files

154

Last publish

Collaborators

  • azanium