it
This commit is contained in:
@@ -447,7 +447,7 @@ class GraphManager {
|
||||
'ip': '#ff9900', // Amber
|
||||
'asn': '#00aaff', // Blue
|
||||
'large_entity': '#ff6b6b', // Red for large entities
|
||||
'dns_record': '#999999'
|
||||
'dns_record': '#9620c0ff'
|
||||
};
|
||||
return colors[nodeType] || '#ffffff';
|
||||
}
|
||||
@@ -463,7 +463,7 @@ class GraphManager {
|
||||
'domain': '#00aa2e',
|
||||
'ip': '#cc7700',
|
||||
'asn': '#0088cc',
|
||||
'dns_record': '#999999'
|
||||
'dns_record': '#c235c9ff'
|
||||
};
|
||||
return borderColors[nodeType] || '#666666';
|
||||
}
|
||||
|
||||
@@ -54,6 +54,7 @@ class DNSReconApp {
|
||||
targetDomain: document.getElementById('target-domain'),
|
||||
maxDepth: document.getElementById('max-depth'),
|
||||
startScan: document.getElementById('start-scan'),
|
||||
addToGraph: document.getElementById('add-to-graph'),
|
||||
stopScan: document.getElementById('stop-scan'),
|
||||
exportResults: document.getElementById('export-results'),
|
||||
configureApiKeys: document.getElementById('configure-api-keys'),
|
||||
@@ -136,6 +137,11 @@ class DNSReconApp {
|
||||
e.preventDefault();
|
||||
this.startScan();
|
||||
});
|
||||
|
||||
this.elements.addToGraph.addEventListener('click', (e) => {
|
||||
e.preventDefault();
|
||||
this.startScan(false);
|
||||
});
|
||||
|
||||
this.elements.stopScan.addEventListener('click', (e) => {
|
||||
console.log('Stop scan button clicked');
|
||||
@@ -230,7 +236,7 @@ class DNSReconApp {
|
||||
/**
|
||||
* Start a reconnaissance scan
|
||||
*/
|
||||
async startScan() {
|
||||
async startScan(clearGraph = true) {
|
||||
console.log('=== STARTING SCAN ===');
|
||||
|
||||
try {
|
||||
@@ -262,7 +268,8 @@ class DNSReconApp {
|
||||
|
||||
const requestData = {
|
||||
target_domain: targetDomain,
|
||||
max_depth: maxDepth
|
||||
max_depth: maxDepth,
|
||||
clear_graph: clearGraph
|
||||
};
|
||||
|
||||
console.log('Request data:', requestData);
|
||||
@@ -273,12 +280,12 @@ class DNSReconApp {
|
||||
|
||||
if (response.success) {
|
||||
this.currentSessionId = response.scan_id;
|
||||
console.log('Starting polling with session ID:', this.currentSessionId);
|
||||
this.startPolling();
|
||||
this.showSuccess('Reconnaissance scan started successfully');
|
||||
|
||||
// Clear previous graph
|
||||
this.graphManager.clear();
|
||||
|
||||
if (clearGraph) {
|
||||
this.graphManager.clear();
|
||||
}
|
||||
|
||||
console.log(`Scan started for ${targetDomain} with depth ${maxDepth}`);
|
||||
|
||||
@@ -627,6 +634,10 @@ class DNSReconApp {
|
||||
this.elements.startScan.disabled = true;
|
||||
this.elements.startScan.classList.add('loading');
|
||||
}
|
||||
if (this.elements.addToGraph) {
|
||||
this.elements.addToGraph.disabled = true;
|
||||
this.elements.addToGraph.classList.add('loading');
|
||||
}
|
||||
if (this.elements.stopScan) {
|
||||
this.elements.stopScan.disabled = false;
|
||||
this.elements.stopScan.classList.remove('loading');
|
||||
@@ -645,6 +656,10 @@ class DNSReconApp {
|
||||
this.elements.startScan.disabled = false;
|
||||
this.elements.startScan.classList.remove('loading');
|
||||
}
|
||||
if (this.elements.addToGraph) {
|
||||
this.elements.addToGraph.disabled = false;
|
||||
this.elements.addToGraph.classList.remove('loading');
|
||||
}
|
||||
if (this.elements.stopScan) {
|
||||
this.elements.stopScan.disabled = true;
|
||||
}
|
||||
@@ -735,7 +750,7 @@ class DNSReconApp {
|
||||
if (!this.elements.nodeModal) return;
|
||||
|
||||
if (this.elements.modalTitle) {
|
||||
this.elements.modalTitle.textContent = `Node Details: ${nodeId}`;
|
||||
this.elements.modalTitle.textContent = `Node Details`;
|
||||
}
|
||||
|
||||
let detailsHtml = '';
|
||||
@@ -781,7 +796,7 @@ class DNSReconApp {
|
||||
const metadata = node.metadata || {};
|
||||
|
||||
// General Node Info
|
||||
detailsHtml += createDetailRow('Node Type', node.type);
|
||||
detailsHtml += createDetailRow('Node Descriptor', node.nodeId);
|
||||
|
||||
// Display data based on node type
|
||||
switch (node.type) {
|
||||
|
||||
Reference in New Issue
Block a user