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

sirius.kernel.AutoSetup Maven / Gradle / Ivy

/*
 * Made with all the love in the world
 * by scireum in Remshalden, Germany
 *
 * Copyright by scireum GmbH
 * http://www.scireum.de - [email protected]
 */

package sirius.kernel;

import sirius.kernel.di.std.ConfigValue;
import sirius.kernel.di.std.PriorityParts;
import sirius.kernel.di.std.Register;
import sirius.kernel.health.Exceptions;
import sirius.kernel.health.Log;

import java.util.List;

/**
 * Responsible for executing {@link AutoSetupRule auto setup rules} during th system startup.
 * 

* As most probably we only want to do this in dev / test / staging systems or once for production systems, * this facility has to be enabled via the system config in sirius.autoSetup. */ @Register(classes = {AutoSetup.class, Startable.class}) public class AutoSetup implements Startable { @ConfigValue("sirius.autoSetup") private boolean enabled; @PriorityParts(AutoSetupRule.class) private List rules; /** * Represents the logger used for everything concerning the system setup */ public static final Log LOG = Log.get("autosetup"); @Override public int getPriority() { return 1000; } @Override public void started() { if (!isEnabled()) { return; } for (AutoSetupRule rule : rules) { LOG.INFO("Executing auto setup rule: %s", rule.getClass().getName()); try { rule.setup(); } catch (Exception e) { Exceptions.handle() .to(LOG) .error(e) .withSystemErrorMessage("Auto seatup rule %s failed: %s (%s)", rule.getClass().getName()) .handle(); } } } /** * Determines if the auto setup facility is active. * * @return true if auto setup is enabled, false otherwise */ public boolean isEnabled() { return enabled; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy