@anglr/rest
Version:
Angular module representing rest services
49 lines • 2.2 kB
JavaScript
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