#!/usr/bin/env php . */ define('INSTALLDIR', realpath(dirname(__FILE__) . '/../..')); require_once INSTALLDIR . '/scripts/commandline.inc'; require_once INSTALLDIR . '/extlib/OAuth.php'; $ini = parse_ini_file("oauth.ini"); // Check to make sure we have everything we need from the ini file foreach(array('consumer_key', 'consumer_secret', 'apiroot', 'request_token_url') as $inikey) { if (empty($ini[$inikey])) { print "You forgot to specify a $inikey in your oauth.ini file.\n"; exit(1); } } $testConsumer = new OAuthConsumer($ini['consumer_key'], $ini['consumer_secret']); $requestTokenUrl = $ini['apiroot'] . $ini['request_token_url']; $parsed = parse_url($requestTokenUrl); $params = array(); parse_str($parsed['query'], $params); $params['oauth_callback'] = 'oob'; // out-of-band $hmac_method = new OAuthSignatureMethod_HMAC_SHA1(); try { $req = OAuthRequest::from_consumer_and_token( $testConsumer, null, "GET", $requestTokenUrl, $params ); $req->sign_request($hmac_method, $testConsumer, NULL); $r = httpRequest($req->to_url()); } catch (Exception $e) { // oh noez print $e->getMessage(); var_dump($req); exit(1); } $body = $r->getBody(); $tokenStuff = array(); parse_str($body, $tokenStuff); $tok = $tokenStuff['oauth_token']; $confirmed = $tokenStuff['oauth_callback_confirmed']; if (empty($tokenStuff['oauth_token']) || empty($confirmed) || $confirmed != 'true') { print "Error: $body\n"; exit(1); } $authurl = $ini['apiroot'] . $ini['authorize_url'] . '?oauth_token=' . $tok; print "\nSuccess! "; print "Authorize URL:\n\n$authurl\n\n"; print "Now paste the Authorize URL into your browser and authorize your temporary credentials.\n"; function httpRequest($url) { $request = HTTPClient::start(); $request->setConfig( array( 'follow_redirects' => true, 'connect_timeout' => 120, 'timeout' => 120, 'ssl_verify_peer' => false, 'ssl_verify_host' => false ) ); return $request->get($url); }