funkygao/cp-ddd-framework

View on GitHub
dddplus-runtime/src/main/java/io/github/dddplus/runtime/registry/DDDBootstrap.java

Summary

Maintainability
A
0 mins
Test Coverage
/*
 * Copyright DDDplus Authors.
 *
 * Licensed under the Apache License version 2.0, available at http://www.apache.org/licenses/LICENSE-2.0
 */
package io.github.dddplus.runtime.registry;

import io.github.dddplus.runtime.IStartupListener;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.BeansException;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.context.ApplicationListener;
import org.springframework.context.event.ContextRefreshedEvent;
import org.springframework.stereotype.Component;

import javax.annotation.Resource;
import java.util.concurrent.atomic.AtomicBoolean;

/**
 * DDD框架启动器,internal only.
 */
@Component
@Slf4j
final class DDDBootstrap implements ApplicationListener<ContextRefreshedEvent>, ApplicationContextAware {
    private AtomicBoolean once = new AtomicBoolean();

    @Resource
    private RegistryFactory registryFactory;

    @Autowired(required = false)
    private IStartupListener startupListener;

    private static ApplicationContext applicationContext;

    @Override
    public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
        if (!once.compareAndSet(false, true)) {
            log.warn("register applicationContext more than once, ignored!");
            return;
        }

        long t0 = System.nanoTime();
        log.info("starting Spring, register DDD beans...");
        registryFactory.register(applicationContext);
        log.info("all DDD beans registered, cost {}ms", (System.nanoTime() - t0) / 1000_000);

        this.applicationContext = applicationContext;
    }

    @Override
    public void onApplicationEvent(ContextRefreshedEvent event) {
        if (event.getApplicationContext().equals(applicationContext)) {
            log.info("Spring started complete!");

            if (startupListener != null) {
                log.debug("calling IStartupListener: {}", startupListener.getClass().getCanonicalName());
                startupListener.onStartComplete();
                log.debug("called IStartupListener: {}", startupListener.getClass().getCanonicalName());
            }
        } else {
            log.info("Spring reloaded complete!");
        }
    }

    static ApplicationContext applicationContext() {
        return applicationContext;
    }

}