UNPKG

@golemio/pid

Version:
41 lines (40 loc) 1.86 kB
import { JISInfotextsModel } from "../../../schema-definitions/jis/models/JISInfotextsModel"; import { IJISInfotext } from "../../../schema-definitions/jis/models/interfaces"; import { ILogger } from "@golemio/core/dist/helpers"; import { IDatabaseConnector } from "@golemio/core/dist/helpers/data-access/postgres/IDatabaseConnector"; import { AbstractValidatableRepository } from "@golemio/core/dist/helpers/data-access/postgres/repositories/AbstractValidatableRepository"; import { JSONSchemaValidator } from "@golemio/core/dist/shared/golemio-validator"; import { Transaction } from "@golemio/core/dist/shared/sequelize"; type RepositoryOptions = { transaction?: Transaction; }; export declare class JISInfotextsRepository extends AbstractValidatableRepository { private logger; validator: JSONSchemaValidator; schema: string; tableName: string; private sequelizeModel; constructor(connector: IDatabaseConnector, logger: ILogger); /** * Delete all items last updated before a given date and time (where their `updated_at` is less than the given limit) * * @param dateTime The `updated_at` limit, where all items last updated before this limit shall be deleted * @param options Options for the operation * @returns The number of deleted items */ deleteAllLastUpdatedBefore(dateTime: Date, options?: RepositoryOptions): Promise<number>; /** * Refresh all data from VYMI and delete old data * * @param data The data to be upserted * @param options Options for the operation */ refreshData(data: IJISInfotext[], options?: RepositoryOptions): Promise<JISInfotextsModel[]>; private getUpdateAttributes; /** * @param options * @returns The number of deleted items */ deleteAll(options?: RepositoryOptions): Promise<number>; } export {};