212 похожих чатов

Подскажите кто и как добавляет проект всякие utils, маперы и

другие упрощающие разработку штуки.

Например, конкретная ситуация (проект на TypeScript):

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

Другой разработчик дописывает к модельке метод toDTO, который он использует в своей конкретной задаче.

И получается ситуация, когда новый метод toDTO не используется во всех предыдущих случаях где он мог бы быть использован.

Чья ответственность внедрить toDTO везде? И нужно ли?

9 ответов

8 просмотров

для начала utils это всегда плохо. в целом удобно держать такой модуль и лочить ревью с двумя апрувами что бы заруку ловить любителей не особо думать куда чего класть. на счет твоего вопроса. У вас был подход. Один разработчик решил его поменять в одном месте. Теперь у вас два подхода. Какой предпочтительнее? почему там не надо было а тут надо? Есть ли у вас кто-то кто отвечает за общие гайдлайны? Ну то есть кто соберет людей, соберет мнение, проведет анализ и примет решение должно быть так, по другому или распишет как решить тот или другой вариант? Или в целом есть ли у вас общий код стайл/гайдлайны?

Alexander- Автор вопроса

Гайдлайнов нет, и вообще каких-либо формализованных требований нет. А есть что-то почитать по составлению гайдлайнов?

А у тебя получается, что у тебя один маппер со стороны repository -> domain, потом второй маппер со стороны domain -> presentation? Ну и в обратную сторону точно так же?

Alexander- Автор вопроса
lutik
А у тебя получается, что у тебя один маппер со сто...

У меня репозитории всегда возвращают domain объекты. А domain объекты не всегда мапятся на presentaion – например, там где нет потребности менять стейт, пишутся обычные запросы и уже их результат мапится на dto. А в обратную сторону на domain ничего не мапится (ну только если не считать конструирование domain объекта при его добавлении в репозитоий мапингом)

Да, понял, точно так же сделано, но у меня еще application прослойка: presentation <- application <- domain на уровне application мапплю

Alexander- Автор вопроса
lutik
Да, понял, точно так же сделано, но у меня еще app...

А. Ну у меня на уровне presentation тоже есть мапинг dtoшек приходящих с application сервисов на уже конкретные модели api – чтобы лишние данные не утекли т.к. typescript не следит за тем есть ли в в объекте данные выходящие за рамки интефейса

Woof Собач
Утилс не всегда плохо.

Ну я привел пример - удобно юзать как ловушку ловить неррдивых разработчиков

Похожие вопросы

Обсуждают сегодня

я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
короче сгенерила мне эта штука код на ассемблере: struc string val { common local .value dq .value .value: if ~val eq db val end if db 0 } fo...
Vi Chapmann Chapmann
12
Всем привет! Массив вводится с клавиатуры, кол-во элементов неизвестно, поэтому я указал arr db 100 dup(?) С нахождением максимума проблем нет, а вот минимум почему-то всегд...
En Vind Av Sorg
11
кто шарит: mattermost отслеживает что ты на пк запускаешь?
Valentin
13
Помогите, пожалуйста, делаю программу для для подсчёта корней квадратного уравнения, знаю, что есть куча недочётов, недоработок, но основная проблема в том, что почему-то при ...
NYC
13
#include <stdio.h> int main(void) { int n; scanf("%d", &n); int digits1[n] = {0}; int digits2[n] = {0}; я не могу таким образом заранее массив нулями заполнить?
Linus
12
в сях есть множество как в питоне? для удаление дубликатов
Linus
25
читать файл максимально быстро? странный вопрос))
zamtmn
53
я про форму записи. смысл указывать что 8 байтный регистр 8 байт?
Aiwan \ (•◡•) / _bot
10
Вроде бы вопрос уже заезжанный, но тем не менее У меня есть функция menu() которая выводит набор возможных действий, а затем спрашивает у пользователя что он хотел бы сделать....
David Golovatin
5
Карта сайта