• Всегда ли нужно использовать фреймворки?

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

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    1. схема нормальная, работаем сейчас по аналогичной
    2. докер в любом случае поможет использовать одно окружение для все разработчиков, CI для проекта
    Ответ написан
    Комментировать
  • Как сделать класс управления записями?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    второй более норм, но есть моменты:
    1. это репозиторий, класс который сохраняет сущности в хранилище
    поэтому
    BookRepository
    2. create update сделать приватными и можно заменить на save
    public function save(Model $model): void{
       if($model->getId()>0){
          $this->update($model);
       }
       else{
         $this->create($model);
       }
    }

    3. public function initDatabase(PDO $db) - это контруктор
    public function __construct(PDO $db)
    4. public function get(Book $book) - что это? public function findById($id): ?Book - более правильно
    5. public function getAll() - правильных ход, но если 1млн записей, все вытащите? нужна критерия выборки и коллекция на выходе а не массив
    public function getAll(Criteria $criteria): BookCollection

    п.с вообще то если ООП то у вас Book должна быть богатой моделью предметной области в данном случае это Rich Model где поведение модели размазано по слоям
    Ответ написан
  • Существуют ли CDN для PHP библиотек?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    JavaScript мне нужен какой-то плагин

    нужно отталкиваться от цели которую преследуете, Например, если на JavaScript мне нужен какой-то плагин - не аргумент, все таки не забывайте php - серверный язык а пример вы берете практики из клиентского ЯП.
    Ответ написан
    Комментировать
  • Как лучше хранить спец цены если их 1000 для каждого клиента?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    два варианта:
    1. Статически. Запускаем скрипт который в бд формирует цены и хранит конечную.
    2. Динамически. Есть базовая цена и расчет конечной на лету.
    3. Совмещение 1 и 2

    по структуре
    товар - ценовая позиция
    Ответ написан
  • Почему Service Locator это зло и что использовать вместо?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    Основные минусы:
    - В результате, между классом и его клиентом существует формальный или неформальный «контракт», который выражается в виде предусловий (требований к клиенту) и постусловий (гарантий выполнения работы). Однако если класс принимает экземпляр сервис локатора, или, хуже того, использует глобальный локатор, то этот контракт, а точнее требования, которые нужно выполнить клиенту класса, становятся неясными
    - Когда наш класс использует сервис локатор, то стабильность класса становится неопределенной. Наш класс, теоретически, может использовать что угодно, поэтому изменение любого класса (или интерфейса) в нашем проекте может затронуть произвольное количество классов и модулей
    - Самое страшное в Сервис Локаторе то, что он дает видимость хорошего дизайна. У нас никто не знает о конкретных классах, все завязаны на интерфейсы, все «нормально» тестируется и «расширяется». Но когда вы попробуете использовать ваш код в другом контексте или когда кто-то попробует использовать его повторно, вы с ужасом поймете, что у вас есть дикая «логическая» связанность, о которой вы и не подозревали
    - Для меня ясность и понятность интерфейса класса важнее количества параметров конструктора. Я не исключаю, что бывают случаи, когда сервис локатор является наименьшим злом, но я бы в любом случае постарался свести его использования к минимуму.
    Ответ написан
    Комментировать
  • Как реализовать алгоритм бонусов?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    function calcBonus(float $sumOrd):float {
    $bonusesSum = [
    1000 => 0.03,
    5000 => 0.05,
    10000 => 0.06
    ];
    $correct = 0;
    foreach($bonusesSum as $sum => $per){
        if($sumOrd >= $sum){
            $correct =  $per;
        }
    }
    return $sumOrd * (1 + $correct) - $sumOrd;    
    }
    print_r(calcBonus(10000));
    Ответ написан
    1 комментарий
  • Composer: как добавить приватный репозиторий в зависимости?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    вам необходимо развернуть satis, это что то вроде packagist.org
    satis на вашем сервере на основе конф.файла satis.json формирует дистрибутивы ваших приватных библиотек, и их заависимостей, так создает карту зависимостей.

    и больше вам нет смысла указывать "repositories": [
    {
    "type": "vcs",
    "url": "git@github.com:my/library.git"
    }
    ],

    просто указываете "my/library":"ver"

    ну и новый источник
    "repositories": [
    {
    "type": "composer",
    "url": "https://mysatis.ru"
    }
    ]
    Ответ написан
    Комментировать
  • Как организовать и хранить конфиг по каждому пользователю, чтобы что-то делать один или несколько раз?

    dmitriylanets
    @dmitriylanets
    веб-разработчик
    я делал через вариант {par1: false, par2: true}

    Я конечно могу через запрос всем добавить другой объект со свойством par3 и новый функционал будет добавлен

    - не обязательно обновлять, если при получении нет свойства например view_modal у объекта значит просто он считается не просмотренный, при просмотре и подтверждении занесите свойство view_modal=true
    Ответ написан
    Комментировать
  • Планирование спринта и поток задач, как совместить?

    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

    контракт было бы неплохо увидеть
    Ответ написан