當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Auth_OpenID_ServiceEndpoint類代碼示例

本文整理匯總了PHP中Auth_OpenID_ServiceEndpoint的典型用法代碼示例。如果您正苦於以下問題:PHP Auth_OpenID_ServiceEndpoint類的具體用法?PHP Auth_OpenID_ServiceEndpoint怎麽用?PHP Auth_OpenID_ServiceEndpoint使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


在下文中一共展示了Auth_OpenID_ServiceEndpoint類的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: parseService

 function parseService($yadis_url, $uri, $type_uris, $service_element)
 {
     // Set the state of this object based on the contents of the
     // service element.
     $this->type_uris = $type_uris;
     $this->identity_url = $yadis_url;
     $this->server_url = $uri;
     $this->delegate = Auth_OpenID_ServiceEndpoint::findDelegate($service_element);
     $this->used_yadis = true;
 }
開發者ID:Tjorriemorrie,項目名稱:app,代碼行數:10,代碼來源:Discover.php

示例2: fromDiscoveryResult

 static function fromDiscoveryResult($discoveryResult)
 {
     if ($discoveryResult->isXRDS()) {
         return Auth_OpenID_ServiceEndpoint::fromXRDS($discoveryResult->normalized_uri, $discoveryResult->response_text);
     } else {
         return Auth_OpenID_ServiceEndpoint::fromHTML($discoveryResult->normalized_uri, $discoveryResult->response_text);
     }
 }
開發者ID:openid,項目名稱:php-openid,代碼行數:8,代碼來源:Discover.php

示例3: openid_server_update_delegation_info

/**
 * Discover and cache OpenID services for a user's delegate OpenID.
 *
 * @param int $userid user ID
 * @url string URL to discover.  If not provided, user's current delegate will be used
 * @return bool true if successful
 */
function openid_server_update_delegation_info($userid, $url = null)
{
    if (empty($url)) {
        $url = get_usermeta($userid, 'openid_delegate');
    }
    if (empty($url)) {
        return false;
    }
    $fetcher = Auth_Yadis_Yadis::getHTTPFetcher();
    $discoveryResult = Auth_Yadis_Yadis::discover($url, $fetcher);
    $endpoints = Auth_OpenID_ServiceEndpoint::fromDiscoveryResult($discoveryResult);
    $services = array();
    if (!empty($endpoints)) {
        foreach ($endpoints as $endpoint) {
            $service = array('Type' => array(), 'URI' => $endpoint->server_url);
            foreach ($endpoint->type_uris as $type) {
                $service['Type'][] = array('content' => $type);
                if ($type == Auth_OpenID_TYPE_2_0_IDP) {
                    $service['LocalID'] = Auth_OpenID_IDENTIFIER_SELECT;
                } else {
                    if ($type == Auth_OpenID_TYPE_2_0) {
                        $service['LocalID'] = $endpoint->local_id;
                    } else {
                        if (in_array($type, array(Auth_OpenID_TYPE_1_0, Auth_OpenID_TYPE_1_1, Auth_OpenID_TYPE_1_2))) {
                            $service['openid:Delegate'] = $endpoint->local_id;
                        }
                    }
                }
            }
            $services[] = $service;
        }
    }
    if (empty($services)) {
        // resort to checking for HTML links
        $response = $fetcher->get($url);
        $html_content = $response->body;
        $p = new Auth_OpenID_Parse();
        $link_attrs = $p->parseLinkAttrs($html_content);
        // check HTML for OpenID2
        $server_url = $p->findFirstHref($link_attrs, 'openid2.provider');
        if ($server_url !== null) {
            $openid_url = $p->findFirstHref($link_attrs, 'openid2.local_id');
            if ($openid_url == null) {
                $openid_url = $url;
            }
            $services[] = array('Type' => array(array('content' => Auth_OpenID_Type_1_1)), 'URI' => $server_url, 'LocalID' => $openid_url);
        }
        // check HTML for OpenID1
        $server_url = $p->findFirstHref($link_attrs, 'openid.server');
        if ($server_url !== null) {
            $openid_url = $p->findFirstHref($link_attrs, 'openid.delegate');
            if ($openid_url == null) {
                $openid_url = $url;
            }
            $services[] = array('Type' => array(array('content' => Auth_OpenID_Type_2_0)), 'URI' => $server_url, 'openid:Delegate' => $openid_url);
        }
    }
    if (empty($services)) {
        return false;
    }
    update_usermeta($userid, 'openid_delegate', $url);
    update_usermeta($userid, 'openid_delegate_services', $services);
    return true;
}
開發者ID:alx,項目名稱:pressid,代碼行數:71,代碼來源:server.php

