xref: /openbmc/webui-vue/src/store/modules/Logs/EventLogStore.js (revision 7c26338edd6fdb16e72702910987a8e5fd899c10)
1import api, { getResponseCount } from '@/store/api';
2import i18n from '@/i18n';
3
4const getHealthStatus = (events, loadedEvents) => {
5  let status = loadedEvents ? 'OK' : '';
6  for (const event of events) {
7    if (event.filterByStatus === 'Unresolved') {
8      if (event.severity === 'Warning') {
9        status = 'Warning';
10      }
11      if (event.severity === 'Critical') {
12        status = 'Critical';
13        break;
14      }
15    }
16  }
17  return status;
18};
19
20// TODO: High priority events should also check if Log
21// is resolved when the property is available in Redfish
22const getHighPriorityEvents = (events) =>
23  events.filter(({ severity }) => severity === 'Critical');
24
25const EventLogStore = {
26  namespaced: true,
27  state: {
28    allEvents: [],
29    loadedEvents: false,
30  },
31  getters: {
32    allEvents: (state) => state.allEvents,
33    highPriorityEvents: (state) => getHighPriorityEvents(state.allEvents),
34    healthStatus: (state) =>
35      getHealthStatus(state.allEvents, state.loadedEvents),
36  },
37  mutations: {
38    setAllEvents: (state, allEvents) => (
39      (state.allEvents = allEvents), (state.loadedEvents = true)
40    ),
41  },
42  actions: {
43    async getEventLogData({ commit }) {
44      return await api
45        .get('/redfish/v1/Systems/system/LogServices/EventLog/Entries')
46        .then(({ data: { Members = [] } = {} }) => {
47          const eventLogs = Members.map((log) => {
48            const {
49              Id,
50              Severity,
51              Created,
52              EntryType,
53              Message,
54              Name,
55              Modified,
56              Resolved,
57              AdditionalDataURI,
58            } = log;
59            return {
60              id: Id,
61              severity: Severity,
62              date: new Date(Created),
63              type: EntryType,
64              description: Message,
65              name: Name,
66              modifiedDate: new Date(Modified),
67              uri: log['@odata.id'],
68              filterByStatus: Resolved ? 'Resolved' : 'Unresolved',
69              status: Resolved, //true or false
70              additionalDataUri: AdditionalDataURI,
71            };
72          });
73          commit('setAllEvents', eventLogs);
74        })
75        .catch((error) => {
76          console.log('Event Log Data:', error);
77        });
78    },
79    async deleteAllEventLogs({ dispatch }, data) {
80      return await api
81        .post(
82          '/redfish/v1/Systems/system/LogServices/EventLog/Actions/LogService.ClearLog'
83        )
84        .then(() => dispatch('getEventLogData'))
85        .then(() => i18n.tc('pageEventLogs.toast.successDelete', data.length))
86        .catch((error) => {
87          console.log(error);
88          throw new Error(
89            i18n.tc('pageEventLogs.toast.errorDelete', data.length)
90          );
91        });
92    },
93    async deleteEventLogs({ dispatch }, uris = []) {
94      const promises = uris.map((uri) =>
95        api.delete(uri).catch((error) => {
96          console.log(error);
97          return error;
98        })
99      );
100      return await api
101        .all(promises)
102        .then((response) => {
103          dispatch('getEventLogData');
104          return response;
105        })
106        .then(
107          api.spread((...responses) => {
108            const { successCount, errorCount } = getResponseCount(responses);
109            const toastMessages = [];
110
111            if (successCount) {
112              const message = i18n.tc(
113                'pageEventLogs.toast.successDelete',
114                successCount
115              );
116              toastMessages.push({ type: 'success', message });
117            }
118
119            if (errorCount) {
120              const message = i18n.tc(
121                'pageEventLogs.toast.errorDelete',
122                errorCount
123              );
124              toastMessages.push({ type: 'error', message });
125            }
126
127            return toastMessages;
128          })
129        );
130    },
131    async resolveEventLogs({ dispatch }, logs) {
132      const promises = logs.map((log) =>
133        api.patch(log.uri, { Resolved: true }).catch((error) => {
134          console.log(error);
135          return error;
136        })
137      );
138      return await api
139        .all(promises)
140        .then((response) => {
141          dispatch('getEventLogData');
142          return response;
143        })
144        .then(
145          api.spread((...responses) => {
146            const { successCount, errorCount } = getResponseCount(responses);
147            const toastMessages = [];
148            if (successCount) {
149              const message = i18n.tc(
150                'pageEventLogs.toast.successResolveLogs',
151                successCount
152              );
153              toastMessages.push({ type: 'success', message });
154            }
155            if (errorCount) {
156              const message = i18n.tc(
157                'pageEventLogs.toast.errorResolveLogs',
158                errorCount
159              );
160              toastMessages.push({ type: 'error', message });
161            }
162            return toastMessages;
163          })
164        );
165    },
166    async unresolveEventLogs({ dispatch }, logs) {
167      const promises = logs.map((log) =>
168        api.patch(log.uri, { Resolved: false }).catch((error) => {
169          console.log(error);
170          return error;
171        })
172      );
173      return await api
174        .all(promises)
175        .then((response) => {
176          dispatch('getEventLogData');
177          return response;
178        })
179        .then(
180          api.spread((...responses) => {
181            const { successCount, errorCount } = getResponseCount(responses);
182            const toastMessages = [];
183            if (successCount) {
184              const message = i18n.tc(
185                'pageEventLogs.toast.successUnresolveLogs',
186                successCount
187              );
188              toastMessages.push({ type: 'success', message });
189            }
190            if (errorCount) {
191              const message = i18n.tc(
192                'pageEventLogs.toast.errorUnresolveLogs',
193                errorCount
194              );
195              toastMessages.push({ type: 'error', message });
196            }
197            return toastMessages;
198          })
199        );
200    },
201    // Single log entry
202    async updateEventLogStatus({ dispatch }, log) {
203      const updatedEventLogStatus = log.status;
204      return await api
205        .patch(log.uri, { Resolved: updatedEventLogStatus })
206        .then(() => {
207          dispatch('getEventLogData');
208        })
209        .then(() => {
210          if (log.status) {
211            return i18n.tc('pageEventLogs.toast.successResolveLogs', 1);
212          } else {
213            return i18n.tc('pageEventLogs.toast.successUnresolveLogs', 1);
214          }
215        })
216        .catch((error) => {
217          console.log(error);
218          throw new Error(i18n.t('pageEventLogs.toast.errorLogStatusUpdate'));
219        });
220    },
221  },
222};
223
224export default EventLogStore;
225