I did a spike exploration to find out what is involved in creating a Windows Service with event logging. I also wanted to find out what is involved in working with sftp, zip and configuration with C#. The code is available on github: https://github.com/k0emt/sftp-windows-service-spike
sftp
In order to test the sftp code I set up a Linux VM in the Azure cloud environment and created a user account on it.
I use the ssh component from http://sshnet.codeplex.com/ for sftp. It is very straight forward to use this component. The key for sftp is to use the SftpClient class. Upload a file with the UploadFile method. The sample code is in the ConsoleSftp projects Program.cs: https://github.com/k0emt/sftp-windows-service-spike/blob/clean/ConsoleSftp/Program.cs
zip
Use System.IO.Compression for creating/expanding zip files.
To use the ZipFile class, you must reference the System.IO.Compression.FileSystem assembly in your project.
http://msdn.microsoft.com/en-us/library/system.io.compression.zipfile(v=vs.110).aspx
I use ZipFile.CreateFromDirectory in the code above to zip an entire directory before sending it over sftp.
configuration
ConfigurationManager is the class that is used for working with application settings.
I used it in the service code to pull in a setting called user: https://github.com/k0emt/sftp-windows-service-spike/blob/clean/TransferService/TransferService.cs
In order for this to come together, you must create an app.config file in your project and change the property setting in Visual Studio to tell it to deploy when the project is built. https://github.com/k0emt/sftp-windows-service-spike/blob/clean/TransferService/App.config
Windows service with event logging
Create a Windows Service by choosing the Windows Service project template.
The Windows Service code must be installed and uninstalled. It is possible to create an installer/uninstaller. I opted to use the command line for this spike.
http://msdn.microsoft.com/en-us/library/y817hyb6(v=vs.110).aspx
http://msdn.microsoft.com/en-us/library/zt39148a(v=vs.110).aspx
I went here to learn about Service Methods – that is the kind of events to which the service can respond. You can use the Visual Studio designer to enable the events you want handle. Then you’ll need to code the events. For this spike code I have it make an entry in the event log for each event type that is triggered.
http://msdn.microsoft.com/en-us/library/System.ServiceProcess.ServiceBase_methods(v=vs.110).aspx
Installing and Uninstalling the service
http://msdn.microsoft.com/en-us/library/sd8zc8ha(v=vs.110).aspx
Install with installutil.exe TransferService.exe
Go to Windows Services to see that the installed service is running. See, the Spike Transfer Service below.
Uninstalling with installutil.exe /u TransferService.exe
Event Logging
For event logging a new EventLog is created. An event source must be created and the source has to be wired up to the EventLog.
Once this is done, the WriteEntry method can be used for writing to the event log.
You can go to the system event log panel to see where the events have been logged.
Summary
Overall, I was pleasantly surprised with the ease of accomplishing the spikes target tasks. There was also decent documentation and examples available.