Jack251970.TaskScheduler
2.12.2
dotnet add package Jack251970.TaskScheduler --version 2.12.2
NuGet\Install-Package Jack251970.TaskScheduler -Version 2.12.2
<PackageReference Include="Jack251970.TaskScheduler" Version="2.12.2" />
<PackageVersion Include="Jack251970.TaskScheduler" Version="2.12.2" />
<PackageReference Include="Jack251970.TaskScheduler" />
paket add Jack251970.TaskScheduler --version 2.12.2
#r "nuget: Jack251970.TaskScheduler, 2.12.2"
#addin nuget:?package=Jack251970.TaskScheduler&version=2.12.2
#tool nuget:?package=Jack251970.TaskScheduler&version=2.12.2
About
The original and most popular .NET wrapper for the Windows Task Scheduler. It provides functionally complete classes that cover all development aspects related to system tasks.
More information can be found on the project page on GitHub.
Support
Below are links to sites that provide in-depth examples, documentation and discussions. Please go here first with your questions as the community has been active for over a decade.
- Wiki - Sample code, library how-to, troubleshooting, etc.
- API documentation - Class/method/property documentation and examples
- Full Issues Log - Use the search box to see if your question may already be answered.
- Discussion Forum - Users helping users, enhancement requests, Q&A (retired Google forum here)
- Troubleshooting Tool - Tool to help identify and fix configuration and connectivity issues. (ClickOnce installer here)
Key Features
Microsoft introduced version 2.0 (internally version 1.2) with a completely new object model with Windows Vista. The managed assembly closely resembles the new object model but allows the 1.0 (internally version 1.1) COM objects to be manipulated. It will automatically choose the most recent version of the library found on the host system (up through 1.4). Core features include:
- Separate, functionally identical, libraries for .NET 2.0, 3.5, 4.0, 4.52, 5.0, 6.0, .NET Standard 2.0, .NET Core 2.0, 2.1, 3.0, 3.1.
- Unlike the base COM libraries, this wrapper accommodates creating and viewing tasks up and down stream.
- Supports all V2 native properties, even under V1 tasks.
- Maintain EmailAction and ShowMessageAction using PowerShell scripts for systems after Win8 where these actions have been deprecated.
- Supports all action types (not just ExecAction) on V1 systems (XP/WS2003) and earlier (if PowerShell is installed).
- Supports multiple actions on V1 systems (XP/WS2003). Native library only supports a single action.
- Supports serialization to XML for both 1.0 and 2.0 tasks (base library only supports 2.0)
- Supports task validation for targeted version.
- Supports secure task reading and maintenance.
- Fluent methods for task creation.
- Cron syntax for trigger creation.
The currently supported localizations include: English, Spanish, Italian, French, Chinese (Simplified), German, Polish and Russian.
Usage
You can perform several actions in a single line of code:
// Run a program every day on the local machine
TaskService.Instance.AddTask("Test", QuickTriggerType.Daily, "myprogram.exe", "-a arg");
// Run a custom COM handler on the last day of every month
TaskService.Instance.AddTask("Test", new MonthlyTrigger { RunOnLastDayOfMonth = true },
new ComHandlerAction(new Guid("{CE7D4428-8A77-4c5d-8A13-5CAB5D1EC734}")));
For many more options, use the library classes to build a complex task. Below is a brief example of how to use the library from C#.
using System;
using Microsoft.Win32.TaskScheduler;
class Program
{
static void Main()
{
// Get the service on the remote machine
using (TaskService ts = new TaskService(@"\\RemoteServer", "username", "domain", "password"))
{
// Create a new task definition and assign properties
TaskDefinition td = ts.NewTask();
td.RegistrationInfo.Description = "Does something";
// Create a trigger that will fire the task at this time every other day
td.Triggers.Add(new DailyTrigger { DaysInterval = 2 });
// Create an action that will launch Notepad whenever the trigger fires
td.Actions.Add(new ExecAction("notepad.exe", "c:\\test.log", null));
// Register the task in the root folder.
// (Use the username here to ensure remote registration works.)
ts.RootFolder.RegisterTaskDefinition(@"Test", td, TaskCreation.CreateOrUpdate, "username");
}
}
}
For extended examples on how to the use the library, look at the Examples Page.
Product | Versions 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. net6.0-windows7.0 is compatible. 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. net7.0-windows7.0 is compatible. 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. net8.0-windows7.0 is compatible. 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. net9.0-windows7.0 is compatible. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 is compatible. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net45 is compatible. net451 was computed. net452 was computed. net46 was computed. net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 is compatible. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETCoreApp 3.1
- Microsoft.Win32.Registry (>= 5.0.0)
- System.Diagnostics.EventLog (>= 6.0.0)
- System.Security.AccessControl (>= 6.0.1)
-
.NETFramework 4.5
- No dependencies.
-
.NETFramework 4.8
- No dependencies.
-
.NETStandard 2.0
- Microsoft.Win32.Registry (>= 5.0.0)
- System.Diagnostics.EventLog (>= 6.0.0)
- System.Reflection (>= 4.3.0)
- System.Runtime.Serialization.Formatters (>= 4.3.0)
- System.Security.AccessControl (>= 6.0.1)
- System.Security.Permissions (>= 8.0.0)
- System.Security.Principal.Windows (>= 5.0.0)
- System.Xml.XmlSerializer (>= 4.3.0)
-
net6.0-windows7.0
- Microsoft.Win32.Registry (>= 5.0.0)
- System.Diagnostics.EventLog (>= 6.0.0)
- System.Security.AccessControl (>= 6.0.1)
-
net7.0-windows7.0
- Microsoft.Win32.Registry (>= 5.0.0)
- System.Diagnostics.EventLog (>= 7.0.0)
- System.Security.AccessControl (>= 6.0.1)
-
net8.0-windows7.0
- Microsoft.Win32.Registry (>= 5.0.0)
- System.Diagnostics.EventLog (>= 8.0.1)
- System.Security.AccessControl (>= 6.0.1)
-
net9.0-windows7.0
- Microsoft.Win32.Registry (>= 5.0.0)
- System.Diagnostics.EventLog (>= 9.0.2)
- System.Security.AccessControl (>= 6.0.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.