Comments (3)
Öncelikle, cevabımın gecikmesi için kusura bakmayın 🙌. Her katmanın kendi bağımlılıkları ve sorumlulukları vardır. Bu nedenle, her katmanda kendi ServiceRegistration dosyasına sahibiz ve ilgili katmanların bağımlılık çözümlerini bu dosyalar üzerinde tanımlayabilirsiniz. Başlatılabilir projede, örneğin WebAPI, bu ServiceRegistration dosyaları aracılığıyla bağımlılıkları IoC konteynerine ekleriz. İsterseniz ilgili ServiceRegistration dosyasında IConfiguration örneğini alabilir ve ilgili konfigürasyonlara göre bağımlılıkları düzenleme işlemlerini gerçekleştirebilirsiniz.
from narchitecture.
Cevabınız için teşekkür ederim, gecikmiş olması benim açımdan iyi oldu bu süre zarfında birçok örnek araştırıp nasıl bir yol ilerlemem gerektiğini araştırdım. Sizin projenizi örnek alarak bir core paketleri projesi oluşturmaya çalışıyorum. Onion mimarisine göre bu core paketlerini yazdığımızda Application katmanının sadece Domain katmanını referans alması gerekiyor fakat sizde Persistence ve Infrastructure katmanlarını referans alıyor. Onion mimarisinde bu yaklaşımı oturtamadığım için Application katmanı altında Application.Infrastructure.Abstractions adında bir proje oluşturmayı düşünüyorum, Infrastructure içerisindeki tüm interfaceleri bu katmana alarak Onion yaklaşımını korumayı düşündüm. Persistence ve Infrastructure katmanları Application.Infrastructure.Abstractions katmanlarını referans alır, Application katmanıda sadece Application.Infrastructure.Abstractions katmanını referans alırsa Onion mimarisi mantığından çıkılmamış olur diye düşünüyorum. @ahmet-cetinkaya
from narchitecture.
Core.Packages projesini şu şekilde yeniden tasarladım,
Onion mimarisine göre tüm katmanları çözümlere ayırdım.
- Application
- Domain
- Infrastructure
- Persistence
Persistence ve Infrastructure katmanı içerisindeki sabit tanımları Domain katmanına aktardım. Persistence katmanındaki Entity tanımlamaları vesayre Domain katmanı içerisinde. Exception türlerinide Domain katmanına aldım, bunu alma sebebim Onion mimarisine göre tüm servislerin ve arayüzlerin Application katmanında tanımlanması gerektiği.
Core.Application.Infrastructure.Abstractions adında bir proje oluşturdum ve arayüzleri buraya aktardım örneğin IRespository, ICacheService vb.
Infrastructure katmanındaki CrossCuttingConcerns projesi ile Persistence projeleri Core.Application.Infrastructure.Abstractions projesine bağımlıdırlar bu sayede Core.Domain katmanına erişerek oradaki gerekli tanımlamalara erişebiliyorlar.
MediaTR ile ilgili pipeline tanımlamalarını Core.Application.API adında bir projeye taşıdım, bu proje Core.Application.Infrastructure.Abstractions projesini referans proje olarak alır.
CrossCuttingConcerns ile Persistence projelerini referans alan bir Core.Packages adında library projesi oluşturmayı ve bu proje içerisinde serviceCollectionExtensions'larını birleştirip paket haline getirdikten sonra ana web api projesinde uygulamanın çekirdeğine yani Domain katmanına eklemeyi düşünüyorum. Ayrıca Core.Application.API diye adlandırdığım projeyide Application katmanına doğrudan referans vereceğim. Sizce izlediğim yol doğru mu?
from narchitecture.
Related Issues (17)
- What is this project about? HOT 4
- How do I create all the respective table in SQL Server database? HOT 5
- Dynamic HOT 1
- Getting error on adding refreshtoken. HOT 3
- Silme, Güncelleme işlem hatası HOT 5
- Thanks for sharing the code. Would you develop a sample client app, for example angualr/react/vue, to consume the api? HOT 1
- [SOLVED] - 'Items' is a namespace but is used like a type
- Microsoft.Data.SqlClient.SqlException (0x80131904): Invalid object name 'Companies'. HOT 2
- users controller'da GetFromAuth endpointinde userId gelmiyor HOT 4
- DeletedDate İndex Önerisi HOT 1
- Entity Framework .Net CLI işlemlerinde hataya çözüm HOT 3
- narchgen generate crud (Hatası) HOT 1
- Core packages esnekliği HOT 1
- MongoDB HOT 1
- Hata
- Refresh token mekanizması çalışmıyor
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from narchitecture.