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);