• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Jak poprawnie nazywać kontrolery i przydzielać do nich akcje?

Object Storage Arubacloud
0 głosów
152 wizyt
pytanie zadane 2 września 2020 w PHP przez Bizuma Gaduła (3,650 p.)

Witam, chciałbym się dowiedzieć jaka jest poprawna praktyka podczas tworzenia kontrolerów w modelu MVC (konkretnie w Laravelu jeżeli ma to znaczenie).

Przykład przedstawiający problem:

Załóżmy, że tworzymy serwis z ogłoszeniami / ofertami.

Każdy zalogowany użytkownik może tworzyć własne ogłoszenia, edytować je, i szukać ogłoszeń innych użytkowników i odpowiadać na nie.

Każdy niezalogowany użytkownik może tylko szukać ogłoszeń innych użytkowników.

Pytanie brzmi jaka powinna być poprawna struktura kontrolera / kontrolerów?

Czy powinienem utworzyć jeden kontroler, który posiada akcje dla wszystkich tych operacji:

  • wyświetlanie listy ogłoszeń należących do zalogowanego użytkownika
  • wyświetlanie formularza do tworzenia nowego ogłoszenia
  • zapisywanie nowego ogłoszenia
  • wyświetlanie konkretnego ogłoszenia
  • wyświetlanie formularza do edycji
  • zapisywanie zmian po edycji
  • usuwanie
  •  
  • lista wszystkich ogłoszeń (niezależnie od użytkownika)
  • wyświetlanie formularza pozwalającego odpowiedzieć na dane ogłoszenie
  • odebranie odpowiedzi na dane ogłoszenie
  • wyświetlanie formularza pozwalającego na wyszukiwanie konkretnych ogłoszeń

 

Czy może powinny być to dwa(lub więcej) różne kontrolery? Jeżeli tak, to jak poprawnie je nazywać?

Dla jednego kontrolera byłoby to pewnie NoticeController a w przypadku gdy jednak poprawnym jest rozdzielenie ich? CreateNoticeController i FindNoticeController? 

2 odpowiedzi

0 głosów
odpowiedź 2 września 2020 przez senpai desu Mądrala (5,720 p.)
Wydaje się ,że kontrolery powinny odpowiadać modelom (zazwyczaj 1:1) więc zależnie od struktury bazy/tabel

tyle kontrolerów ile tabel, każdy kontroler odpowiada za CRUD jednego modelu, w zależności od wymagań biznesowych do kontrolerów dodaje się więcej kodu/metod, więc obsługa wszystkich operacji związanych z tabelą users była by w kontrolerze User

https://webdevetc.com/blog/laravel-naming-conventions
0 głosów
odpowiedź 2 września 2020 przez Assasz Nałogowiec (30,460 p.)
Tylko kontrolery invoke'owane, czyli posiadające tylko i wyłącznie jedną publiczną metodę. Jeden kontroler = jeden endpoint, nie ma czegoś takiego jak "odwzorowanie modelu" w kontrolerze, są to dwie całkiem niezależne warstwy.

Proponuję poczytać np. o architekturze ADR (Action-Domain-Responder) i z niej czerpać, ponieważ MVC nie jest wzorcem stworzonym dla aplikacji webowych i skłania programistów do wielu złych praktyk. Również nic nie stoi na przeszkodzie, aby zaimplementować konwencję akcji w aplikacji MVC ;)

Podobne pytania

0 głosów
0 odpowiedzi 77 wizyt
0 głosów
0 odpowiedzi 84 wizyt
pytanie zadane 16 stycznia 2022 w JavaScript przez Bakkit Dyskutant (7,600 p.)
0 głosów
1 odpowiedź 378 wizyt

92,568 zapytań

141,420 odpowiedzi

319,622 komentarzy

61,954 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...