mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-04 02:50:29 +01:00
92 lines
3.2 KiB
PHP
92 lines
3.2 KiB
PHP
<?php
|
|
|
|
require_once __DIR__.'/../../vendor/autoload.php';
|
|
|
|
// Create server
|
|
$server = new League\OAuth1\Client\Server\Xing(array(
|
|
'identifier' => 'your-identifier',
|
|
'secret' => 'your-secret',
|
|
'callback_uri' => "http://your-callback-uri/",
|
|
));
|
|
|
|
// Start session
|
|
session_start();
|
|
|
|
// Step 4
|
|
if (isset($_GET['user'])) {
|
|
|
|
// Check somebody hasn't manually entered this URL in,
|
|
// by checking that we have the token credentials in
|
|
// the session.
|
|
if ( ! isset($_SESSION['token_credentials'])) {
|
|
echo 'No token credentials.';
|
|
exit(1);
|
|
}
|
|
|
|
// Retrieve our token credentials. From here, it's play time!
|
|
$tokenCredentials = unserialize($_SESSION['token_credentials']);
|
|
|
|
// // Below is an example of retrieving the identifier & secret
|
|
// // (formally known as access token key & secret in earlier
|
|
// // OAuth 1.0 specs).
|
|
// $identifier = $tokenCredentials->getIdentifier();
|
|
// $secret = $tokenCredentials->getSecret();
|
|
|
|
// Some OAuth clients try to act as an API wrapper for
|
|
// the server and it's API. We don't. This is what you
|
|
// get - the ability to access basic information. If
|
|
// you want to get fancy, you should be grabbing a
|
|
// package for interacting with the APIs, by using
|
|
// the identifier & secret that this package was
|
|
// designed to retrieve for you. But, for fun,
|
|
// here's basic user information.
|
|
$user = $server->getUserDetails($tokenCredentials);
|
|
var_dump($user);
|
|
|
|
// Step 3
|
|
} elseif (isset($_GET['oauth_token']) && isset($_GET['oauth_verifier'])) {
|
|
|
|
// Retrieve the temporary credentials from step 2
|
|
$temporaryCredentials = unserialize($_SESSION['temporary_credentials']);
|
|
|
|
// Third and final part to OAuth 1.0 authentication is to retrieve token
|
|
// credentials (formally known as access tokens in earlier OAuth 1.0
|
|
// specs).
|
|
$tokenCredentials = $server->getTokenCredentials($temporaryCredentials, $_GET['oauth_token'], $_GET['oauth_verifier']);
|
|
|
|
// Now, we'll store the token credentials and discard the temporary
|
|
// ones - they're irrelevant at this stage.
|
|
unset($_SESSION['temporary_credentials']);
|
|
$_SESSION['token_credentials'] = serialize($tokenCredentials);
|
|
session_write_close();
|
|
|
|
// Redirect to the user page
|
|
header("Location: http://{$_SERVER['HTTP_HOST']}/?user=user");
|
|
exit;
|
|
|
|
// Step 2.5 - denied request to authorize client
|
|
} elseif (isset($_GET['denied'])) {
|
|
echo 'Hey! You denied the client access to your Xing account! If you did this by mistake, you should <a href="?go=go">try again</a>.';
|
|
|
|
// Step 2
|
|
} elseif (isset($_GET['go'])) {
|
|
|
|
// First part of OAuth 1.0 authentication is retrieving temporary credentials.
|
|
// These identify you as a client to the server.
|
|
$temporaryCredentials = $server->getTemporaryCredentials();
|
|
|
|
// Store the credentials in the session.
|
|
$_SESSION['temporary_credentials'] = serialize($temporaryCredentials);
|
|
session_write_close();
|
|
|
|
// Second part of OAuth 1.0 authentication is to redirect the
|
|
// resource owner to the login screen on the server.
|
|
$server->authorize($temporaryCredentials);
|
|
|
|
// Step 1
|
|
} else {
|
|
|
|
// Display link to start process
|
|
echo '<a href="?go=go">Login</a>';
|
|
}
|