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
		
- 
				
				 appmaker3928y@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. appmaker3928y@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?
- 
				
				 appmaker3928y@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. appmaker3928y@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.
- 
				
				
- 
				
				 ChappIO46638y@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. ChappIO46638y@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.
- 
				
				 serpent56778yLooks 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... serpent56778yLooks 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...
- 
				
				 donuts232478y@bendr but the lowercase name should already mean it's private. Otherwise it would be a Property donuts232478y@bendr but the lowercase name should already mean it's private. Otherwise it would be a Property
- 
				
				 appmaker3928yFor some reason i cant post my comment. So i attached a pic of what I wanted to write lol appmaker3928yFor 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
- 
				
				 stryter6228yThat'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. stryter6228yThat'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







 Thanks, Microsoft.
Thanks, Microsoft.
 How do you even come up with shit like this?
How do you even come up with shit like this?
When you have a ton of business logic in one of the main services. Good or bad?
undefined
repository
dependency injection
c#
services
webapi