diff --git a/src/admin/Bootstrap.Admin/Controllers/Api/TasksController.cs b/src/admin/Bootstrap.Admin/Controllers/Api/TasksController.cs
index e9b5b4c9..ccbbfc13 100644
--- a/src/admin/Bootstrap.Admin/Controllers/Api/TasksController.cs
+++ b/src/admin/Bootstrap.Admin/Controllers/Api/TasksController.cs
@@ -1,7 +1,9 @@
using Bootstrap.DataAccess;
+using Longbow;
using Longbow.Tasks;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
+using System;
using System.Collections.Generic;
using System.Linq;
@@ -44,5 +46,53 @@ namespace Bootstrap.Admin.Controllers.Api
}
return true;
}
+
+ ///
+ /// 保存任务方法
+ ///
+ ///
+ [HttpPost]
+ public bool Post([FromBody]TaskWidget widget)
+ {
+ // 判断 Cron 表达式
+ if (string.IsNullOrEmpty(widget.CronExpression)) return false;
+ if (_tasks.Any(t => t.Equals(widget.Name, StringComparison.OrdinalIgnoreCase))) return false;
+
+ // 加载任务执行体
+ // 此处可以扩展为任意 DLL 中的任意继承 ITask 接口的实体类
+ var taskExecutor = LgbActivator.CreateInstance("Bootstrap.Admin", widget.TaskExecutorName);
+ if (taskExecutor == null) return false;
+
+ // 此处未存储到数据库中,直接送入任务中心
+ TaskServicesManager.Remove(widget.Name);
+ var expression = Longbow.Tasks.Cron.ParseCronExpression(widget.CronExpression);
+ TaskServicesManager.GetOrAdd(widget.Name, token => taskExecutor.Execute(token), TriggerBuilder.Build(widget.CronExpression));
+ return true;
+ }
+
+ private static IEnumerable _tasks = new string[] {
+ "单次任务",
+ "周期任务",
+ "Cron 任务",
+ "超时任务",
+ "取消任务",
+ "禁用任务",
+ "SQL日志"
+ };
+ ///
+ /// 删除任务方法
+ ///
+ ///
+ ///
+ [HttpDelete]
+ public bool Delete([FromBody]IEnumerable ids)
+ {
+ // 演示模式下禁止删除内置任务
+ if (DictHelper.RetrieveSystemModel() && _tasks.Any(t => ids.Any(id => id.Equals(t, StringComparison.OrdinalIgnoreCase)))) return false;
+
+ // 循环删除任务
+ ids.ToList().ForEach(id => TaskServicesManager.Remove(id));
+ return true;
+ }
}
}
diff --git a/src/admin/Bootstrap.Admin/Models/TaskModel.cs b/src/admin/Bootstrap.Admin/Models/TaskModel.cs
index e821bdab..ef362b62 100644
--- a/src/admin/Bootstrap.Admin/Models/TaskModel.cs
+++ b/src/admin/Bootstrap.Admin/Models/TaskModel.cs
@@ -4,22 +4,39 @@ using System.Collections.Generic;
namespace Bootstrap.Admin.Models
{
///
- ///
+ /// 任务管理页面 Model 类
///
public class TaskModel : NavigatorBarModel
{
///
- ///
+ /// 构造函数
///
///
public TaskModel(ControllerBase controller) : base(controller)
{
- Tasks = new string[] { "测试任务" };
+ // 此处为演示代码,具体生产环境可以从数据库配置获得
+ // Key 为任务名称 Value 为任务执行体 FullName
+ TaskExecutors = new Dictionary
+ {
+ { "测试任务", "Bootstrap.Admin.DefaultTaskExecutor" }
+ };
+
+ TaskTriggers = new Dictionary
+ {
+ { "每 5 秒钟执行一次", Longbow.Tasks.Cron.Secondly(5) },
+ { "每 1 分钟执行一次", Longbow.Tasks.Cron.Minutely(1) }
+ };
}
///
- /// 获得 系统配置的所有任务
+ /// 获得 系统内置的所有任务
///
- public IEnumerable Tasks { get; }
+ public IDictionary TaskExecutors { get; }
+
+ ///
+ /// 获得 系统内置触发器集合
+ ///
+ ///
+ public IDictionary TaskTriggers { get; }
}
}
diff --git a/src/admin/Bootstrap.Admin/Tasks/DefaultTaskExecutor.cs b/src/admin/Bootstrap.Admin/Tasks/DefaultTaskExecutor.cs
new file mode 100644
index 00000000..2846bf80
--- /dev/null
+++ b/src/admin/Bootstrap.Admin/Tasks/DefaultTaskExecutor.cs
@@ -0,0 +1,19 @@
+using System.Threading;
+using System.Threading.Tasks;
+using Longbow.Tasks;
+
+namespace Bootstrap.Admin
+{
+ ///
+ /// 默认任务执行体实体类
+ ///
+ public class DefaultTaskExecutor : ITask
+ {
+ ///
+ /// 任务执行方法
+ ///
+ ///
+ ///
+ public Task Execute(CancellationToken cancellationToken) => Task.Delay(1000, cancellationToken);
+ }
+}
diff --git a/src/admin/Bootstrap.Admin/Tasks/TaskWidget.cs b/src/admin/Bootstrap.Admin/Tasks/TaskWidget.cs
new file mode 100644
index 00000000..c4e3a8dc
--- /dev/null
+++ b/src/admin/Bootstrap.Admin/Tasks/TaskWidget.cs
@@ -0,0 +1,23 @@
+namespace Bootstrap.Admin
+{
+ ///
+ /// 任务描述类
+ ///
+ public class TaskWidget
+ {
+ ///
+ /// 获得/设置 任务名称
+ ///
+ public string Name { get; set; } = "";
+
+ ///
+ /// 获得/设置 任务执行体名称
+ ///
+ public string TaskExecutorName { get; set; } = "";
+
+ ///
+ /// 获得/设置 Cron 任务表达式
+ ///
+ public string CronExpression { get; set; } = "";
+ }
+}
diff --git a/src/admin/Bootstrap.Admin/Views/Admin/Tasks.cshtml b/src/admin/Bootstrap.Admin/Views/Admin/Tasks.cshtml
index 26e5eb8c..7dfc35c8 100644
--- a/src/admin/Bootstrap.Admin/Views/Admin/Tasks.cshtml
+++ b/src/admin/Bootstrap.Admin/Views/Admin/Tasks.cshtml
@@ -1,86 +1,61 @@
@model TaskModel
@{
ViewBag.Title = "任务管理";
- Layout = "_Admin";
+ Layout = "_Default";
}
@section css {
-
-
-
-
-
-
}
@section javascript {
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
}
+@section tableButtons {
+
+
+
+}
@section modal {
-