ft_transcendence/pong/node_modules/@nestjs/common/module-utils/utils/get-injection-providers.util.js
2023-05-02 19:15:50 +02:00

37 lines
1.5 KiB
JavaScript

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.getInjectionProviders = void 0;
/**
* check if x is OptionalFactoryDependency, based on prototype presence
* (to avoid classes with a static 'token' field)
* @param x
* @returns x is OptionalFactoryDependency
*/
function isOptionalFactoryDependency(x) {
return !!((x === null || x === void 0 ? void 0 : x.token) && !(x === null || x === void 0 ? void 0 : x.prototype));
}
const mapInjectToTokens = (t) => isOptionalFactoryDependency(t) ? t.token : t;
/**
*
* @param providers List of a module's providers
* @param tokens Injection tokens needed for a useFactory function (usually the module's options' token)
* @returns All the providers needed for the tokens' injection (searched recursively)
*/
function getInjectionProviders(providers, tokens) {
const result = [];
let search = tokens.map(mapInjectToTokens);
while (search.length > 0) {
const match = (providers !== null && providers !== void 0 ? providers : []).filter(p => !result.includes(p) && // this prevents circular loops and duplication
(search.includes(p) || search.includes(p === null || p === void 0 ? void 0 : p.provide)));
result.push(...match);
// get injection tokens of the matched providers, if any
search = match
.filter(p => p === null || p === void 0 ? void 0 : p.inject)
.map(p => p.inject)
.flat()
.map(mapInjectToTokens);
}
return result;
}
exports.getInjectionProviders = getInjectionProviders;