public void Load(ISpeedDateStartable startable, IConfigProvider configProvider, Action <SpeedDateConfig> startedCallback) { _logger = LogManager.GetLogger("SpeedDate"); _config = configProvider.Result; _container = CreateContainer(startable); configProvider.Configure(_container.ResolveAll <IConfig>()); _container.BuildUp(startable); //Filter plugins for namespace & inject configuration into valid plugins foreach (var plugin in _container.ResolveAll <IPlugin>()) { if (_config.Plugins.Namespaces.Split(';').Any(ns => Regex.IsMatch(plugin.GetType().Namespace, ns.Trim().AsRegular()))) { _logger.Debug($"Loading plugin: {plugin}"); //Inject configs, cannot use _container.BuildUp because the configProvider may have additional IConfigs var fields = from field in plugin.GetType() .GetFields(BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.Public) where Attribute.IsDefined(field, typeof(InjectAttribute)) select field; foreach (var field in fields) { if (field.GetValue(plugin) == null && _config.TryGetConfig(field.FieldType.FullName, out var config)) { field.SetValue(plugin, config); } } } else { _container.Unregister(typeof(IPlugin), plugin.GetType().FullName); } } //Inject additional dependencies e.g. ILogger foreach (var plugin in _container.ResolveAll <IPlugin>()) { _container.BuildUp(plugin); } //Finally notify every plugin that loading has finished foreach (var plugin in _container.ResolveAll <IPlugin>()) { plugin.Loaded(); _logger.Info($"Loaded {plugin.GetType().Name}"); } startedCallback.Invoke(_config); }
public void Start() { SpeedDateConfig.Initialize(_configFile); var logger = LogManager.GetLogger("SpeedDate"); var kernel = CreateKernel(); var startable = kernel.Get <ISpeedDateStartable>(); startable.Started += () => Started?.Invoke(); startable.Stopped += () => Stopped?.Invoke(); PluginProver = kernel.Get <IPluginProvider>(); foreach (var plugin in kernel.GetAll <IPlugin>()) { PluginProver.RegisterPlugin(plugin); } foreach (var plugin in PluginProver.GetAll()) { plugin.Loaded(PluginProver); logger.Info($"Loaded {plugin.GetType().Name}"); } var server = kernel.TryGet <IServer>(); if (server != null) { logger.Info("Acting as server: " + server.GetType().Name); } var client = kernel.TryGet <IClient>(); if (client != null) { logger.Info("Acting as client: " + client.GetType().Name); } startable.Start(); }