Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vectier/springpress
Writing Express but feel like Spring Boot
https://github.com/vectier/springpress
express mvc nodejs server springboot typescript
Last synced: 3 months ago
JSON representation
Writing Express but feel like Spring Boot
- Host: GitHub
- URL: https://github.com/vectier/springpress
- Owner: vectier
- License: mit
- Created: 2022-04-25T10:42:43.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2023-01-24T12:46:56.000Z (almost 2 years ago)
- Last Synced: 2024-10-09T17:31:26.154Z (3 months ago)
- Topics: express, mvc, nodejs, server, springboot, typescript
- Language: JavaScript
- Homepage:
- Size: 290 KB
- Stars: 9
- Watchers: 1
- Forks: 3
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# Springpress
A Top-level framework of Express.js for developing clean architecture API service, especially on [TypeScript](https://github.com/microsoft/TypeScript).
**Springpress** provides basic *Express.js* functions and MVC utilities related out of the box. Let you deep-dive into the world of [OOP](https://developer.mozilla.org/en-US/docs/Learn/JavaScript/Objects/Object-oriented_programming) and the scent of our motivation, *Spring Boot* with **Springpress**.
## Installation
> **Node.js 16.15.0 (LTS) is required**
Using npm:
```
$ npm install springpress
```Using yarn:
```
$ yarn add springpress
```## Usage
*Assume you are creating a dog controller that sends a response of the dog's name when requesting to `/dog/name`.*
### Server
First, you need to create a main class that extends `Springpress` class. This class will store all of your things. *e.g. services, controllers, repositories initialization*.
```ts
import { Springpress } from 'springpress';class ExampleServer extends Springpress {
public onStartup(): Promise {
// This code will run when your start your application.
// All of initialization should do it here.
}}
```Don't forget to call `Springpress#listen` to bind to and to listen for conections. This method returns an [http.Server](https://nodejs.org/docs/latest-v16.x/api/http.html#class-httpserver) object (the built-in HTTP module). *You can use this instance in your testing framework to work with HTTP*.
```ts
const port = 3000; // you can specify whatever port you want :)
const exampleServer = new ExampleServer(port);
exampleServer.listen();
```### Controller
#### Controller Mapping
Easily define your controller with `@ControllerMapping` decorator:
```ts
@ControllerMapping('/dog') // <-- Decorator here!
class DogController extends Controller {
// Routes implementation will be here.
}
```The `@ControllerMapping` decorator will mount your class on a router with the path where you specified in the first decorator parameter. In this case, this class will be mapped with `/dog` on the router.
- A client can connect by `http://localhost:3000/dog/` followed by your implemented route. *(port 3000 is just an example)*
- On this step, you will not actually be able to access it. You need to implement a route first by following the next step.#### Route Mapping
Easily define your route with `@RouteMapping` decorator:
```ts
@ControllerMapping('/dog')
class DogController extends Controller {@RouteMapping('/name', Methods.GET) // <-- Decorator here!
private async getName(req: Request, res: Response) {
res.status(200).json({
name: 'Doge',
});
}}
```The `@RouteMapping` decorator will mount your decorated method as a routing destination of an HTTP request in a controller.
A RouteMapping parameter
- path - a string of route path
- It can be anything that [Express.js](https://expressjs.com/en/guide/routing.html) routing support
- method - an enum of HTTP method (You can use `Methods` imported from Springpress)Now, your client will see `http://localhost:3000/dog/name` and get a response like below in a JSON format.
```json
{
"name": "Doge"
}
```#### Controller Registration
Everything above in the Controller section will not work if you haven't registered the controller in the Server class.
```ts
import { Springpress } from 'springpress';
import { DogController } from './controllers/DogController';class ExampleServer extends Springpress {
public onStartup(): Promise {
// Don't forget here!
const controllerRegistry = this.getControllerRegistry();
controllerRegistry.register(new DogController());
}}
```## Contribution
There are many ways in which you can participate in this project, for example:
- [Submit bugs and feature requests](https://github.com/riflowth/springpress/issues).
- Review [source code changes](https://github.com/riflowth/tier-discord-bot/pulls).
- Fixing issues and contributing directly to the code base by [submitting pull requests](https://github.com/riflowth/tier-discord-bot/pulls).## License
Copyright (c) Vectier. All rights reserved.
Licensed under the [MIT](https://github.com/riflowth/nextpress/blob/main/LICENSE) license.