r.pipe
HttpEffect route builder based on IxMonad
Importing
import { r } from '@marblejs/http';
pipe
pipe
r
namespace function. Creates pipeable RouteEffect builder.
Type declaration
pipe :: ...Arity<IxBuilder, IxBuilder> -> RouteEffect
r.pipe
builder pays attention to the order of applied operators.
const example$ = r.pipe(
r.matchPath('/'),
r.matchType('GET'),
r.use(middleware_1$),
r.useEffect(req$ => req$.pipe(
// ...
)),
r.use(middleware_2$), // ❌ type error!
);
// or
const example$ = r.pipe(
r.matchType('GET'),
r.matchPath('/'), // ❌ type error!
r.use(middleware_1$),
r.use(middleware_2$),
r.useEffect(req$ => req$.pipe(
// ...
)),
);
Correct order:
<optional> applyMeta
matchPath
matchType
use
[...]useEffect
applyMeta
[...]
matchPath
matchPath
r
namespace function. Matches request path for connected HttpEffect.
Type declaration
matchPath :: string -> IxBuilder -> IxBuilder
Parameters
parameter
definition
path
string
matchType
matchType
r
namespace function. Matches HTTP method type for connected HttpEffect.
Type declaration
matchType :: HttpMethod -> IxBuilder -> IxBuilder
Parameters
parameter
definition
path
HttpMethod
use
use
r
namespace function. Registers HTTP middleware with connected HttpEffect.
Type declaration
use :: HttpMiddlewareEffect -> IxBuilder -> IxBuilder
Parameters
parameter
definition
middleware
HttpMiddlewareEffect
useEffect
useEffect
r
namespace function. Registers HttpEffect.
Type declaration
useEffect :: HttpEffect -> IxBuilder -> IxBuilder
Parameters
parameter
definition
effect
HttpEffect
applyMeta
applyMeta
r
namespace function. Applies metadata to connected HttpEffect.
Type declaration
applyMeta :: RouteMeta -> IxBuilder -> IxBuilder
Parameters
parameter
definition
meta
RouteMeta
RouteMeta
attributes:
parameter
type
definition
name
<optional> string
route/effect name
overridable
<optional> boolean
if true, the route can be overrode by another route
Example
import { r } from '@marblejs/http';
const example$ = r.pipe(
r.applyMeta({ continuous: true }),
r.matchPath('/'),
r.matchType('GET'),
r.use(middleware_1$),
r.use(middleware_2$),
r.useEffect(req$ => req$.pipe(
// ...
)),
r.applyMeta({ meta_1: /* ... */ }),
r.applyMeta({ meta_1: /* ... */ }),
);
Last updated