Задать вопрос
  • Планирование спринта и поток задач, как совместить?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    закладвайте буфер на спринт в кол-ве n часов на форс-мажор
    Ответ написан
    Комментировать
  • Как правильно создавать объект-сущность?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    на самом деле выглядит громоздко, но в этом есть ряд приимуществ.
    1. вы не зависите от слоя хранения, получения
    2. легко накатить тесты

    попробуйте организовать вашу логику и работу приложения не концентрируясь на внешнем апи.
    1. создайте сущности+интерфейсы+исключения
    2. создайте тестовый репозитрий реализующий метод получения но с хранением объектов прямо в репо.
    3. реализуйите логику работы с репозиториями и сущностями
    4. покройте код тестами используя тестовый репо, проверьте работу приложения
    5. реализуйте репозиторий работающий с внешним апи, переключите работу приложения на него.

    из приемуществ: тестируемый код , маштабируемость в будущем.
    Ответ написан
    Комментировать
  • Где проверять авторизацию пользователя?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    Иногда логика отображания может быть очень сложной, и вроде бы все просто есть контроллер, есть шаблон, есть данные. Подходов для решения может быть много, я бы выбрал следующий:
    1. Контроллер принимает запрос от пользозователя и обращается к сервису для получения контента
    2. Сервис контента, формирует контент но при этом проверяет права доступа, авторизиван не авторизован, дата,время, группа пользователя если атворизован, его пол и все что угодно. Отдает обратно контент согласно условиям.
    3. Контроллер получив контент передает в шаблон.
    Ответ написан
  • Что делать с vendor при переключении веток?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    если координально отличаются ветки например master и develop
    то создать два сайта master.site.loc и develop.site.loc
    и вести разработку паралельно
    Ответ написан
    Комментировать
  • Почему Symfony больше для Enterprise, нежели Laravel?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    В симфони разработка ведется от бизнес-логики, в laravel от инфраструктуры.
    Ответ написан
    6 комментариев
  • Какие преимущества проекта на laravel нежели на CMS- битрикс?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    1. Клиент выбирает битрикс с выгодой для бизнеса
    2. Вы выбираете Laravel с выгодой для себя
    Ответ написан
    1 комментарий
  • Достоверно известно, что некоторый API периодически отваливается по таймауту или с 5хх ошибкой, как решить?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    обработать ответ 500 ,подождать несколько секунд и попробовать снова, итак N попыток
    Ответ написан
    Комментировать
  • Какие инструменты использовать для разбора писем с помощью php?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    На самом деле все инструменты , их перечислю ниже, имеют свои недостатки, поэтому пришлось написать некий функционал явялющийся звеном для драйверов-библиотек, суть функционала :
    1. подключиться к серверу почты, получить N кол-во писем, скачать их содержимое, сохранить локально
    2. Прочитать письмо и пробразовать в ООП структуру, используя драйвер, в случае неудачи попробовать другой

    вот сообственно библиотеки который использовал:
    1. php_imap нативное php расширение, использовали в самом начале, не читало вложения некоторых писем, не работал imap_search для некторых серверов
    2. eden/mail - не читало некоторые вложения
    3. zend-mail (он же laminas-mail) - настроен на очень строгий rfc, если письмо отходит от стандарта кидает исключение.

    В текущйи момент остановились на измененном zend-mail драйвере но временами ловим письма которые не читаются, приходится адаптивровать драйвер.
    Ответ написан
    Комментировать
  • Правильно ли я делаю с точки зрения ООП?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    хелпер может существовать без данных, наверно вряд ли + метод получения ошибок
    тогда будет так
    $validation = new Validation($this->request->post());
    if(!$validation->validate()){
       //var_dump($validation->getErrors());
        return 'error';
    }


    про Helper молчу, вообще непонятно что делает
    Ответ написан
    Комментировать
  • Как создать модульность в mvc?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    хороший подход, использую очень давно, делается просто, я использую из твига такой вызов

    {{ module('Local.Slider',{speed:400}) }}

    или из php
    <?=module('Local.Slider',['speed'=>400]')?>

    Структура
    Local/Modules/Slider/Slider.php
    Local/Modules/Slider/tpl/default.twig

    тут нет модели. так как модель хранится чуть выше уровнем в пакете Local
    Ответ написан
    Комментировать
  • Привязать модель к репозиторию в Laravel?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    все правильно берешь и юзаешь получение данных через $this->model
    реализуя контракт UserRepositoryContract

    контракт было бы неплохо увидеть
    Ответ написан
  • Принцип генерации id для заказа?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    Смотря для каких целей, понятно что в бд уникальный id, но для клиента может содержать что угодно, например id торговой точки + порядковый номер
    Ответ написан
    2 комментария
  • Правильно ли так организовывать код?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    1) из класса Partner должно идти как минимум одно исключение PartnerException
    все исключения в классе Partner будут "переварены в одно" PartnerException
    в вашем случае вы можете добавить еще наследника и PartnerNotFoundException
    логика становиться более лаконичной:
    //App\Services\Partner
    public function getSong(string $singer, string $song_name) : array
        {
            try {
                $json = file_get_contents('partner-domain.com/api?singer=' . $singer);
            } catch (\Exception $e) {
                throw new PartnerException($e->getMessage());
            }
    
            $songs = json_decode($json, true);
    
            //Filter songs by given name
            $result = array_filter($songs, function($song) use ($song_name) {
                return mb_strtolower($song['name'] === mb_strtolower($song_name));
            });
    
            //We need to return only 1 song
            if (!isset($result[0])) {
                  throw new PartnerNotFoundException(sprintf(
                       'parnter not found by %s and %s', $singer, $song_name
                ));
            } 
    
           return [
                    'status' => 'ok',
                    'data' => $result[0];
          ];
    }


    - в контроллере try catch если нужно поймать
    public function getSong(string $singer, string $song_name) : string
        {
             try{
                 $song = $this->partnerService->getSong($singer, $song_name);
             }
            catch(PartnerNotFoundException $ex){
    
                //п.с не помню как в лаевел но смысл поняли
                 return response()->status(404)->send();
            }
    
             return response()->json($song);
        }

    2) через конструктор
    3) аналогично п1
    4) метод называется getSong получить песню, это значит все альтернативные варианты загоняем в исключения, нет песни - исключение, ошибка сервиса, исключение
    Ответ написан
    Комментировать
  • Как лучше реализовать проверку данных в классе-сущности?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    а у вас не должно быть такого что заказ остался а покупателя удалили,
    это то же самое что удалить заказ а позиции заказа остались.

    при удалении покупателя нужно удалять все его заказы
    Ответ написан
  • Как организовать gitflow для библиотеки, подключаемой через composer?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    смотрите
    у вас в библиотеке два изменения
    вы ведь эти изменения делаете ветках? соотвественно
    Новая фича1 требует ветку dev-feature1 - указываете в компосере
    фича2 требует ветку dev-feature2 - указываете в компосере
    вот и все
    Ответ написан
  • Паттерн Фабрика или Фасад?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    Фабрика
    Ответ написан
    Комментировать
  • Лучшие практики разработки ecomm проектов?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    Скажу одно: есть два типа разработки, разработка от бизнес логики и разработка от ифраструктуры. От бизнес логики , пишешь логику, покрываешь тестами, а потом думаешь где и как сохранять, как авторизировывать , какие библиотеки использовать.
    От инфраструктуры - берешь фраймворки и пилишь. В каждом есть свои плюсы и минусы.
    CMS это отдельная тема, в ней идет набор готовой бизнес логики, если она вписывается в твою, используй.
    Ответ написан
    Комментировать
  • Codeception организация тестирования приемочных тестов?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    Да, верно, база должна быть эталонная, но не должна содержать пользовательских динамических данных, только дефолтные данные .
    во время тестирования туда будут загонятся тестовые данные, например регистрация пользователя и тд.
    при завершении тестов, база будет дропатся и тем самым не нужно будут удалять тестовые данные.
    п.с. Отлично подходит докер для этих целей , после тестов контейнер со всем данными удаляется.
    Ответ написан
    Комментировать
  • Как правильно перевести php в twig?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    $this->twig->render('template.twig',$arr)
    Ответ написан
    Комментировать
  • Основы CMS интернет-магазина?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    присоединяюсь к Froggyweb
    дополню, чтобы при увеличении функционала не ухудшалась его поддержка, для этого нужно заложить архитектуру, а для этого нужен опыт.
    Ответ написан
    Комментировать