Используя Autofac, я хотел бы зарегистрировать компонент и указать конкретную зависимость, которая должна быть разрешена для именованного экземпляра.
Я нашел примеры, подобные приведенным ниже, с использованием внедрения в конструктор, что почти то, что мне нужно.
builder.Register(c => new ObjectContainer(ConnectionStrings.CustomerDB))
.As<IObjectContainer>()
.Named("CustomerObjectContainer");
builder.Register(c => new ObjectContainer(ConnectionStrings.FooDB))
.As<IObjectContainer>()
.Named("FooObjectContainer");
builder.Register(c => new CustomerRepository(
c.Resolve<IObjectContainer>("CustomerObjectContainer"));
builder.Register(c => new FooRepository(
c.Resolve<IObjectContainer>("FooObjectContainer"));
Однако мне нужно это с внедрением свойства, и я не хочу указывать все зависимости.
Что-то вроде:
builder.Register<CustomerRepository>().With<IObjectContainer>("CustomerObjectContainer");
builder.Register<FooRepository>().With<IObjectContainer>("FooObjectContainer");
Сборка всехНеуказанные зависимости должны возникать с неназванными экземплярами.
Спасибо, Алекс
[ДОБАВЛЕНИЕ К ОТВЕТУ ОТ Даниэля]
Перегрузка для разрешения по типу для любого свойства этого типа.
public static IRegistrationBuilder<TLimit, TReflectionActivatorData, TStyle> WithDependency<TLimit, TReflectionActivatorData, TStyle, TProperty>(
this IRegistrationBuilder<TLimit, TReflectionActivatorData, TStyle> registration,
Func<IComponentContext, TProperty> valueProvider)
where TReflectionActivatorData : ReflectionActivatorData
{
return registration.WithProperty(new ResolvedParameter((p, c) =>
{
PropertyInfo prop;
return p.TryGetDeclaringProperty(out prop) &&
prop.PropertyType == typeof(TProperty);
},
(p, c) => valueProvider(c)));
}