mirror of https://github.com/MISP/MISP
new: [Rest client] Download results as file
parent
c754e3b967
commit
7f95be9b0d
|
@ -92,7 +92,7 @@
|
|||
</fieldset>
|
||||
|
||||
<?php
|
||||
$formats = array('Raw', 'JSON', 'HTML');
|
||||
$formats = array('Raw', 'JSON', 'HTML', 'Download');
|
||||
if (!empty($data['code']) && $data['code'] < 300) {
|
||||
$query_formats = array('curl' => 'cURL', 'python' => 'PyMISP');
|
||||
echo '<ul class="nav nav-tabs" style="margin-bottom:5px;">';
|
||||
|
@ -120,7 +120,7 @@
|
|||
if (is_array($value)) {
|
||||
$value = implode(',', $value);
|
||||
}
|
||||
echo sprintf(' <span class="bold">%s</span>: %s<br />', h($header), h($value));
|
||||
echo sprintf(' <span class="bold">%s</span>: <span id="header-%s">%s</span><br />', h($header), h($header), h($value));
|
||||
}
|
||||
$format_toggles = '';
|
||||
foreach ($formats as $k => $format) {
|
||||
|
@ -148,6 +148,7 @@
|
|||
echo $this->Html->script('moment-with-locales');
|
||||
echo $this->Html->css('query-builder.default');
|
||||
echo $this->Html->script('query-builder');
|
||||
echo $this->Html->script('FileSaver');
|
||||
echo $this->Html->script('restClient');
|
||||
?>
|
||||
|
||||
|
|
|
@ -0,0 +1,165 @@
|
|||
/*
|
||||
* FileSaver.js
|
||||
* A saveAs() FileSaver implementation.
|
||||
*
|
||||
* By Eli Grey, http://eligrey.com
|
||||
*
|
||||
* License : https://github.com/eligrey/FileSaver.js/blob/master/LICENSE.md (MIT)
|
||||
* source : http://purl.eligrey.com/github/FileSaver.js
|
||||
*/
|
||||
|
||||
|
||||
// The one and only way of getting global scope in all environments
|
||||
// https://stackoverflow.com/q/3277182/1008999
|
||||
var _global = typeof window === 'object' && window.window === window
|
||||
? window : typeof self === 'object' && self.self === self
|
||||
? self : typeof global === 'object' && global.global === global
|
||||
? global
|
||||
: this
|
||||
|
||||
function bom (blob, opts) {
|
||||
if (typeof opts === 'undefined') opts = { autoBom: false }
|
||||
else if (typeof opts !== 'object') {
|
||||
console.warn('Deprecated: Expected third argument to be a object')
|
||||
opts = { autoBom: !opts }
|
||||
}
|
||||
|
||||
// prepend BOM for UTF-8 XML and text/* types (including HTML)
|
||||
// note: your browser will automatically convert UTF-16 U+FEFF to EF BB BF
|
||||
if (opts.autoBom && /^\s*(?:text\/\S*|application\/xml|\S*\/\S*\+xml)\s*;.*charset\s*=\s*utf-8/i.test(blob.type)) {
|
||||
return new Blob([String.fromCharCode(0xFEFF), blob], { type: blob.type })
|
||||
}
|
||||
return blob
|
||||
}
|
||||
|
||||
function download (url, name, opts) {
|
||||
var xhr = new XMLHttpRequest()
|
||||
xhr.open('GET', url)
|
||||
xhr.responseType = 'blob'
|
||||
xhr.onload = function () {
|
||||
saveAs(xhr.response, name, opts)
|
||||
}
|
||||
xhr.onerror = function () {
|
||||
console.error('could not download file')
|
||||
}
|
||||
xhr.send()
|
||||
}
|
||||
|
||||
function corsEnabled (url) {
|
||||
var xhr = new XMLHttpRequest()
|
||||
// use sync to avoid popup blocker
|
||||
xhr.open('HEAD', url, false)
|
||||
xhr.send()
|
||||
return xhr.status >= 200 && xhr.status <= 299
|
||||
}
|
||||
|
||||
// `a.click()` doesn't work for all browsers (#465)
|
||||
function click(node) {
|
||||
try {
|
||||
node.dispatchEvent(new MouseEvent('click'))
|
||||
} catch (e) {
|
||||
var evt = document.createEvent('MouseEvents')
|
||||
evt.initMouseEvent('click', true, true, window, 0, 0, 0, 80,
|
||||
20, false, false, false, false, 0, null)
|
||||
node.dispatchEvent(evt)
|
||||
}
|
||||
}
|
||||
|
||||
var saveAs = _global.saveAs || (
|
||||
// probably in some web worker
|
||||
(typeof window !== 'object' || window !== _global)
|
||||
? function saveAs () { /* noop */ }
|
||||
|
||||
// Use download attribute first if possible (#193 Lumia mobile)
|
||||
: 'download' in HTMLAnchorElement.prototype
|
||||
? function saveAs (blob, name, opts) {
|
||||
var URL = _global.URL || _global.webkitURL
|
||||
var a = document.createElement('a')
|
||||
name = name || blob.name || 'download'
|
||||
|
||||
a.download = name
|
||||
a.rel = 'noopener' // tabnabbing
|
||||
|
||||
// TODO: detect chrome extensions & packaged apps
|
||||
// a.target = '_blank'
|
||||
|
||||
if (typeof blob === 'string') {
|
||||
// Support regular links
|
||||
a.href = blob
|
||||
if (a.origin !== location.origin) {
|
||||
corsEnabled(a.href)
|
||||
? download(blob, name, opts)
|
||||
: click(a, a.target = '_blank')
|
||||
} else {
|
||||
click(a)
|
||||
}
|
||||
} else {
|
||||
// Support blobs
|
||||
a.href = URL.createObjectURL(blob)
|
||||
setTimeout(function () { URL.revokeObjectURL(a.href) }, 4E4) // 40s
|
||||
setTimeout(function () { click(a) }, 0)
|
||||
}
|
||||
}
|
||||
|
||||
// Use msSaveOrOpenBlob as a second approach
|
||||
: 'msSaveOrOpenBlob' in navigator
|
||||
? function saveAs (blob, name, opts) {
|
||||
name = name || blob.name || 'download'
|
||||
|
||||
if (typeof blob === 'string') {
|
||||
if (corsEnabled(blob)) {
|
||||
download(blob, name, opts)
|
||||
} else {
|
||||
var a = document.createElement('a')
|
||||
a.href = blob
|
||||
a.target = '_blank'
|
||||
setTimeout(function () { click(a) })
|
||||
}
|
||||
} else {
|
||||
navigator.msSaveOrOpenBlob(bom(blob, opts), name)
|
||||
}
|
||||
}
|
||||
|
||||
// Fallback to using FileReader and a popup
|
||||
: function saveAs (blob, name, opts, popup) {
|
||||
// Open a popup immediately do go around popup blocker
|
||||
// Mostly only available on user interaction and the fileReader is async so...
|
||||
popup = popup || open('', '_blank')
|
||||
if (popup) {
|
||||
popup.document.title =
|
||||
popup.document.body.innerText = 'downloading...'
|
||||
}
|
||||
|
||||
if (typeof blob === 'string') return download(blob, name, opts)
|
||||
|
||||
var force = blob.type === 'application/octet-stream'
|
||||
var isSafari = /constructor/i.test(_global.HTMLElement) || _global.safari
|
||||
var isChromeIOS = /CriOS\/[\d]+/.test(navigator.userAgent)
|
||||
|
||||
if ((isChromeIOS || (force && isSafari)) && typeof FileReader === 'object') {
|
||||
// Safari doesn't allow downloading of blob URLs
|
||||
var reader = new FileReader()
|
||||
reader.onloadend = function () {
|
||||
var url = reader.result
|
||||
url = isChromeIOS ? url : url.replace(/^data:[^;]*;/, 'data:attachment/file;')
|
||||
if (popup) popup.location.href = url
|
||||
else location = url
|
||||
popup = null // reverse-tabnabbing #460
|
||||
}
|
||||
reader.readAsDataURL(blob)
|
||||
} else {
|
||||
var URL = _global.URL || _global.webkitURL
|
||||
var url = URL.createObjectURL(blob)
|
||||
if (popup) popup.location = url
|
||||
else location.href = url
|
||||
popup = null // reverse-tabnabbing #460
|
||||
setTimeout(function () { URL.revokeObjectURL(url) }, 4E4) // 40s
|
||||
}
|
||||
}
|
||||
)
|
||||
|
||||
_global.saveAs = saveAs.saveAs = saveAs
|
||||
|
||||
if (typeof module !== 'undefined') {
|
||||
module.exports = saveAs;
|
||||
}
|
|
@ -43,18 +43,41 @@ function setApiInfoBox(isTyping) {
|
|||
$(document).ready(function () {
|
||||
insertRawRestResponse();
|
||||
$('.format-toggle-button').bind('click', function() {
|
||||
$('#rest-response-container').empty();
|
||||
if ($(this).data('toggle-type') == 'Raw') {
|
||||
$('#rest-response-container').empty();
|
||||
insertRawRestResponse();
|
||||
} else if ($(this).data('toggle-type') == 'HTML') {
|
||||
$('#rest-response-container').empty();
|
||||
insertHTMLRestResponse();
|
||||
} else if ($(this).data('toggle-type') == 'JSON') {
|
||||
$('#rest-response-container').empty();
|
||||
insertJSONRestResponse();
|
||||
} else if ($(this).data('toggle-type') == 'Download') {
|
||||
var download_content = $('#rest-response-hidden-container').text();
|
||||
var extension = 'json';
|
||||
var export_type = 'json';
|
||||
var mime = 'application/json';
|
||||
if ($('#header-X-Response-Format').length != 0) {
|
||||
extension = $('#header-X-Response-Format').text();
|
||||
}
|
||||
if ($('#header-Content-Type').length != 0) {
|
||||
mime = $('#header-Content-Type').text();
|
||||
}
|
||||
if ($('#header-X-Export-Module-Used').length != 0) {
|
||||
export_type = $('#header-X-Export-Module-Used').text();
|
||||
}
|
||||
var filename = export_type + '.result.' + extension;
|
||||
var blob = new Blob([download_content], {
|
||||
type: mime
|
||||
});
|
||||
saveAs(blob, filename);
|
||||
}
|
||||
});
|
||||
|
||||
$('#ServerUrl').keyup(function() {
|
||||
$('#TemplateSelect').val($(this).val()).trigger("chosen:updated").trigger("change");
|
||||
});
|
||||
|
||||
$('#TemplateSelect').change(function() {
|
||||
var selected_template = $('#TemplateSelect').val();
|
||||
if (selected_template !== '' && allValidApis[selected_template] !== undefined) {
|
||||
|
@ -110,10 +133,10 @@ function setApiInfoBox(isTyping) {
|
|||
}
|
||||
});
|
||||
querybuilderTool = querybuilderTool[0].queryBuilder;
|
||||
|
||||
|
||||
$('#btn-apply').on('click', function() {
|
||||
var result = querybuilderTool.getRules();
|
||||
|
||||
|
||||
if (!$.isEmptyObject(result)) {
|
||||
alert(JSON.stringify(result, null, 2));
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue