fleet/website/api/controllers/microsoft-proxy/remove-one-compliance-partner-tenant.js
Eric 61261bb8a4
Website: Microsoft proxy: Add debugging logs for Fleet's integration (#32001)
Related to: https://github.com/fleetdm/fleet/issues/31986

Changes:
- Updated Microsoft proxy endpoints to log API responses from Microsoft
when it runs for Fleet's dogfood integration.
2025-08-15 19:35:46 -05:00

80 lines
2.6 KiB
JavaScript
Vendored

module.exports = {
friendlyName: 'Remove one compliance partner tenant',
description: 'Updates a microsfot compliance tenant\'s status as "deprovisioned" and deletes the associated Database record',
inputs: {
entraTenantId: {
type: 'string',
required: true,
},
fleetServerSecret: {
type: 'string',
requried: true,
},
},
exits: {
success: {
description: 'The requesting entra tenant has been successfully deprovisioned.'
},
tenantNotFound: {
description: 'A Microsoft compliance tenant could not be found using the provided information.',
responseType: 'notFound',
}
},
fn: async function ({entraTenantId, fleetServerSecret}) {
let informationAboutThisTenant = await MicrosoftComplianceTenant.findOne({entraTenantId: entraTenantId, fleetServerSecret: fleetServerSecret});
if(!informationAboutThisTenant) {
throw 'tenantNotFound';
}
// If setup was completed, we will need to deprovision this Complaince tenant, otherwise, we will only delete the databse record.
if(informationAboutThisTenant.setupCompleted){
let tokenAndApiUrls = await sails.helpers.microsoftProxy.getAccessTokenAndApiUrls.with({
complianceTenantRecordId: informationAboutThisTenant.id
});
let accessToken = tokenAndApiUrls.manageApiAccessToken;
let tenantDataSyncUrl = tokenAndApiUrls.tenantDataSyncUrl;
// Deprovison this tenant
let deprovisionTenantResponse = await sails.helpers.http.sendHttpRequest.with({
method: 'PUT',
url: `${tenantDataSyncUrl}/PartnerTenants(guid'${informationAboutThisTenant.entraTenantId}')?api-version=1.6`,
headers: {
'Authorization': `Bearer ${accessToken}`
},
body: {
Provisioned: 2,// 1 = provisioned, 2 = deprovisioned.
PartnerEnrollmentUrl: `https://fleetdm.com/microsoft-compliance-partner/enroll`,
PartnerRemediationUrl: `https://fleetdm.com/microsoft-compliance-partner/remediate`,
}
}).intercept((err)=>{
return new Error({error: `an error occurred when deprovisioning a Microsoft compliance tenant. Full error: ${require('util').inspect(err, {depth: 3})}`});
});
// Log responses from Micrsoft APIs for Fleet's integration
if(informationAboutThisTenant.fleetInstanceUrl === 'https://dogfood.fleetdm.com') {
sails.log.info(`Microsoft proxy: remove-one-compliance-partner-tenant deprovisioned a tenant: ${deprovisionTenantResponse.body}`);
}
}
await MicrosoftComplianceTenant.destroyOne({id: informationAboutThisTenant.id});
// All done.
return this.res.json({});
}
};