Created
November 1, 2012 22:54
-
-
Save maxfridbe/3997274 to your computer and use it in GitHub Desktop.
Autofac Bootstrap and logging
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
public class LogInjectionModule : Module | |
{ | |
protected override void Load(ContainerBuilder builder) | |
{ | |
//log4net added by extension | |
log4net.Config.XmlConfigurator.Configure(); | |
builder.Register<ILogger>((c, p) => new Log4NetLog(p.TypedAs<Type>())); | |
} | |
protected override void AttachToComponentRegistration(IComponentRegistry registry, IComponentRegistration registration) | |
{ | |
log4net.Config.XmlConfigurator.Configure(); | |
registration.Preparing += OnComponentPreparing; | |
} | |
static void OnComponentPreparing(object sender, PreparingEventArgs e) | |
{ | |
var t = e.Component.Activator.LimitType; | |
e.Parameters = e.Parameters.Union( | |
new[] { | |
new ResolvedParameter((p, i) => p.ParameterType == typeof(ILogger), (p, i) => new Log4NetLog(t)) | |
} | |
); | |
} | |
} | |
public static class Bootstrapper | |
{ | |
public static IContainer Container { get; set; } | |
public static void Initialize() | |
{ | |
var builder = new ContainerBuilder(); | |
builder.RegisterModule<LogInjectionModule>(); | |
builder.RegisterModule<OperationsModule>(); | |
builder.RegisterModule<StudioToExternalCommonModule>(); | |
Container = builder.Build(); | |
} | |
public static T Get<T>() | |
{ | |
return Container.Resolve<T>(); | |
} | |
public static ILogger GetLogger(Type type) | |
{ | |
return Container.Resolve<ILogger>(TypedParameter.From(type)); | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment