const VIDOC_API_KEY = process.env.VIDOC_API_KEY;
const API_BASE = 'https://api.vidocsecurity.com/v1';
async function runScan(codebaseId, branch) {
// Start scan
const startResponse = await fetch(`${API_BASE}/scan-workflows/start`, {
method: 'POST',
headers: {
'Authorization': `Bearer ${VIDOC_API_KEY}`,
'Content-Type': 'application/json',
},
body: JSON.stringify({ codebaseId, branch }),
});
const { id: scanId } = await startResponse.json();
console.log(`Scan started: ${scanId}`);
// Wait for completion
let status = 'pending';
while (status === 'pending' || status === 'running') {
await new Promise(r => setTimeout(r, 5000));
const statusResponse = await fetch(
`${API_BASE}/scan-workflows/${scanId}/status`,
{
headers: { 'Authorization': `Bearer ${VIDOC_API_KEY}` },
}
);
const scan = await statusResponse.json();
status = scan.status;
console.log(`Status: ${status}`);
if (status === 'completed') {
console.log(`Found ${scan.issuesFound} issues`);
return scan;
}
if (status === 'failed') {
throw new Error('Scan failed');
}
}
}
runScan('codebase_abc123', 'main');