summaryrefslogtreecommitdiff
path: root/vendor/lusitanian/oauth/examples/bitly.php
blob: 9cd27e34cd370e77d4ce929e42fa5ebeafc345bf (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
<?php

/**
 * Example of retrieving an authentication token of the Bitly service
 *
 * PHP version 5.4
 *
 * @author     David Desberg <david@daviddesberg.com>
 * @author     Pieter Hordijk <info@pieterhordijk.com>
 * @copyright  Copyright (c) 2012 The authors
 * @license    http://www.opensource.org/licenses/mit-license.html  MIT License
 */

use OAuth\OAuth2\Service\Bitly;
use OAuth\Common\Storage\Session;
use OAuth\Common\Consumer\Credentials;

/**
 * Bootstrap the example
 */
require_once __DIR__ . '/bootstrap.php';

// Session storage
$storage = new Session();

// Setup the credentials for the requests
$credentials = new Credentials(
    $servicesCredentials['bitly']['key'],
    $servicesCredentials['bitly']['secret'],
    $currentUri->getAbsoluteUri()
);

// Instantiate the Bitly service using the credentials, http client and storage mechanism for the token
/** @var $bitlyService Bitly */
$bitlyService = $serviceFactory->createService('bitly', $credentials, $storage);

if (!empty($_GET['code'])) {
    // This was a callback request from bitly, get the token
    $bitlyService->requestAccessToken($_GET['code']);

    // Send a request with it
    $result = json_decode($bitlyService->request('user/info'), true);

    // Show some of the resultant data
    echo 'Your unique user id is: ' . $result['data']['login'] . ' and your name is ' . $result['data']['display_name'];

} elseif (!empty($_GET['go']) && $_GET['go'] === 'go') {
    $url = $bitlyService->getAuthorizationUri();
    header('Location: ' . $url);
} else {
    $url = $currentUri->getRelativeUri() . '?go=go';
    echo "<a href='$url'>Login with Bitly!</a>";
}