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

ru.tinkoff.kora.database.flyway.FlywayJdbcDatabaseInterceptor Maven / Gradle / Ivy

package ru.tinkoff.kora.database.flyway;

import org.flywaydb.core.Flyway;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import ru.tinkoff.kora.application.graph.GraphInterceptor;
import ru.tinkoff.kora.database.jdbc.JdbcDatabase;

import java.time.Duration;

public final class FlywayJdbcDatabaseInterceptor implements GraphInterceptor {

    private static final Logger logger = LoggerFactory.getLogger(FlywayJdbcDatabaseInterceptor.class);

    @Override
    public JdbcDatabase init(JdbcDatabase value) {
        final long started = System.nanoTime();
        logger.info("FlyWay migration starting...");

        Flyway.configure()
            .dataSource(value.value())
            .load()
            .migrate();

        logger.info("FlyWay migration finished in {}", Duration.ofNanos(System.nanoTime() - started).toString().substring(2).toLowerCase());
        return value;
    }

    @Override
    public JdbcDatabase release(JdbcDatabase value) {
        return value;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy