mirror of
https://github.com/SlavikMIPT/tgcloud.git
synced 2025-02-12 11:12:09 +00:00
Working prototype
This commit is contained in:
parent
dc917f6e89
commit
41a6a0c3c5
5 changed files with 228 additions and 178 deletions
3
.gitmodules
vendored
3
.gitmodules
vendored
|
@ -4,3 +4,6 @@
|
|||
[submodule "filebrowser"]
|
||||
path = filebrowser
|
||||
url = https://github.com/SlavikMIPT/filebrowser
|
||||
[submodule "dedupfs"]
|
||||
path = dedupfs
|
||||
url = https://github.com/xolox/dedupfs.git
|
||||
|
|
1
dedupfs
Submodule
1
dedupfs
Submodule
|
@ -0,0 +1 @@
|
|||
Subproject commit 78f0814a6f5e43915e0512273d8b26e87b3ae353
|
|
@ -3,205 +3,163 @@
|
|||
|
||||
from __future__ import print_function
|
||||
from __future__ import unicode_literals
|
||||
import mimetypes
|
||||
import os
|
||||
import re
|
||||
import shutil
|
||||
import socket
|
||||
import time
|
||||
|
||||
# from PIL import Image
|
||||
# from moviepy.editor import *
|
||||
# from moviepy.config import change_settings
|
||||
# change_settings({"FFMPEG_BINARY": "ffmpeg"})
|
||||
from rq import get_current_job
|
||||
from telethon.tl.types import DocumentAttributeAudio
|
||||
import tempfile
|
||||
from telethon.tl.types import DocumentAttributeFilename
|
||||
from telethon.tl.types import DocumentAttributeVideo
|
||||
|
||||
from file_telegram_rxtx.telegram_client_x import TelegramClientX
|
||||
# from hachoir.metadata import extractMetadata
|
||||
# from hachoir.parser import createParser
|
||||
from telegram_client_x import TelegramClientX
|
||||
from tg_access import *
|
||||
from io import StringIO
|
||||
import sys
|
||||
|
||||
path_home = './'#os.path.abspath('.')
|
||||
path_shared = './shared'
|
||||
|
||||
class Buffer: # {{{1
|
||||
|
||||
"""
|
||||
This class wraps cStringIO.StringIO with two additions: The __len__
|
||||
method and a dirty flag to determine whether a buffer has changed.
|
||||
"""
|
||||
|
||||
def __init__(self):
|
||||
self.buf = StringIO()
|
||||
self.dirty = False
|
||||
|
||||
def __getattr__(self, attr, default=None):
|
||||
""" Delegate to the StringIO object. """
|
||||
return getattr(self.buf, attr, default)
|
||||
|
||||
def __len__(self):
|
||||
""" Get the total size of the buffer in bytes. """
|
||||
position = self.buf.tell()
|
||||
self.buf.seek(0, os.SEEK_END)
|
||||
length = self.buf.tell()
|
||||
self.buf.seek(position, os.SEEK_SET)
|
||||
return length
|
||||
|
||||
def truncate(self, *args):
|
||||
""" Truncate the file at the current position and set the dirty flag. """
|
||||
if len(self) > self.buf.tell():
|
||||
self.dirty = True
|
||||
return self.buf.truncate(*args)
|
||||
|
||||
def write(self, *args):
|
||||
""" Write a string to the file and set the dirty flag. """
|
||||
self.dirty = True
|
||||
return self.buf.write(*args)
|
||||
|
||||
|
||||
path_home = './' # os.path.abspath('.')
|
||||
path_local = './local'
|
||||
last_call_time = time.time()
|
||||
last_call_time2 = time.time()
|
||||
client = TelegramClientX(entity, api_id, api_hash, update_workers=None, spawn_read_thread=True)
|
||||
client.set_upload_threads_count(24)
|
||||
client.set_download_threads_count(8)
|
||||
if not client.is_connected():
|
||||
client.connect()
|
||||
last_call_time_sent = time.time()
|
||||
last_call_time_receive = time.time()
|
||||
|
||||
if not client.is_user_authorized():
|
||||
client.send_code_request(phone)
|
||||
client.sign_in(phone, input('Enter code: '))
|
||||
|
||||
|
||||
# client.get_entity('AudioTubeBot')
|
||||
# client.get_entity('VideoTubeBot')
|
||||
# client.get_entity('SlavikMIPT')
|
||||
|
||||
def on_download_progress(recv_bytes, total_bytes):
|
||||
global last_call_time
|
||||
if time.time() - last_call_time < 0.5:
|
||||
global last_call_time_receive
|
||||
if time.time() - last_call_time_receive < 1:
|
||||
return 0
|
||||
last_call_time = time.time()
|
||||
job = get_current_job()
|
||||
job.meta['recv_bytes'] = recv_bytes
|
||||
job.meta['total_bytes'] = total_bytes
|
||||
job.save_meta()
|
||||
last_call_time_receive = time.time()
|
||||
# print(f"receive {recv_bytes}/{total_bytes}", end="\r")
|
||||
return 0
|
||||
|
||||
|
||||
def on_upload_progress(send_bytes, total_bytes):
|
||||
global last_call_time2
|
||||
if time.time() - last_call_time2 < 0.5:
|
||||
global last_call_time_sent
|
||||
if time.time() - last_call_time_sent < 1:
|
||||
return 0
|
||||
last_call_time2 = time.time()
|
||||
# print(send_bytes/total_bytes)
|
||||
job = get_current_job()
|
||||
job.meta['send_bytes'] = send_bytes
|
||||
job.meta['total_bytes'] = total_bytes
|
||||
job.save_meta()
|
||||
last_call_time_sent = time.time()
|
||||
# print(f"sent {send_bytes}/{total_bytes}", end="\r")
|
||||
return 0
|
||||
|
||||
|
||||
def download_big_file(chat_id: int, uid: str):
|
||||
tmpdir = str(uid)
|
||||
os.chdir(path_home)
|
||||
def download_block(chat_id, hash_uid):
|
||||
try:
|
||||
client.start()
|
||||
job = get_current_job()
|
||||
job.meta['handled_by'] = socket.gethostname()
|
||||
job.save_meta()
|
||||
print('Current job: %s' % (job.id))
|
||||
agent_entity = client.get_entity(int(chat_id))
|
||||
messages = client.get_messages(agent_entity, limit=20)
|
||||
os.chdir(path_home)
|
||||
if not client.is_connected():
|
||||
client.connect()
|
||||
if not client.is_user_authorized():
|
||||
client.send_code_request(phone)
|
||||
client.sign_in(phone, input('Enter code: '))
|
||||
chat_id = int(chat_id) if chat_id.isdigit() else str(chat_id)
|
||||
entity = client.get_entity(chat_id)
|
||||
messages = client.get_messages(entity, limit=20)
|
||||
for i in range(20):
|
||||
msg = messages[i]
|
||||
if msg.message == str(uid):
|
||||
try:
|
||||
is_voice = msg.media.document.attributes[0].voice
|
||||
except Exception:
|
||||
is_voice = False
|
||||
if is_voice:
|
||||
cleaned_filename = str(uid) + '.ogg'
|
||||
else:
|
||||
filename = msg.media.document.attributes[1].file_name
|
||||
file_ext = filename[len(filename) - 4:]
|
||||
file_title = filename[:-4]
|
||||
reg = re.compile(r'[^a-zA-Z0-9_]')
|
||||
cleaned_title = reg.sub('', file_title)
|
||||
cleaned_title = re.sub(r' ', '_', cleaned_title,flags=re.UNICODE)
|
||||
cleaned_filename = str(uid) + cleaned_title + file_ext
|
||||
print(cleaned_filename)
|
||||
tmpdir_shared = os.path.join(path_shared, str(uid))
|
||||
tmpdir = os.path.join(path_local,str(uid))
|
||||
output_file_path = os.path.join(tmpdir, cleaned_filename)
|
||||
output_file_path_shared = os.path.join(tmpdir_shared, cleaned_filename)
|
||||
os.chdir(path_home)
|
||||
if not os.path.exists(tmpdir):
|
||||
os.mkdir(tmpdir)
|
||||
client.download_media(msg, output_file_path, progress_callback=on_download_progress)
|
||||
while not os.path.exists(output_file_path_shared):
|
||||
time.sleep(0.1)
|
||||
return output_file_path_shared
|
||||
return False
|
||||
except Exception:
|
||||
if os.path.exists(tmpdir):
|
||||
shutil.rmtree(tmpdir)
|
||||
raise Exception
|
||||
finally:
|
||||
client.disconnect()
|
||||
if msg.message == str(hash_uid):
|
||||
outbuf = tempfile.NamedTemporaryFile()
|
||||
client.download_media(msg, file=outbuf, progress_callback=on_upload_progress)
|
||||
|
||||
|
||||
def upload_file(chat_id: int, user_id: int, file_path: str, uid, title=None, performer=None, duration=None, t_thumb=0,
|
||||
is_gif=False):
|
||||
try:
|
||||
job = get_current_job()
|
||||
job.meta['handled_by'] = socket.gethostname()
|
||||
job.save_meta()
|
||||
mimetypes.add_type('audio/aac', '.aac')
|
||||
mimetypes.add_type('audio/ogg', '.ogg')
|
||||
filename = str(os.path.basename(file_path))
|
||||
print(filename)
|
||||
client.start()
|
||||
entity = client.get_entity(int(chat_id))
|
||||
if filename.endswith('.mp4'):
|
||||
clip = VideoFileClip(str(file_path))
|
||||
thumbnail_path = str(file_path)[:-4] + '.jpg'
|
||||
frame_path = str(file_path)[:-4] + 'f.jpg'
|
||||
if (not os.path.exists(thumbnail_path)) or (t_thumb != 0):
|
||||
t_thumb = float(t_thumb)
|
||||
t_thumb = t_thumb if clip.duration > t_thumb else clip.duration
|
||||
clip.save_frame(frame_path, t=t_thumb)
|
||||
else:
|
||||
os.rename(thumbnail_path, frame_path)
|
||||
im = Image.open(frame_path)
|
||||
thumb_w = clip.w
|
||||
thumb_h = clip.h
|
||||
if thumb_w >= thumb_h:
|
||||
thumb_w = 180
|
||||
thumb_h = int(thumb_h * thumb_w / clip.w)
|
||||
else:
|
||||
thumb_w = 102
|
||||
thumb_h = int(thumb_h * thumb_w / clip.w)
|
||||
im = im.resize((thumb_w, thumb_h))
|
||||
im.save(thumbnail_path, "JPEG")
|
||||
if t_thumb == 1.0:
|
||||
thumbnail_path = 'thumb_one.jpg'
|
||||
if is_gif:
|
||||
if int(clip.duration) > 120:
|
||||
raise Exception
|
||||
gif_filename = str(file_path)[:-4] + 'gif.mp4'
|
||||
file_path = gif_filename
|
||||
clip.write_videofile(str(file_path), audio=False)
|
||||
document_attribute = [DocumentAttributeVideo(duration=int(clip.duration), w=clip.w, h=clip.h,
|
||||
supports_streaming=True),
|
||||
DocumentAttributeFilename(filename)]
|
||||
|
||||
client.send_file(entity,
|
||||
str(file_path),
|
||||
caption=str(str(user_id) + ':' + str(uid) + ':' + str(int(clip.duration)) + ':v'),
|
||||
file_name=str(filename),
|
||||
allow_cache=False,
|
||||
part_size_kb=512,
|
||||
thumb=str(thumbnail_path),
|
||||
attributes=document_attribute,
|
||||
progress_callback=on_upload_progress)
|
||||
return 'SUCCESS'
|
||||
else:
|
||||
print(duration)
|
||||
if title is None:
|
||||
title = str(filename[:-4])
|
||||
if performer is None:
|
||||
performer = ''
|
||||
document_attribute = [DocumentAttributeAudio(int(duration),
|
||||
voice=False,
|
||||
title=str(title),
|
||||
performer=performer)]
|
||||
print(file_path, user_id, uid, duration)
|
||||
client.send_file(entity,
|
||||
str(file_path),
|
||||
caption=str(str(user_id) + ':' + str(uid) + ':' + str(duration)),
|
||||
file_name=str(filename),
|
||||
allow_cache=False,
|
||||
part_size_kb=512,
|
||||
attributes=document_attribute,
|
||||
progress_callback=on_upload_progress)
|
||||
|
||||
return 'SUCCESS'
|
||||
outbuf.seek(0)
|
||||
sys.stdout.buffer.write(outbuf.read())
|
||||
outbuf.close()
|
||||
return 0
|
||||
return -1
|
||||
except Exception as e:
|
||||
print(e)
|
||||
if os.path.exists(os.path.dirname(file_path)):
|
||||
shutil.rmtree(os.path.dirname(file_path))
|
||||
raise Exception
|
||||
# print(e)
|
||||
return -1
|
||||
finally:
|
||||
client.disconnect()
|
||||
if os.path.exists(os.path.dirname(file_path)):
|
||||
shutil.rmtree(os.path.dirname(file_path))
|
||||
|
||||
|
||||
def upload_block(bytesin, chat_id, hash_uid):
|
||||
try:
|
||||
filename = str(hash_uid)
|
||||
os.chdir(path_home)
|
||||
if not client.is_connected():
|
||||
client.connect()
|
||||
if not client.is_user_authorized():
|
||||
client.send_code_request(phone)
|
||||
client.sign_in(phone, input('Enter code: '))
|
||||
chat_id = int(chat_id) if chat_id.isdigit() else str(chat_id)
|
||||
entity = client.get_entity(chat_id)
|
||||
document_attribute = [DocumentAttributeFilename(filename)]
|
||||
client.send_file(entity,
|
||||
file=bytesin,
|
||||
caption=str(hash_uid),
|
||||
file_name=filename,
|
||||
allow_cache=False,
|
||||
part_size_kb=512,
|
||||
attributes=document_attribute,
|
||||
progress_callback=on_upload_progress)
|
||||
return 0
|
||||
except Exception as e:
|
||||
# print(e)
|
||||
return -1
|
||||
finally:
|
||||
client.disconnect()
|
||||
|
||||
|
||||
def main(argv):
|
||||
try:
|
||||
service = str(argv[1])
|
||||
if service == 'download':
|
||||
chat_id = str(argv[2])
|
||||
uid = str(argv[3])
|
||||
download_block(chat_id=chat_id, hash_uid=uid)
|
||||
return 0
|
||||
elif service == 'upload':
|
||||
data = sys.stdin.buffer.read()
|
||||
chat_id = str(argv[2])
|
||||
uid = str(argv[3])
|
||||
upload_block(bytesin=data, chat_id=chat_id, hash_uid=uid)
|
||||
return 0
|
||||
|
||||
except Exception as e:
|
||||
# print(e)
|
||||
return -1
|
||||
finally:
|
||||
client.disconnect()
|
||||
return 0
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
import sys
|
||||
|
||||
main(sys.argv[0:])
|
||||
|
||||
# upload_file(48012045,48012045,'test2.mp4','4801204577235b9d06db52e7209086ebbc8',is_gif=False)
|
||||
# download_big_file(507379365,'480120454934975b0fd66213758b53ab5f2ab3')
|
||||
# download_block(709766994,'012345678910abcdef')
|
||||
|
|
|
@ -82,8 +82,8 @@ class TelegramClientX(TelegramClient):
|
|||
self.result = None
|
||||
|
||||
def run(self):
|
||||
print('Thread %s started' % self.name)
|
||||
time.sleep(random.randrange(200, 2000, 10) * 0.001)
|
||||
# print('Thread %s started' % self.name)
|
||||
# time.sleep(random.randrange(200, 2000, 10) * 0.001)
|
||||
if not self.client.is_connected():
|
||||
self.client.connect()
|
||||
while True:
|
||||
|
@ -97,7 +97,7 @@ class TelegramClientX(TelegramClient):
|
|||
break
|
||||
self.q_request.task_done()
|
||||
self.client.disconnect()
|
||||
print('Thread {0} stopped result {1}'.format(self.name, self.result))
|
||||
# print('Thread {0} stopped result {1}'.format(self.name, self.result))
|
||||
return
|
||||
|
||||
def set_upload_threads_count(self, count: int):
|
||||
|
@ -268,8 +268,8 @@ class TelegramClientX(TelegramClient):
|
|||
self.result = None
|
||||
|
||||
def run(self):
|
||||
print('Thread %s started' % self.name)
|
||||
time.sleep(random.randrange(200, 2000, 10) * 0.001)
|
||||
# print('Thread %s started' % self.name)
|
||||
# time.sleep(random.randrange(200, 2000, 10) * 0.001)
|
||||
if not self.client.is_connected():
|
||||
self.client.connect()
|
||||
while True:
|
||||
|
@ -286,7 +286,7 @@ class TelegramClientX(TelegramClient):
|
|||
break
|
||||
self.q_request.task_done()
|
||||
self.client.disconnect()
|
||||
print('Thread {0} stopped result {1}'.format(self.name, self.result))
|
||||
# print('Thread {0} stopped result {1}'.format(self.name, self.result))
|
||||
return
|
||||
|
||||
def download_file(self,
|
||||
|
|
88
test.py
Normal file
88
test.py
Normal file
|
@ -0,0 +1,88 @@
|
|||
#!/usr/bin/python3
|
||||
import shelve
|
||||
import os
|
||||
from subprocess import Popen, PIPE
|
||||
|
||||
try:
|
||||
from StringIO import StringIO
|
||||
except ImportError:
|
||||
from io import StringIO
|
||||
|
||||
import subprocess
|
||||
import tempfile
|
||||
|
||||
class Buffer: # {{{1
|
||||
|
||||
"""
|
||||
This class wraps cStringIO.StringIO with two additions: The __len__
|
||||
method and a dirty flag to determine whether a buffer has changed.
|
||||
"""
|
||||
|
||||
def __init__(self):
|
||||
self.buf = StringIO()
|
||||
self.dirty = False
|
||||
|
||||
def __getattr__(self, attr, default=None):
|
||||
""" Delegate to the StringIO object. """
|
||||
return getattr(self.buf, attr, default)
|
||||
|
||||
def __len__(self):
|
||||
""" Get the total size of the buffer in bytes. """
|
||||
position = self.buf.tell()
|
||||
self.buf.seek(0, os.SEEK_END)
|
||||
length = self.buf.tell()
|
||||
self.buf.seek(position, os.SEEK_SET)
|
||||
return length
|
||||
|
||||
def truncate(self, *args):
|
||||
""" Truncate the file at the current position and set the dirty flag. """
|
||||
if len(self) > self.buf.tell():
|
||||
self.dirty = True
|
||||
return self.buf.truncate(*args)
|
||||
|
||||
def write(self, *args):
|
||||
""" Write a string to the file and set the dirty flag. """
|
||||
self.dirty = True
|
||||
return self.buf.write(*args)
|
||||
|
||||
|
||||
chat_id = 709766994
|
||||
user_id = 709766994
|
||||
|
||||
file_id = '012345678910abcdef'
|
||||
|
||||
|
||||
def get_block_from_telegram(chat_id, digest):
|
||||
# path = download_block(chat_id=chat_id, uid=digest)
|
||||
# buf = open('tempfile2', 'wb')
|
||||
buf = tempfile.TemporaryFile()
|
||||
process = Popen(["python3.6", "download_service.py", "download", str(chat_id), str(digest)], stdout=buf, bufsize=-1,shell=False)
|
||||
process.wait()
|
||||
# buf.close()
|
||||
# buf = open('tempfile2', 'rb')
|
||||
buf.seek(0)
|
||||
block = buf.read()
|
||||
buf.close()
|
||||
return block
|
||||
|
||||
block = get_block_from_telegram(chat_id, file_id)
|
||||
outfile = open('tempfile.mp3','wb')
|
||||
outfile.write(block)
|
||||
outfile.close()
|
||||
buf = Buffer()
|
||||
buf = b'12345678'
|
||||
# with open('testfile.mp3','rb') as fp:
|
||||
# buf = fp.read()
|
||||
#
|
||||
process = Popen(["python3.6", "download_service.py", "upload", str(chat_id), str(file_id)], stdin=PIPE, bufsize=-1)
|
||||
process.stdin.write(buf)
|
||||
process.stdin.close()
|
||||
process.wait()
|
||||
|
||||
|
||||
# upload_block(string_to_upload=buf.buf.getvalue(), chat_id=chat_id, hash_uid=str(file_id))
|
||||
# storage = shelve.open('./storage.db')
|
||||
# object = get_block_from_telegram(chat_id, file_id)
|
||||
#
|
||||
# storage[file_id] = object
|
||||
# print(storage[file_id])
|
Loading…
Reference in a new issue