используя сервис локализации GetAllLanguages ​​из компонента composer, неправильный DI? - PullRequest
0 голосов
/ 16 апреля 2019

У меня есть интерфейс, как показано ниже, который я использую для добавления определенного языка, если он не существует:

public interface IGetLanguagesService
    {
        void GetLanguages(ILocalizationService localization);
    }


    public class LanguageService : IGetLanguagesService
    {
        ILocalizationService _localizationService;
        public void GetLanguages(ILocalizationService localization)
        {
            _localizationService = localization;
            var currentLanguages = _localizationService.GetAllLanguages();
            bool exists = false;
            foreach (var currentLan in currentLanguages)
            {
                if (currentLan.IsoCode == "es-ES")
                {
                    exists = true;
                }
            }
            if (!exists)
            {
                AddLanguage(_localizationService);
            }
        }

        public void AddLanguage(ILocalizationService localization)
        {
            var languageSE = new Language("es-ES") { CultureName = "es-ES", IsMandatory = true };
            localization.Save(languageSE);
        }
    }

Я хочу использовать это при запуске, поэтому создал компонент composer, который при Initialize () я хочу вызвать CallGetLanguages ​​(), но я не совсем уверен, что должно быть в Initialize (), я думаю, что мой DI может быть неправильно?

   public class LanguagesComposer : ComponentComposer<LanguagesComponent>
        {
            public void Compose(Composition composition)
            {
                composition.Register<IGetLanguagesService>(Lifetime.Singleton);
                composition.Register<ILocalizationService>(Lifetime.Singleton);

                composition.Components().Append<LanguagesComponent>();
            }
        }

        public class LanguagesComponent : IComponent
        {
            public void Initialize()
            {
               ???????
            }

            public void Terminate()
            {
                throw new NotImplementedException();
            }

            IGetLanguagesService _getLanguagesService;
            ILocalizationService _localization;
            public void CallGetLanguages(IGetLanguagesService getLanguages, ILocalizationService localization)
            {
                _getLanguagesService = getLanguages;
                _localization = localization;
                _getLanguagesService.GetLanguages(localization);
            }


}

1 Ответ

2 голосов
/ 16 апреля 2019

Вы дважды передали ILocalizationService localization в LanguageService, передаете его конструктору и используете инъекцию конструктора. То же самое с LanguagesComponent, передать его зависимости конструктору вместо методов

...