示例4: _verifyDiscoveryResultsOpenID2

 /**
  * @access private
  */
 function _verifyDiscoveryResultsOpenID2($message, $endpoint)
 {
     $to_match = new Auth_OpenID_ServiceEndpoint();
     $to_match->type_uris = array(Auth_OpenID_TYPE_2_0);
     $to_match->claimed_id = $message->getArg(Auth_OpenID_OPENID2_NS, 'claimed_id');
     $to_match->local_id = $message->getArg(Auth_OpenID_OPENID2_NS, 'identity');
     $to_match->server_url = $message->getArg(Auth_OpenID_OPENID2_NS, 'op_endpoint');
     if ($to_match->server_url === null) {
         return new Auth_OpenID_FailureResponse($endpoint, "OP Endpoint URL missing");
     }
     // claimed_id and identifier must both be present or both be
     // absent
     if ($to_match->claimed_id === null && $to_match->local_id !== null) {
         return new Auth_OpenID_FailureResponse($endpoint, 'openid.identity is present without openid.claimed_id');
     }
     if ($to_match->claimed_id !== null && $to_match->local_id === null) {
         return new Auth_OpenID_FailureResponse($endpoint, 'openid.claimed_id is present without openid.identity');
     }
     if ($to_match->claimed_id === null) {
         // This is a response without identifiers, so there's
         // really no checking that we can do, so return an
         // endpoint that's for the specified `openid.op_endpoint'
         return Auth_OpenID_ServiceEndpoint::fromOPEndpointURL($to_match->server_url);
     }
     if (!$endpoint) {
         // The claimed ID doesn't match, so we have to do
         // discovery again. This covers not using sessions, OP
         // identifier endpoints and responses that didn't match
         // the original request.
         // oidutil.log('No pre-discovered information supplied.')
         return $this->_discoverAndVerify($to_match->claimed_id, array($to_match));
     } else {
         // The claimed ID matches, so we use the endpoint that we
         // discovered in initiation. This should be the most
         // common case.
         $result = $this->_verifyDiscoverySingle($endpoint, $to_match);
         if (Auth_OpenID::isFailure($result)) {
             $endpoint = $this->_discoverAndVerify($to_match->claimed_id, array($to_match));
             if (Auth_OpenID::isFailure($endpoint)) {
                 return $endpoint;
             }
         }
     }
     // The endpoint we return should have the claimed ID from the
     // message we just verified, fragment and all.
     if ($endpoint->claimed_id != $to_match->claimed_id) {
         $endpoint->claimed_id = $to_match->claimed_id;
     }
     return $endpoint;
 }
開發者ID:raphox,項目名稱:php-openid,代碼行數:53,代碼來源:Consumer.php

示例5: test_useCanonicalID

 function test_useCanonicalID()
 {
     $endpoint = new Auth_OpenID_ServiceEndpoint();
     $endpoint->claimed_id = Auth_Yadis_XRI("=!1000");
     $endpoint->canonicalID = Auth_Yadis_XRI("=!1000");
     $htis->assertEquals($endpoint->getLocalID(), Auth_Yadis_XRI("=!1000"));
 }
開發者ID:BGCX067,項目名稱:ezopenid-svn-to-git,代碼行數:7,代碼來源:Discover_OpenID.php

示例6: Auth_OpenID_discoverWithoutYadis

function Auth_OpenID_discoverWithoutYadis($uri, &$fetcher)
{
    $http_resp = @$fetcher->get($uri);
    if ($http_resp->status != 200) {
        return array($uri, array());
    }
    $identity_url = $http_resp->final_url;
    // Try to parse the response as HTML to get OpenID 1.0/1.1 <link
    // rel="...">
    $openid_services = Auth_OpenID_ServiceEndpoint::fromHTML($identity_url, $http_resp->body);
    return array($identity_url, $openid_services);
}
開發者ID:ramziammar,項目名稱:websites,代碼行數:12,代碼來源:Discover.php

示例7: test_useCanonicalID

 function test_useCanonicalID()
 {
     // When there is no delegate, the CanonicalID should be used
     // with XRI.
     $endpoint = new Auth_OpenID_ServiceEndpoint();
     $endpoint->identity_url = "=example";
     $endpoint->canonicalID = Services_Yadis_XRI("=!1000");
     $this->assertEquals($endpoint->getServerID(), Services_Yadis_XRI("=!1000"));
 }
開發者ID:aprilchild,項目名稱:aprilchild,代碼行數:9,代碼來源:Discover.php


注:本文中的Auth_OpenID_ServiceEndpoint類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。