BulkCurlTask constructor now accepts BulkCurlTaskOperation[] instead of shaped arrays

This commit is contained in:
Dylan K. Taylor
2020-12-20 21:49:55 +00:00
parent 9228f006d4
commit c5693598aa
5 changed files with 87 additions and 10 deletions

View File

@ -44,20 +44,23 @@ class BulkCurlTask extends AsyncTask{
* "timeout", "extraHeaders" and "extraOpts". Documentation of these options are same as those in
* {@link Utils::simpleCurl}.
*
* @param mixed[][] $operations
* @phpstan-param list<array{page: string, timeout?: float, extraHeaders?: list<string>, extraOpts?: array<int, mixed>}> $operations
* @param BulkCurlTaskOperation[] $operations
* @phpstan-param list<BulkCurlTaskOperation> $operations
*/
public function __construct(array $operations){
$this->operations = igbinary_serialize($operations);
}
public function onRun() : void{
/** @phpstan-var list<array{page: string, timeout?: float, extraHeaders?: list<string>, extraOpts?: array<int, mixed>}> $operations */
/**
* @var BulkCurlTaskOperation[] $operations
* @phpstan-var list<BulkCurlTaskOperation> $operations
*/
$operations = igbinary_unserialize($this->operations);
$results = [];
foreach($operations as $op){
try{
$results[] = Internet::simpleCurl($op["page"], $op["timeout"] ?? 10, $op["extraHeaders"] ?? [], $op["extraOpts"] ?? []);
$results[] = Internet::simpleCurl($op->getPage(), $op->getTimeout(), $op->getExtraHeaders(), $op->getExtraOpts());
}catch(InternetException $e){
$results[] = $e;
}

View File

@ -0,0 +1,71 @@
<?php
/*
*
* ____ _ _ __ __ _ __ __ ____
* | _ \ ___ ___| | _____| |_| \/ (_)_ __ ___ | \/ | _ \
* | |_) / _ \ / __| |/ / _ \ __| |\/| | | '_ \ / _ \_____| |\/| | |_) |
* | __/ (_) | (__| < __/ |_| | | | | | | | __/_____| | | | __/
* |_| \___/ \___|_|\_\___|\__|_| |_|_|_| |_|\___| |_| |_|_|
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* @author PocketMine Team
* @link http://www.pocketmine.net/
*
*
*/
declare(strict_types=1);
namespace pocketmine\scheduler;
final class BulkCurlTaskOperation{
/** @var string */
private $page;
/** @var float */
private $timeout;
/**
* @var string[]
* @phpstan-var list<string>
*/
private $extraHeaders;
/**
* @var mixed[]
* @phpstan-var array<int, mixed>
*/
private $extraOpts;
/**
* @param string[] $extraHeaders
* @param mixed[] $extraOpts
* @phpstan-param list<string> $extraHeaders
* @phpstan-param array<int, mixed> $extraOpts
*/
public function __construct(string $page, float $timeout = 10, array $extraHeaders = [], array $extraOpts = []){
$this->page = $page;
$this->timeout = $timeout;
$this->extraHeaders = $extraHeaders;
$this->extraOpts = $extraOpts;
}
public function getPage() : string{ return $this->page; }
public function getTimeout() : float{ return $this->timeout; }
/**
* @return string[]
* @phpstan-return list<string>
*/
public function getExtraHeaders() : array{ return $this->extraHeaders; }
/**
* @return mixed[]
* @phpstan-return array<int, mixed>
*/
public function getExtraOpts() : array{ return $this->extraOpts; }
}