1
0
Fork 0
mirror of https://github.com/SlavikMIPT/tgcloud.git synced 2025-02-12 11:12:09 +00:00

Working prototype

This commit is contained in:
Вячеслав Баженов 2019-06-14 03:08:43 +03:00
parent dc917f6e89
commit 41a6a0c3c5
5 changed files with 228 additions and 178 deletions

3
.gitmodules vendored
View file

@ -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

@ -0,0 +1 @@
Subproject commit 78f0814a6f5e43915e0512273d8b26e87b3ae353

View file

@ -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')

View file

@ -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
View 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])