This commit is contained in:
Daniil Gentili 2019-06-25 12:39:31 +02:00
parent 5f50fa4636
commit 45841add14

View File

@ -213,6 +213,7 @@ trait Files
$fetched = true; $fetched = true;
$bytes = yield $callable($part_num * $part_size, $part_size); $bytes = yield $callable($part_num * $part_size, $part_size);
if (!$already_fetched) { if (!$already_fetched) {
hash_update($ctx, $bytes); hash_update($ctx, $bytes);
} }
@ -246,8 +247,8 @@ trait Files
$time = microtime(true) - $start; $time = microtime(true) - $start;
$speed = (int) (($size * 8) / $time) / 1000000; $speed = (int) (($size * 8) / $time) / 1000000;
$this->logger->logger("Partial download time: $time"); $this->logger->logger("Partial upload time: $time");
$this->logger->logger("Partial download speed: $speed mbps"); $this->logger->logger("Partial upload speed: $speed mbps");
} }
} }
@ -259,8 +260,8 @@ trait Files
} }
$time = microtime(true) - $start; $time = microtime(true) - $start;
$speed = (int) (($size * 8) / $time) / 1000000; $speed = (int) (($size * 8) / $time) / 1000000;
$this->logger->logger("Total download time: $time"); $this->logger->logger("Total upload time: $time");
$this->logger->logger("Total download speed: $speed mbps"); $this->logger->logger("Total upload speed: $speed mbps");
$constructor = ['_' => $constructor, 'id' => $file_id, 'parts' => $part_total_num, 'name' => $file_name, 'mime_type' => $mime]; $constructor = ['_' => $constructor, 'id' => $file_id, 'parts' => $part_total_num, 'name' => $file_name, 'mime_type' => $mime];
if ($encrypted === true) { if ($encrypted === true) {
@ -299,22 +300,16 @@ trait Files
private $pending = []; private $pending = [];
public $nextRead; public $nextRead;
public $size; public $size;
public function write(string $data, int $offset) public $part_size;
{
if (isset($this->pending[$offset])) {
$promise = $this->pending[$offset];
unset($this->pending[$offset]);
$promise->resolve($data);
} else {
$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; $nextRead = $this->nextRead;
$this->nextRead = new Deferred; $this->nextRead = new Deferred;
if ($nextRead) {
$nextRead->resolve(true); $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) {
@ -325,21 +320,35 @@ trait Files
return $result; return $result;
} }
$this->pending[$offset] = new Deferred; $this->pending[$offset] = new Deferred;
$res = $this->pending[$offset]->promise(); return $this->pending[$offset]->promise();
if ($offset + $size >= $this->size) {
$this->nextRead->resolve(true);
} }
return $res; public function write(string $data, int $offset)
{
if (isset($this->pending[$offset])) {
$promise = $this->pending[$offset];
unset($this->pending[$offset]);
$promise->resolve($data);
} else {
$this->done[$offset] = $data;
}
$length = strlen($data);
if ($offset + $length === $this->size || $length < $this->part_size) {
return;
}
return $this->nextRead->promise();
} }
}; };
$bridge->nextRead = new Deferred;
$bridge->size = $size; $bridge->size = $size;
$bridge->part_size = $chunk_size;
$reader = [$bridge, 'read']; $reader = [$bridge, 'read'];
$writer = [$bridge, 'write']; $writer = [$bridge, 'write'];
yield $this->all([
$this->upload_from_callable_async($reader, $size, $mime, '', $cb, false, $encrypted), $read = $this->upload_from_callable_async($reader, $size, $mime, '', $cb, false, $encrypted);
$this->download_to_callable_async($media, $writer, null, false, 0, -1, $chunk_size) $write = $this->download_to_callable_async($media, $writer, null, true, 0, -1, $chunk_size);
]);
list($res, ) = yield $this->all([$read, $write]);
return $res;
} }
public function gen_all_file_async($media) public function gen_all_file_async($media)
@ -934,7 +943,7 @@ trait Files
$end_at = $part_size; $end_at = $part_size;
if ($end !== -1 && $x + $part_size > $end) { if ($end !== -1 && $x + $part_size > $end) {
$end_at = ($x + $part_size) - $end; $end_at = $end % $part_size;
$breakOut = true; $breakOut = true;
} }
@ -956,6 +965,7 @@ trait Files
return true; return true;
} }
$count = count($params); $count = count($params);
$cb = function () use ($cb, $count) { $cb = function () use ($cb, $count) {
static $cur = 0; static $cur = 0;
$cur++; $cur++;