tonoman3g / oauth1-server
There is no license information available for the latest version (v0.3.1) of this package.
v0.3.1
2019-01-09 08:48 UTC
Requires
- php: >=5.4
- symfony/http-foundation: 2.8.*|3.0.*|3.2.*|3.4.*|4.2.*
Requires (Dev)
- mayflower/php-codebrowser: ~1.1
- pdepend/pdepend: 2.1.0
- phpmd/phpmd: @stable
- phpunit/phpunit: ~4.0
- sebastian/phpcpd: *
- squizlabs/php_codesniffer: *
This package is not auto-updated.
Last update: 2024-04-23 07:34:27 UTC
README
#OAuth PSR2 Compliant OAuth 1.0 library base on Andy Smith's OAuth library found here: http://oauth.googlecode.com/svn/code/php/
##2-Legged OAuth Server Example
$request = JoakimKejser\OAuth\OauthRequest::createFromGlobals(); // Simple Example ConsumerStore using arrays $consumerStore = new JoakimKejser\OAuth\ConsumerStore\ArrayConsumerStore(array('key' => 'secret', 'key2' => 'secret2')); // Simple Example NonceStore using arrays - you should use a persistent store $nonceStore = new JoakimKejser\OAuth\NonceStore\ArrayNonceStore(); // We don't need a TokenStore since we'll be doing Two Legged $server = new JoakimKejser\OAuth\Server($request, $consumerStore, $nonceStore, null); // Add the signature method you wanna support $server->addSignatureMethod(new JoakimKejser\OAuth\SignatureMethod\HmacSha1); try { list($consumer, $token) = $server->verifyRequest(); echo "Welcome consumer with key: " . $consumer->key; } catch (JoakimKejser\OAuth\Exception $e) { echo "Something went wrong: " . $e->getMessage(); }
##2-Legged OAuth Client Example
$key = 'key'; $secret = 'secret'; $consumer = new JoakimKejser\OAuth\Consumer($key, $secret); $sigMethod = new JoakimKejser\OAuth\SignatureMethod\HmacSha1; $method = "POST"; //API endpoint to call $api_endpoint = 'http://apiyouwanna/call'; //Create and sign the request - 2-Legged so token is null $req = OauthRequest::createFromConsumerAndToken($consumer, $method, $api_endpoint, null); $req->sign($sigMethod, $consumer, null); //Token is still null $ch = curl_init(); $url = $req->getNormalizedHttpUrl(); // Get the URL for the GET request, without oauth parameters, as we'll add them to the Authorization header if ($method == "GET") { $url = $req->toUrl(true); } // Set up CURL curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); // Add the Authorization header to the request curl_setopt($ch, CURLOPT_HTTPHEADER, array($req->toHeader())); // If it's post, add the post data if ($method == "POST") { curl_setopt($ch, CURLOPT_POST, 1); curl_setopt($ch, CURLOPT_POSTFIELDS, $req->toPostData(true)); } // And go $output = curl_exec($ch); curl_close($ch); echo $output;