-
Notifications
You must be signed in to change notification settings - Fork 24
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Add MoryxService to handle closing the console window. #357
base: dev
Are you sure you want to change the base?
Add MoryxService to handle closing the console window. #357
Conversation
andreniggemann
commented
Nov 23, 2023
- Add MoryxService to handle closing the console window.
- Add extension method to KernelServiceCollectionExtensions to use the MoryxService.
- Add dependency to Microsoft.Extensions.Hosting to make background services available.
The motivation behind this addition is, as I understand, that if you host your MORYX application for example with IIS, everything works fine. But if you want to run the .exe file on your machine, closing the terminal that appears kills the application without reaching the point where the modules are stopped. I.e. this would allow for a graceful shutdown for certain kinds of deployments. What do you think about it @Toxantron? |
Generally I think it is a good idea and one aspect of the old DeveloperConsole that is gone. Right now the shutdown via Ctrl+C should properly shutdown the application. However: This code is windows only. Since invoking the extension is up to the developer, I don't mind, but maybe there should be some sort of handling to exclude the code on Linux. |
I talked to @1nf0rmagician about this briefly. Do you agree with this approach? |
Sorry it took so long to respond to this. It simply got forgotten. To be hones @andreniggemann I am not a fan of framework monikers and different versions of DLLs, even if nuget takes care of it. I consider portability a big benefit of .NET and would prefer a runtime check like "if (Environment.OS == Windows)" instead. And in an additional request I would like to ask for a more descriptive name of the service and extension. |
Best practise from Microsoft:
https://learn.microsoft.com/en-us/dotnet/standard/frameworks |
@Toxantron I will try to see if this is possible with a runtime check around line 66 of MoryxService on Linux. I'm not sure about a more descriptive name. I think for other frameworks I have seen it as Add{FrameWork}Hosting. To call it something specific to the feature of awaiting the window closing would be weird for compatibility with linux, because it would not do that. Even without the window closing feature the MoryxHost has utility on all platforms in reducing boiler plate in our program.cs files and enabling more general use-cases that rely on the lifecycle of MORYX applications. |
@andreniggemann my naming concern mostly comes from the meaning of host and service in the context of ASP and service collection. Basically everthing you register in the service collection is considered a service and therefor AddMoryxService is quite non descriptive. I like Host, even more something that represents the windows host or window handling. |
Add extension method to KernelServiceCollectionExtensions to use the MoryxService. Add dependency to Microsoft.Extensions.Hosting to make background services available.
9b34863
to
7d64c35
Compare
Add Platform check, so that it does not crash on other platforms. Add StateChanged event to enable other servicees to plug into the moryx lifecycle via the host.
@Toxantron, @1nf0rmagician reminded me of this topic today. Sorry for taking so long it completely slipped my mind. |