2017-07-23 19:56:51 +02:00
|
|
|
|
{% extends "main.html" %}
|
|
|
|
|
|
2020-07-03 18:25:16 +02:00
|
|
|
|
{% from 'bootstrap/utils.html' import render_messages %}
|
2020-07-15 18:04:34 +02:00
|
|
|
|
{% from "macros.html" import shorten_string %}
|
2020-07-03 18:25:16 +02:00
|
|
|
|
|
2017-07-23 19:56:51 +02:00
|
|
|
|
{% block title %}Tree{% endblock %}
|
|
|
|
|
|
2017-09-29 14:48:37 +02:00
|
|
|
|
{% block scripts %}
|
2019-06-28 12:08:35 +02:00
|
|
|
|
{{ super() }}
|
2020-04-02 17:37:27 +02:00
|
|
|
|
<script src='{{ url_for('static', filename='d3.v5.min.js') }}'></script>
|
|
|
|
|
<script src='{{ url_for('static', filename='FileSaver.js') }}'></script>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
<script src='{{ url_for('static', filename='tree.js') }}'></script>
|
2020-04-20 16:41:42 +02:00
|
|
|
|
<script>
|
|
|
|
|
$('#modulesModal').on('show.bs.modal', function(e) {
|
2020-07-27 18:37:22 +02:00
|
|
|
|
var button = $(e.relatedTarget);
|
|
|
|
|
var modal = $(this);
|
|
|
|
|
modal.find('.modal-body').load(button.data("remote"));
|
2020-04-20 16:41:42 +02:00
|
|
|
|
});
|
|
|
|
|
</script>
|
|
|
|
|
<script>
|
2020-05-13 17:31:27 +02:00
|
|
|
|
$('#statsModal').on('show.bs.modal', function(e) {
|
|
|
|
|
var button = $(e.relatedTarget);
|
|
|
|
|
var modal = $(this);
|
|
|
|
|
modal.find('.modal-body').load(button.data("remote"));
|
|
|
|
|
});
|
|
|
|
|
</script>
|
|
|
|
|
<script>
|
2020-04-20 16:41:42 +02:00
|
|
|
|
$('.modulesForceRefresh').on('click',function(){
|
2020-07-27 18:37:22 +02:00
|
|
|
|
$('.modal-body').load("{{ url_for('trigger_modules', tree_uuid=tree_uuid, force=True) }}",function(){
|
|
|
|
|
$('#modulesModal').modal({show:true});
|
|
|
|
|
});
|
2020-04-20 16:41:42 +02:00
|
|
|
|
});
|
|
|
|
|
</script>
|
2020-06-29 11:59:01 +02:00
|
|
|
|
{% if urlnode_uuid %}
|
|
|
|
|
<script>
|
|
|
|
|
history.scrollRestoration = "manual";
|
|
|
|
|
window.addEventListener('DOMContentLoaded', (event) => {
|
2020-07-23 17:47:12 +02:00
|
|
|
|
PermanentNodeHighlight('{{urlnode_uuid}}');
|
2020-06-29 11:59:01 +02:00
|
|
|
|
});
|
|
|
|
|
</script>
|
|
|
|
|
{% endif%}
|
2017-09-29 14:48:37 +02:00
|
|
|
|
{% endblock %}
|
2017-09-22 00:26:38 +02:00
|
|
|
|
|
2017-07-23 19:56:51 +02:00
|
|
|
|
{% block content %}
|
2017-09-25 15:11:01 +02:00
|
|
|
|
{{super()}}
|
2020-07-27 18:37:22 +02:00
|
|
|
|
|
2017-09-22 00:26:38 +02:00
|
|
|
|
<script>
|
2020-05-20 19:11:15 +02:00
|
|
|
|
var treeUUID = "{{ tree_uuid }}";
|
2019-06-28 12:08:35 +02:00
|
|
|
|
var treeData = {{ tree_json | safe }};
|
2017-09-22 00:26:38 +02:00
|
|
|
|
</script>
|
2017-09-25 15:11:01 +02:00
|
|
|
|
|
2020-07-03 18:25:16 +02:00
|
|
|
|
{{ render_messages(container=True, dismissible=True) }}
|
|
|
|
|
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<!-- Containers -->
|
|
|
|
|
|
|
|
|
|
<div id="menu_container" class="container">
|
|
|
|
|
<div id=menu class="collapse show">
|
|
|
|
|
<div class="menu_header">
|
|
|
|
|
<a href="/" >
|
|
|
|
|
<img src="{{ url_for('static', filename='lookyloo.jpeg') }}" alt="Lookyloo icon" height="110">
|
|
|
|
|
</a>
|
|
|
|
|
</div>
|
|
|
|
|
<center>
|
|
|
|
|
<div style="display: inline">
|
|
|
|
|
<b>Menu</b>
|
|
|
|
|
</div>
|
|
|
|
|
<div style="display: inline;">
|
|
|
|
|
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#menu">
|
2020-07-28 18:26:07 +02:00
|
|
|
|
<img src="{{ url_for('static', filename='up.jpg') }}" alt="Minimize menu" height="25" width="25">
|
2020-07-27 18:37:22 +02:00
|
|
|
|
</button>
|
|
|
|
|
</div>
|
|
|
|
|
</center>
|
|
|
|
|
<ul class="list-unstyled components">
|
|
|
|
|
<li>
|
|
|
|
|
<a href="#modulesModal" data-remote="{{ url_for('trigger_modules', tree_uuid=tree_uuid, force=False) }}"
|
|
|
|
|
data-toggle="modal" data-target="#modulesModal" role="button">Show third party reports</a>
|
|
|
|
|
</li>
|
|
|
|
|
<li>
|
|
|
|
|
<a href="#statsModal" data-remote="{{ url_for('stats', tree_uuid=tree_uuid) }}"
|
|
|
|
|
data-toggle="modal" data-target="#statsModal" role="button">Show Statistics</a>
|
|
|
|
|
</li>
|
2020-07-28 18:26:07 +02:00
|
|
|
|
<li>
|
|
|
|
|
<a href="#unflag" role="button" onclick="UnflagAllNodes();">Unflag all nodes</a>
|
|
|
|
|
</li>
|
2020-07-27 18:37:22 +02:00
|
|
|
|
{% if enable_mail_notification %}
|
|
|
|
|
<li>
|
|
|
|
|
<a href="#emailModal" data-toggle="modal" data-target="#emailModal" role="button">Notify by mail</a>
|
|
|
|
|
</li>
|
|
|
|
|
{%endif%}
|
|
|
|
|
</ul>
|
|
|
|
|
</div>
|
|
|
|
|
<div style="width: 100px">
|
|
|
|
|
<div style="display: inline;">
|
|
|
|
|
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#menu">
|
2020-07-28 18:26:07 +02:00
|
|
|
|
<img src="{{ url_for('static', filename='down.jpg') }}" alt="Maximize" height="40" width="40">
|
2020-07-27 18:37:22 +02:00
|
|
|
|
</button>
|
|
|
|
|
</div>
|
|
|
|
|
<div style="display: inline">
|
|
|
|
|
<b>Menu</b>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2019-02-06 18:01:17 +01:00
|
|
|
|
</div>
|
2018-03-22 17:22:19 +01:00
|
|
|
|
|
2019-04-18 17:34:36 +02:00
|
|
|
|
<div id="legend_container" class="container">
|
2019-06-28 12:08:35 +02:00
|
|
|
|
<div id=legend class="collapse show">
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<center>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
<div style="display: inline">
|
|
|
|
|
<b>Legend</b>
|
|
|
|
|
</div>
|
|
|
|
|
<div style="display: inline;">
|
2019-04-18 17:34:36 +02:00
|
|
|
|
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#legend">
|
2020-07-28 18:26:07 +02:00
|
|
|
|
<img src="{{ url_for('static', filename='down.jpg') }}" alt="Minimize legend" height="25" width="25">
|
2019-04-18 17:34:36 +02:00
|
|
|
|
</button>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
</div>
|
2020-07-27 18:37:22 +02:00
|
|
|
|
</center>
|
|
|
|
|
<hr/>
|
|
|
|
|
<img src="{{ url_for('static', filename='javascript.png') }}"
|
|
|
|
|
alt="JavaScript" height="20" width="20"> Javascript <br>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<img src="{{ url_for('static', filename='cookie_received.png') }}"
|
|
|
|
|
alt="Cookie received" height="20" width="20"> Cookie received<br>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<img src="{{ url_for('static', filename='cookie_read.png') }}"
|
|
|
|
|
alt="Cookie read" height="20" width="20"> Cookie read<br>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<img src="{{ url_for('static', filename='redirect.png') }}"
|
|
|
|
|
alt="Redirect" height="20" width="20"> Redirect<br>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<img src="{{ url_for('static', filename='font.png') }}"
|
|
|
|
|
alt="Font" height="20" width="20"> Font<br>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<img src="{{ url_for('static', filename='html.png') }}"
|
|
|
|
|
alt="HTML" height="20" width="20"> HTML<br>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<img src="{{ url_for('static', filename='json.png') }}"
|
|
|
|
|
alt="JSON" height="20" width="20"> JSON<br>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<img src="{{ url_for('static', filename='css.png') }}"
|
|
|
|
|
alt="CSS" height="20" width="20"> CSS<br>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<img src="{{ url_for('static', filename='exe.png') }}"
|
|
|
|
|
alt="EXE" height="20" width="20"> EXE<br>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<img src="{{ url_for('static', filename='img.png') }}"
|
|
|
|
|
alt="Image" height="20" width="20"> Image<br>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<img src="{{ url_for('static', filename='video.png') }}"
|
|
|
|
|
alt="Video" height="20" width="20"> Video<br>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<img src="{{ url_for('static', filename='ifr.png') }}"
|
|
|
|
|
alt="iFrame" height="20" width="20"> iFrame<br>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<img src="{{ url_for('static', filename='wtf.png') }}"
|
|
|
|
|
alt="Content type not set/unknown" height="20" width="20"> Content type not set/unknown<br>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
</div>
|
|
|
|
|
<div style="width: 100px">
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<div style="display: inline;">
|
|
|
|
|
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#legend">
|
2020-07-28 18:26:07 +02:00
|
|
|
|
<img src="{{ url_for('static', filename='up.jpg') }}" alt="Maximize legend" height="40" width="40">
|
2020-07-27 18:37:22 +02:00
|
|
|
|
</button>
|
|
|
|
|
</div>
|
|
|
|
|
<div style="display: inline">
|
|
|
|
|
<b>Legend</b>
|
|
|
|
|
</div>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
</div>
|
2017-09-25 15:11:01 +02:00
|
|
|
|
</div>
|
2019-04-18 17:34:36 +02:00
|
|
|
|
|
2019-04-19 14:41:04 +02:00
|
|
|
|
<div id="tree-details_container" class="container">
|
2019-06-28 12:08:35 +02:00
|
|
|
|
<div id=tree-details class="collapse show">
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<div>
|
|
|
|
|
<center>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
<div style="display: inline">
|
|
|
|
|
<b>Tree details</b>
|
2019-04-19 14:41:04 +02:00
|
|
|
|
</div>
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<div style="display: inline;">
|
|
|
|
|
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#tree-details">
|
2020-07-28 18:26:07 +02:00
|
|
|
|
<img src="{{ url_for('static', filename='down.jpg') }}"
|
2020-07-27 18:37:22 +02:00
|
|
|
|
alt="Minimize tree details" height="25" width="25">
|
|
|
|
|
</button>
|
|
|
|
|
</div>
|
|
|
|
|
</center>
|
|
|
|
|
</div>
|
|
|
|
|
<hr/>
|
|
|
|
|
<b>Root URL</b>: {{ shorten_string(root_url, 150) }}
|
|
|
|
|
<br>
|
|
|
|
|
<b>Start time</b>: {{ start_time }}<br>
|
|
|
|
|
<b>User Agent</b>: {{ user_agent }}<br>
|
|
|
|
|
{% if meta %}
|
|
|
|
|
{%for k, v in meta.items()%}
|
|
|
|
|
<b>{{k.title()}}</b>: {{ v }}<br>
|
|
|
|
|
{%endfor%}
|
|
|
|
|
{%endif%}
|
|
|
|
|
<b>Screenshot</b>:
|
|
|
|
|
<a href="{{ url_for('image', tree_uuid=tree_uuid) }}" class="btn btn-info" role="button">Download</a>
|
|
|
|
|
<a href="#screenshotModal" data-toggle="modal" data-target="#screenshotModal" class="btn btn-info" role="button">Show screenshot</a>
|
|
|
|
|
</div>
|
|
|
|
|
<div style="width: 100px;float: right;">
|
|
|
|
|
<div style="display: inline;">
|
|
|
|
|
<button type="button" class="btn btn-link" data-toggle="collapse" data-target="#tree-details">
|
2020-07-28 18:26:07 +02:00
|
|
|
|
<img src="{{ url_for('static', filename='up.jpg') }}" alt="Minimize tree details" height="40" width="40">
|
2020-07-27 18:37:22 +02:00
|
|
|
|
</button>
|
|
|
|
|
</div>
|
|
|
|
|
<div style="display: inline">
|
|
|
|
|
<b>Tree details</b>
|
|
|
|
|
</div>
|
2019-06-28 12:08:35 +02:00
|
|
|
|
</div>
|
2017-09-25 15:11:01 +02:00
|
|
|
|
</div>
|
|
|
|
|
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<!-- Modals -->
|
|
|
|
|
|
2020-05-13 17:31:27 +02:00
|
|
|
|
<div class="modal fade" id="statsModal" tabindex="-1" role="dialog">
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<div class="modal-dialog modal-xl" role="document">
|
|
|
|
|
<div class="modal-content">
|
|
|
|
|
<div class="modal-header">
|
|
|
|
|
<h5 class="modal-title" id="modulesModalLabel">Statistics</h5>
|
|
|
|
|
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
|
|
|
|
|
<span aria-hidden="true">×</span>
|
|
|
|
|
</button>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="modal-body">
|
|
|
|
|
... loading statistics ...
|
|
|
|
|
</div>
|
|
|
|
|
<div class="modal-footer">
|
|
|
|
|
<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<div class="modal fade" id="screenshotModal" tabindex="-1" role="dialog">
|
|
|
|
|
<div class="modal-dialog modal-xl" role="document">
|
|
|
|
|
<div class="modal-content">
|
|
|
|
|
<div class="modal-header">
|
|
|
|
|
<h5 class="modal-title" id="modulesModalLabel">Screenshot</h5>
|
|
|
|
|
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
|
|
|
|
|
<span aria-hidden="true">×</span>
|
|
|
|
|
</button>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="modal-body">
|
|
|
|
|
<img src="{{ url_for('image', tree_uuid=tree_uuid) }}" class="img-fluid"/>
|
2020-05-13 17:31:27 +02:00
|
|
|
|
</div>
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<div class="modal-footer">
|
|
|
|
|
<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2020-05-13 17:31:27 +02:00
|
|
|
|
</div>
|
|
|
|
|
|
2020-04-20 16:41:42 +02:00
|
|
|
|
<div class="modal fade" id="modulesModal" tabindex="-1" role="dialog">
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<div class="modal-dialog modal-xl" role="document">
|
|
|
|
|
<div class="modal-content">
|
|
|
|
|
<div class="modal-header">
|
|
|
|
|
<h5 class="modal-title" id="modulesModalLabel">Reports from 3rd party services</h5>
|
|
|
|
|
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
|
|
|
|
|
<span aria-hidden="true">×</span>
|
|
|
|
|
</button>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="modal-body">
|
|
|
|
|
... loading results from 3rd party modules ...
|
|
|
|
|
</div>
|
|
|
|
|
<div class="modal-footer">
|
|
|
|
|
<button type="button" class="btn btn-success modulesForceRefresh">Re-run all modules</button>
|
|
|
|
|
<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2020-04-20 16:41:42 +02:00
|
|
|
|
</div>
|
|
|
|
|
|
2020-05-11 19:01:02 +02:00
|
|
|
|
<div class="modal fade" id="emailModal" tabindex="-1" role="dialog">
|
2020-07-27 18:37:22 +02:00
|
|
|
|
<div class="modal-dialog modal-xl" role="document">
|
|
|
|
|
<form role="form" action="{{ tree_uuid }}/send_mail" method=post enctype=multipart/form-data>
|
|
|
|
|
<div class="modal-content">
|
|
|
|
|
<div class="modal-header">
|
|
|
|
|
<h5 class="modal-title" id="emailModalLabel">Notify by email</h5>
|
|
|
|
|
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
|
|
|
|
|
<span aria-hidden="true">×</span>
|
|
|
|
|
</button>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="modal-body">
|
|
|
|
|
<div class="form-group">
|
|
|
|
|
<label for="email">Email address - used to get back in touch with you if needed (optional)</label>
|
|
|
|
|
<input type="email" class="form-control" name="email" id="email" placeholder="Enter email">
|
|
|
|
|
</div>
|
|
|
|
|
<div class="form-group">
|
|
|
|
|
<label for="comment">Please write a comment (optional)</label>
|
|
|
|
|
<textarea class="form-control" name="comment" id=comment rows="3"></textarea>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="modal-footer">
|
|
|
|
|
<button type="submit" class="btn btn-success">Send email</button>
|
|
|
|
|
<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</form>
|
|
|
|
|
</div>
|
2020-05-11 19:01:02 +02:00
|
|
|
|
</div>
|
2017-09-25 15:11:01 +02:00
|
|
|
|
{% endblock content %}
|