combineRoutes
Combines routing for different Effects, prefixed with path passed as a first argument.
import { combineRoutes } from '@marblejs/http';
combineRoutes :: (string, RouteCombinerConfig) -> RouteEffectGroup
combineRoutes :: (string, (RouteEffect | RouteEffectGroup)[]) -> RouteEffectGroup
parameter | definition |
path | string |
configOrEffects | RouteCombinerConfig | Array<RouteEffect | RouteEffectGroup> |
parameter | definition |
effects | Array<RouteEffect | RouteEffectGroup> |
middlewares | <optional> Array<HttpMiddlewareEffect> |
Factorized
RouteEffectGroup
object.user.effects.ts
import { combineRoutes } from '@marblejs/http';
import { authorize$ } from 'auth.middleware';
// const getUsers$ = ...
// const postUser$ = ...
export const user$ = combineRoutes('/user', {
middlewares: [authorize$],
effects: [getUsers$, postUser$],
});
api.effects.ts
import { combineRoutes } from '@marblejs/http';
import { user$ } from './user.effects';
// const root$ = ...
// const notFound$ = ...
export const api$ = combineRoutes('/api/v1', [
root$,
user$,
notFound$,
]);
Last modified 1yr ago