All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.wizarius.orm.migrations.DBMigrationSystem Maven / Gradle / Ivy

package com.wizarius.orm.migrations;

import com.wizarius.orm.database.connection.DBConnectionPool;
import com.wizarius.orm.migrations.entities.DBMigrationEntity;
import com.wizarius.orm.migrations.entities.DBMigrationEntityList;
import com.wizarius.orm.migrations.savers.IMigrationSaver;
import lombok.extern.slf4j.Slf4j;

/**
 * @author Vladyslav Shyshkin
 * Date: 2019-11-19
 * Time: 11:01
 */
@Slf4j
public class DBMigrationSystem {
    /**
     * Migration saver
     */
    private final IMigrationSaver saver;

    /**
     * Migrations list
     */
    private final DBMigrationList migrations;

    /**
     * Connection pool
     */
    private final DBConnectionPool pool;

    /**
     * Migration system
     *
     * @param pool       connection pool
     * @param migrations migrations list
     * @param saver      migration save
     */
    public DBMigrationSystem(DBConnectionPool pool,
                             DBMigrationList migrations,
                             IMigrationSaver saver) {
        this.saver = saver;
        this.migrations = migrations;
        this.pool = pool;
        this.setupPoolInMigrations();
    }

    /**
     * Setup pool in all migrations
     */
    private void setupPoolInMigrations() {
        for (DBMigration migration : migrations) {
            migration.setupConnectionPool(pool);
        }
    }

    /**
     * Setup migration system
     */
    public void setup() throws DBMigrationException {
        log.info("Start migrations setup");
        saver.beforeMigrations();
        log.info("Read current migrations");
        //get all record from dump file
        DBMigrationEntityList entities = saver.read();
        for (DBMigration migration : migrations) {
            if (entities.getByLevels(migration.getLevel()) == null) {
                log.info(migration.getClass().getCanonicalName() + " : " + "UP NEW MIGRATION WITH LEVEL " + migration.getLevel() + " AND NAME " + migration.getName());
                migration.up();
                migration.execute();
                saver.save(new DBMigrationEntity(migration.getLevel(), migration.getName()));
            } else {
                log.info(migration.getClass().getCanonicalName() + " : " + "SKIP MIGRATION WITH LEVEL " + migration.getLevel() + " - ALREADY EXIST");
            }
        }
    }

    /**
     * Read saved migrations
     *
     * @return save migrations
     * @throws DBMigrationException on unable to get saved migrations
     */
    public DBMigrationEntityList getSavedMigrations() throws DBMigrationException {
        return saver.read();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy