2amigos/yii2-usuario
2amigos/yii2-usuario
Предлагаю обсудить архитектуру модуля 2amigos/yii2-usuario. К примеру сравнив ее с dektrium/yii2-user который более "стандартный". Как считаете, имеет ли данная архитектура реальные преимущества по сравнению со "стандартной"? Если да, то возможно стоит добавить нечто подобное в документацию, как пример более продвинутой структуры модуля?
Re: 2amigos/yii2-usuario
расскажите, что вы подразумеваете под архитектурой и в чем вы видите различия между модулями.
- BrusSENS
- Сообщения: 565
- Зарегистрирован: 2012.07.26, 06:51
- Откуда: Новороссийск
- Контактная информация:
Re: 2amigos/yii2-usuario
Лично я не понял, зачем контроллеры называть командами, разве команды сложнее? Вроде нет. DI использовать тоже не помешало бы. По сути, имхо, неоправданно переусложненный код, в котором подмена реализации чего-либо превратиться в переписывание кода. Опять же ИМХО
Native Web - небольшой блог о веб разработке (временно на ремонте)
Режим обслуживания сайта для Yii 2.x.x
Режим обслуживания сайта для Yii 2.x.x
Re: 2amigos/yii2-usuario
Это консольные контроллеры, которые в yii2-app-basic тоже лежат в папке commands.
Автор передаёт сущности и другие данные в конструкторы вместо передачи зависимостей. Видимо, не умеет делать stateless сервисы для DIC.
Да, это участь любых универсальных модулей. Этим они отличаются от библиотек.
Re: 2amigos/yii2-usuario
Ну если вкратце, то организацию проекта/его элементов и их взаимодействие. По поводу различий, по функционалу их практически нет, но структура модуля другая. Вот и хочу понять, а надо ли оно вообще?
Можно подробнее про "stateless сервисы для DIC"?ElisDN писал(а):Автор передаёт сущности и другие данные в конструкторы вместо передачи зависимостей. Видимо, не умеет делать stateless сервисы для DIC.
Т.е. если я правильно вас понял, эта структура на практике не дает никакого профита? Просто выпендреж паттернами?
Re: 2amigos/yii2-usuario
Я про данный конкретный модуль, а не про паттерны в целом. Насколько правильно в нем это все используется (Factory, Strategy, Service) и есть ли от них практическая польза?
Re: 2amigos/yii2-usuario
- BrusSENS
- Сообщения: 565
- Зарегистрирован: 2012.07.26, 06:51
- Откуда: Новороссийск
- Контактная информация:
Re: 2amigos/yii2-usuario
Просто команда всё таки другая штука, и консоль было бы разумнее назвать Console Да и с просонья смотрел код, не посмотрел, что это консольные контроллеры.
Я о том же.
Печально это, очень печально.
Вообще, хоть и не так давно познакомился с шиной команд, но могу сказать: жаль, что в конкретных модулях всё реализовывается с конкретными привязками на контроллеры (даже и на Stanalone экшены иногда). Лучше, если бы все модули предоставляли реализацию каких-либо конкретных команд. Таким образом, пришли бы всего лишь к неким библиотекам, которые не являются модулем, а всего лишь предлагают готовые команды для быстрой его разработки.
Native Web - небольшой блог о веб разработке (временно на ремонте)
Режим обслуживания сайта для Yii 2.x.x
Режим обслуживания сайта для Yii 2.x.x
Re: 2amigos/yii2-usuario
та самая это штука.
это не консоль. Это команды консольного приложения.
в таком случае 80% разработчиков yii не поняли что вообще происходит, а 15 не смогли бы прикрутить. Расширения для тех, кто в yii нашел advanced wordpress.
- BrusSENS
- Сообщения: 565
- Зарегистрирован: 2012.07.26, 06:51
- Откуда: Новороссийск
- Контактная информация:
Re: 2amigos/yii2-usuario
Разве консольный контроллер === команды консольного приложения?
Согласен. Именно поэтому упоминал уже на форуме, что стОит доводить до мозга девелоперов, как и что стоит готовить. Объяснить, что такое шина команд, зачем она нужна и в чём профит от её использования. И это касается не только шины команд. На конкретных примерах сообщество и начнёт расти. А так получается, что вводишь в гугол "Yii" или "Yii2" и получаешь кучу статей, которые по сути пережёвывают официальную (!!!переведенную на русский!!!) доку. Best Practices нужно народу. И некоторые моменты из обсуждения в данном разделе можно вполне вынести, как выдержки или даже некие рецепты. Давно уже пора понять, что тут частенько появляется народ, не имеющий вообще понятия, что такое ООП в php, или имеют только поверхностное представление об этом.
P.S.: Тут ТС поднял тему об архитектуре модуля, но опять же, имхо, в обоих модулях из шапки идёт тесная и безжалостная привязка к структуре дефолтных приложений Yii, посему и архитектуры тут никакой не будет. Всё так же завязано что в первом, что во втором случае. Посему проще написать своё, с DI и CommandBus, чем переписывать существующие контроллеры, а потом, не упаси Господь, пытаться поменять что-то в моделях. Лично я не хочу плодить миллион классов-наследников. Это штука на любителя.
Native Web - небольшой блог о веб разработке (временно на ремонте)
Режим обслуживания сайта для Yii 2.x.x
Режим обслуживания сайта для Yii 2.x.x
Re: 2amigos/yii2-usuario
на самом деле это то же самое, что объяснять нищему почему он должен покупать пирожные. объяснить можно, но денег нет.
- BrusSENS
- Сообщения: 565
- Зарегистрирован: 2012.07.26, 06:51
- Откуда: Новороссийск
- Контактная информация:
Re: 2amigos/yii2-usuario
Я наверное не особо правильно выразился... Нужно описывать некие Best Practices, склонять сообщество делать так, а не иначе. Хотя... С другой стороны, кому это нужно, найдёт ответы или задаст свои вопросы в данном разделе, кому не нужно - он на эти самые Best Practices положит с прибором, даже если будут примеры в официальной доке. В общем Вы правы.
P.S.:Отличное сравнение, кстати. Надо будет запомнить)))
Native Web - небольшой блог о веб разработке (временно на ремонте)
Режим обслуживания сайта для Yii 2.x.x
Режим обслуживания сайта для Yii 2.x.x
Re: 2amigos/yii2-usuario
Именно. Уже обсуждали в viewtopic.php?f=12&t=44836, viewtopic.php?f=34&t=42788 и ранее. Кому всё это нужно - прочтёт книги по архитектуре и документацию других фреймворков на английском и там уже найдёт все нужные Best Practices. А кому не нужно - прождолжит клепать на Yii/Wordpress/Самописах.BrusSENS писал(а): ↑2017.09.12, 01:51 Нужно описывать некие Best Practices, склонять сообщество делать так, а не иначе. Хотя... С другой стороны, кому это нужно, найдёт ответы или задаст свои вопросы в данном разделе, кому не нужно - он на эти самые Best Practices положит с прибором, даже если будут примеры в официальной доке.
- samdark
- Администратор
- Сообщения: 9489
- Зарегистрирован: 2009.04.02, 13:46
- Откуда: Воронеж
- Контактная информация:
Re: 2amigos/yii2-usuario
На чём "клепать" тут не важно, главное что "клепать" На всём можно писать прекрасно, ужасно или достаточно хорошо.А кому не нужно - прождолжит клепать на Yii/Wordpress/Самописах.
Нравится Yii? Давайте сделаем его лучше!.
Re: 2amigos/yii2-usuario
Было бы замечательно.Именно поэтому упоминал уже на форуме, что стОит доводить до мозга девелоперов, как и что стоит готовить. Объяснить, что такое шина команд, зачем она нужна и в чём профит от её использования. И это касается не только шины команд. На конкретных примерах сообщество и начнёт расти
По теме, хотел просто понять, насколько хорошо написан данный модуль. Редко вижу в открытом доступе что-то отличающееся от стандартной структуры из документации, а тут хоть какие-то намеки на слои.
samdark, как кор разработчик, что думаете о структуре данного модуля?
- BrusSENS
- Сообщения: 565
- Зарегистрирован: 2012.07.26, 06:51
- Откуда: Новороссийск
- Контактная информация:
Re: 2amigos/yii2-usuario
Вот именно, что лучше структура, но не архитектура, о чём ТС собственно и спрашивал.
Native Web - небольшой блог о веб разработке (временно на ремонте)
Режим обслуживания сайта для Yii 2.x.x
Режим обслуживания сайта для Yii 2.x.x
Re: 2amigos/yii2-usuario
Что в ней не так, кроме
?Автор передаёт сущности и другие данные в конструкторы вместо передачи зависимостей.
- BrusSENS
- Сообщения: 565
- Зарегистрирован: 2012.07.26, 06:51
- Откуда: Новороссийск
- Контактная информация:
Re: 2amigos/yii2-usuario
Вы путаетесь в понятиях архитектура и структура, вот о чём я.
Native Web - небольшой блог о веб разработке (временно на ремонте)
Режим обслуживания сайта для Yii 2.x.x
Режим обслуживания сайта для Yii 2.x.x