forked from p15670423/monkey
Added deletion of files
This commit is contained in:
parent
a51d7da1f9
commit
7281f2284b
|
@ -119,7 +119,8 @@ def init_app(mongo_url):
|
||||||
api.add_resource(Log, '/api/log', '/api/log/')
|
api.add_resource(Log, '/api/log', '/api/log/')
|
||||||
api.add_resource(IslandLog, '/api/log/island/download', '/api/log/island/download/')
|
api.add_resource(IslandLog, '/api/log/island/download', '/api/log/island/download/')
|
||||||
api.add_resource(PBAFileDownload, '/api/pba/download/<string:path>')
|
api.add_resource(PBAFileDownload, '/api/pba/download/<string:path>')
|
||||||
api.add_resource(FileUpload, '/api/fileUpload/<string:file_type>')
|
api.add_resource(FileUpload, '/api/fileUpload/<string:file_type>',
|
||||||
|
'/api/fileUpload/<string:file_type>?load=<string:file_name>')
|
||||||
api.add_resource(RemoteRun, '/api/remote-monkey', '/api/remote-monkey/')
|
api.add_resource(RemoteRun, '/api/remote-monkey', '/api/remote-monkey/')
|
||||||
|
|
||||||
return app
|
return app
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
import flask_restful
|
import flask_restful
|
||||||
from flask import request, send_from_directory
|
from flask import request, send_from_directory, Response
|
||||||
from cc.services.config import ConfigService
|
from cc.services.config import ConfigService
|
||||||
import os
|
import os
|
||||||
from werkzeug.utils import secure_filename
|
from werkzeug.utils import secure_filename
|
||||||
|
import logging
|
||||||
|
|
||||||
|
LOG = logging.getLogger(__name__)
|
||||||
UPLOADS_DIR = "./monkey_island/cc/userUploads"
|
UPLOADS_DIR = "./monkey_island/cc/userUploads"
|
||||||
|
|
||||||
|
|
||||||
|
@ -12,18 +14,48 @@ class FileUpload(flask_restful.Resource):
|
||||||
def get(self, path):
|
def get(self, path):
|
||||||
return send_from_directory(UPLOADS_DIR, path)
|
return send_from_directory(UPLOADS_DIR, path)
|
||||||
|
|
||||||
|
def get(self, file_type, file_name):
|
||||||
|
req_data = request.data
|
||||||
|
|
||||||
def post(self, file_type):
|
def post(self, file_type):
|
||||||
|
filename = ''
|
||||||
if file_type == 'PBAlinux':
|
if file_type == 'PBAlinux':
|
||||||
config = ConfigService.get_config()
|
filename = FileUpload.upload_pba_file(request)
|
||||||
file_info = ConfigService.get_config_value(['monkey', 'behaviour', 'custom_post_breach', 'linux_file_info'])
|
|
||||||
filename = secure_filename(request.files['filepond'].filename)
|
|
||||||
file_path = os.path.join(UPLOADS_DIR, filename)
|
|
||||||
request.files['filepond'].save(file_path)
|
|
||||||
file_size = os.path.getsize(file_path)
|
|
||||||
# config['monkey']['behaviour']['cutom_post_breach']['linux_file_info']['size'] = file_size
|
|
||||||
# config['monkey']['behaviour']['cutom_post_breach']['linux_file_info']['name'] = filename
|
|
||||||
# ConfigService.update_config(config, True)
|
|
||||||
|
|
||||||
|
|
||||||
elif file_type == 'PBAwindows':
|
elif file_type == 'PBAwindows':
|
||||||
request.files['filepond'].save("./useless.file")
|
filename = FileUpload.upload_pba_file(request, False)
|
||||||
|
|
||||||
|
response = Response(
|
||||||
|
response=filename,
|
||||||
|
status=200, mimetype='text/plain')
|
||||||
|
return response
|
||||||
|
|
||||||
|
def delete(self, file_type):
|
||||||
|
config = ConfigService.get_config(should_decrypt=False)
|
||||||
|
if file_type == 'PBAlinux':
|
||||||
|
file_info = 'linux_file_info'
|
||||||
|
else:
|
||||||
|
file_info = 'windows_file_info'
|
||||||
|
filename = config['monkey']['behaviour']['custom_post_breach'][file_info]['name']
|
||||||
|
file_path = os.path.join(UPLOADS_DIR, filename)
|
||||||
|
try:
|
||||||
|
if os.path.exists(file_path):
|
||||||
|
os.remove(file_path)
|
||||||
|
except OSError as e:
|
||||||
|
LOG.error("Can't remove previously uploaded post breach files: %s" % e)
|
||||||
|
return {}
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def upload_pba_file(request_, is_linux=True):
|
||||||
|
config = ConfigService.get_config(should_decrypt=False)
|
||||||
|
filename = secure_filename(request_.files['filepond'].filename)
|
||||||
|
file_path = os.path.join(UPLOADS_DIR, filename)
|
||||||
|
request_.files['filepond'].save(file_path)
|
||||||
|
file_size = os.path.getsize(file_path)
|
||||||
|
if is_linux:
|
||||||
|
file_info = 'linux_file_info'
|
||||||
|
else:
|
||||||
|
file_info = 'windows_file_info'
|
||||||
|
config['monkey']['behaviour']['custom_post_breach'][file_info]['size'] = file_size
|
||||||
|
config['monkey']['behaviour']['custom_post_breach'][file_info]['name'] = filename
|
||||||
|
ConfigService.update_config(config, should_encrypt=False)
|
||||||
|
return filename
|
||||||
|
|
|
@ -153,6 +153,9 @@ class ConfigurePageComponent extends AuthComponent {
|
||||||
};
|
};
|
||||||
|
|
||||||
PBAwindows = () => {
|
PBAwindows = () => {
|
||||||
|
if (! this.state.configuration.monkey.behaviour.custom_post_breach.windows_file_info){
|
||||||
|
|
||||||
|
}
|
||||||
return (<FilePond server='/api/fileUpload/PBAwindows'/>)
|
return (<FilePond server='/api/fileUpload/PBAwindows'/>)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue