Beispiel #1
0
        public void Boot(BootConfiguration configuration)
        {
            if (!configuration.Sealed)
            {
                throw new BootException(CoreErrorCodes.CannotBootNonSealedConfig);
            }

            this.BootConfiguration = configuration;
            this.bootlog           = new BootLog(new Clock());
            if (BootConfiguration.Verbose)
            {
                bootlog.SetOutstream(BootConfiguration.Output);
            }

            this.bootlog.Info("Kernel", "Booting...");
            this.SetupServiceLocator(configuration.ServiceRegistrations, bootlog);
            this.RegisterCommands(configuration.Commands);
            this.CheckSanity(ServiceLocator, configuration.SanityChecks.ToArray(), bootlog).GetAwaiter().GetResult();
            this.bootlog.Info("Kernel", "Done");
        }
Beispiel #2
0
        private async Task CheckSanity(IServiceLocator serviceLocator, Type[] sanityCheckTypes, BootLog log)
        {
            this.bootlog.Info(Constants.BootComponents.SanityChecks, "Starting Sanity Checks");
            var processor = serviceLocator.GetService <SanityCheckProcessor>();
            var sanity    = await processor.Check(sanityCheckTypes, log);

            if (sanity.Any(kvp => kvp.Value == false))
            {
                throw new BootException(CoreErrorCodes.InsaneKernel);
            }
            this.bootlog.Info(Constants.BootComponents.SanityChecks, "Completed Sanity Checks");
        }
Beispiel #3
0
        private void SetupServiceLocator(IReadOnlyList <IServiceRegistration> registrations, BootLog log)
        {
            this.bootlog.Info(Constants.BootComponents.ServiceLocator, "Loading Service Locator");
            var locator = new SimpleInjectorServiceLocator();

            locator.RegisterServices(registrations.ToArray(), log);
            this.ServiceLocator = locator;
            this.bootlog.Info(Constants.BootComponents.ServiceLocator, "Completed Loading");
        }