-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathcallback.php
52 lines (45 loc) · 1.88 KB
/
callback.php
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
<?php
/**
* @file
* Take the user when they return from Twitter. Get access tokens.
* Verify credentials and redirect to based on response from Twitter.
*/
/* Start session and load lib */
ini_set('session.gc_maxlifetime',300);
ini_set('session.gc_probability',1);
ini_set('session.gc_divisor',1);
session_start();
require_once('lib/twitteroauth.php');
require_once('config.php');
/* If the oauth_token is old redirect to the connect page. */
if (isset($_REQUEST['oauth_token']) && $_SESSION['oauth_token'] !== $_REQUEST['oauth_token']) {
$_SESSION['oauth_status'] = 'oldtoken';
header('Location: ./clearsessions.php');
}
/* Create TwitteroAuth object with app key/secret and token key/secret from default phase */
$connection = new TwitterOAuth(TWITTER_KEY, TWITTER_SECRET, $_SESSION['oauth_token'], $_SESSION['oauth_token_secret']);
/* Request access tokens from twitter */
$access_token = $connection->getAccessToken($_REQUEST['oauth_verifier']);
/* Save the access tokens. Normally these would be saved in a database for future use. */
$_SESSION['access_token'] = $access_token;
/* Remove no longer needed request tokens */
unset($_SESSION['oauth_token']);
unset($_SESSION['oauth_token_secret']);
/* If HTTP response is 200 continue otherwise start over */
if (200 == $connection->http_code) {
$_SESSION['status'] = 'verified';
session_write_close();
header('Location: ./');
} else if (400 == $connection->http_code) {
$_SESSION['tweet_error'] = "You have exceeded your Twitter API limit. Please try again soon.";
session_write_close();
header('Location: ./');
} else if (500 == $connection->http_code || 503 == $connection->http_code || 0 == $connection->http_code) {
$_SESSION['tweet_error'] = "The Twitter API seems to be unavailable at this time. Please try again soon.";
session_write_close();
header('Location: ./');
} else {
session_write_close();
header('Location: ./clearsessions.php');
}
?>