Update main.py
Browse files
main.py
CHANGED
|
@@ -1,5 +1,6 @@
|
|
| 1 |
from flask import Flask, request, jsonify
|
| 2 |
-
import
|
|
|
|
| 3 |
|
| 4 |
app = Flask(__name__)
|
| 5 |
|
|
@@ -7,6 +8,15 @@ app = Flask(__name__)
|
|
| 7 |
users = {}
|
| 8 |
transfers = {}
|
| 9 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 10 |
@app.route('/register', methods=['POST'])
|
| 11 |
def register():
|
| 12 |
data = request.json
|
|
@@ -29,7 +39,8 @@ def create_transfer():
|
|
| 29 |
if not filename or not ip or not port:
|
| 30 |
return jsonify({'error': 'Отсутствуют необходимые параметры'}), 400
|
| 31 |
|
| 32 |
-
|
|
|
|
| 33 |
transfers[transfer_id] = {
|
| 34 |
'filename': filename,
|
| 35 |
'ip': ip,
|
|
@@ -37,11 +48,11 @@ def create_transfer():
|
|
| 37 |
'filesize': filesize,
|
| 38 |
'downloaded': False
|
| 39 |
}
|
| 40 |
-
# Формируем ссылку для
|
| 41 |
-
download_link = request.host_url + '
|
| 42 |
return jsonify({'download_link': download_link})
|
| 43 |
|
| 44 |
-
@app.route('/
|
| 45 |
def get_transfer(transfer_id):
|
| 46 |
transfer = transfers.get(transfer_id)
|
| 47 |
if not transfer:
|
|
@@ -50,4 +61,4 @@ def get_transfer(transfer_id):
|
|
| 50 |
|
| 51 |
if __name__ == '__main__':
|
| 52 |
# Запускаем сервер на всех интерфейсах на порту 5000
|
| 53 |
-
app.run(host='0.0.0.0', port=
|
|
|
|
| 1 |
from flask import Flask, request, jsonify
|
| 2 |
+
import random
|
| 3 |
+
import string
|
| 4 |
|
| 5 |
app = Flask(__name__)
|
| 6 |
|
|
|
|
| 8 |
users = {}
|
| 9 |
transfers = {}
|
| 10 |
|
| 11 |
+
def generate_short_id(length=8):
|
| 12 |
+
"""
|
| 13 |
+
Генерирует короткий уникальный идентификатор для передачи файла.
|
| 14 |
+
"""
|
| 15 |
+
while True:
|
| 16 |
+
token = ''.join(random.choices(string.ascii_letters + string.digits, k=length))
|
| 17 |
+
if token not in transfers:
|
| 18 |
+
return token
|
| 19 |
+
|
| 20 |
@app.route('/register', methods=['POST'])
|
| 21 |
def register():
|
| 22 |
data = request.json
|
|
|
|
| 39 |
if not filename or not ip or not port:
|
| 40 |
return jsonify({'error': 'Отсутствуют необходимые параметры'}), 400
|
| 41 |
|
| 42 |
+
# Используем короткий идентификатор для передачи файла
|
| 43 |
+
transfer_id = generate_short_id(8)
|
| 44 |
transfers[transfer_id] = {
|
| 45 |
'filename': filename,
|
| 46 |
'ip': ip,
|
|
|
|
| 48 |
'filesize': filesize,
|
| 49 |
'downloaded': False
|
| 50 |
}
|
| 51 |
+
# Формируем короткую ссылку для скачивания (маршрут изменён на /d/)
|
| 52 |
+
download_link = request.host_url + 'd/' + transfer_id
|
| 53 |
return jsonify({'download_link': download_link})
|
| 54 |
|
| 55 |
+
@app.route('/d/<transfer_id>', methods=['GET'])
|
| 56 |
def get_transfer(transfer_id):
|
| 57 |
transfer = transfers.get(transfer_id)
|
| 58 |
if not transfer:
|
|
|
|
| 61 |
|
| 62 |
if __name__ == '__main__':
|
| 63 |
# Запускаем сервер на всех интерфейсах на порту 5000
|
| 64 |
+
app.run(host='0.0.0.0', port=5000)
|