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 {};
