mirror of
https://github.com/ail-project/ail-framework.git
synced 2024-11-23 06:37:15 +00:00
add feature, user can submit paste on the web interface
This commit is contained in:
parent
8e9c77b364
commit
c64588f60e
10 changed files with 475 additions and 206 deletions
|
@ -163,6 +163,8 @@ function launching_scripts {
|
||||||
screen -S "Script_AIL" -X screen -t "Tags" bash -c './Tags.py; read x'
|
screen -S "Script_AIL" -X screen -t "Tags" bash -c './Tags.py; read x'
|
||||||
sleep 0.1
|
sleep 0.1
|
||||||
screen -S "Script_AIL" -X screen -t "SentimentAnalysis" bash -c './SentimentAnalysis.py; read x'
|
screen -S "Script_AIL" -X screen -t "SentimentAnalysis" bash -c './SentimentAnalysis.py; read x'
|
||||||
|
sleep 0.1
|
||||||
|
screen -S "Script_AIL" -X screen -t "SubmitPaste" bash -c './submit_paste.py; read x'
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -9,8 +9,80 @@ import io
|
||||||
import redis
|
import redis
|
||||||
import base64
|
import base64
|
||||||
import datetime
|
import datetime
|
||||||
|
import time
|
||||||
|
|
||||||
|
from sflock.main import unpack
|
||||||
|
import sflock
|
||||||
|
|
||||||
from Helper import Process
|
from Helper import Process
|
||||||
|
from pubsublogger import publisher
|
||||||
|
|
||||||
|
def create_paste(uuid, paste_content, ltags, ltagsgalaxies, name):
|
||||||
|
|
||||||
|
now = datetime.datetime.now()
|
||||||
|
save_path = 'submitted/' + now.strftime("%Y") + '/' + now.strftime("%m") + '/' + now.strftime("%d") + '/' + name + '.gz'
|
||||||
|
|
||||||
|
full_path = filename = os.path.join(os.environ['AIL_HOME'],
|
||||||
|
p.config.get("Directories", "pastes"), save_path)
|
||||||
|
|
||||||
|
if os.path.isfile(full_path):
|
||||||
|
addError(uuid, 'File: ' + save_path + ' already exist in submitted pastes')
|
||||||
|
return 1
|
||||||
|
|
||||||
|
gzipencoded = gzip.compress(paste_content)
|
||||||
|
gzip64encoded = base64.standard_b64encode(gzipencoded).decode()
|
||||||
|
|
||||||
|
# send paste to Global module
|
||||||
|
relay_message = "{0} {1}".format(save_path, gzip64encoded)
|
||||||
|
p.populate_set_out(relay_message, 'Mixer')
|
||||||
|
|
||||||
|
# add tags
|
||||||
|
add_tags(ltags, ltagsgalaxies, full_path)
|
||||||
|
|
||||||
|
r_serv_log_submit.incr(uuid + ':nb_end')
|
||||||
|
r_serv_log_submit.incr(uuid + ':nb_sucess')
|
||||||
|
|
||||||
|
if r_serv_log_submit.get(uuid + ':nb_end') == r_serv_log_submit.get(uuid + ':nb_total'):
|
||||||
|
r_serv_log_submit.set(uuid + ':end', 1)
|
||||||
|
|
||||||
|
print(' {} send to Global'.format(save_path))
|
||||||
|
r_serv_log_submit.sadd(uuid + ':paste_submit_link', full_path)
|
||||||
|
|
||||||
|
return 0
|
||||||
|
|
||||||
|
def addError(uuid, errorMessage):
|
||||||
|
print(errorMessage)
|
||||||
|
error = r_serv_log_submit.get(uuid + ':error')
|
||||||
|
if error != None:
|
||||||
|
r_serv_log_submit.set(uuid + ':error', error + '<br></br>' + errorMessage)
|
||||||
|
r_serv_log_submit.incr(uuid + ':nb_end')
|
||||||
|
|
||||||
|
def abord_file_submission(uuid, errorMessage):
|
||||||
|
addError(uuid, errorMessage)
|
||||||
|
r_serv_log_submit.set(uuid + ':end', 1)
|
||||||
|
remove_submit_uuid(uuid)
|
||||||
|
|
||||||
|
|
||||||
|
def remove_submit_uuid(uuid):
|
||||||
|
# save temp value on disk
|
||||||
|
r_serv_db.delete(uuid + ':ltags')
|
||||||
|
r_serv_db.delete(uuid + ':ltagsgalaxies')
|
||||||
|
r_serv_db.delete(uuid + ':paste_content')
|
||||||
|
r_serv_db.delete(uuid + ':isfile')
|
||||||
|
r_serv_db.delete(uuid + ':password')
|
||||||
|
|
||||||
|
r_serv_log_submit.expire(uuid + ':end', expire_time)
|
||||||
|
r_serv_log_submit.expire(uuid + ':processing', expire_time)
|
||||||
|
r_serv_log_submit.expire(uuid + ':nb_total', expire_time)
|
||||||
|
r_serv_log_submit.expire(uuid + ':nb_sucess', expire_time)
|
||||||
|
r_serv_log_submit.expire(uuid + ':nb_end', expire_time)
|
||||||
|
r_serv_log_submit.expire(uuid + ':error', expire_time)
|
||||||
|
r_serv_log_submit.srem(uuid + ':paste_submit_link', '')
|
||||||
|
r_serv_log_submit.expire(uuid + ':paste_submit_link', expire_time)
|
||||||
|
|
||||||
|
# delete uuid
|
||||||
|
r_serv_db.srem('submitted:uuid', uuid)
|
||||||
|
print('{} all file submitted'.format(uuid))
|
||||||
|
|
||||||
def add_tags(tags, tagsgalaxies, path):
|
def add_tags(tags, tagsgalaxies, path):
|
||||||
list_tag = tags.split(',')
|
list_tag = tags.split(',')
|
||||||
|
@ -32,21 +104,22 @@ def add_tags(tags, tagsgalaxies, path):
|
||||||
#add new tag in list of all used tags
|
#add new tag in list of all used tags
|
||||||
r_serv_tags.sadd('list_tags', tag)
|
r_serv_tags.sadd('list_tags', tag)
|
||||||
|
|
||||||
|
def verify_extention_filename(filename):
|
||||||
|
if not '.' in filename:
|
||||||
|
return True
|
||||||
|
else:
|
||||||
|
file_type = filename.rsplit('.', 1)[1]
|
||||||
|
|
||||||
|
#txt file
|
||||||
|
if file_type in ALLOWED_EXTENSIONS:
|
||||||
|
return True
|
||||||
|
else:
|
||||||
|
return False
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
if len(sys.argv) != 6:
|
|
||||||
print('usage:', 'submit_paste.py', 'ltags', 'ltagsgalaxies', 'paste_content', 'paste_name', 'id')
|
|
||||||
exit(1)
|
|
||||||
|
|
||||||
try:
|
publisher.port = 6380
|
||||||
ltags = sys.argv[1]
|
publisher.channel = "Script"
|
||||||
ltagsgalaxies = sys.argv[2]
|
|
||||||
paste_content = sys.argv[3]
|
|
||||||
paste_name = sys.argv[4]
|
|
||||||
id = sys.argv[5]
|
|
||||||
except:
|
|
||||||
print('unable to get elements')
|
|
||||||
exit(1)
|
|
||||||
|
|
||||||
configfile = os.path.join(os.environ['AIL_BIN'], 'packages/config.cfg')
|
configfile = os.path.join(os.environ['AIL_BIN'], 'packages/config.cfg')
|
||||||
if not os.path.exists(configfile):
|
if not os.path.exists(configfile):
|
||||||
|
@ -57,6 +130,12 @@ if __name__ == "__main__":
|
||||||
cfg = configparser.ConfigParser()
|
cfg = configparser.ConfigParser()
|
||||||
cfg.read(configfile)
|
cfg.read(configfile)
|
||||||
|
|
||||||
|
r_serv_db = redis.StrictRedis(
|
||||||
|
host=cfg.get("ARDB_DB", "host"),
|
||||||
|
port=cfg.getint("ARDB_DB", "port"),
|
||||||
|
db=cfg.getint("ARDB_DB", "db"),
|
||||||
|
decode_responses=True)
|
||||||
|
|
||||||
r_serv_log_submit = redis.StrictRedis(
|
r_serv_log_submit = redis.StrictRedis(
|
||||||
host=cfg.get("Redis_Log_submit", "host"),
|
host=cfg.get("Redis_Log_submit", "host"),
|
||||||
port=cfg.getint("Redis_Log_submit", "port"),
|
port=cfg.getint("Redis_Log_submit", "port"),
|
||||||
|
@ -75,43 +154,117 @@ if __name__ == "__main__":
|
||||||
db=cfg.getint("ARDB_Metadata", "db"),
|
db=cfg.getint("ARDB_Metadata", "db"),
|
||||||
decode_responses=True)
|
decode_responses=True)
|
||||||
|
|
||||||
# TODO put on config
|
expire_time = 120
|
||||||
expire_time = 10200
|
MAX_FILE_SIZE = 1000000000
|
||||||
|
ALLOWED_EXTENSIONS = 'txt'
|
||||||
r_serv_log_submit.expire(id + ':end', expire_time)
|
|
||||||
r_serv_log_submit.expire(id + ':nb_total', expire_time)
|
|
||||||
r_serv_log_submit.expire(id + ':nb_end', expire_time)
|
|
||||||
r_serv_log_submit.expire(id + ':error', expire_time)
|
|
||||||
|
|
||||||
config_section = 'submit_paste'
|
config_section = 'submit_paste'
|
||||||
p = Process(config_section)
|
p = Process(config_section)
|
||||||
|
|
||||||
now = datetime.datetime.now()
|
while True:
|
||||||
save_path = 'submitted/' + now.strftime("%Y") + '/' + now.strftime("%m") + '/' + now.strftime("%d") + '/' + id + '.gz'
|
|
||||||
|
|
||||||
full_path = filename = os.path.join(os.environ['AIL_HOME'],
|
# paste submitted
|
||||||
p.config.get("Directories", "pastes"), save_path)
|
if r_serv_db.scard('submitted:uuid') > 0:
|
||||||
|
uuid = r_serv_db.srandmember('submitted:uuid')
|
||||||
|
|
||||||
if os.path.isfile(full_path):
|
# get temp value save on disk
|
||||||
error = r_serv_log_submit.get(id + ':error')
|
ltags = r_serv_db.get(uuid + ':ltags')
|
||||||
r_serv_log_submit.set(id + ':error', error + '<br></br>File: ' + save_path + ' already exist in submitted pastes')
|
ltagsgalaxies = r_serv_db.get(uuid + ':ltagsgalaxies')
|
||||||
exit(1)
|
paste_content = r_serv_db.get(uuid + ':paste_content')
|
||||||
|
isfile = r_serv_db.get(uuid + ':isfile')
|
||||||
|
password = r_serv_db.get(uuid + ':password')
|
||||||
|
|
||||||
|
# needed if redis is restarted
|
||||||
|
r_serv_log_submit.set(uuid + ':end', 0)
|
||||||
|
r_serv_log_submit.set(uuid + ':processing', 0)
|
||||||
|
r_serv_log_submit.set(uuid + ':nb_total', -1)
|
||||||
|
r_serv_log_submit.set(uuid + ':nb_end', 0)
|
||||||
|
r_serv_log_submit.set(uuid + ':nb_sucess', 0)
|
||||||
|
r_serv_log_submit.set(uuid + ':error', 'error:')
|
||||||
|
r_serv_log_submit.sadd(uuid + ':paste_submit_link', '')
|
||||||
|
|
||||||
|
|
||||||
gzipencoded = gzip.compress(paste_content.encode())
|
r_serv_log_submit.set(uuid + ':processing', 1)
|
||||||
gzip64encoded = base64.standard_b64encode(gzipencoded).decode()
|
|
||||||
|
|
||||||
# send paste to Global module
|
if isfile == 'True':
|
||||||
relay_message = "{0} {1}".format(save_path, gzip64encoded)
|
file_full_path = paste_content
|
||||||
p.populate_set_out(relay_message, 'Mixer')
|
|
||||||
|
|
||||||
# add tags
|
if not os.path.exists(file_full_path):
|
||||||
add_tags(ltags, ltagsgalaxies, full_path)
|
abord_file_submission(uuid, "Server Error, the archive can't be found")
|
||||||
|
continue
|
||||||
|
|
||||||
r_serv_log_submit.incr(id + ':nb_end')
|
#verify file lengh
|
||||||
|
if os.stat(file_full_path).st_size > MAX_FILE_SIZE:
|
||||||
|
abord_file_submission(uuid, 'File :{} too large'.format(file_full_path))
|
||||||
|
|
||||||
|
else:
|
||||||
|
filename = file_full_path.split('/')[-1]
|
||||||
|
if not '.' in filename:
|
||||||
|
# read file
|
||||||
|
with open(file_full_path,'r') as f:
|
||||||
|
content = f.read()
|
||||||
|
r_serv_log_submit.set(uuid + ':nb_total', 1)
|
||||||
|
create_paste(uuid, content.encode(), ltags, ltagsgalaxies, uuid)
|
||||||
|
remove_submit_uuid(uuid)
|
||||||
|
|
||||||
|
else:
|
||||||
|
file_type = filename.rsplit('.', 1)[1]
|
||||||
|
|
||||||
|
#txt file
|
||||||
|
if file_type == 'txt':
|
||||||
|
with open(file_full_path,'r') as f:
|
||||||
|
content = f.read()
|
||||||
|
r_serv_log_submit.set(uuid + ':nb_total', 1)
|
||||||
|
create_paste(uuid, content.encode(), ltags, ltagsgalaxies, uuid)
|
||||||
|
remove_submit_uuid(uuid)
|
||||||
|
#compressed file
|
||||||
|
else:
|
||||||
|
#decompress file
|
||||||
|
try:
|
||||||
|
if password == '':
|
||||||
|
files = unpack(file_full_path.encode())
|
||||||
|
#print(files.children)
|
||||||
|
else:
|
||||||
|
try:
|
||||||
|
files = unpack(file_full_path.encode(), password)
|
||||||
|
#print(files.children)
|
||||||
|
except sflock.exception.IncorrectUsageException:
|
||||||
|
abord_file_submission(uuid, "Wrong Password")
|
||||||
|
continue
|
||||||
|
except:
|
||||||
|
abord_file_submission(uuid, "file decompression error")
|
||||||
|
continue
|
||||||
|
print('unpacking {} file'.format(files.unpacker))
|
||||||
|
if(not files.children):
|
||||||
|
abord_file_submission(uuid, "Empty compressed file")
|
||||||
|
continue
|
||||||
|
# set number of files to submit
|
||||||
|
r_serv_log_submit.set(uuid + ':nb_total', len(files.children))
|
||||||
|
n = 1
|
||||||
|
for child in files.children:
|
||||||
|
if verify_extention_filename(child.filename.decode()):
|
||||||
|
create_paste(uuid, child.contents, ltags, ltagsgalaxies, uuid+'_'+ str(n) )
|
||||||
|
n = n + 1
|
||||||
|
else:
|
||||||
|
print('bad extention')
|
||||||
|
addError(uuid, 'Bad file extension: {}'.format(child.filename.decode()) )
|
||||||
|
|
||||||
|
except FileNotFoundError:
|
||||||
|
print('file not found')
|
||||||
|
addError(uuid, 'File not found: {}'.format(file_full_path), uuid )
|
||||||
|
|
||||||
|
remove_submit_uuid(uuid)
|
||||||
|
|
||||||
|
|
||||||
if r_serv_log_submit.get(id + ':nb_end') == r_serv_log_submit.get(id + ':nb_total'):
|
|
||||||
r_serv_log_submit.set(id + ':end', 1)
|
|
||||||
|
|
||||||
exit(0)
|
# textarea input paste
|
||||||
|
else:
|
||||||
|
r_serv_log_submit.set(uuid + ':nb_total', 1)
|
||||||
|
create_paste(uuid, paste_content.encode(), ltags, ltagsgalaxies, uuid)
|
||||||
|
remove_submit_uuid(uuid)
|
||||||
|
time.sleep(0.5)
|
||||||
|
|
||||||
|
# wait for paste
|
||||||
|
else:
|
||||||
|
publisher.debug("Script submit_paste is Idling 10s")
|
||||||
|
time.sleep(3)
|
||||||
|
|
|
@ -33,6 +33,9 @@ sudo pip install nose -y
|
||||||
sudo apt-get install libfuzzy-dev -y
|
sudo apt-get install libfuzzy-dev -y
|
||||||
sudo apt-get install build-essential libffi-dev automake autoconf libtool -y
|
sudo apt-get install build-essential libffi-dev automake autoconf libtool -y
|
||||||
|
|
||||||
|
# sflock, gz requirement
|
||||||
|
sudo apt-get install p7zip-full -y
|
||||||
|
|
||||||
# REDIS #
|
# REDIS #
|
||||||
test ! -d redis/ && git clone https://github.com/antirez/redis.git
|
test ! -d redis/ && git clone https://github.com/antirez/redis.git
|
||||||
pushd redis/
|
pushd redis/
|
||||||
|
|
|
@ -56,6 +56,9 @@ pycountry
|
||||||
# To fetch Onion urls
|
# To fetch Onion urls
|
||||||
PySocks
|
PySocks
|
||||||
|
|
||||||
|
# decompress files
|
||||||
|
sflock
|
||||||
|
|
||||||
#ASN lookup requirements
|
#ASN lookup requirements
|
||||||
#https://storage.googleapis.com/google-code-archive-downloads/v2/code.google.com/adns-python/adns-python-1.2.1.tar.gz
|
#https://storage.googleapis.com/google-code-archive-downloads/v2/code.google.com/adns-python/adns-python-1.2.1.tar.gz
|
||||||
https://github.com/trolldbois/python3-adns/archive/master.zip
|
https://github.com/trolldbois/python3-adns/archive/master.zip
|
||||||
|
|
|
@ -7,7 +7,7 @@ import json
|
||||||
import datetime
|
import datetime
|
||||||
import time
|
import time
|
||||||
import calendar
|
import calendar
|
||||||
from flask import Flask, render_template, jsonify, request
|
from flask import Flask, render_template, jsonify, request, Request
|
||||||
import flask
|
import flask
|
||||||
import importlib
|
import importlib
|
||||||
import os
|
import os
|
||||||
|
@ -28,7 +28,7 @@ cfg = Flask_config.cfg
|
||||||
|
|
||||||
Flask_config.app = Flask(__name__, static_url_path='/static/')
|
Flask_config.app = Flask(__name__, static_url_path='/static/')
|
||||||
app = Flask_config.app
|
app = Flask_config.app
|
||||||
#app.secret_key = Flask_config.secret_key
|
app.config['MAX_CONTENT_LENGTH'] = 900 * 1024 * 1024
|
||||||
|
|
||||||
# ========= HEADER GENERATION ========
|
# ========= HEADER GENERATION ========
|
||||||
|
|
||||||
|
|
|
@ -84,6 +84,12 @@ r_serv_metadata = redis.StrictRedis(
|
||||||
db=cfg.getint("ARDB_Metadata", "db"),
|
db=cfg.getint("ARDB_Metadata", "db"),
|
||||||
decode_responses=True)
|
decode_responses=True)
|
||||||
|
|
||||||
|
r_serv_db = redis.StrictRedis(
|
||||||
|
host=cfg.get("ARDB_DB", "host"),
|
||||||
|
port=cfg.getint("ARDB_DB", "port"),
|
||||||
|
db=cfg.getint("ARDB_DB", "db"),
|
||||||
|
decode_responses=True)
|
||||||
|
|
||||||
# VARIABLES #
|
# VARIABLES #
|
||||||
max_preview_char = int(cfg.get("Flask", "max_preview_char")) # Maximum number of character to display in the tooltip
|
max_preview_char = int(cfg.get("Flask", "max_preview_char")) # Maximum number of character to display in the tooltip
|
||||||
max_preview_modal = int(cfg.get("Flask", "max_preview_modal")) # Maximum number of character to display in the modal
|
max_preview_modal = int(cfg.get("Flask", "max_preview_modal")) # Maximum number of character to display in the modal
|
||||||
|
@ -91,3 +97,5 @@ max_preview_modal = int(cfg.get("Flask", "max_preview_modal")) # Maximum number
|
||||||
DiffMaxLineLength = int(cfg.get("Flask", "DiffMaxLineLength"))#Use to display the estimated percentage instead of a raw value
|
DiffMaxLineLength = int(cfg.get("Flask", "DiffMaxLineLength"))#Use to display the estimated percentage instead of a raw value
|
||||||
|
|
||||||
bootstrap_label = ['primary', 'success', 'danger', 'warning', 'info']
|
bootstrap_label = ['primary', 'success', 'danger', 'warning', 'info']
|
||||||
|
|
||||||
|
UPLOAD_FOLDER = os.path.join(os.environ['AIL_FLASK'], 'submitted')
|
||||||
|
|
|
@ -5,9 +5,7 @@
|
||||||
Flask functions and routes for the trending modules page
|
Flask functions and routes for the trending modules page
|
||||||
'''
|
'''
|
||||||
import redis
|
import redis
|
||||||
from flask import Flask, render_template, jsonify, request, Blueprint
|
from flask import Flask, render_template, jsonify, request, Blueprint, url_for
|
||||||
|
|
||||||
'''import random'''
|
|
||||||
|
|
||||||
import unicodedata
|
import unicodedata
|
||||||
import string
|
import string
|
||||||
|
@ -15,6 +13,7 @@ import subprocess
|
||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
import datetime
|
import datetime
|
||||||
|
import uuid
|
||||||
|
|
||||||
from pytaxonomies import Taxonomies
|
from pytaxonomies import Taxonomies
|
||||||
from pymispgalaxies import Galaxies, Clusters
|
from pymispgalaxies import Galaxies, Clusters
|
||||||
|
@ -25,21 +24,26 @@ import Flask_config
|
||||||
app = Flask_config.app
|
app = Flask_config.app
|
||||||
cfg = Flask_config.cfg
|
cfg = Flask_config.cfg
|
||||||
r_serv_tags = Flask_config.r_serv_tags
|
r_serv_tags = Flask_config.r_serv_tags
|
||||||
|
r_serv_metadata = Flask_config.r_serv_metadata
|
||||||
|
r_serv_db = Flask_config.r_serv_db
|
||||||
r_serv_log_submit = Flask_config.r_serv_log_submit
|
r_serv_log_submit = Flask_config.r_serv_log_submit
|
||||||
|
|
||||||
PasteSubmit = Blueprint('PasteSubmit', __name__, template_folder='templates')
|
PasteSubmit = Blueprint('PasteSubmit', __name__, template_folder='templates')
|
||||||
|
|
||||||
valid_filename_chars = "-_ %s%s" % (string.ascii_letters, string.digits)
|
valid_filename_chars = "-_ %s%s" % (string.ascii_letters, string.digits)
|
||||||
|
|
||||||
ALLOWED_EXTENSIONS = set(['txt', 'zip', 'gzip'])
|
ALLOWED_EXTENSIONS = set(['txt', 'zip', 'gz', 'tar.gz'])
|
||||||
|
UPLOAD_FOLDER = Flask_config.UPLOAD_FOLDER
|
||||||
|
|
||||||
# ============ FUNCTIONS ============
|
# ============ FUNCTIONS ============
|
||||||
def one():
|
def one():
|
||||||
return 1
|
return 1
|
||||||
|
|
||||||
def allowed_file(filename):
|
def allowed_file(filename):
|
||||||
return '.' in filename and \
|
if not '.' in filename:
|
||||||
filename.rsplit('.', 1)[1].lower() in ALLOWED_EXTENSIONS
|
return True
|
||||||
|
else:
|
||||||
|
return filename.rsplit('.', 1)[1].lower() in ALLOWED_EXTENSIONS
|
||||||
|
|
||||||
def clean_filename(filename, whitelist=valid_filename_chars, replace=' '):
|
def clean_filename(filename, whitelist=valid_filename_chars, replace=' '):
|
||||||
# replace characters
|
# replace characters
|
||||||
|
@ -52,23 +56,28 @@ def clean_filename(filename, whitelist=valid_filename_chars, replace=' '):
|
||||||
# keep only whitelisted chars
|
# keep only whitelisted chars
|
||||||
return ''.join(c for c in cleaned_filename if c in whitelist)
|
return ''.join(c for c in cleaned_filename if c in whitelist)
|
||||||
|
|
||||||
'''@app.before_request
|
def launch_submit(ltags, ltagsgalaxies, paste_content, UUID, password, isfile = False):
|
||||||
def csrf_protect():
|
|
||||||
if request.method == "POST":
|
|
||||||
token = session.pop('_csrf_token', None)
|
|
||||||
if not token or token != request.form.get('_csrf_token'):
|
|
||||||
abort(400)
|
|
||||||
|
|
||||||
def generate_csrf_token():
|
print(UUID)
|
||||||
if '_csrf_token' not in session:
|
|
||||||
session['_csrf_token'] = some_random_string()
|
|
||||||
return session['_csrf_token']
|
|
||||||
|
|
||||||
app.jinja_env.globals['csrf_token'] = generate_csrf_token
|
# save temp value on disk
|
||||||
|
r_serv_db.set(UUID + ':ltags', ltags)
|
||||||
|
r_serv_db.set(UUID + ':ltagsgalaxies', ltagsgalaxies)
|
||||||
|
r_serv_db.set(UUID + ':paste_content', paste_content)
|
||||||
|
r_serv_db.set(UUID + ':password', password)
|
||||||
|
r_serv_db.set(UUID + ':isfile', isfile)
|
||||||
|
|
||||||
def some_random_string():
|
r_serv_log_submit.set(UUID + ':end', 0)
|
||||||
N = 15
|
r_serv_log_submit.set(UUID + ':processing', 0)
|
||||||
return ''.join(random.SystemRandom().choice(string.ascii_uppercase + string.digits) for _ in range(N))'''
|
r_serv_log_submit.set(UUID + ':nb_total', -1)
|
||||||
|
r_serv_log_submit.set(UUID + ':nb_end', 0)
|
||||||
|
r_serv_log_submit.set(UUID + ':nb_sucess', 0)
|
||||||
|
r_serv_log_submit.set(UUID + ':error', 'error:')
|
||||||
|
r_serv_log_submit.sadd(UUID + ':paste_submit_link', '')
|
||||||
|
|
||||||
|
|
||||||
|
# save UUID on disk
|
||||||
|
r_serv_db.sadd('submitted:uuid', UUID)
|
||||||
|
|
||||||
|
|
||||||
def addTagsVerification(tags, tagsgalaxies):
|
def addTagsVerification(tags, tagsgalaxies):
|
||||||
|
@ -124,7 +133,9 @@ def PasteSubmit_page():
|
||||||
@PasteSubmit.route("/PasteSubmit/submit", methods=['POST'])
|
@PasteSubmit.route("/PasteSubmit/submit", methods=['POST'])
|
||||||
def submit():
|
def submit():
|
||||||
|
|
||||||
paste_name = request.form['paste_name']
|
#paste_name = request.form['paste_name']
|
||||||
|
|
||||||
|
password = request.form['password']
|
||||||
ltags = request.form['tags_taxonomies']
|
ltags = request.form['tags_taxonomies']
|
||||||
ltagsgalaxies = request.form['tags_galaxies']
|
ltagsgalaxies = request.form['tags_galaxies']
|
||||||
paste_content = request.form['paste_content']
|
paste_content = request.form['paste_content']
|
||||||
|
@ -133,68 +144,107 @@ def submit():
|
||||||
if not addTagsVerification(ltags, ltagsgalaxies):
|
if not addTagsVerification(ltags, ltagsgalaxies):
|
||||||
return 'INVALID TAGS'
|
return 'INVALID TAGS'
|
||||||
|
|
||||||
if 'file' not in request.files:
|
# add submitted tags
|
||||||
|
if(ltags != ''):
|
||||||
|
ltags = ltags + ',submitted'
|
||||||
|
else:
|
||||||
|
ltags ='submitted'
|
||||||
|
|
||||||
|
print(request.files)
|
||||||
|
|
||||||
|
if 'file' in request.files:
|
||||||
|
print(request.files)
|
||||||
|
|
||||||
file = request.files['file']
|
file = request.files['file']
|
||||||
|
if file:
|
||||||
|
|
||||||
if file.filename == '':
|
if file and allowed_file(file.filename):
|
||||||
|
|
||||||
if paste_content != '':
|
# get UUID
|
||||||
if sys.getsizeof(paste_content) < 900000:
|
UUID = str(uuid.uuid4())
|
||||||
|
|
||||||
to_launch = os.environ['AIL_BIN'] + 'submit_paste.py'
|
'''if paste_name:
|
||||||
# get id
|
# clean file name
|
||||||
id = str(r_serv_tags.get('submit_id'))
|
UUID = clean_filename(paste_name)'''
|
||||||
|
|
||||||
if paste_name:
|
|
||||||
# clean file name
|
|
||||||
id = clean_filename(paste_name)
|
|
||||||
|
|
||||||
# create logs
|
|
||||||
r_serv_log_submit.set(id + ':end', 0)
|
|
||||||
r_serv_log_submit.set(id + ':nb_total', 1)
|
|
||||||
r_serv_log_submit.set(id + ':nb_end', 0)
|
|
||||||
r_serv_log_submit.set(id + ':error', 'error:')
|
|
||||||
|
|
||||||
#incr id
|
|
||||||
r_serv_tags.incr('submit_id')
|
|
||||||
|
|
||||||
# add submitted tags
|
|
||||||
if(ltags != ''):
|
|
||||||
ltags = ltags + ',submitted'
|
|
||||||
else:
|
|
||||||
ltags ='submitted'
|
|
||||||
|
|
||||||
# launch process
|
|
||||||
process = subprocess.Popen(["python", to_launch, ltags, ltagsgalaxies, paste_content, paste_name, id],
|
|
||||||
stdout=subprocess.PIPE)
|
|
||||||
|
|
||||||
return render_template("submiting.html",
|
|
||||||
id = id)
|
|
||||||
|
|
||||||
|
if not '.' in file.filename:
|
||||||
|
full_path = os.path.join(UPLOAD_FOLDER, UUID)
|
||||||
else:
|
else:
|
||||||
return 'size error'
|
if file.filename[-6:] == 'tar.gz':
|
||||||
|
file_type = 'tar.gz'
|
||||||
|
else:
|
||||||
|
file_type = file.filename.rsplit('.', 1)[1]
|
||||||
|
name = UUID + '.' + file_type
|
||||||
|
full_path = os.path.join(UPLOAD_FOLDER, name)
|
||||||
|
|
||||||
return 'submit'
|
#Flask verify the file size
|
||||||
|
file.save(full_path)
|
||||||
|
|
||||||
if file and allowed_file(file.filename):
|
paste_content = full_path
|
||||||
print(file.read())
|
|
||||||
|
|
||||||
return 'error'
|
launch_submit(ltags, ltagsgalaxies, paste_content, UUID, password ,True)
|
||||||
|
|
||||||
|
return render_template("submiting.html",
|
||||||
|
UUID = UUID)
|
||||||
|
|
||||||
|
else:
|
||||||
|
print('wrong file type')
|
||||||
|
|
||||||
|
|
||||||
|
if paste_content != '':
|
||||||
|
if sys.getsizeof(paste_content) < 900000:
|
||||||
|
|
||||||
|
# get id
|
||||||
|
UUID = str(uuid.uuid4())
|
||||||
|
print(UUID)
|
||||||
|
|
||||||
|
#if paste_name:
|
||||||
|
# clean file name
|
||||||
|
#id = clean_filename(paste_name)
|
||||||
|
|
||||||
|
launch_submit(ltags, ltagsgalaxies, paste_content, UUID, password)
|
||||||
|
|
||||||
|
return render_template("submiting.html",
|
||||||
|
UUID = UUID)
|
||||||
|
|
||||||
|
else:
|
||||||
|
return 'size error'
|
||||||
|
|
||||||
|
return 'submit'
|
||||||
|
|
||||||
|
|
||||||
|
return PasteSubmit_page()
|
||||||
|
|
||||||
@PasteSubmit.route("/PasteSubmit/submit_status", methods=['GET'])
|
@PasteSubmit.route("/PasteSubmit/submit_status", methods=['GET'])
|
||||||
def submit_status():
|
def submit_status():
|
||||||
id = request.args.get('id')
|
UUID = request.args.get('UUID')
|
||||||
|
|
||||||
if id:
|
if UUID:
|
||||||
end = r_serv_log_submit.get(id + ':end')
|
end = r_serv_log_submit.get(UUID + ':end')
|
||||||
nb_total = r_serv_log_submit.get(id + ':nb_total')
|
nb_total = r_serv_log_submit.get(UUID + ':nb_total')
|
||||||
nb_end = r_serv_log_submit.get(id + ':nb_end')
|
nb_end = r_serv_log_submit.get(UUID + ':nb_end')
|
||||||
error = r_serv_log_submit.get(id + ':error')
|
error = r_serv_log_submit.get(UUID + ':error')
|
||||||
if (end != None) and (nb_total != None) and (nb_end != None) and (error != None):
|
processing = r_serv_log_submit.get(UUID + ':processing')
|
||||||
|
nb_sucess = r_serv_log_submit.get(UUID + ':nb_sucess')
|
||||||
|
paste_submit_link = list(r_serv_log_submit.smembers(UUID + ':paste_submit_link'))
|
||||||
|
|
||||||
in_progress = nb_end + ' / ' + nb_total
|
if (end != None) and (nb_total != None) and (nb_end != None) and (error != None) and (processing != None) and (paste_submit_link != None):
|
||||||
prog = int(int(nb_end) * 100 / int(nb_total))
|
|
||||||
|
link = ''
|
||||||
|
if paste_submit_link:
|
||||||
|
for paste in paste_submit_link:
|
||||||
|
url = url_for('showsavedpastes.showsavedpaste') + '?paste=' + paste
|
||||||
|
link += '<a target="_blank" href="' + url + '" class="list-group-item">' + paste +'</a>'
|
||||||
|
|
||||||
|
if nb_total == '-1':
|
||||||
|
in_progress = nb_sucess + ' / '
|
||||||
|
else:
|
||||||
|
in_progress = nb_sucess + ' / ' + nb_total
|
||||||
|
|
||||||
|
if int(nb_total) != 0:
|
||||||
|
prog = int(int(nb_end) * 100 / int(nb_total))
|
||||||
|
else:
|
||||||
|
prog = 0
|
||||||
|
|
||||||
if error == 'error:':
|
if error == 'error:':
|
||||||
isError = False
|
isError = False
|
||||||
|
@ -206,15 +256,29 @@ def submit_status():
|
||||||
else:
|
else:
|
||||||
end = True
|
end = True
|
||||||
|
|
||||||
|
if processing == '0':
|
||||||
|
processing = False
|
||||||
|
else:
|
||||||
|
processing = True
|
||||||
|
|
||||||
return jsonify(end=end,
|
return jsonify(end=end,
|
||||||
in_progress=in_progress,
|
in_progress=in_progress,
|
||||||
prog=prog,
|
prog=prog,
|
||||||
|
link=link,
|
||||||
|
processing=processing,
|
||||||
isError=isError,
|
isError=isError,
|
||||||
error=error)
|
error=error)
|
||||||
else:
|
else:
|
||||||
|
# FIXME TODO
|
||||||
|
print(end)
|
||||||
|
print(nb_total)
|
||||||
|
print(nb_end)
|
||||||
|
print(error)
|
||||||
|
print(processing)
|
||||||
|
print(nb_sucess)
|
||||||
return 'to do'
|
return 'to do'
|
||||||
else:
|
else:
|
||||||
return 'INVALID ID'
|
return 'INVALID UUID'
|
||||||
|
|
||||||
# ========= REGISTRATION =========
|
# ========= REGISTRATION =========
|
||||||
app.register_blueprint(PasteSubmit)
|
app.register_blueprint(PasteSubmit)
|
||||||
|
|
|
@ -36,22 +36,18 @@
|
||||||
<input type="hidden" id="tags_galaxies" name="tags_galaxies" value="test">
|
<input type="hidden" id="tags_galaxies" name="tags_galaxies" value="test">
|
||||||
|
|
||||||
<div class="panel panel-primary pull-left" style="width: 40%;">
|
<div class="panel panel-primary pull-left" style="width: 40%;">
|
||||||
<div class="panel-heading">paste info
|
<div class="panel-heading">Files submission
|
||||||
</div>
|
</div>
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
|
|
||||||
<div class="form-group row">
|
<div class="form-group">
|
||||||
<label class="col-sm-2 col-form-label">ID: 34</label>
|
<label for="file">Submit a file</label>
|
||||||
|
<input type="file" class="form-control-file" id="file" name="file">
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="paste_name">Name</label>
|
<label for="paste_name">Archive Password</label>
|
||||||
<input type="text" class="form-control" id="paste_name" name="paste_name" placeholder="Optionnal">
|
<input type="password" class="form-control" id="password" name="password" placeholder="Optionnal">
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="form-group">
|
|
||||||
<label for="file_submit">Or submit a file</label>
|
|
||||||
<input type="file" class="form-control-file" id="file_submit">
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -129,6 +125,9 @@
|
||||||
var ltagsgalaxies
|
var ltagsgalaxies
|
||||||
$(document).ready(function(){
|
$(document).ready(function(){
|
||||||
|
|
||||||
|
activePage = "page-PasteSubmit"
|
||||||
|
$("#"+activePage).addClass("active");
|
||||||
|
|
||||||
$.getJSON('/Tags/get_all_tags_taxonomies',
|
$.getJSON('/Tags/get_all_tags_taxonomies',
|
||||||
function(data) {
|
function(data) {
|
||||||
|
|
||||||
|
@ -148,9 +147,6 @@
|
||||||
name: 'ltagsgalaxies'
|
name: 'ltagsgalaxies'
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
activePage = "page-PasteSubmit"
|
|
||||||
$("#"+activePage).addClass("active");
|
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
|
@ -22,99 +22,111 @@
|
||||||
<script src="/static//js/bootstrap.min.js"></script>
|
<script src="/static//js/bootstrap.min.js"></script>
|
||||||
<script src="{{ url_for('static', filename='js/tags.js') }}"></script>
|
<script src="{{ url_for('static', filename='js/tags.js') }}"></script>
|
||||||
|
|
||||||
|
<style>
|
||||||
|
.glyphicon-refresh-animate {
|
||||||
|
-animation: spin .7s infinite linear;
|
||||||
|
-webkit-animation: spin2 .7s infinite linear;
|
||||||
|
}
|
||||||
|
|
||||||
|
@-webkit-keyframes spin2 {
|
||||||
|
from { -webkit-transform: rotate(0deg);}
|
||||||
|
to { -webkit-transform: rotate(360deg);}
|
||||||
|
}
|
||||||
|
|
||||||
|
@keyframes spin {
|
||||||
|
from { transform: scale(1) rotate(0deg);}
|
||||||
|
to { transform: scale(1) rotate(360deg);}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
||||||
{% include 'navbar.html' %}
|
{% include 'navbar.html' %}
|
||||||
|
|
||||||
<div id="page-wrapper">
|
<div id="page-wrapper">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<!-- /.col-lg-12 -->
|
<!-- /.col-lg-12 -->
|
||||||
|
|
||||||
<form action="/PasteSubmit/submit" id="pasteSubmitForm" method="post" onsubmit="submitPaste()">
|
<form action="/PasteSubmit/submit" id="pasteSubmitForm" method="post" enctype=multipart/form-data onsubmit="submitPaste()">
|
||||||
|
|
||||||
<input type="hidden" id="tags_taxonomies" name="tags_taxonomies" value="test">
|
<input type="hidden" id="tags_taxonomies" name="tags_taxonomies" value="test">
|
||||||
<input type="hidden" id="tags_galaxies" name="tags_galaxies" value="test">
|
<input type="hidden" id="tags_galaxies" name="tags_galaxies" value="test">
|
||||||
|
|
||||||
<div class="panel panel-primary pull-left" style="width: 40%;">
|
<div class="panel panel-primary pull-left" style="width: 40%;">
|
||||||
<div class="panel-heading">paste info
|
<div class="panel-heading">Files submission
|
||||||
</div>
|
</div>
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
|
|
||||||
<div class="form-group row">
|
<div class="form-group">
|
||||||
<label class="col-sm-2 col-form-label">ID: 34</label>
|
<label for="file">Submit a file</label>
|
||||||
</div>
|
<input type="file" class="form-control-file" id="file" name="file">
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="paste_name">Name</label>
|
<label for="paste_name">Archive Password</label>
|
||||||
<input type="text" class="form-control" id="paste_name" name="paste_name" placeholder="Optionnal">
|
<input type="password" class="form-control" id="password" name="password" placeholder="Optionnal">
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="form-group">
|
<div class="panel panel-info pull-right" style="width: auto;">
|
||||||
<label for="file_submit">Or submit a file</label>
|
<div class="panel-heading"> Tags :
|
||||||
<input type="file" class="form-control-file" id="file_submit">
|
<ul class="list-group">
|
||||||
</div>
|
<li class="list-group-item">
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="panel panel-info pull-right" style="width: auto;">
|
<div class="form-group input-group" >
|
||||||
<div class="panel-heading"> Tags :
|
<input id="ltags" style="width:450%;" type="text">
|
||||||
<ul class="list-group">
|
</div>
|
||||||
<li class="list-group-item">
|
|
||||||
|
|
||||||
<div class="form-group input-group" >
|
<div class="btn-group btn-block">
|
||||||
<input id="ltags" style="width:450%;" type="text">
|
<button type="button" class="btn btn-primary dropdown-toggle btn-block" data-toggle="dropdown">Taxonomie Selection
|
||||||
</div>
|
<i class="fa fa-chevron-down"></i>
|
||||||
|
</button>
|
||||||
<div class="btn-group btn-block">
|
<ul class="dropdown-menu scrollable-menu" role="menu">
|
||||||
<button type="button" class="btn btn-primary dropdown-toggle btn-block" data-toggle="dropdown">Taxonomie Selection
|
<li><a href="#" id="all-tags-taxonomies">All Tags <i class="fa fa-tags"></i></a></li>
|
||||||
<i class="fa fa-chevron-down"></i>
|
<li role="separator" class="divider"></li>
|
||||||
</button>
|
{% for taxo in active_taxonomies %}
|
||||||
<ul class="dropdown-menu scrollable-menu" role="menu">
|
<li><a href="#" id="{{ taxo }}-id{{ loop.index0 }}">{{ taxo }}</a></li>
|
||||||
<li><a href="#" id="all-tags-taxonomies">All Tags <i class="fa fa-tags"></i></a></li>
|
{% endfor %}
|
||||||
<li role="separator" class="divider"></li>
|
|
||||||
{% for taxo in active_taxonomies %}
|
|
||||||
<li><a href="#" id="{{ taxo }}-id{{ loop.index0 }}">{{ taxo }}</a></li>
|
|
||||||
{% endfor %}
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</li>
|
|
||||||
<li class="list-group-item">
|
|
||||||
|
|
||||||
<div class="form-group input-group" >
|
|
||||||
<input id="ltagsgalaxies" style="width:450%;" type="text">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="btn-group btn-block">
|
|
||||||
<button type="button" class="btn btn-primary dropdown-toggle btn-block" data-toggle="dropdown">Galaxy Selection
|
|
||||||
<i class="fa fa-chevron-down"></i>
|
|
||||||
</button>
|
|
||||||
<ul class="dropdown-menu scrollable-menu" role="menu">
|
|
||||||
<li><a href="#" id="all-tags-galaxies">All Tags <i class="fa fa-tags"></i></a></li>
|
|
||||||
<li role="separator" class="divider"></li>
|
|
||||||
{% for galaxy in active_galaxies %}
|
|
||||||
<li><a href="#" id="{{ galaxy }}-idgalax{{ loop.index0 }}">{{ galaxy }}</a></li>
|
|
||||||
{% endfor %}
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</li>
|
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div>
|
</li>
|
||||||
|
<li class="list-group-item">
|
||||||
|
|
||||||
<div class="form-group">
|
<div class="form-group input-group" >
|
||||||
<textarea class="form-control" id="paste_content" name="paste_content" rows="25"></textarea>
|
<input id="ltagsgalaxies" style="width:450%;" type="text">
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="form-group">
|
|
||||||
<button class="btn btn-primary " name="submit" type="submit">Submit this paste</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="btn-group btn-block">
|
||||||
|
<button type="button" class="btn btn-primary dropdown-toggle btn-block" data-toggle="dropdown">Galaxy Selection
|
||||||
|
<i class="fa fa-chevron-down"></i>
|
||||||
|
</button>
|
||||||
|
<ul class="dropdown-menu scrollable-menu" role="menu">
|
||||||
|
<li><a href="#" id="all-tags-galaxies">All Tags <i class="fa fa-tags"></i></a></li>
|
||||||
|
<li role="separator" class="divider"></li>
|
||||||
|
{% for galaxy in active_galaxies %}
|
||||||
|
<li><a href="#" id="{{ galaxy }}-idgalax{{ loop.index0 }}">{{ galaxy }}</a></li>
|
||||||
|
{% endfor %}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<textarea class="form-control" id="paste_content" name="paste_content" rows="25"></textarea>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<button class="btn btn-primary " name="submit" type="submit">Submit this paste</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
</form>
|
</form>
|
||||||
|
|
||||||
<!-- /.row -->
|
<!-- /.row -->
|
||||||
|
@ -136,16 +148,21 @@
|
||||||
<div class="modal-body">
|
<div class="modal-body">
|
||||||
<br></br>
|
<br></br>
|
||||||
|
|
||||||
<div class="progress">
|
<div class="progress hidden" id="pr">
|
||||||
<div class="progress-bar progress-bar-striped active" role="progressbar"
|
<div class="progress-bar progress-bar-striped active" role="progressbar"
|
||||||
aria-valuenow="40" aria-valuemin="0" aria-valuemax="100" style="width:40%" id="progress-bar">
|
aria-valuenow="0" aria-valuemin="0" aria-valuemax="100" style="width:0%" id="progress-bar">
|
||||||
40%
|
0%
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<span class="btn btn-info" id="files_submitted_btn">
|
<span class="btn btn-info hidden" id="files_submitted_btn">
|
||||||
Files Submitted <span class="badge badge-light" id="files_submitted">1 / 1</span>
|
Files Submitted <span class="badge badge-light" id="files_submitted">1 / 1</span>
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
<button class="btn btn-lg btn-warning" style="margin: auto;" id="loading_button">
|
||||||
|
<span class="glyphicon glyphicon-refresh glyphicon-refresh-animate">
|
||||||
|
</span> Loading . . .
|
||||||
|
</button>
|
||||||
|
|
||||||
<br></br>
|
<br></br>
|
||||||
|
|
||||||
<div class="panel panel-danger hidden" id="panel_error">
|
<div class="panel panel-danger hidden" id="panel_error">
|
||||||
|
@ -155,6 +172,10 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="list-group hidden" id="submit_pastes">
|
||||||
|
<li class="list-group-item active">Submitted pastes</li>
|
||||||
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="modal-footer">
|
<div class="modal-footer">
|
||||||
|
@ -261,15 +282,22 @@ function submitPaste(){
|
||||||
$(".progress-bar").css("width", i + "%").text(i + " %");
|
$(".progress-bar").css("width", i + "%").text(i + " %");
|
||||||
function makeProgress(){
|
function makeProgress(){
|
||||||
|
|
||||||
$.getJSON('/PasteSubmit/submit_status?id={{ id }}',
|
$.getJSON('/PasteSubmit/submit_status?UUID={{ UUID }}',
|
||||||
function(data) {
|
function(data) {
|
||||||
|
|
||||||
var end = data.end;
|
var end = data.end;
|
||||||
var prog = data.prog;
|
var prog = data.prog;
|
||||||
var in_progress = data.in_progress;
|
var in_progress = data.in_progress;
|
||||||
|
var processing = data.processing;
|
||||||
var isError = data.isError;
|
var isError = data.isError;
|
||||||
var error = data.error;
|
var error = data.error;
|
||||||
|
|
||||||
|
if(processing){
|
||||||
|
$("#loading_button").addClass('hidden');
|
||||||
|
$("#pr").removeClass('hidden');
|
||||||
|
$("#files_submitted_btn").removeClass('hidden');
|
||||||
|
}
|
||||||
|
|
||||||
if(i < 100){
|
if(i < 100){
|
||||||
$(".progress-bar").css("width", prog + "%").text(prog + " %");
|
$(".progress-bar").css("width", prog + "%").text(prog + " %");
|
||||||
}
|
}
|
||||||
|
@ -291,17 +319,30 @@ function submitPaste(){
|
||||||
setTimeout("makeProgress()", 100);
|
setTimeout("makeProgress()", 100);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
//error handler
|
|
||||||
document.getElementById('files_submitted').innerHTML = in_progress;
|
document.getElementById('files_submitted').innerHTML = in_progress;
|
||||||
|
$("#progress-bar").removeClass('active');
|
||||||
|
$("#submit_result").removeClass('hidden');
|
||||||
|
|
||||||
if(isError){
|
if(isError){
|
||||||
document.getElementById('error_message').innerHTML = error;
|
document.getElementById('error_message').innerHTML = error;
|
||||||
$("#panel_error").removeClass('hidden');
|
$("#panel_error").removeClass('hidden');
|
||||||
$("#error_submit_button").removeClass('hidden');
|
$("#error_submit_button").removeClass('hidden');
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
$("#success_submit_button").removeClass('hidden');
|
$("#success_submit_button").removeClass('hidden');
|
||||||
$("#submit_result").removeClass('hidden');
|
|
||||||
$("#progress-bar").removeClass('active');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(in_progress == '0 / '){
|
||||||
|
document.getElementById('files_submitted').innerHTML = '0 / 0'
|
||||||
|
$(".progress-bar").css("width", "100%").text("100 %");
|
||||||
|
$("#progress-bar").addClass('progress-bar-danger')
|
||||||
|
} else {
|
||||||
|
var link = data.link;
|
||||||
|
$("#submit_pastes").append(link);
|
||||||
|
$("#submit_pastes").removeClass('hidden');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -93,7 +93,6 @@
|
||||||
window.location.replace("{{ url_for('Tags.get_tagged_paste') }}?ltags=" + data);
|
window.location.replace("{{ url_for('Tags.get_tagged_paste') }}?ltags=" + data);
|
||||||
}
|
}
|
||||||
function emptyTags() {
|
function emptyTags() {
|
||||||
console.log('b');
|
|
||||||
ltags.clear();
|
ltags.clear();
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
Loading…
Reference in a new issue