UNPKG

@anglr/rest

Version:

Angular module representing rest services

49 lines 2.2 kB
import { Observable } from 'rxjs'; import { ParamsDataIterator } from '../misc/classes/paramsData.iterator'; import { handleHeaderParam } from '../misc/utils'; /** * Middleware that is used for adding header from parameter */ export class HeaderParameterMiddleware { //######################### public static properties ######################### /** * String identification of middleware */ static { this.id = 'HeaderParameterMiddleware'; } //######################### 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) { return new Observable(observer => { (async () => { const parameters = target.parameters; let pHeader; let pTransforms; if (parameters) { pHeader = parameters[methodName]?.header; pTransforms = parameters[methodName]?.transforms; } if (pHeader) { const headers = {}; for (const data of new ParamsDataIterator(pHeader, pTransforms, args, this)) { await handleHeaderParam(data, headers, args); } request = request.clone({ setHeaders: headers }); } return next(request).subscribe(observer); })(); }); } } //# sourceMappingURL=headerParameter.middleware.js.map