From fbf05196a4cad69723c437dec4ba15f9404052b6 Mon Sep 17 00:00:00 2001 From: Ravi Lodhi Date: Fri, 13 Dec 2024 16:37:02 +0530 Subject: [PATCH] Improved: Updated RuleGroup.lastModifiedDate whenever rules are added, modified or archived (#360). --- src/services/RuleService.ts | 24 +++++++++++++++++++++++- 1 file changed, 23 insertions(+), 1 deletion(-) diff --git a/src/services/RuleService.ts b/src/services/RuleService.ts index 377048dc..a4d62e76 100644 --- a/src/services/RuleService.ts +++ b/src/services/RuleService.ts @@ -1,6 +1,7 @@ import api from '@/api'; import logger from '@/logger'; import { hasError } from '@/utils'; +import { DateTime } from "luxon"; const fetchRuleGroup = async (payload: any): Promise => { return api({ @@ -39,6 +40,25 @@ const createRuleGroup = async (payload: any): Promise => { return Promise.resolve(ruleGroup); } +const updateRuleGroup = async (ruleGroupId: string, payload: any): Promise => { + try { + const resp = await api({ + url: `ruleGroups/${ruleGroupId}`, + method: "POST", + data: payload + }) as any; + + if(!hasError(resp)) { + return Promise.resolve(resp); + } else { + throw resp.data + } + } catch(err: any) { + logger.error(err) + return Promise.reject("Failed to update rule group"); + } +} + const createRule = async (payload: any): Promise => { let rule = {} try { @@ -69,6 +89,7 @@ const updateRule = async (payload: any, ruleId: string): Promise => { }) as any; if(!hasError(resp)) { + updateRuleGroup(payload.ruleGroupId, {lastModifiedDate: DateTime.now().toMillis()}) return Promise.resolve(resp) } else { throw resp.data @@ -126,5 +147,6 @@ export const RuleService = { fetchRuleScheduleInformation, runNow, scheduleRuleGroup, - updateRule + updateRule, + updateRuleGroup } \ No newline at end of file