fleet/ee/bulk-operations-dashboard/api/controllers/software/delete-software.js
Eric 6d468cada4
Msp dashboard: Update error handling in software related actions (#24283)
Changes:
- Updated the edit-software endpoint to:
- log a detailed warning when a request to get a stream of an existing
software installer returns a non-200 repsonse
- Use the modify package API endpoint when a software installer is
replaced.
- include the nested response from the Fleet instance in error messages
- Updated the delete-software endpoint to return a
'softwareDeletionFailed` exit when a specified software installer is
included in the macOS setup experience and cannot be deleted via API
requests.
- Updated the software page to show an error message with a link to the
controls page on the connected Fleet instance if the delete-software
endpoint returns a `softwareDeletionFailed` exit
2024-12-02 14:46:07 -06:00

54 lines
1.7 KiB
JavaScript

module.exports = {
friendlyName: 'Delete software',
description: 'Deletes deployed software for all teams on a Fleet instance, or undeployed software in the app\'s database',
inputs: {
software: {
type: {},
description: 'The software that will be deleted.',
required: true,
}
},
exits: {
softwareDeletionFailed: {
description: 'The specified software could not be deleted from the Fleet instance.',
statusCode: 409,
}
},
fn: async function ({software}) {
// If the provided software does not have a teams array and has an ID, it is an undeployed software that will be deleted.
if(software.id && !software.teams){
await sails.rm(sails.config.uploads.prefixForFileDeletion+software.uploadFd);
await UndeployedSoftware.destroy({id: software.id});
} else {// Otherwise, this is a deployed software, and we'll use information from the teams array to remove the software.
for(let team of software.teams){
await sails.helpers.http.sendHttpRequest.with({
method: 'DELETE',
baseUrl: sails.config.custom.fleetBaseUrl,
url: `/api/v1/fleet/software/titles/${software.fleetApid}/available_for_install?team_id=${team.fleetApid}`,
headers: {
Authorization: `Bearer ${sails.config.custom.fleetApiToken}`,
}
})
.intercept({raw:{statusCode: 409}}, (error)=>{
// If the Fleet instance's returns a 409 response, then the software is configured to be installed as
// part of the macOS setup experience, and must be removed before it can be deleted via API requests.
return {softwareDeletionFailed: error};
});
}
}
// All done.
return;
}
};