fulton-server
TypeScript icon, indicating that this package has built-in type declarations

0.3.4 • Public • Published

Fulton Server

Fulton Server is integrated many essential features and packages that a functional web server needs. Using Fulton Sever can accelerate a lot of time from building a state of art web server from scratch.

CLI

Using Fulton Server with Fulton CLI can helps you get started with Fulton.

Integration

typescript

we encourage you use Fulton Server with typescript because typescript provide better experiences than pure javascript. Also, Fulton Server takes the advantage of decoration of typescript.

For Example,

@router("/my")
class MyRouter extends Router {
    @httpGet()
    hi(req, res){
        res.send("Hi there")
    }
}

here @router and @httpGet are the decorators. As you can see, it make your code more meaningful.

express

Fulton Server is based on express. express is a very lite and the most popular web framework for nodejs. And we use the feature of decoration of typescript to build Router. See Router for more information.

inversify

Dependency Injection(DI) and inversion of control(IoC) are a good developing pattern. And inversify is a very mature package, so we includes it into Fulton Server. See DI for more information.

passport

Authentication is a basic feature of a web server. Fulton Server providers this feature definitely. Authentication is somehow complicated, so Fulton Server integrates passport, a useful authentication package, to help your web server authenticate users. See Identity for more information.

typeorm

Fulton Server takes the advantages of typeorm to connect multiple database engine. See Entity for more information.

swagger

Fulton Server can generate swagger.json that might help export your web server to other service. Also, Fulton Server embedded the swagger ui, so developments can see the api docs with look at code. See docs for more information.

winston

Fulton Server uses winston for its loggers. See logging for more information.

jsonapi

Fulton Server fully supports jsonapi.

Options

We want Fulton can be easy to configure, so we put almost every configurable settings in options variable. For example,

export class ExampleApp extends FultonApp {
    protected async onInit(options: FultonAppOptions): Promise<any> {
        options.routers = [
            FoodRouter,
            IngredientRouter
        ];
        
        options.entities = [Food, Ingredient]

        options.cors.enabled = true;
        options.docs.enabled = true;

        options.identity.enabled = true;
        options.identity.google.enabled = true;
    }
}

Fulton Server has js-docs for almost all of public classes, functions and members on its typescript declaration files. Therefore, typescript supported IDEs such as Visual Studio Code can give you Auto-Complete with documents that can improve the coding experiences as this picture.

server-options-auto-complete

As you can see, the features of Fulton Server can be very easy to change. See Options for more information.

Requirements

  • node.js > 7.0, Fulton Server uses a lot of features on ES2015 and ES2016, so it needs newer version of nodejs
  • typescript > 2.4

Issues

There are some known issues, see the notes to avoid the issues.

  • Because typescript isn't really a programming language. The ts code will compiled to javascript. And javascript doesn't have interface and generic type and a lot features which only exists on typescript for helping coding experience. After compiling, they are all gone. For example,

     // typescript
     interface MyInterface{
     	p1: string;
     	p2: string;
     }
    
     class MyClass <T extends MyInterface> {
     	p1: T;
     	p2: T;
     }
     // the javascript that complied from typescript
     class MyClass {
     }
     // all others staff are gone.
  • zone.js has a problem for es2017. use es2016 for now.

Readme

Keywords

none

Package Sidebar

Install

npm i fulton-server

Weekly Downloads

10

Version

0.3.4

License

MIT

Unpacked Size

726 kB

Total Files

328

Last publish

Collaborators

  • swarmnyc-dev
  • touren
  • wadehuang36