Skip to content
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4,077 changes: 3,281 additions & 796 deletions packages/devtools/management-ui/package-lock.json

Large diffs are not rendered by default.

105 changes: 46 additions & 59 deletions packages/devtools/management-ui/server/api/integrations.js
Original file line number Diff line number Diff line change
Expand Up @@ -391,9 +391,7 @@ async function getAvailableIntegrations() {
details: 'Failed to configure integration'
});
}
}
});
}
});

// Get integration configuration
router.get('/:integrationName/config', async (req, res) => {
Expand All @@ -411,21 +409,16 @@ router.get('/:integrationName/config', async (req, res) => {
if (await fs.pathExists(configPath)) {
const config = await fs.readJson(configPath);
res.json({ config });
} else {
res.json({ config: {} });
}
} else {
res.json({ config: {} });
}
}

} catch (error) {
res.status(500).json({
error: error.message,
details: 'Failed to read integration configuration'
});
}
res.status(500).json({
error: error.message,
details: 'Failed to read integration configuration'
});
}
});
}

// Remove an integration
router.delete('/:integrationName', async (req, res) => {
Expand All @@ -438,59 +431,53 @@ router.delete('/:integrationName', async (req, res) => {
packageName: integrationName,
message: `Removing ${integrationName}...`
});
}

// Remove the package
const { stdout, stderr } = await execAsync(
`npm uninstall ${integrationName}`,
{ cwd: path.join(process.cwd(), '../../../backend') }
);

// Remove config if exists
const configPath = path.join(
process.cwd(),
'../../../backend',
'config',
'integrations',
`${integrationName}.json`
);

if (await fs.pathExists(configPath)) {
await fs.remove(configPath);
}
`npm uninstall ${integrationName}`,
{ cwd: path.join(process.cwd(), '../../../backend') }
);

// Broadcast success
wsHandler.broadcast('integration-remove', {
status: 'removed',
packageName: integrationName,
message: `Successfully removed ${integrationName}`
});
}
// Remove config if exists
const configPath = path.join(
process.cwd(),
'../../../backend',
'config',
'integrations',
`${integrationName}.json`
);

if (await fs.pathExists(configPath)) {
await fs.remove(configPath);
}

// Broadcast success
wsHandler.broadcast('integration-remove', {
status: 'removed',
packageName: integrationName,
message: `Successfully removed ${integrationName}`
});

res.json({
status: 'success',
message: `Integration ${integrationName} removed successfully`
});
}
status: 'success',
message: `Integration ${integrationName} removed successfully`
});

} catch (error) {
// Broadcast error
wsHandler.broadcast('integration-remove', {
status: 'error',
packageName: integrationName,
message: `Failed to remove ${integrationName}`,
error: error.message
});
}

res.status(500).json({
error: error.message,
details: 'Failed to remove integration'
});
}
// Broadcast error
wsHandler.broadcast('integration-remove', {
status: 'error',
packageName: integrationName,
message: `Failed to remove ${integrationName}`,
error: error.message
});

res.status(500).json({
error: error.message,
details: 'Failed to remove integration'
});
}
});
}

export { getInstalledIntegrations }
export default router
export { getInstalledIntegrations };
export default router;
Loading
Loading