blob: 328e31643ad9da4e9b58a6198c3c649c7b0f4f50 [file] [log] [blame]
import api, { getResponseCount } from '@/store/api';
import i18n from '@/i18n';
const DumpsStore = {
namespaced: true,
state: {
allDumps: [],
},
getters: {
allDumps: (state) => state.allDumps,
},
mutations: {
setAllDumps: (state, dumps) => {
state.allDumps = dumps.map((dump) => ({
data: dump.AdditionalDataURI,
dateTime: new Date(dump.Created),
dumpType: dump.Name,
id: dump.Id,
location: dump['@odata.id'],
size: dump.AdditionalDataSizeBytes,
}));
},
},
actions: {
async getBmcDumpEntries() {
return api
.get('/redfish/v1/')
.then((response) => api.get(response.data.Managers['@odata.id']))
.then((response) => api.get(`${response.data['@odata.id']}/bmc`))
.then((response) => api.get(response.data.LogServices['@odata.id']))
.then((response) => api.get(`${response.data['@odata.id']}/Dump`))
.then((response) => api.get(response.data.Entries['@odata.id']))
.catch((error) => console.log(error));
},
async getSystemDumpEntries() {
return api
.get('/redfish/v1/')
.then((response) => api.get(response.data.Systems['@odata.id']))
.then((response) => api.get(`${response.data['@odata.id']}/system`))
.then((response) => api.get(response.data.LogServices['@odata.id']))
.then((response) => api.get(`${response.data['@odata.id']}/Dump`))
.then((response) => api.get(response.data.Entries['@odata.id']))
.catch((error) => console.log(error));
},
async getAllDumps({ commit, dispatch }) {
return await api
.all([dispatch('getBmcDumpEntries'), dispatch('getSystemDumpEntries')])
.then((response) => {
const bmcDumpEntries = response[0].data?.Members || [];
const systemDumpEntries = response[1].data?.Members || [];
const allDumps = [...bmcDumpEntries, ...systemDumpEntries];
commit('setAllDumps', allDumps);
})
.catch((error) => console.log(error));
},
async createBmcDump() {
return await api
.post(
'/redfish/v1/Managers/bmc/LogServices/Dump/Actions/LogService.CollectDiagnosticData',
{
DiagnosticDataType: 'Manager',
OEMDiagnosticDataType: '',
},
)
.catch((error) => {
console.log(error);
throw new Error(i18n.t('pageDumps.toast.errorStartBmcDump'));
});
},
async createSystemDump() {
return await api
.post(
'/redfish/v1/Systems/system/LogServices/Dump/Actions/LogService.CollectDiagnosticData',
{
DiagnosticDataType: 'OEM',
OEMDiagnosticDataType: 'System',
},
)
.catch((error) => {
console.log(error);
throw new Error(i18n.t('pageDumps.toast.errorStartSystemDump'));
});
},
async deleteDumps({ dispatch }, dumps) {
const promises = dumps.map(({ location }) =>
api.delete(location).catch((error) => {
console.log(error);
return error;
}),
);
return await api
.all(promises)
.then((response) => {
dispatch('getAllDumps');
return response;
})
.then(
api.spread((...responses) => {
const { successCount, errorCount } = getResponseCount(responses);
const toastMessages = [];
if (successCount) {
const message = i18n.tc(
'pageDumps.toast.successDeleteDump',
successCount,
);
toastMessages.push({ type: 'success', message });
}
if (errorCount) {
const message = i18n.tc(
'pageDumps.toast.errorDeleteDump',
errorCount,
);
toastMessages.push({ type: 'error', message });
}
return toastMessages;
}),
);
},
async deleteAllDumps({ commit, state }) {
const totalDumpCount = state.allDumps.length;
return await api
.post(
'/redfish/v1/Managers/bmc/LogServices/Dump/Actions/LogService.ClearLog',
)
.then(() => {
commit('setAllDumps', []);
return i18n.tc('pageDumps.toast.successDeleteDump', totalDumpCount);
})
.catch((error) => {
console.log(error);
throw new Error(
i18n.tc('pageDumps.toast.errorDeleteDump', totalDumpCount),
);
});
},
},
};
export default DumpsStore;