2021-09-25 23:02:05 +00:00
|
|
|
from app.classes.shared.main_controller import Controller
|
2021-08-22 20:31:49 +00:00
|
|
|
import tornado.options
|
|
|
|
import tornado.web
|
|
|
|
import tornado.httpserver
|
|
|
|
from tornado.options import options
|
2021-09-08 22:01:10 +00:00
|
|
|
from app.classes.models.server_permissions import Enum_Permissions_Server
|
2021-08-22 20:31:49 +00:00
|
|
|
from app.classes.shared.helpers import helper
|
|
|
|
from app.classes.web.websocket_helper import websocket_helper
|
|
|
|
from app.classes.shared.console import console
|
2021-08-22 14:17:33 +00:00
|
|
|
import logging
|
2021-08-22 20:31:49 +00:00
|
|
|
import os
|
|
|
|
import json
|
|
|
|
import time
|
2021-08-22 14:17:33 +00:00
|
|
|
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
2021-08-22 20:31:49 +00:00
|
|
|
# Class&Function Defination
|
|
|
|
MAX_STREAMED_SIZE = 1024 * 1024 * 1024
|
2021-08-22 14:17:33 +00:00
|
|
|
|
2021-08-22 20:31:49 +00:00
|
|
|
@tornado.web.stream_request_body
|
|
|
|
class UploadHandler(tornado.web.RequestHandler):
|
2021-09-28 16:40:31 +00:00
|
|
|
|
2021-09-28 21:48:54 +00:00
|
|
|
def initialize(self, controller: Controller=None, tasks_manager=None, translator=None):
|
2021-09-25 23:02:05 +00:00
|
|
|
self.controller = controller
|
2021-09-28 21:48:54 +00:00
|
|
|
self.tasks_manager = tasks_manager
|
|
|
|
self.translator = translator
|
2021-09-25 23:02:05 +00:00
|
|
|
|
2021-08-22 14:17:33 +00:00
|
|
|
def prepare(self):
|
2021-08-22 20:31:49 +00:00
|
|
|
self.do_upload = True
|
|
|
|
user_data = json.loads(self.get_secure_cookie('user_data'))
|
|
|
|
user_id = user_data['user_id']
|
2021-08-22 14:17:33 +00:00
|
|
|
|
2021-08-22 20:31:49 +00:00
|
|
|
server_id = self.request.headers.get('X-ServerId', None)
|
2021-08-22 14:17:33 +00:00
|
|
|
|
2021-08-22 20:31:49 +00:00
|
|
|
if user_id is None:
|
|
|
|
logger.warning('User ID not found in upload handler call')
|
|
|
|
console.warning('User ID not found in upload handler call')
|
|
|
|
self.do_upload = False
|
2021-09-28 16:40:31 +00:00
|
|
|
|
2021-08-22 20:31:49 +00:00
|
|
|
if server_id is None:
|
|
|
|
logger.warning('Server ID not found in upload handler call')
|
|
|
|
console.warning('Server ID not found in upload handler call')
|
|
|
|
self.do_upload = False
|
2021-08-22 14:54:34 +00:00
|
|
|
|
2021-09-28 16:40:31 +00:00
|
|
|
user_permissions = self.controller.server_perms.get_user_permissions_list(user_id, server_id)
|
2021-08-22 20:59:33 +00:00
|
|
|
if Enum_Permissions_Server.Files not in user_permissions:
|
2021-08-22 20:31:49 +00:00
|
|
|
logger.warning(f'User {user_id} tried to upload a file to {server_id} without permissions!')
|
|
|
|
console.warning(f'User {user_id} tried to upload a file to {server_id} without permissions!')
|
|
|
|
self.do_upload = False
|
2021-08-22 14:54:34 +00:00
|
|
|
|
2021-08-22 20:31:49 +00:00
|
|
|
path = self.request.headers.get('X-Path', None)
|
|
|
|
filename = self.request.headers.get('X-FileName', None)
|
|
|
|
full_path = os.path.join(path, filename)
|
2021-08-22 14:54:34 +00:00
|
|
|
|
2021-11-21 10:52:29 +00:00
|
|
|
if not helper.in_path(helper.get_os_understandable_path(self.controller.servers.get_server_data_by_id(server_id)['path']), full_path):
|
|
|
|
print(user_id, server_id, helper.get_os_understandable_path(self.controller.servers.get_server_data_by_id(server_id)['path']), full_path)
|
2021-08-22 20:31:49 +00:00
|
|
|
logger.warning(f'User {user_id} tried to upload a file to {server_id} but the path is not inside of the server!')
|
|
|
|
console.warning(f'User {user_id} tried to upload a file to {server_id} but the path is not inside of the server!')
|
|
|
|
self.do_upload = False
|
2021-09-28 16:40:31 +00:00
|
|
|
|
2021-08-22 20:31:49 +00:00
|
|
|
if self.do_upload:
|
|
|
|
try:
|
|
|
|
self.f = open(full_path, "wb")
|
|
|
|
except Exception as e:
|
|
|
|
logger.error("Upload failed with error: {}".format(e))
|
|
|
|
self.do_upload = False
|
|
|
|
# If max_body_size is not set, you cannot upload files > 100MB
|
|
|
|
self.request.connection.set_max_body_size(MAX_STREAMED_SIZE)
|
2021-08-22 14:54:34 +00:00
|
|
|
|
2021-08-22 20:31:49 +00:00
|
|
|
def post(self):
|
|
|
|
logger.info("Upload completed")
|
2021-08-23 22:22:35 +00:00
|
|
|
files_left = int(self.request.headers.get('X-Files-Left', None))
|
2021-09-28 16:40:31 +00:00
|
|
|
|
2021-08-22 20:31:49 +00:00
|
|
|
if self.do_upload:
|
|
|
|
time.sleep(5)
|
2021-08-23 22:22:35 +00:00
|
|
|
if files_left == 0:
|
|
|
|
websocket_helper.broadcast('close_upload_box', 'success')
|
2021-08-22 21:37:37 +00:00
|
|
|
self.finish('success') # Nope, I'm sending "success"
|
2021-08-22 20:31:49 +00:00
|
|
|
self.f.close()
|
|
|
|
else:
|
|
|
|
time.sleep(5)
|
2021-08-23 22:22:35 +00:00
|
|
|
if files_left == 0:
|
|
|
|
websocket_helper.broadcast('close_upload_box', 'error')
|
2021-08-22 20:31:49 +00:00
|
|
|
self.finish('error')
|
2021-08-22 14:54:34 +00:00
|
|
|
|
2021-08-22 20:31:49 +00:00
|
|
|
def data_received(self, data):
|
|
|
|
if self.do_upload:
|
|
|
|
self.f.write(data)
|