Czy mogę korzystać z mojego projektu Ninject .NET w ramach Orchard CMS?

Tworzę stronę internetową przy użyciu Orchard CMS i mam zewnętrzny projekt .NET napisany przy pomocy Ninject do wstrzykiwania zależności, który chciałbym wykorzystać wraz z modułem w Orchard CMS. Wiem, że Orchard używa Autofac do wstrzykiwania zależności i to powoduje problemy, ponieważ nigdy wcześniej nie pracowałem z DI.

Stworzyłem moduł Autofac,UserModule, który rejestruje źródło,UserRegistrationSource, lubię to:

UserModule.cs

public class UserModule : Module
{
    protected override void Load(ContainerBuilder builder)
    {
        builder.RegisterSource(new UserRegistrationSource());
    }
}

UserRegistrationSource.cs

public class UserRegistrationSource : IRegistrationSource
{
    public bool IsAdapterForIndividualComponents
    {
        get { return false; }
    }

    public IEnumerable<IComponentRegistration> RegistrationsFor(Service service, Func<Service, IEnumerable<IComponentRegistration>> registrationAccessor)
    {
        var serviceWithType = service as IServiceWithType;
        if (serviceWithType == null)
            yield break;

        var serviceType = serviceWithType.ServiceType;
        if (!serviceType.IsInterface || !typeof(IUserServices).IsAssignableFrom(serviceType) || serviceType != typeof(IUserServices))
            yield break;

        var registrationBuilder = // something...

        yield return registrationBuilder.CreateRegistration();
    }
}

UserServices.cs

public interface IUserServices : IDependency
{
    void Add(string email, string password);
}

public class UserServices : IUserServices
{
    private readonly EFMembershipManager _manager;

    public UserServices(EFMembershipManager manager)
    {
        _manager = manager;
    }

    public void Add(string email, string password)
    {
        _manager.createUser(email, password);
    }
}

EFMembershipManager.cs konstruktor

public EFMembershipManager(ServerRepository db,
                           ServerRepositoryMembershipProvider membershipProvider,
                           string testUsername,
                           string serverUsername)
{
...
}

EFMembershipManager jest klasą z zewnętrznego projektu, który używa Ninject dla DI i zastosowańServerRepository iServerRepositoryMembershipProvider którzy również są wstrzykiwani za pomocą Ninject.

A teraz utknąłem ...

PowinienUserRegistrationSource weź kontener Ninject (jądro) jako argument konstruktora i spróbuj znaleźćIUserServices usługi, a następnie pośredniczymy w rozwiązaniach do jądra Ninject i zwracamy pusty Enumerable, aby Autofac nie próbował rozwiązać niczego związanego zIUserServices czy jest to niewłaściwe podejście?

questionAnswers(1)

yourAnswerToTheQuestion