From 61857a2386d03670fd9f50e93bb1f26df53ef524 Mon Sep 17 00:00:00 2001 From: Rohan Vazarkar Date: Fri, 13 May 2016 12:24:46 -0400 Subject: [PATCH] Testing node pruning --- NewLayout.html | 4 +- js/bloodhound.js | 106 +++++++++++++++++++++++++++++++++++++++++++---- 2 files changed, 100 insertions(+), 10 deletions(-) diff --git a/NewLayout.html b/NewLayout.html index 7cc5d24a7..bfe535785 100644 --- a/NewLayout.html +++ b/NewLayout.html @@ -274,7 +274,7 @@

Pre-Built Analytics Queries

- Find Shortest Paths to DA
+ Find Shortest Paths to DA
Find User with Most Sessions
@@ -323,7 +323,7 @@

{{label}} Properties

First Degree Local Admin
{{first_degree_admin}}
Group Delegated Local Admin Rights
-
{{dlar}}
+
{{dlar}}
Derivative Local Admin Rights
{{derivative}}
Sessions
diff --git a/js/bloodhound.js b/js/bloodhound.js index f4187c5d4..39e2ae0c6 100644 --- a/js/bloodhound.js +++ b/js/bloodhound.js @@ -26,6 +26,7 @@ $(document).ready(function(){ font: 'Roboto', glyphFillColor: 'black', glyphTextColor: 'white', + glyphTextThreshold: 1, defaultLabelActiveColor:'red' }) @@ -60,7 +61,7 @@ $(document).ready(function(){ }, size: { by: 'degree', - bins: 7, + bins: 10, min: 10, max: 20 }, @@ -113,7 +114,13 @@ $(document).ready(function(){ }); // Initialize the noverlap plugin - sigmaInstance.configNoverlap({nodeMargin: 2.0, easing: 'cubicInOut', gridSize: 50}) + noverlapListener = sigmaInstance.configNoverlap({nodeMargin: 2.0, easing: 'cubicInOut', gridSize: 50}) + noverlapListener.bind('stop', function(event){ + if (noanimate){ + sigmaInstance.settings('animationsTime', 200); + noanimate = false; + } + }) // Initialize the tooltips plugin var tooltips = sigma.plugins.tooltips( @@ -147,9 +154,24 @@ $(document).ready(function(){ '
  • Get Members
  • ' + '
  • Admin To
  • ' + ' {{/type_group}}' + + ' {{#expand}}' + + '
  • Expand
  • ' + + ' {{/expand}}' + + ' {{#collapse}}' + + '
  • Collapse
  • ' + + ' {{/collapse}}' + ' ', autoadjust:true, renderer: function(node, template){ + node.expand = false; + node.collapse = false; + if (typeof node.folded != 'undefined'){ + if (typeof sigmaInstance.graph.nodes(node.folded.nodes[0].id) == 'undefined'){ + node.expand = true; + }else{ + node.collapse = true; + } + } return Mustache.render(template, node) } }] @@ -668,6 +690,7 @@ var ingesthtml = null; var ingestWorker = null var uploadwidth = null; var labelsVisible = false; +var noanimate = true; function makeWorker(script) { @@ -733,13 +756,17 @@ function setLabelAsEnd(label){ } }; -function doQuery(query, start, end){ +function doQuery(query, start, end, prune){ if (typeof start === 'undefined'){ start = "" } if (typeof end === 'undefined'){ end = "" } + + if (typeof end === 'undefined'){ + prune = false; + } if (!firstquery){ queryStack.push([sigmaInstance.graph.nodes(), sigmaInstance.graph.edges()]); } @@ -754,7 +781,7 @@ function doQuery(query, start, end){ sigma.neo4j.cypher( {url: localStorage.getItem("dbpath"), user:localStorage.getItem("uname"), password:localStorage.getItem("pwd")}, - query + " LIMIT 500", + query, sigmaInstance, function() { var startNode = null; @@ -766,6 +793,8 @@ function doQuery(query, start, end){ }else{ $.each(sigmaInstance.graph.nodes(), function(index, node){ node.degree = sigmaInstance.graph.degree(node.id) + }) + $.each(sigmaInstance.graph.nodes(), function(index, node){ if (node.neo4j_labels[0]=='Group'){ node.type_group = true }else if (node.neo4j_labels[0] == 'User'){ @@ -781,6 +810,27 @@ function doQuery(query, start, end){ if (node.neo4j_data.name == end){ endNode = node; } + if (prune){ + var e = sigmaInstance.graph.adjacentEdges(node.id); + if (e.length == 1 && (typeof node.folded == 'undefined')){ + if (e[0].label == "MemberOf" || e[0].label == "AdminTo"){ + var t = sigmaInstance.graph.nodes(e[0].target); + if (typeof t.folded == 'undefined'){ + t.folded = {}; + t.folded.nodes = []; + t.folded.edges = []; + t.hasfold = true; + } + t.folded.nodes.push(node); + t.folded.edges.push(e[0]); + sigmaInstance.graph.dropNode(node.id); + t.glyphs = [{ + 'position':'bottom-left', + 'content': t.folded.nodes.length + }] + } + } + } }) sigmaInstance.refresh(); design.apply() @@ -803,11 +853,17 @@ function doQuery(query, start, end){ 'content': '\uF05B', 'fontScale': 1.5 }] + + if (typeof endNode.folded != 'undefined'){ + endNode.glyphs.push({ + 'position':'bottom-left', + 'content': endNode.folded.nodes.length + }) + } endNode.size = endNode.size + 5 } if (usedagre){ - sigma.layouts.dagre.start(sigmaInstance); - + sigma.layouts.dagre.start(sigmaInstance); }else{ sigma.layouts.startForceLink(); } @@ -863,9 +919,9 @@ function updateNodeData(node){ }, { "statement" : "MATCH (n:User {name:'" + node.data.node.label + "'}), (target:Computer), p=allShortestPaths((n)-[:AdminTo*1]->(target)) RETURN count(target)" }, { - "statement" : "MATCH (n:User {name:'" + node.data.node.label + "'}), (m:Computer), p=allShortestPaths((n)-[r*1..]->(m)) RETURN count(distinct(m))" + "statement" : "MATCH (n:User {name:'" + node.data.node.label + "'}), (m:Computer), (o:Group), n-[r:MemberOf]->o-[s:AdminTo]->m RETURN count(distinct(m))" }, { - "statement" : "MATCH (n:User {name:'" + node.data.node.label + "'}), (target:Computer), p=allShortestPaths((n)-[*]->(target)) RETURN count(target)" + "statement" : "MATCH (n:User {name:'" + node.data.node.label + "'}), (target:Computer), p=allShortestPaths((n)-[*]->(target)) RETURN count(distinct(target))" }, { "statement" : "MATCH (n:Computer)-[r:HasSession]->(m:User {name:'" + node.data.node.label + "'}) RETURN count(n)" } ] @@ -1342,4 +1398,38 @@ function cancelIngest(){ }, 2000) }) }) +} + +function unfold(id){ + sigmaInstance.graph.read(sigmaInstance.graph.nodes(id).folded); + design.deprecate(); + + noanimate = true; + sigmaInstance.settings('animationsTime', 0); + + if (usedagre){ + sigma.layouts.dagre.start(sigmaInstance); + }else{ + sigma.layouts.startForceLink(); + } + + design.apply(); +} + +function collapse(id){ + design.deprecate(); + $.each(sigmaInstance.graph.nodes(id).folded.nodes, function(index, node){ + sigmaInstance.graph.dropNode(node.id); + }) + + noanimate = true; + sigmaInstance.settings('animationsTime', 0); + + if (usedagre){ + sigma.layouts.dagre.start(sigmaInstance); + }else{ + sigma.layouts.startForceLink(); + } + + design.apply(); } \ No newline at end of file