James Bennett, one of Django’s core developers and author of books about Django, wrote two blog articles explaining why these “service layers” are a bad idea for Django projects. What he wrote matches mine experience 1:1 (I use Django since 1.1 and worked on several large projects).
I highly recommend the reading, Mr Bennett's argument did make much more sense to me. There's a set of "rules" he adopts that do help keeping code organized.
Really appreciate your comment. Those blogs were a great read. My instinct from previous jobs is to always separate business logic into a service layer, but he makes a compelling argument for instead utilizing the model manager and query set subclasses. I am excited to have justification for trying this "the easy way" that I've always been discouraged from doing... If a project scales to the point where this becomes a hindrance or inconvenience, there will be so many other more pressing concerns to worry about that it really won't matter.
Thanks for comment, it's really nice to contrasting new ideas with the "voice" of experienced developers. I don't have much experience but there's something with the idea of putting the core app logic outside the models that makes me noise.
Model managers and queryset classes. Those are often the best place for business logic to reside. Consider reporting. All you're suggesting is taking all the code that was organized where it belongs and sticking it in one or two big mega files of helper functions, then calling it from where the could should be. Testing the API should be done. What if a model field changes? Filter and search fields fail in runtime.
I am grateful for this video, because otherwise James Bennett would not have told what are the drawbacks of this solution. I saw its partial usage in the codebase of my colleague and also tried it in my own pet-project, but it becomes just too heavy to keep consistent in the long run. The idea of James Bennett with implementing it in QuerySets and Managers sounds much more reasonable right now for me. But till this video, I didn't know where to put the business logic and did not know about manager/queryset opportunities.
Services Pros Provided by the speaker: The general unit that holds business logic together. Service = A simple, type annotated function. Speaks the domain language of the software that we are creating. Can handle permissions & multiple cross-cutting concerns, such as calling other services or tasks. Work mostly & mainly with models. Services Cons by James Bennet: In short: Business Logic belongs in "the model", which incudes managers and QuerySets. I think it just an extended way to write the models file, and to migrate its complexed logic to another file(s)..
@@liorbm1 I was just fooling around. Just started learning Django 2 weeks ago, I worked in Spring Boot for the past 3 years and the Service layer was a no brainer there. It is kind of confusing for me that there is no such thing in Django 'by default'. In Django terms it really seems that the service layer is just an extension of the Model layer in another file, but I still think it is a better approach even if it is not supported by default. The model should be an interface, and the service layer should handle the business logic, it is cleaner in my opinion. With all these said I am still at the start of my Django learning and things that worked in Spring might not work as well in Django.
@@GuitaristManiaaac hm, i have a reverse case - 2 years worked with Django and started to looking closely into Spring because of topic of that video. Why do you moving away from spring boot to django?
If you don’t allow to use ModelSerializer in create/update views, then you don’t benefit from any model validation such as CharField’s max_length etc...
This is quite a good and clean solution when prioritizing scalability - BUT - if you're using Django 4fun and small school/personal projects, this lecture should be considered just a "point of view" of professional developer (as video title suggests). In mentioned guidlines Django and DRF are used as frameworks for simply avoiding manual HTTP, SQL and serializing - this does not take advantage of MASSIVE support for fast and reliable development which both of the frameworks provide (and were meant for). As for professional use, this is a very thoughtful solution, not so much for "fun" projects this approach can take away the "fun".
IMHO fat models underrated. Django's ORM is a kind of Active Record. If fat models cannot handle the complexity of business logic in your specific applications, it may means that the Django itself is not suited for your app, especially Active Record ORM. In that case better to choose other framework with other orm approach such as Data Mapper...
According to him, it's just a separation of concerns. As the name goes, serializers are for transforming data to and from Python objects and shouldn't handle the other things like creation. You could have a rigorous object creation process that is needed in other parts of the code and so won't be very good to mix it up with serialization logic
do it like this instead of importing like "from app.views import UserView" do it like this "import app.views as app_view" then use your view with "app_view.UserView"
I'm a newbie but I already had an experience of changing some little detail in the serializer from which others were inheriting/using and breaking my front end :/
Django is pretty flexible. You are not required to put all your code inside a Model or View. You can wrap all the Django ORM in a Repository and Unit of Work interfaces. Views are just one more input port for Commands, each can be mapped to an Use Case of the application.
This really just leads to a big, unanswered question for me: why use Django at all, then? Why not just use Pyramid or whatever, where the ORM isn't ActiveRecord and fighting your every attempt to abstract it away? And the cynical answer, to me, is that you can still say you're a Django company and you can recruit Django developers, despite not actually using Django in any meaningful sense.
Some useful informations but yeah you should maybe choose the appropriate level of abstraction on a per task basis and not as a golden rule although you're losing repeatability. But with such a reasoning we could also just argue that using Django isn't the right choice and neither is python if extrapolating
i work with Django already 10 years. This Talk about escapism. And don't matter which framework Rado don't want to use. It can be Flack, Django, Tornado, FastAPI... And it very easy to say: i don't like abstractions, i take from framework nothing. I don't wane to use SRRO, and DRY - this is abstractions also.
James Bennett, one of Django’s core developers and author of books about Django, wrote two blog articles explaining why these “service layers” are a bad idea for Django projects. What he wrote matches mine experience 1:1 (I use Django since 1.1 and worked on several large projects).
Could you share those blogs?
I highly recommend the reading, Mr Bennett's argument did make much more sense to me. There's a set of "rules" he adopts that do help keeping code organized.
@@samucancld Search for "james bennett Against service layers in Django". I tried sharing the link but YT keeps deleting my comment.
Really appreciate your comment. Those blogs were a great read. My instinct from previous jobs is to always separate business logic into a service layer, but he makes a compelling argument for instead utilizing the model manager and query set subclasses. I am excited to have justification for trying this "the easy way" that I've always been discouraged from doing... If a project scales to the point where this becomes a hindrance or inconvenience, there will be so many other more pressing concerns to worry about that it really won't matter.
Thanks for comment, it's really nice to contrasting new ideas with the "voice" of experienced developers. I don't have much experience but there's something with the idea of putting the core app logic outside the models that makes me noise.
Model managers and queryset classes. Those are often the best place for business logic to reside. Consider reporting.
All you're suggesting is taking all the code that was organized where it belongs and sticking it in one or two big mega files of helper functions, then calling it from where the could should be.
Testing the API should be done. What if a model field changes? Filter and search fields fail in runtime.
I am grateful for this video, because otherwise James Bennett would not have told what are the drawbacks of this solution. I saw its partial usage in the codebase of my colleague and also tried it in my own pet-project, but it becomes just too heavy to keep consistent in the long run. The idea of James Bennett with implementing it in QuerySets and Managers sounds much more reasonable right now for me. But till this video, I didn't know where to put the business logic and did not know about manager/queryset opportunities.
Did you use HackSoftware guideline?
@@speedcuber-diary I don't remember that name in my mind, so I think probably no.
Services Pros Provided by the speaker:
The general unit that holds business logic together.
Service = A simple, type annotated function.
Speaks the domain language of the software that we are creating.
Can handle permissions & multiple cross-cutting concerns, such as calling other services or tasks.
Work mostly & mainly with models.
Services Cons by James Bennet:
In short: Business Logic belongs in "the model", which incudes managers and QuerySets.
I think it just an extended way to write the models file, and to migrate its complexed logic to another file(s)..
no
@@GuitaristManiaaac Very detailed..
@@liorbm1 I was just fooling around. Just started learning Django 2 weeks ago, I worked in Spring Boot for the past 3 years and the Service layer was a no brainer there. It is kind of confusing for me that there is no such thing in Django 'by default'. In Django terms it really seems that the service layer is just an extension of the Model layer in another file, but I still think it is a better approach even if it is not supported by default. The model should be an interface, and the service layer should handle the business logic, it is cleaner in my opinion.
With all these said I am still at the start of my Django learning and things that worked in Spring might not work as well in Django.
@@GuitaristManiaaac hm, i have a reverse case - 2 years worked with Django and started to looking closely into Spring because of topic of that video. Why do you moving away from spring boot to django?
@@aksel58 Changed workplace and we are using different stack here :)
Brilliant explanation. Thanks a lot.
make sense 🙏, except the selector havent tried that
Nice pattern, thanks to share!
Excellent talk and very helpful! Thanx a lot!
If you don’t allow to use ModelSerializer in create/update views, then you don’t benefit from any model validation such as CharField’s max_length etc...
I think that’s why they call the obj.full_clean() to still gain that benefit
hah nice there, been exactly on the same conference you mentioned at the beginning :)
This is quite a good and clean solution when prioritizing scalability - BUT - if you're using Django 4fun and small school/personal projects, this lecture should be considered just a "point of view" of professional developer (as video title suggests). In mentioned guidlines Django and DRF are used as frameworks for simply avoiding manual HTTP, SQL and serializing - this does not take advantage of MASSIVE support for fast and reliable development which both of the frameworks provide (and were meant for). As for professional use, this is a very thoughtful solution, not so much for "fun" projects this approach can take away the "fun".
Very well said
selector: fetch DB
service: write to DB
Nice talk , but why not we use query sets and model manager. I think this methods are more optimized then service layer
he answers this in the questions section ~38:00
This was really useful for me
IMHO fat models underrated. Django's ORM is a kind of Active Record. If fat models cannot handle the complexity of business logic in your specific applications, it may means that the Django itself is not suited for your app, especially Active Record ORM. In that case better to choose other framework with other orm approach such as Data Mapper...
Just what I needed.
very nice talk
Can someone explain what is the downside of using the ModelSerializer inside the CreateAPI?
According to him, it's just a separation of concerns. As the name goes, serializers are for transforming data to and from Python objects and shouldn't handle the other things like creation. You could have a rigorous object creation process that is needed in other parts of the code and so won't be very good to mix it up with serialization logic
Hi, i have a question.
How are circular dependencies handled when two services use functions between themselves?
Thanks!
The Mediator pattern might be a solution you are looking for
do it like this
instead of importing like "from app.views import UserView"
do it like this "import app.views as app_view"
then use your view with "app_view.UserView"
Thank you....
Where is the source code?
Anyone else here has hands-on experience that reusing serializers is bad practice? This part is not quite clear for me.
I'm a newbie but I already had an experience of changing some little detail in the serializer from which others were inheriting/using and breaking my front end :/
@@IllevensKO Sounds like you need more integration tests. I don't think a service layer is going to fix that.
-None of the boxes [given by the framework] are appropriate for business logic. The exact same situation as Rails.
Django is pretty flexible. You are not required to put all your code inside a Model or View. You can wrap all the Django ORM in a Repository and Unit of Work interfaces. Views are just one more input port for Commands, each can be mapped to an Use Case of the application.
What can I do if my service depends on a lot of validations, 10 for example .. Is it convenient to do them all in service?
This really just leads to a big, unanswered question for me: why use Django at all, then? Why not just use Pyramid or whatever, where the ORM isn't ActiveRecord and fighting your every attempt to abstract it away? And the cynical answer, to me, is that you can still say you're a Django company and you can recruit Django developers, despite not actually using Django in any meaningful sense.
@@oasntet And python if we push the reasoning further.
@@heroe1486 At the very least, sqlalchemy is much more suited to this sort of use case. It's not ActiveRecord.
i like this
Some useful informations but yeah you should maybe choose the appropriate level of abstraction on a per task basis and not as a golden rule although you're losing repeatability. But with such a reasoning we could also just argue that using Django isn't the right choice and neither is python if extrapolating
i work with Django already 10 years. This Talk about escapism. And don't matter which framework Rado don't want to use. It can be Flack, Django, Tornado, FastAPI... And it very easy to say: i don't like abstractions, i take from framework nothing. I don't wane to use SRRO, and DRY - this is abstractions also.
very nice talk