@anglr/rest
Version:
Angular module representing rest services
35 lines • 1.63 kB
JavaScript
import { HttpContext } from '@angular/common/http';
import { IGNORED_INTERCEPTORS } from '@anglr/common';
import { isBlank } from '@jscrpt/common';
/**
* Middleware that is used for adding support for ignored interceptors
*/
export class IgnoredInterceptorsMiddleware {
//######################### public static properties #########################
/**
* String identification of middleware
*/
static { this.id = 'IgnoredInterceptorsMiddleware'; }
//######################### public methods - implementation of RestMiddleware #########################
/**
* Runs code that is defined for this rest middleware, in this method you can modify request and response
* @param this - Method is bound to RESTClient
* @param id - Unique id that identifies request method
* @param target - Prototype of class that are decorators applied to
* @param methodName - Name of method that is being modified
* @param descriptor - Descriptor of method that is being modified
* @param args - Array of arguments passed to called method
* @param request - Http request that you can modify
* @param next - Used for calling next middleware with modified request
*/
run(_id, _target, _methodName, descriptor, _args, request, next) {
if (isBlank(descriptor.disabledInterceptors)) {
return next(request);
}
request = request.clone({
context: new HttpContext().set(IGNORED_INTERCEPTORS, descriptor.disabledInterceptors)
});
return next(request);
}
}
//# sourceMappingURL=ignoredInterceptors.middleware.js.map