Hi,
First of all thank you very much your reply, it's much appreciated specially because I know that you are busy man :D
Just a quick reply, you mentioned:
In an ideal design, an application service should work like that to implement a use case of the application:
- Get related entities from repositories
- Use domain layer (domain services or entity methods) to manipulate them (perform business logic) - But do not implement business logic inside app service, just delegate the work to domain layer and orchestrate them.
- Save changed entities via repositories (actually Unit Of Work pattern (EF DbContext)) already does it when you SaveChanges).
So, this simple method implement it:
public async Task Cancel(EntityRequestInput<Guid> input) { var @event = await _eventManager.GetAsync(input.Id); _eventManager.Cancel(@event); }
Gets entity from manager (could get it from repository - it would be better) and uses domain layer to perform the operation: It does not just set event.Cancelled = true; because maybe we want to force to perform additional business logic on event cancellation.
This is perfect, this is precisely what I was trying to say. When I was following the Examples and Step by Steps guides I got confused because they were not following the DDD principles (some parts were and some parts weren't). I know now that you used that approach to make the examples a little bit simpler.
Once more thanks for the reply. Cheers, H
Hello there,
I wasn't criticising, far from that. Your work is very appreciated and after working for 20 years in the software industry I know that there isn't such a thing as a perfect solution and that "theory" and "practice" don't always walk together :D
The reason is related to the fact that I was giving a deep reading to the documentation, checking the examples and I wasn't being able to have a clear view. On my mind I had questions like: (note: (you don't need to answer the next questions), they are here just to show you the type of questions that someone reading the documentation and seeing the examples may have.
So perhaps I would ask you to answer just the last question. Why in your example you decided to have the repository and the manager at the application service? Why "Get" operations use the repository and the C,U,D operations are just a proxy to the manager? (again I'm not criticising, I'm just trying to brainstorm the decisions behind an architecture).
Keep up the good work ;) Cheers H
<cite>ismcagdas: </cite> Hi,
Actually we thought the pages in downloaded template contains update operations and it would be enough but maybe we are wrong.
We will consider adding update samples in step by step documents.
Thanks for sharing your problem with us.
Do you have any feedback on this subject? Would be nice to see an example implementing the Update for the main entity. New users that are using your framework to also learn some new skills struggle a bit with this part.
Thanks.
I will share my logic and how I will implement it.
Objectives and Restrictions:
Consideration that I also used to make a decision (for now)
Decisions
if (Tenant == null)
{
// Host seed
// Code removed from post for simplicity
}
else
{
InitialManagementDataBuilder(); // Countries, Post Codes,
if (DebugHelper.IsDebug)
{
new CompaniesBuilder(context).Create();
new OtherEntity1Builder(context).Create();
new OtherEntity2Builder(context).Create();
....
}
Cheers and Thanks for the replying. HugoL
Ok. I will do some research and some tests later on. I will share here what I can find out.
Thanks for the reply. HugoL
Ok I added this to the Github.
Thank you, HugoL
The migration tool and the default host works well when using this connection string on the app.config and the web.config like this:
<add name="Default" connectionString="Data Source=tcp:s12.winhost.com;Initial Catalog=DB_######main;User ID=DB##_main_user;Password=***;Integrated Security=False;" providerName="System.Data.SqlClient"
The questions are:
Thanks, Hugo
You welcome.
I understand your point of view. Perhaps just adding a recommendation something like "if you are using one database per tenant (Multi Database) you should use the Migration Tool to update all the databases.
Cheers, HugoL
Yes I did. This isn't related with the ABP, it's an outlook.com "feature".
When you send an email from an outllok.com Alias it seems that it uses your Main Profile Name (even if you specify by code a Display Name), which in my humble opinion, defeats the purpose of having an alias.
Anyway, this is sorted.
Thank you very much once more for your help. 5* support. Keep up the good work.
<cite>moustafa: </cite> Actually i have the same problem with the same host provider winhost did you fix it ?
I think this is related to the fact that you probably have MVC site deployed to your main domain and you are trying to deploy a another MVC site to a subdomain. Or even if it's your main site.
If you add the following entry to the web.config you will be able to run the site (main domain or sub domain) <system.web> <trust level="Full"/>
You can play with "High" and "Medium" and see if you can sort out the problem.