summaryrefslogtreecommitdiff
path: root/vendor/lusitanian/oauth/examples/linkedin.php
blob: db14ab25752c309ceefb0e7505c38d6bde7faceb (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
54
55
56
57
<?php

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

use OAuth\OAuth2\Service\Linkedin;
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['linkedin']['key'],
    $servicesCredentials['linkedin']['secret'],
    $currentUri->getAbsoluteUri()
);

// Instantiate the Linkedin service using the credentials, http client and storage mechanism for the token
/** @var $linkedinService Linkedin */
$linkedinService = $serviceFactory->createService('linkedin', $credentials, $storage, array('r_basicprofile'));

if (!empty($_GET['code'])) {
    // retrieve the CSRF state parameter
    $state = isset($_GET['state']) ? $_GET['state'] : null;

    // This was a callback request from linkedin, get the token
    $token = $linkedinService->requestAccessToken($_GET['code'], $state);

    // Send a request with it. Please note that XML is the default format.
    $result = json_decode($linkedinService->request('/people/~?format=json'), true);

    // Show some of the resultant data
    echo 'Your linkedin first name is ' . $result['firstName'] . ' and your last name is ' . $result['lastName'];

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