@decaf-ts/db-decorators
Version:
Agnostic database decorators and repository
15 lines • 11.6 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
const decorator_validation_1 = require("@decaf-ts/decorator-validation");
const validation_1 = require("./validation.cjs");
decorator_validation_1.Model.prototype.hasErrors = function (previousVersion, ...exclusions) {
if (previousVersion && !(previousVersion instanceof decorator_validation_1.Model)) {
exclusions.unshift(previousVersion);
previousVersion = undefined;
}
const errs = (0, decorator_validation_1.validate)(this, ...exclusions);
if (errs || !previousVersion)
return errs;
return (0, validation_1.validateCompare)(previousVersion, this, ...exclusions);
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"model.js","sourceRoot":"","sources":["../../src/model/model.ts"],"names":[],"mappings":";;AAAA,yEAawC;AACxC,iDAA+C;AAE/C,4BAAK,CAAC,SAAS,CAAC,SAAS,GAAG,UAE1B,eAAyB,EACzB,GAAG,UAAiB;IAEpB,IAAI,eAAe,IAAI,CAAC,CAAC,eAAe,YAAY,4BAAK,CAAC,EAAE,CAAC;QAC3D,UAAU,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;QACpC,eAAe,GAAG,SAAS,CAAC;IAC9B,CAAC;IAED,MAAM,IAAI,GAAG,IAAA,+BAAQ,EAAC,IAAI,EAAE,GAAG,UAAU,CAAC,CAAC;IAC3C,IAAI,IAAI,IAAI,CAAC,eAAe;QAAE,OAAO,IAAI,CAAC;IAE1C,OAAO,IAAA,4BAAe,EAAC,eAAe,EAAE,IAAI,EAAE,GAAG,UAAU,CAAC,CAAC;AAC/D,CAAC,CAAC","sourcesContent":["import {\n  Comparable,\n  Hashable,\n  ModelArg,\n  ModelErrorDefinition,\n  Serializable,\n  Validatable,\n  Model,\n  validate,\n  Constructor,\n  ModelBuilderFunction,\n  BuilderRegistry,\n  ModelConstructor,\n} from \"@decaf-ts/decorator-validation\";\nimport { validateCompare } from \"./validation\";\n\nModel.prototype.hasErrors = function <M extends Model>(\n  this: M,\n  previousVersion?: M | any,\n  ...exclusions: any[]\n): ModelErrorDefinition | undefined {\n  if (previousVersion && !(previousVersion instanceof Model)) {\n    exclusions.unshift(previousVersion);\n    previousVersion = undefined;\n  }\n\n  const errs = validate(this, ...exclusions);\n  if (errs || !previousVersion) return errs;\n\n  return validateCompare(previousVersion, this, ...exclusions);\n};\n\ndeclare module \"@decaf-ts/decorator-validation\" {\n  // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n  // @ts-expect-error\n  declare abstract class Model\n    implements Validatable, Serializable, Hashable, Comparable<Model>\n  {\n    protected constructor(arg?: ModelArg<Model>);\n\n    hasErrors(...exclusions: any[]): ModelErrorDefinition | undefined;\n    hasErrors(\n      previousVersion?: Model | any,\n      ...exclusions: any[]\n    ): ModelErrorDefinition | undefined;\n\n    /**\n     * @summary Compare object equality recursively\n     * @param {any} obj object to compare to\n     * @param {string} [exceptions] property names to be excluded from the comparison\n     */\n    equals(obj: any, ...exceptions: string[]): boolean;\n\n    /**\n     * @summary Returns the serialized model according to the currently defined {@link Serializer}\n     */\n    serialize(): string;\n\n    /**\n     * @summary Override the implementation for js's 'toString()' which sucks...\n     * @override\n     */\n    toString(): string;\n\n    /**\n     * @summary Defines a default implementation for object hash. Relies on a very basic implementation based on Java's string hash;\n     */\n    hash(): string;\n\n    /**\n     * @summary Deserializes a Model\n     * @param {string} str\n     *\n     * @throws {Error} If it fails to parse the string, or if it fails to build the model\n     */\n    static deserialize(str: string): any;\n\n    /**\n     * @summary Repopulates the Object properties with the ones from the new object\n     * @description Iterates all common properties of obj (if existing) and self, and copies them onto self\n     *\n     * @param {T} self\n     * @param {T | Record<string, any>} [obj]\n     *\n     */\n    static fromObject<T extends Model>(\n      self: T,\n      obj?: T | Record<string, any>\n    ): T;\n\n    /**\n     * @summary Repopulates the instance with the ones from the new Model Object\n     * @description Iterates all common properties of obj (if existing) and self, and copies them onto self.\n     * Is aware of nested Model Objects and rebuilds them also.\n     * When List properties are decorated with {@link list}, they list items will also be rebuilt\n     *\n     * @param {T} self\n     * @param {T | Record<string, any>} [obj]\n     *\n     */\n    static fromModel<T extends Model>(\n      self: T,\n      obj?: T | Record<string, any>\n    ): T;\n\n    /**\n     * @summary Sets the Global {@link ModelBuilderFunction}\n     * @param {ModelBuilderFunction} [builder]\n     */\n    static setBuilder(builder?: ModelBuilderFunction): void;\n\n    /**\n     * @summary Retrieves the current global {@link ModelBuilderFunction}\n     */\n    static getBuilder(): ModelBuilderFunction | undefined;\n\n    /**\n     * Returns the current {@link ModelRegistryManager}\n     *\n     * @return ModelRegistry, defaults to {@link ModelRegistryManager}\n     */\n    private static getRegistry;\n\n    /**\n     * Returns the current actingModelRegistry\n     *\n     * @param {BuilderRegistry} modelRegistry the new implementation of Registry\n     */\n    static setRegistry(modelRegistry: BuilderRegistry<any>): void;\n\n    /**\n     * @summary register new Models\n     * @param {any} constructor\n     * @param {string} [name] when not defined, the name of the constructor will be used\n     *\n     * @see ModelRegistry\n     */\n    static register<T extends Model>(\n      constructor: ModelConstructor<T>,\n      name?: string\n    ): void;\n\n    /**\n     * @summary Gets a registered Model {@link ModelConstructor}\n     * @param {string} name\n     *\n     * @see ModelRegistry\n     */\n    static get<T extends Model>(name: string): ModelConstructor<T> | undefined;\n\n    /**\n     * @param {Record<string, any>} obj\n     * @param {string} [clazz] when provided, it will attempt to find the matching constructor\n     *\n     * @throws Error If clazz is not found, or obj is not a {@link Model} meaning it has no {@link ModelKeys.ANCHOR} property\n     *\n     * @see ModelRegistry\n     */\n    static build<T extends Model>(obj?: Record<string, any>, clazz?: string): T;\n\n    static getMetadata<V extends Model>(model: V): any;\n\n    static getAttributes<V extends Model>(model: Constructor<V> | V): string[];\n\n    static equals<M extends Model>(\n      obj1: M,\n      obj2: M,\n      ...exceptions: any[]\n    ): boolean;\n\n    static hasErrors<M extends Model>(\n      model: M,\n      ...propsToIgnore: string[]\n    ): ModelErrorDefinition | undefined;\n\n    static serialize<M extends Model>(model: M): any;\n\n    static hash<M extends Model>(model: M): any;\n\n    /**\n     * @summary Builds the key to store as Metadata under Reflections\n     * @description concatenates {@link ModelKeys#REFLECT} with the provided key\n     * @param {string} str\n     */\n    static key(str: string): string;\n\n    /**\n     * @description Determines if an object is a model instance or has model metadata\n     * @summary Checks whether a given object is either an instance of the Model class or\n     * has model metadata attached to it. This function is essential for serialization and\n     * deserialization processes, as it helps identify model objects that need special handling.\n     * It safely handles potential errors during metadata retrieval.\n     *\n     * @param {Record<string, any>} target - The object to check\n     * @return {boolean} True if the object is a model instance or has model metadata, false otherwise\n     *\n     * @example\n     * ```typescript\n     * // Check if an object is a model\n     * const user = new User({ name: \"John\" });\n     * const isUserModel = isModel(user); // true\n     *\n     * // Check a plain object\n     * const plainObject = { name: \"John\" };\n     * const isPlainObjectModel = isModel(plainObject); // false\n     * ```\n     */\n    static isModel(target: Record<string, any>): boolean;\n\n    /**\n     * @description Checks if a property of a model is itself a model or has a model type\n     * @summary Determines whether a specific property of a model instance is either a model instance\n     * or has a type that is registered as a model. This function is used for model serialization\n     * and deserialization to properly handle nested models.\n     * @template M extends {@link Model}\n     * @param {M} target - The model instance to check\n     * @param {string} attribute - The property name to check\n     * @return {boolean | string | undefined} Returns true if the property is a model instance,\n     * the model name if the property has a model type, or undefined if not a model\n     */\n    static isPropertyModel<M extends Model>(\n      target: M,\n      attribute: string\n    ): boolean | string | undefined;\n  }\n}\n"]}