Ranter
Join devRant
Do all the things like
++ or -- rants, post your own rants, comment on others' rants and build your customized dev avatar
Sign Up
Pipeless API
From the creators of devRant, Pipeless lets you power real-time personalized recommendations and activity feeds using a simple API
Learn More
Comments
-
appmaker3938y@lotd I am injecting various repositories into my service layer. What you see are private variables. I inject the repo's in the constructor of the service.
-
@appmaker
I get that... but my question is what the hell does this service do that it requires you to inject 17 Repos, 2 other services and a mapping engine? -
appmaker3938y@GinjaNinja the service has a bunch of business logic seperated out to different methods where it needs these repositories to get data from their respective entities.
-
-
ChappIO46878y@appmaker how I generally set up my services is I only give them the repository they are responsible for. All the other stuff you talk to the services.
So in that case I would not inject the UserRepository into the CourierService but the UserService instead.
Idk if this method would cut down on dependencies for you?
Also, if you can identify an unrelated responsibility (like parsing some data) in your CourierService you could consider creating a service from that. -
serpent56838yLooks like SDD (Service Driven Design). You should seriously look at the ideas of Domain Driven Design here. Business logic in services is considered bad for so many reasons...
-
donuts236218y@bendr but the lowercase name should already mean it's private. Otherwise it would be a Property
-
appmaker3938yFor some reason i cant post my comment. So i attached a pic of what I wanted to write lol
-
I think this would be solved using a Repository Context, that way you only inject the context and all the possibly needed repositories would be available and usually services are not dependent of each other, you might be implementing bad the layered architecture, if this sounds somewhere right or not please tag me.
-
@billgates I don't know if the question has been answered but that convention is what I use for read-only variables
-
stryter6238yThat's a pretty busy-looking service you have there. We have a general rule-of-thumb where I work: If you are injecting more than 5 dependencies into your services, it probably should be broken apart or refactored.
It has served us fairly well over the past couple years. We've gone back in some instances and cleaned up some pretty coupled code.
Related Rants
When you have a ton of business logic in one of the main services. Good or bad?
undefined
repository
dependency injection
c#
services
webapi