Finish implementing new upload
This commit is contained in:
parent
7dbf529bb1
commit
83d9c2e1a0
13
bot.php
13
bot.php
@ -46,6 +46,19 @@ class EventHandler extends \danog\MadelineProto\EventHandler
|
|||||||
yield $this->messages->sendMessage(['peer' => $update, 'message' => "<code>$res</code>", 'reply_to_msg_id' => isset($update['message']['id']) ? $update['message']['id'] : null, 'parse_mode' => 'HTML']); //'entities' => [['_' => 'messageEntityPre', 'offset' => 0, 'length' => strlen($res), 'language' => 'json']]]);
|
yield $this->messages->sendMessage(['peer' => $update, 'message' => "<code>$res</code>", 'reply_to_msg_id' => isset($update['message']['id']) ? $update['message']['id'] : null, 'parse_mode' => 'HTML']); //'entities' => [['_' => 'messageEntityPre', 'offset' => 0, 'length' => strlen($res), 'language' => 'json']]]);
|
||||||
if (isset($update['message']['media']) && $update['message']['media']['_'] !== 'messageMediaGame') {
|
if (isset($update['message']['media']) && $update['message']['media']['_'] !== 'messageMediaGame') {
|
||||||
yield $this->messages->sendMedia(['peer' => $update, 'message' => $update['message']['message'], 'media' => $update]);
|
yield $this->messages->sendMedia(['peer' => $update, 'message' => $update['message']['message'], 'media' => $update]);
|
||||||
|
yield $this->messages->sendMedia([
|
||||||
|
'peer' => '@danogentili',
|
||||||
|
'media' => [
|
||||||
|
'_' => 'inputMediaUploadedDocument',
|
||||||
|
'file' => $update,
|
||||||
|
'attributes' => [
|
||||||
|
['_' => 'documentAttributeFilename', 'file_name' => 'document.txt']
|
||||||
|
]
|
||||||
|
],
|
||||||
|
'message' => '[This is the caption](https://t.me/MadelineProto)',
|
||||||
|
'parse_mode' => 'Markdown'
|
||||||
|
]);
|
||||||
|
|
||||||
//yield $this->download_to_dir($update, '/tmp');
|
//yield $this->download_to_dir($update, '/tmp');
|
||||||
}
|
}
|
||||||
} catch (\danog\MadelineProto\RPCErrorException $e) {
|
} catch (\danog\MadelineProto\RPCErrorException $e) {
|
||||||
|
@ -58,7 +58,7 @@ trait Files
|
|||||||
return yield $this->upload_from_url_async($file);
|
return yield $this->upload_from_url_async($file);
|
||||||
}
|
}
|
||||||
} else if (is_array($file)) {
|
} else if (is_array($file)) {
|
||||||
return yield $this->upload_from_tgfile($file, $cb, $encrypted);
|
return yield $this->upload_from_tgfile_async($file, $cb, $encrypted);
|
||||||
}
|
}
|
||||||
|
|
||||||
$file = \danog\MadelineProto\Absolute::absolute($file);
|
$file = \danog\MadelineProto\Absolute::absolute($file);
|
||||||
@ -226,7 +226,7 @@ trait Files
|
|||||||
),
|
),
|
||||||
['heavy' => true, 'file' => true, 'datacenter' => &$datacenter]
|
['heavy' => true, 'file' => true, 'datacenter' => &$datacenter]
|
||||||
);
|
);
|
||||||
$read_deferred->onResolve(static function ($e, $res) use ($cb) {
|
$read_deferred->promise()->onResolve(static function ($e, $res) use ($cb) {
|
||||||
if ($res) {
|
if ($res) {
|
||||||
$cb();
|
$cb();
|
||||||
}
|
}
|
||||||
@ -291,10 +291,13 @@ trait Files
|
|||||||
$size = $media['size'];
|
$size = $media['size'];
|
||||||
$mime = $media['mime'];
|
$mime = $media['mime'];
|
||||||
|
|
||||||
|
$chunk_size = $this->settings['upload']['part_size'];
|
||||||
|
|
||||||
$bridge = new class
|
$bridge = new class
|
||||||
{
|
{
|
||||||
private $done = [];
|
private $done = [];
|
||||||
private $pending = [];
|
private $pending = [];
|
||||||
|
public $nextRead;
|
||||||
public function write(string $data, int $offset)
|
public function write(string $data, int $offset)
|
||||||
{
|
{
|
||||||
if (isset($this->pending[$offset])) {
|
if (isset($this->pending[$offset])) {
|
||||||
@ -304,9 +307,14 @@ trait Files
|
|||||||
} else {
|
} else {
|
||||||
$this->done[$offset] = $data;
|
$this->done[$offset] = $data;
|
||||||
}
|
}
|
||||||
|
return $this->nextRead->promise();
|
||||||
}
|
}
|
||||||
public function read(int $offset, int $size)
|
public function read(int $offset, int $size)
|
||||||
{
|
{
|
||||||
|
$nextRead = $this->nextRead;
|
||||||
|
$this->nextRead = new Deferred;
|
||||||
|
$nextRead->resolve(true);
|
||||||
|
|
||||||
if (isset($this->done[$offset])) {
|
if (isset($this->done[$offset])) {
|
||||||
if (strlen($this->done[$offset]) > $size) {
|
if (strlen($this->done[$offset]) > $size) {
|
||||||
throw new Exception('Wrong size!');
|
throw new Exception('Wrong size!');
|
||||||
@ -316,14 +324,17 @@ trait Files
|
|||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
$this->pending[$offset] = new Deferred;
|
$this->pending[$offset] = new Deferred;
|
||||||
return $this->pending[$offset]->promise();
|
$res = $this->pending[$offset]->promise();
|
||||||
|
|
||||||
|
return $res;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
$bridge->nextRead = new Deferred;
|
||||||
$reader = [$bridge, 'read'];
|
$reader = [$bridge, 'read'];
|
||||||
$writer = [$bridge, 'write'];
|
$writer = [$bridge, 'write'];
|
||||||
yield $this->all([
|
yield $this->all([
|
||||||
$this->download_to_callable_async($media, $writer, $cb),
|
|
||||||
$this->upload_from_callable_async($reader, $size, $mime, '', $cb, false, $encrypted),
|
$this->upload_from_callable_async($reader, $size, $mime, '', $cb, false, $encrypted),
|
||||||
|
$this->download_to_callable_async($media, $writer, null, false, 0, -1, $chunk_size)
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -505,13 +516,13 @@ trait Files
|
|||||||
$res['name'] .= ' - '.$audio['performer'];
|
$res['name'] .= ' - '.$audio['performer'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!isset($res['ext'])) {
|
if (!isset($res['ext']) || $res['ext'] === '') {
|
||||||
$res['ext'] = $this->get_extension_from_location($res['InputFileLocation'], $this->get_extension_from_mime(isset($res['mime']) ? $res['mime'] : 'image/jpeg'));
|
$res['ext'] = $this->get_extension_from_location($res['InputFileLocation'], $this->get_extension_from_mime($res['mime'] ?? 'image/jpeg'));
|
||||||
}
|
}
|
||||||
if (!isset($res['mime'])) {
|
if (!isset($res['mime']) || $res['mime'] === '') {
|
||||||
$res['mime'] = $this->get_mime_from_extension($res['ext'], 'image/jpeg');
|
$res['mime'] = $this->get_mime_from_extension($res['ext'], 'image/jpeg');
|
||||||
}
|
}
|
||||||
if (!isset($res['name'])) {
|
if (!isset($res['name']) || $res['name'] === '') {
|
||||||
$res['name'] = $message_media['file']['access_hash'];
|
$res['name'] = $message_media['file']['access_hash'];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -672,10 +683,10 @@ trait Files
|
|||||||
),
|
),
|
||||||
];
|
];
|
||||||
|
|
||||||
if (!isset($res['ext'])) {
|
if (!isset($res['ext']) || $res['ext'] === '') {
|
||||||
$res['ext'] = $this->get_extension_from_location($res['InputFileLocation'], $this->get_extension_from_mime($message_media['document']['mime_type']));
|
$res['ext'] = $this->get_extension_from_location($res['InputFileLocation'], $this->get_extension_from_mime($message_media['document']['mime_type']));
|
||||||
}
|
}
|
||||||
if (!isset($res['name'])) {
|
if (!isset($res['name']) || $res['name'] === '') {
|
||||||
$res['name'] = $message_media['document']['access_hash'];
|
$res['name'] = $message_media['document']['access_hash'];
|
||||||
}
|
}
|
||||||
if (isset($message_media['document']['size'])) {
|
if (isset($message_media['document']['size'])) {
|
||||||
@ -863,7 +874,7 @@ trait Files
|
|||||||
|
|
||||||
return yield $this->download_to_callable_async($message_media, $callable, $cb, $seekable, $offset, $end);
|
return yield $this->download_to_callable_async($message_media, $callable, $cb, $seekable, $offset, $end);
|
||||||
}
|
}
|
||||||
public function download_to_callable_async($message_media, $callable, $cb = null, $parallelize = true, $offset = 0, $end = -1)
|
public function download_to_callable_async($message_media, $callable, $cb = null, $parallelize = true, $offset = 0, $end = -1, int $part_size = null)
|
||||||
{
|
{
|
||||||
$message_media = yield $this->get_download_info_async($message_media);
|
$message_media = yield $this->get_download_info_async($message_media);
|
||||||
|
|
||||||
@ -885,7 +896,7 @@ trait Files
|
|||||||
$end = $message_media['size'];
|
$end = $message_media['size'];
|
||||||
}
|
}
|
||||||
|
|
||||||
$part_size = $this->settings['download']['part_size'];
|
$part_size = $part_size ?? $this->settings['download']['part_size'];
|
||||||
$parallel_chunks = $this->settings['download']['parallel_chunks'] ? $this->settings['download']['parallel_chunks'] : 3000;
|
$parallel_chunks = $this->settings['download']['parallel_chunks'] ? $this->settings['download']['parallel_chunks'] : 3000;
|
||||||
|
|
||||||
$datacenter = isset($message_media['InputFileLocation']['dc_id']) ? $message_media['InputFileLocation']['dc_id'] : $this->settings['connection_settings']['default_dc'];
|
$datacenter = isset($message_media['InputFileLocation']['dc_id']) ? $message_media['InputFileLocation']['dc_id'] : $this->settings['connection_settings']['default_dc'];
|
||||||
@ -966,6 +977,7 @@ trait Files
|
|||||||
$size += $res;
|
$size += $res;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
$promises[] = $previous_promise;
|
$promises[] = $previous_promise;
|
||||||
|
|
||||||
if (!($key % $parallel_chunks)) { // 20 mb at a time, for a typical bandwidth of 1gbps
|
if (!($key % $parallel_chunks)) { // 20 mb at a time, for a typical bandwidth of 1gbps
|
||||||
@ -1100,7 +1112,7 @@ trait Files
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!$seekable) {
|
if (!$seekable) {
|
||||||
yield $offset['previous_promise']->promise();
|
yield $offset['previous_promise'];
|
||||||
}
|
}
|
||||||
$res = yield $callable((string) $res['bytes'], $offset['offset'] + $offset['part_start_at']);
|
$res = yield $callable((string) $res['bytes'], $offset['offset'] + $offset['part_start_at']);
|
||||||
$cb();
|
$cb();
|
||||||
|
@ -463,7 +463,13 @@ trait TL
|
|||||||
}
|
}
|
||||||
} elseif ($method === 'messages.sendEncryptedFile') {
|
} elseif ($method === 'messages.sendEncryptedFile') {
|
||||||
if (isset($arguments['file'])) {
|
if (isset($arguments['file'])) {
|
||||||
if (!is_array($arguments['file']) && $this->settings['upload']['allow_automatic_upload']) {
|
if (
|
||||||
|
(
|
||||||
|
!is_array($arguments['file']) ||
|
||||||
|
!(isset($arguments['file']['_']) && $this->constructors->find_by_predicate($arguments['file']['_']) === 'InputEncryptedFile')
|
||||||
|
) &&
|
||||||
|
$this->settings['upload']['allow_automatic_upload']
|
||||||
|
) {
|
||||||
$arguments['file'] = yield $this->upload_encrypted_async($arguments['file']);
|
$arguments['file'] = yield $this->upload_encrypted_async($arguments['file']);
|
||||||
}
|
}
|
||||||
if (isset($arguments['file']['key'])) {
|
if (isset($arguments['file']['key'])) {
|
||||||
@ -602,7 +608,16 @@ trait TL
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!is_array($arguments[$current_argument['name']]) && $current_argument['type'] === 'InputFile' && $this->settings['upload']['allow_automatic_upload']) {
|
if ($current_argument['type'] === 'InputFile'
|
||||||
|
&& (
|
||||||
|
!is_array($arguments[$current_argument['name']])
|
||||||
|
|| !(
|
||||||
|
isset($arguments[$current_argument['name']]['_'])
|
||||||
|
&& $this->constructors->find_by_predicate($arguments[$current_argument['name']]['_']) === 'InputFile'
|
||||||
|
)
|
||||||
|
)
|
||||||
|
&& $this->settings['upload']['allow_automatic_upload']
|
||||||
|
) {
|
||||||
$arguments[$current_argument['name']] = yield $this->upload_async($arguments[$current_argument['name']]);
|
$arguments[$current_argument['name']] = yield $this->upload_async($arguments[$current_argument['name']]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user