| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310 | <?php/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements.  See the NOTICE file * distributed with this work for additional information * regarding copyright ownership.  The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License.  You may obtain a copy of the License at * *     http://www.apache.org/licenses/LICENSE-2.0 * * 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. *//** * */define('AUTH_TYPE_RAM_AK', 'RAM_AK');/** * */define('AUTH_TYPE_RAM_ROLE_ARN', 'RAM_ROLE_ARN');/** * */define('AUTH_TYPE_ECS_RAM_ROLE', 'ECS_RAM_ROLE');/** * */define('AUTH_TYPE_BEARER_TOKEN', 'BEARER_TOKEN');/** * @deprecated See: https://github.com/aliyun/openapi-sdk-php * Class DefaultProfile */class DefaultProfile implements IClientProfile{    /**     * @var IClientProfile     */    private static $profile;    /**     * @var array     */    private static $endpoints;    /**     * @var AbstractCredential     */    private static $credential;    /**     * @var string     */    private static $regionId;    /**     * @var string     */    private static $acceptFormat;    /**     * @var string     */    private static $authType;    /**     * @var ISigner     */    private static $isigner;    /**     * @var AbstractCredential     */    private static $iCredential;    /**     * DefaultProfile constructor.     *     * @param        $regionId     * @param        $credential     * @param string $authType     * @param null   $isigner     */    private function __construct($regionId, $credential, $authType = AUTH_TYPE_RAM_AK, $isigner = null)    {        self::$regionId   = $regionId;        self::$credential = $credential;        self::$authType   = $authType;        self::$isigner    = $isigner;    }    /**     * @param      $regionId     * @param      $accessKeyId     * @param      $accessSecret     * @param null $securityToken     *     * @return DefaultProfile|IClientProfile     */    public static function getProfile($regionId, $accessKeyId, $accessSecret, $securityToken = null)    {        $credential    = new Credential($accessKeyId, $accessSecret, $securityToken);        self::$profile = new DefaultProfile($regionId, $credential);        return self::$profile;    }    /**     * @param $regionId     * @param $accessKeyId     * @param $accessSecret     * @param $roleArn     * @param $roleSessionName     *     * @return DefaultProfile|IClientProfile     */    public static function getRamRoleArnProfile($regionId, $accessKeyId, $accessSecret, $roleArn, $roleSessionName)    {        $credential    = new RamRoleArnCredential($accessKeyId, $accessSecret, $roleArn, $roleSessionName);        self::$profile = new DefaultProfile($regionId, $credential, AUTH_TYPE_RAM_ROLE_ARN);        return self::$profile;    }    /**     * @param $regionId     * @param $roleName     *     * @return DefaultProfile|IClientProfile     */    public static function getEcsRamRoleProfile($regionId, $roleName)    {        $credential    = new EcsRamRoleCredential($roleName);        self::$profile = new DefaultProfile($regionId, $credential, AUTH_TYPE_ECS_RAM_ROLE);        return self::$profile;    }    /**     * @param $regionId     * @param $bearerToken     *     * @return DefaultProfile|IClientProfile     */    public static function getBearerTokenProfile($regionId, $bearerToken)    {        $credential    = new BearerTokenCredential($bearerToken);        self::$profile = new DefaultProfile($regionId, $credential, AUTH_TYPE_BEARER_TOKEN, new BearTokenSigner());        return self::$profile;    }    /**     * @return ISigner|ShaHmac1Signer|null     */    public function getSigner()    {        if (null == self::$isigner) {            self::$isigner = new ShaHmac1Signer();        }        return self::$isigner;    }    /**     * @return string     */    public function getRegionId()    {        return self::$regionId;    }    /**     * @return string     */    public function getFormat()    {        return self::$acceptFormat;    }    /**     * @return AbstractCredential     */    public function getCredential()    {        if (null == self::$credential && null != self::$iCredential) {            self::$credential = self::$iCredential;        }        return self::$credential;    }    /**     * @return bool     */    public function isRamRoleArn()    {        return self::$authType == AUTH_TYPE_RAM_ROLE_ARN;    }    /**     * @return bool     */    public function isEcsRamRole()    {        return self::$authType == AUTH_TYPE_ECS_RAM_ROLE;    }    /**     * @return array     */    public static function getEndpoints()    {        if (null == self::$endpoints) {            self::$endpoints = EndpointProvider::getEndpoints();        }        return self::$endpoints;    }    /**     * @param $endpointName     * @param $regionId     * @param $product     * @param $domain     */    public static function addEndpoint($endpointName, $regionId, $product, $domain)    {        if (null == self::$endpoints) {            self::$endpoints = self::getEndpoints();        }        $endpoint = self::findEndpointByName($endpointName);        if (null == $endpoint) {            self::addEndpoint_($endpointName, $regionId, $product, $domain);        } else {            self::updateEndpoint($regionId, $product, $domain, $endpoint);        }        LocationService::addEndPoint($regionId, $product, $domain);    }    /**     * @param $endpointName     *     * @return mixed     */    public static function findEndpointByName($endpointName)    {        if (self::$endpoints === null) {            return null;        }        foreach (self::$endpoints as $key => $endpoint) {            if ($endpoint->getName() == $endpointName) {                return $endpoint;            }        }        return null;    }    /**     * @param $endpointName     * @param $regionId     * @param $product     * @param $domain     */    private static function addEndpoint_($endpointName, $regionId, $product, $domain)    {        $regionIds         = [$regionId];        $productsDomains   = [new ProductDomain($product, $domain)];        $endpoint          = new Endpoint($endpointName, $regionIds, $productsDomains);        self::$endpoints[] = $endpoint;    }    /**     * @param string   $regionId     * @param string   $product     * @param string   $domain     * @param Endpoint $endpoint     */    private static function updateEndpoint($regionId, $product, $domain, $endpoint)    {        $regionIds = $endpoint->getRegionIds();        if (!in_array($regionId, $regionIds)) {            $regionIds[] = $regionId;            $endpoint->setRegionIds($regionIds);        }        $productDomains = $endpoint->getProductDomains();        if (null == self::findProductDomainAndUpdate($productDomains, $product, $domain)) {            $productDomains[] = new ProductDomain($product, $domain);        }        $endpoint->setProductDomains($productDomains);    }    /**     * @param $productDomains     * @param $product     * @param $domain     *     * @return string|null     */    private static function findProductDomainAndUpdate($productDomains, $product, $domain)    {        foreach ($productDomains as $key => $productDomain) {            if ($productDomain->getProductName() == $product) {                $productDomain->setDomainName($domain);                return $productDomain;            }        }        return null;    }}
 |