HTTP for Leverage!
This is a plugin for Leverage that handles the http
type of components.
A HTTP Component has the following interface:
import {
ComponentUnit,
ComponentInstance,
ComponentConfig,
ComponentConfigInstance,
} from '@leverage/core';
import { Express } from 'express';
export type Route = string | RegExp;
type HTTPCallback = (
request: Express.Request,
response: Express.Response,
) => void;
interface HTTPComponentConfig {
http: {
path: Route | Route[];
method: string;
};
}
export interface HTTPComponent extends ComponentUnit {
config: ComponentConfig & HTTPComponentConfig;
http: HTTPCallback;
}
export interface HTTPComponentInstance extends ComponentInstance {
config: ComponentConfigInstance & HTTPComponentConfig;
http: HTTPCallback;
}
A HTTP Middleware has the following interface:
import * as http from 'http';
import { Express } from 'express';
import { MiddlewareInstance } from '@leverage/core';
export interface HTTPMiddleware extends MiddlewareInstance {
http: (options: { app: Express.Application; server: http.Server }) => void;
}
import { Manager } from '@leverage/core';
import {
HTTP,
HTTPComponent,
HTTPMiddleware,
} from '@leverage/plugin-http';
const http = new HTTP();
const manager = new Manager();
const component: HTTPComponent = {
is: 'component',
type: 'http',
config: {
http: {
path: '/',
method: 'get',
},
},
http (req, res) {
res.send('Hello, World!');
},
};
const middleware: HTTPMiddleware = {
is: 'middleware',
type: 'http',
http ({ app }) {
app.get('/middleware', (req, res) => {
res.send('Hello, Custom Middleware!');
});
},
};
manager.add(http, component, middleware);
http.listen(8080);