Обновление клиента (apps, 3rdparty, install)

This commit is contained in:
root
2026-03-16 08:42:57 +00:00
parent b8905de237
commit f390426546
3354 changed files with 505213 additions and 3 deletions
@@ -0,0 +1,279 @@
<?php
/**
* LICENSE: The MIT License (the "License")
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* https://github.com/azure/azure-storage-php/LICENSE
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* PHP version 5
*
* @category Microsoft
* @package MicrosoftAzure\Storage\Common\Models
* @author Azure Storage PHP SDK <dmsh@microsoft.com>
* @copyright 2016 Microsoft Corporation
* @license https://github.com/azure/azure-storage-php/LICENSE
* @link https://github.com/azure/azure-storage-php
*/
namespace MicrosoftAzure\Storage\Common\Models;
use MicrosoftAzure\Storage\Common\Internal\Resources;
use MicrosoftAzure\Storage\Common\Internal\Serialization\XmlSerializer;
/**
* Encapsulates service properties
*
* @category Microsoft
* @package MicrosoftAzure\Storage\Common\Models
* @author Azure Storage PHP SDK <dmsh@microsoft.com>
* @copyright 2016 Microsoft Corporation
* @license https://github.com/azure/azure-storage-php/LICENSE
* @link https://github.com/azure/azure-storage-php
*/
class ServiceProperties
{
private $logging;
private $hourMetrics;
private $minuteMetrics;
private $corses;
private $defaultServiceVersion;
private static $xmlRootName = 'StorageServiceProperties';
/**
* Creates ServiceProperties object from parsed XML response.
*
* @internal
* @param array $parsedResponse XML response parsed into array.
*
* @return ServiceProperties.
*/
public static function create(array $parsedResponse)
{
$result = new ServiceProperties();
if (array_key_exists(Resources::XTAG_DEFAULT_SERVICE_VERSION, $parsedResponse) &&
$parsedResponse[Resources::XTAG_DEFAULT_SERVICE_VERSION] != null) {
$result->setDefaultServiceVersion($parsedResponse[Resources::XTAG_DEFAULT_SERVICE_VERSION]);
}
if (array_key_exists(Resources::XTAG_LOGGING, $parsedResponse)) {
$result->setLogging(Logging::create($parsedResponse[Resources::XTAG_LOGGING]));
}
$result->setHourMetrics(Metrics::create($parsedResponse[Resources::XTAG_HOUR_METRICS]));
if (array_key_exists(Resources::XTAG_MINUTE_METRICS, $parsedResponse)) {
$result->setMinuteMetrics(Metrics::create($parsedResponse[Resources::XTAG_MINUTE_METRICS]));
}
if (array_key_exists(Resources::XTAG_CORS, $parsedResponse) &&
$parsedResponse[Resources::XTAG_CORS] != null) {
//There could be multiple CORS rules, so need to extract them all.
$corses = array();
$corsArray =
$parsedResponse[Resources::XTAG_CORS][Resources::XTAG_CORS_RULE];
if (count(array_filter(array_keys($corsArray), 'is_string')) > 0) {
//single cors rule
$corses[] = CORS::create($corsArray);
} else {
//multiple cors rule
foreach ($corsArray as $cors) {
$corses[] = CORS::create($cors);
}
}
$result->setCorses($corses);
} else {
$result->setCorses(array());
}
return $result;
}
/**
* Gets logging element.
*
* @return Logging
*/
public function getLogging()
{
return $this->logging;
}
/**
* Sets logging element.
*
* @param Logging $logging new element.
*
* @return void
*/
public function setLogging(Logging $logging)
{
$this->logging = clone $logging;
}
/**
* Gets hour metrics element.
*
* @return Metrics
*/
public function getHourMetrics()
{
return $this->hourMetrics;
}
/**
* Sets hour metrics element.
*
* @param Metrics $metrics new element.
*
* @return void
*/
public function setHourMetrics(Metrics $hourMetrics)
{
$this->hourMetrics = clone $hourMetrics;
}
/**
* Gets minute metrics element.
*
* @return Metrics
*/
public function getMinuteMetrics()
{
return $this->minuteMetrics;
}
/**
* Sets minute metrics element.
*
* @param Metrics $metrics new element.
*
* @return void
*/
public function setMinuteMetrics(Metrics $minuteMetrics)
{
$this->minuteMetrics = clone $minuteMetrics;
}
/**
* Gets corses element.
*
* @return CORS[]
*/
public function getCorses()
{
return $this->corses;
}
/**
* Sets corses element.
*
* @param CORS[] $corses new elements.
*
* @return void
*/
public function setCorses(array $corses)
{
$this->corses = $corses;
}
/**
* Gets the default service version.
*
* @return string
*/
public function getDefaultServiceVersion()
{
return $this->defaultServiceVersion;
}
/**
* Sets the default service version. This can obly be set for the blob service.
*
* @param string $defaultServiceVersion the default service version
*
* @return void
*/
public function setDefaultServiceVersion($defaultServiceVersion)
{
$this->defaultServiceVersion = $defaultServiceVersion;
}
/**
* Converts this object to array with XML tags
*
* @internal
* @return array
*/
public function toArray()
{
$result = array();
if (!empty($this->getLogging())) {
$result[Resources::XTAG_LOGGING] =
$this->getLogging()->toArray();
}
if (!empty($this->getHourMetrics())) {
$result[Resources::XTAG_HOUR_METRICS] =
$this->getHourMetrics()->toArray();
}
if (!empty($this->getMinuteMetrics())) {
$result[Resources::XTAG_MINUTE_METRICS] =
$this->getMinuteMetrics()->toArray();
}
$corsesArray = $this->getCorsesArray();
if (!empty($corsesArray)) {
$result[Resources::XTAG_CORS] =$corsesArray;
}
if ($this->defaultServiceVersion != null) {
$result[Resources::XTAG_DEFAULT_SERVICE_VERSION] = $this->defaultServiceVersion;
}
return $result;
}
/**
* Gets the array that contains all the CORSes.
*
* @return array
*/
private function getCorsesArray()
{
$corsesArray = array();
if (count($this->getCorses()) == 1) {
$corsesArray = array(
Resources::XTAG_CORS_RULE => $this->getCorses()[0]->toArray()
);
} elseif ($this->getCorses() != array()) {
foreach ($this->getCorses() as $cors) {
$corsesArray[] = [Resources::XTAG_CORS_RULE => $cors->toArray()];
}
}
return $corsesArray;
}
/**
* Converts this current object to XML representation.
*
* @internal
* @param XmlSerializer $xmlSerializer The XML serializer.
*
* @return string
*/
public function toXml(XmlSerializer $xmlSerializer)
{
$properties = array(XmlSerializer::ROOT_NAME => self::$xmlRootName);
return $xmlSerializer->serialize($this->toArray(), $properties);
}
}