CoreDaemon 1.2.0

dotnet add package CoreDaemon --version 1.2.0
                    
NuGet\Install-Package CoreDaemon -Version 1.2.0
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="CoreDaemon" Version="1.2.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="CoreDaemon" Version="1.2.0" />
                    
Directory.Packages.props
<PackageReference Include="CoreDaemon" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add CoreDaemon --version 1.2.0
                    
#r "nuget: CoreDaemon, 1.2.0"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package CoreDaemon@1.2.0
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=CoreDaemon&version=1.2.0
                    
Install as a Cake Addin
#tool nuget:?package=CoreDaemon&version=1.2.0
                    
Install as a Cake Tool

icon

About

This package will help you produce binaries capable of installing init.d services of themselves on the target machine. The goal of writing this code, was to ease the deployment of dotnetcore web applications on linux hosts from Cicd pipelines.

Get the library

This library is available on NuGet.org, so you can add library to your dotnet core application via .Net Cli using:

	dotnet add package CoreDaemon 

Or Visualstudio Package Manager, using

	Install-Package CoreDaemon 

Or by directly adding reference to .csproj file:

	<PackageReference Include="CoreDaemon" />

Usage

To use the library, You would add the package in your project. Then at the Main Entry (Program.cs → Main(args[])) add call the library's entry:


static void Main(string[] args)
{
            Damien.Summon().ExecuteCommands(args);

           // Start your sync (blocking) service here
} 

The library will check input commands and install or uninstall a service on running machine according to the input arguments.

The commands would be

  • daemon install
  • daemon uninstall
  • daemon help

Check if CoreDaemon Handled the input commands

Most probably you would prefer your service not being started when the binary is called by daemon arguments. For this you can simply check the result of calling the Damien execution:



static void Main(string[] args)
 {
	if (Damien.Summon().ExecuteCommands(args) == ExecutionResult.NoActionTaken)
	{
	    // Start sync (blocking) service here 
	}

 } 

You can specify the default way of creating/removing daemons by using Damien.UseInitRc() to create service in /etc/init.d or using UseServiceUnitFile() to create service in /etc/systemd/system. This will be a default and can be overridden when using the application (Next section).

Logging

You can use any implementation of Microsoft's ILogger by calling Damien.UseLogger(logger), where logger is your ILogger instance.


     var logger = new ConsoleLogger();

     Damien.Summon().UseLogger(logger);

How daemon gets installed/uninstalled

By adding the code mentioned above, to your application entry, when your applicatin gets started by CoreDaemon commands, It will handle the commands and will install or uninstall a service (on linux's init.d). CoreDaemon commands are:

  • daemon install
  • daemon uninstall
  • daemon help

For example if your application name is Example, after it has been built, you would call

	sudo ./Example daemon install

For install scripts, cicds and etc. You can add 'init-rc' or 'unit' argument to both install and uninstall commands. These arguments will override the default installation method. init-rc will install/uninstall the select-case script in /etc/init.d/service-name, and unit will
install/uninstall the service unit file in /etc/systemd/system/servce-name.service.

Limitations

  • For now, the library only woks on Linux.
  • The code has been tested on Ubuntu
  • Since CoreDaemon writes on System files, calling your application with daemon commands must be elevated. (use sudo or call by root user)

Regards; Mani

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
.NET Core netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.1 is compatible. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
1.2.0 617 10/13/2022
1.1.0 511 12/5/2021
1.0.1 590 5/15/2021
1.0.0 647 5/15/2021 1.0.0 is deprecated because it has critical bugs.