inversify
Version:
A powerful and lightweight inversion of control container for JavaScript and Node.js apps powered by TypeScript.
110 lines (109 loc) • 4.62 kB
JavaScript
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.createTaggedDecorator = exports.tagProperty = exports.tagParameter = exports.decorate = void 0;
const ERROR_MSGS = __importStar(require("../constants/error_msgs"));
const METADATA_KEY = __importStar(require("../constants/metadata_keys"));
const js_1 = require("../utils/js");
function targetIsConstructorFunction(target) {
return target.prototype !== undefined;
}
function _throwIfMethodParameter(parameterName) {
if (parameterName !== undefined) {
throw new Error(ERROR_MSGS.INVALID_DECORATOR_OPERATION);
}
}
function tagParameter(annotationTarget, parameterName, parameterIndex, metadata) {
_throwIfMethodParameter(parameterName);
_tagParameterOrProperty(METADATA_KEY.TAGGED, annotationTarget, parameterIndex.toString(), metadata);
}
exports.tagParameter = tagParameter;
function tagProperty(annotationTarget, propertyName, metadata) {
if (targetIsConstructorFunction(annotationTarget)) {
throw new Error(ERROR_MSGS.INVALID_DECORATOR_OPERATION);
}
_tagParameterOrProperty(METADATA_KEY.TAGGED_PROP, annotationTarget.constructor, propertyName, metadata);
}
exports.tagProperty = tagProperty;
function _ensureNoMetadataKeyDuplicates(metadata) {
let metadatas = [];
if (Array.isArray(metadata)) {
metadatas = metadata;
const duplicate = (0, js_1.getFirstArrayDuplicate)(metadatas.map(md => md.key));
if (duplicate !== undefined) {
throw new Error(`${ERROR_MSGS.DUPLICATED_METADATA} ${duplicate.toString()}`);
}
}
else {
metadatas = [metadata];
}
return metadatas;
}
function _tagParameterOrProperty(metadataKey, annotationTarget, key, metadata) {
const metadatas = _ensureNoMetadataKeyDuplicates(metadata);
let paramsOrPropertiesMetadata = {};
if (Reflect.hasOwnMetadata(metadataKey, annotationTarget)) {
paramsOrPropertiesMetadata = Reflect.getMetadata(metadataKey, annotationTarget);
}
let paramOrPropertyMetadata = paramsOrPropertiesMetadata[key];
if (paramOrPropertyMetadata === undefined) {
paramOrPropertyMetadata = [];
}
else {
for (const m of paramOrPropertyMetadata) {
if (metadatas.some(md => md.key === m.key)) {
throw new Error(`${ERROR_MSGS.DUPLICATED_METADATA} ${m.key.toString()}`);
}
}
}
paramOrPropertyMetadata.push(...metadatas);
paramsOrPropertiesMetadata[key] = paramOrPropertyMetadata;
Reflect.defineMetadata(metadataKey, paramsOrPropertiesMetadata, annotationTarget);
}
function createTaggedDecorator(metadata) {
return (target, targetKey, indexOrPropertyDescriptor) => {
if (typeof indexOrPropertyDescriptor === 'number') {
tagParameter(target, targetKey, indexOrPropertyDescriptor, metadata);
}
else {
tagProperty(target, targetKey, metadata);
}
};
}
exports.createTaggedDecorator = createTaggedDecorator;
function _decorate(decorators, target) {
Reflect.decorate(decorators, target);
}
function _param(paramIndex, decorator) {
return function (target, key) { decorator(target, key, paramIndex); };
}
function decorate(decorator, target, parameterIndexOrProperty) {
if (typeof parameterIndexOrProperty === 'number') {
_decorate([_param(parameterIndexOrProperty, decorator)], target);
}
else if (typeof parameterIndexOrProperty === 'string') {
Reflect.decorate([decorator], target, parameterIndexOrProperty);
}
else {
_decorate([decorator], target);
}
}
exports.decorate = decorate;
;