mirror of
				https://github.com/TeaOSLab/EdgeAPI.git
				synced 2025-11-04 07:50:25 +08:00 
			
		
		
		
	IP名单删除任务完成后删除任务
This commit is contained in:
		@@ -8,6 +8,7 @@ import (
 | 
				
			|||||||
	"github.com/iwind/TeaGo/dbs"
 | 
						"github.com/iwind/TeaGo/dbs"
 | 
				
			||||||
	"github.com/iwind/TeaGo/maps"
 | 
						"github.com/iwind/TeaGo/maps"
 | 
				
			||||||
	"github.com/iwind/TeaGo/types"
 | 
						"github.com/iwind/TeaGo/types"
 | 
				
			||||||
 | 
						"strings"
 | 
				
			||||||
	"time"
 | 
						"time"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -19,7 +20,7 @@ const (
 | 
				
			|||||||
	NodeTaskTypeConfigChanged             NodeTaskType = "configChanged"             // 节点整体配置变化
 | 
						NodeTaskTypeConfigChanged             NodeTaskType = "configChanged"             // 节点整体配置变化
 | 
				
			||||||
	NodeTaskTypeDDosProtectionChanged     NodeTaskType = "ddosProtectionChanged"     // 节点DDoS配置变更
 | 
						NodeTaskTypeDDosProtectionChanged     NodeTaskType = "ddosProtectionChanged"     // 节点DDoS配置变更
 | 
				
			||||||
	NodeTaskTypeGlobalServerConfigChanged NodeTaskType = "globalServerConfigChanged" // 全局服务设置变化
 | 
						NodeTaskTypeGlobalServerConfigChanged NodeTaskType = "globalServerConfigChanged" // 全局服务设置变化
 | 
				
			||||||
	NodeTaskTypeIPListDeleted             NodeTaskType = "ipListDeleted"
 | 
						NodeTaskTypeIPListDeleted             NodeTaskType = "ipListDeleted"             // IPList被删除
 | 
				
			||||||
	NodeTaskTypeIPItemChanged             NodeTaskType = "ipItemChanged"             // IP条目变更
 | 
						NodeTaskTypeIPItemChanged             NodeTaskType = "ipItemChanged"             // IP条目变更
 | 
				
			||||||
	NodeTaskTypeNodeVersionChanged        NodeTaskType = "nodeVersionChanged"        // 节点版本变化
 | 
						NodeTaskTypeNodeVersionChanged        NodeTaskType = "nodeVersionChanged"        // 节点版本变化
 | 
				
			||||||
	NodeTaskTypeScriptsChanged            NodeTaskType = "scriptsChanged"            // 脚本配置变化
 | 
						NodeTaskTypeScriptsChanged            NodeTaskType = "scriptsChanged"            // 脚本配置变化
 | 
				
			||||||
@@ -266,6 +267,23 @@ func (this *NodeTaskDAO) FindDoingNodeTasks(tx *dbs.Tx, role string, nodeId int6
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
// UpdateNodeTaskDone 修改节点任务的完成状态
 | 
					// UpdateNodeTaskDone 修改节点任务的完成状态
 | 
				
			||||||
func (this *NodeTaskDAO) UpdateNodeTaskDone(tx *dbs.Tx, taskId int64, isOk bool, errorMessage string) error {
 | 
					func (this *NodeTaskDAO) UpdateNodeTaskDone(tx *dbs.Tx, taskId int64, isOk bool, errorMessage string) error {
 | 
				
			||||||
 | 
						if isOk {
 | 
				
			||||||
 | 
							// 特殊任务删除
 | 
				
			||||||
 | 
							taskType, err := this.Query(tx).
 | 
				
			||||||
 | 
								Pk(taskId).
 | 
				
			||||||
 | 
								Result("type").
 | 
				
			||||||
 | 
								FindStringCol("")
 | 
				
			||||||
 | 
							if err != nil {
 | 
				
			||||||
 | 
								return err
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							if strings.HasPrefix(taskType, NodeTaskTypeIPListDeleted+"@") {
 | 
				
			||||||
 | 
								return this.Query(tx).
 | 
				
			||||||
 | 
									Pk(taskId).
 | 
				
			||||||
 | 
									DeleteQuickly()
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// 其他任务标记为完成
 | 
				
			||||||
	var query = this.Query(tx).
 | 
						var query = this.Query(tx).
 | 
				
			||||||
		Pk(taskId)
 | 
							Pk(taskId)
 | 
				
			||||||
	if !isOk {
 | 
						if !isOk {
 | 
				
			||||||
@@ -275,8 +293,9 @@ func (this *NodeTaskDAO) UpdateNodeTaskDone(tx *dbs.Tx, taskId int64, isOk bool,
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
		query.Set("version", version)
 | 
							query.Set("version", version)
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	_, err := query.
 | 
						_, err := query.
 | 
				
			||||||
		Set("isDone", 1).
 | 
							Set("isDone", true).
 | 
				
			||||||
		Set("isOk", isOk).
 | 
							Set("isOk", isOk).
 | 
				
			||||||
		Set("error", errorMessage).
 | 
							Set("error", errorMessage).
 | 
				
			||||||
		Update()
 | 
							Update()
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -54,3 +54,12 @@ func TestNodeTaskDAO_FindDoingNodeTasks(t *testing.T) {
 | 
				
			|||||||
		t.Fatal(err)
 | 
							t.Fatal(err)
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func TestNodeTaskDAO_UpdateNodeTaskDone(t *testing.T) {
 | 
				
			||||||
 | 
						var tx *dbs.Tx
 | 
				
			||||||
 | 
						var dao = models.NewNodeTaskDAO()
 | 
				
			||||||
 | 
						err := dao.UpdateNodeTaskDone(tx, 1741, true, "")
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							t.Fatal(err)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user