308 lines
No EOL
8.1 KiB
PHP
308 lines
No EOL
8.1 KiB
PHP
<?php
|
|
//***************************************************************************//
|
|
// index_data.php - schedule on the system:
|
|
// * * * * * php cronjobs/index_data.php >/dev/null 2>&1
|
|
// Collect data from various services and store locally for later display.
|
|
//***************************************************************************//
|
|
if(in_array($_SERVER['SERVER_NAME'],array('localhost','a.io'))) {
|
|
$CACHE_FILE = '../data/cache.txt';
|
|
$DATA_FILE = '../data/index.txt';
|
|
} else {
|
|
chdir('/home/atomaka/data');
|
|
|
|
$CACHE_FILE = 'cache.txt';
|
|
$DATA_FILE = 'index.txt';
|
|
}
|
|
|
|
$dataSources = array(
|
|
//function, cache_duration
|
|
'twitter' => 300,
|
|
'github' => 300,
|
|
'hulu' => 600,
|
|
'lastfm' => 60,
|
|
'sc2ranks' => 43200,
|
|
'steam' => 3600,
|
|
'wow' => 43200,
|
|
);
|
|
|
|
if(file_exists($CACHE_FILE)) {
|
|
$cacheData = json_decode(file_get_contents($CACHE_FILE),true);
|
|
} else {
|
|
$cacheData = array();
|
|
}
|
|
if(file_exists($DATA_FILE)) {
|
|
$sourceData = json_decode(file_get_contents($DATA_FILE),true);
|
|
} else {
|
|
$sourceData = array();
|
|
}
|
|
|
|
foreach($dataSources as $dataSource=>$refreshTime) {
|
|
// check last time the data was updated
|
|
$lastModified = (array_key_exists($dataSource, $cacheData)) ?
|
|
$cacheData[$dataSource] : 0;
|
|
|
|
// and see if we need to retrieve new information
|
|
if(time() - $lastModified > $refreshTime) {
|
|
$cacheData[$dataSource] = time();
|
|
|
|
$sourceData[$dataSource] = call_user_func($dataSource);
|
|
}
|
|
}
|
|
|
|
file_put_contents($CACHE_FILE,json_encode($cacheData));
|
|
file_put_contents($DATA_FILE,json_encode($sourceData));
|
|
|
|
|
|
//***************************************************************************//
|
|
// Data sources
|
|
//***************************************************************************//
|
|
function twitter() {
|
|
$url = 'http://www.twitter.com/statuses/user_timeline/atomaka.json?count=1';
|
|
$tweetInfo = json_decode(file_get_contents($url));
|
|
|
|
if(empty($tweetInfo)) {
|
|
return array(
|
|
'text' => 'Last post was a retweet and cannot be listed.',
|
|
'time' => 0,
|
|
);
|
|
} else {
|
|
$tweet = urlify($tweetInfo[0]->text);
|
|
|
|
return array(
|
|
'text' => $tweet,
|
|
'time' => strtotime($tweetInfo[0]->created_at),
|
|
);
|
|
}
|
|
}
|
|
|
|
function github() {
|
|
// get the last repo we worked on
|
|
$url = 'https://api.github.com/users/atomaka/repos';
|
|
$repos = json_decode(curl_request($url));
|
|
|
|
usort(&$repos,'github_sort');
|
|
|
|
// and then get the last commit to that repo
|
|
$url = sprintf('https://api.github.com/repos/atomaka/%s/commits',
|
|
$repos[0]->name);
|
|
$commits = json_decode(curl_request($url));
|
|
|
|
return array(
|
|
'commit' => $commits[0]->commit->message,
|
|
'repo' => $repos[0]->name,
|
|
'url' => $repos[0]->html_url,
|
|
);
|
|
}
|
|
|
|
function lastfm() {
|
|
$url = 'http://ws.audioscrobbler.com/2.0/?method=user.getrecenttracks&user=atomaka&limit=1&api_key=27ea07733c17562cf1fe512586954825';
|
|
$xml = simplexml_load_file($url);
|
|
$latestSong = $xml->recenttracks->track[0];
|
|
|
|
$cover = (is_array($latestSong->image)) ?
|
|
'img/lastfm/blank_album64.png' : (string)$latestSong->image[1];
|
|
$time = (isset($latestSong->attributes()->nowplaying) && (bool)$latestSong->attributes()->nowplaying) ?
|
|
0 : strtotime($latestSong->date . ' UTC');
|
|
|
|
print_r($time);
|
|
|
|
return array(
|
|
'song' => (string)$latestSong->name,
|
|
'artist' => (string)$latestSong->artist,
|
|
'time' => $time,
|
|
'url' => (string)$latestSong->url,
|
|
'cover' => $cover,
|
|
);
|
|
}
|
|
|
|
function sc2ranks() {
|
|
$url = 'http://sc2ranks.com/api/base/teams/us/Gaffer$888.json?appKey=whoisandrew.com';
|
|
$profile = json_decode(file_get_contents($url));
|
|
|
|
// find the 1v1 team
|
|
foreach($profile->teams as $team) {
|
|
if($team->bracket == 1) break;
|
|
}
|
|
|
|
return array(
|
|
'league' => $team->league,
|
|
'division' => $team->division,
|
|
'rank' => $team->division_rank,
|
|
'points' => $team->points,
|
|
'wins' => $team->wins,
|
|
);
|
|
}
|
|
|
|
function hulu() {
|
|
$url = 'http://www.hulu.com/feed/history/atomaka';
|
|
$xml = simplexml_load_file($url);
|
|
|
|
// data for last show
|
|
$lastShow = $xml->channel->item[0];
|
|
|
|
$title = explode(' - ', $lastShow->title);
|
|
preg_match('/<img src="(.*)" align="right"/',(string)$lastShow->description,$thumb);
|
|
|
|
return array(
|
|
'series' => isset($title[2]) ? $title[2] : 'Not Available',
|
|
'title' => $title[0],
|
|
'time' => strtotime($lastShow->pubDate),
|
|
'url' => (string)$lastShow->link,
|
|
'thumb' => $thumb[1],
|
|
);
|
|
}
|
|
|
|
function steam() {
|
|
$url = 'http://steamcommunity.com/profiles/76561197993725971/?xml=1';
|
|
$xml = simplexml_load_file($url);
|
|
|
|
// find the most recently played games
|
|
$recentGames = array();
|
|
if(isset($xml->mostPlayedGames)) {
|
|
foreach($xml->mostPlayedGames->mostPlayedGame as $game) {
|
|
$recentGames[] = array(
|
|
'name' => (string)$game->gameName,
|
|
'link' => (string)$game->gameLink,
|
|
'hours' => (float)$game->hoursPlayed,
|
|
);
|
|
}
|
|
}
|
|
|
|
return array(
|
|
'hours' => (float)$xml->hoursPlayed2Wk,
|
|
'recent' => $recentGames,
|
|
);
|
|
}
|
|
|
|
function wow() {
|
|
$CLASSES = array(
|
|
6 => 'deathknight',
|
|
5 => 'priest',
|
|
11 => 'druid',
|
|
4 => 'rogue',
|
|
8 => 'mage',
|
|
7 => 'shaman',
|
|
1 => 'warrior',
|
|
9 => 'warlock',
|
|
3 => 'hunter',
|
|
);
|
|
|
|
$benchmark_start = time();
|
|
$characters = array(
|
|
'Gaffer' => false,
|
|
'Getburnt' => false,
|
|
'Veincane' => false,
|
|
'Toppazz' => false,
|
|
'Toopro' => false,
|
|
'Levita' => false,
|
|
'Ttg' => false,
|
|
'Notgaffer' => false,
|
|
'Loveglove' => false,
|
|
);
|
|
$currentInstance = 25; // 25 = Firelands
|
|
|
|
// build our mutli curl request
|
|
$mh = curl_multi_init();
|
|
foreach($characters as $character=>$data) {
|
|
$url = sprintf('http://us.battle.net/api/wow/character/crushridge/%s?fields=progression,talents',
|
|
$character);
|
|
|
|
$characters[$character] = curl_prep($url);
|
|
curl_multi_add_handle($mh, $characters[$character]);
|
|
}
|
|
|
|
// execute the multi curl request
|
|
$running = 0;
|
|
do {
|
|
curl_multi_exec($mh, $running);
|
|
} while($running > 0);
|
|
|
|
// and process the results
|
|
$characterData = array();
|
|
foreach($characters as $character=>$data) {
|
|
$json = json_decode(
|
|
curl_multi_getcontent($characters[$character])
|
|
);
|
|
|
|
// merge the two ragnaros bosses
|
|
$bosses = $json->progression->raids[$currentInstance]->bosses;
|
|
$bosses[6]->heroicKills = $bosses[7]->heroicKills;
|
|
unset($bosses[7]);
|
|
|
|
// find the boss with the lowest kills
|
|
$leastN = 1000;
|
|
$leastH = 1000;
|
|
foreach($bosses as $boss) {
|
|
if($boss->normalKills == -1) $boss->normalKills = 0;
|
|
if(($boss->normalKills + $boss->heroicKills) < $leastN) $leastN = $boss->normalKills + $boss->heroicKills;
|
|
if($boss->heroicKills < $leastH) $leastH = $boss->heroicKills;
|
|
}
|
|
|
|
//find our active talent tree
|
|
$spec = null;
|
|
foreach($json->talents as $talent) {
|
|
if(isset($talent->selected)) {
|
|
$spec = $talent;
|
|
break;
|
|
}
|
|
}
|
|
|
|
$characterData[$character] = array(
|
|
'name' => $character,
|
|
'level' => $json->level,
|
|
'class' => $CLASSES[$json->class],
|
|
'progression' => $leastH > 0 ? $leastH * 100 : $leastN,
|
|
'armory' => sprintf('http://us.battle.net/wow/en/character/crushridge/%s/advanced',$character),
|
|
'spec_icon' => $talent->icon,
|
|
'spec_name' => $talent->name,
|
|
);
|
|
}
|
|
|
|
usort(&$characterData,'progression_sort');
|
|
|
|
return $characterData;
|
|
}
|
|
|
|
|
|
//***************************************************************************//
|
|
// Helper functions
|
|
//***************************************************************************//
|
|
function curl_request($url) {
|
|
$curl = curl_init();
|
|
|
|
curl_setopt($curl, CURLOPT_URL, $url);
|
|
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
|
|
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
|
|
|
|
$contents = curl_exec($curl);
|
|
curl_close($curl);
|
|
|
|
return $contents;
|
|
}
|
|
|
|
function curl_prep($url) {
|
|
$curl = curl_init();
|
|
|
|
curl_setopt($curl, CURLOPT_URL, $url);
|
|
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
|
|
curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1);
|
|
curl_setopt($curl, CURLOPT_ENCODING, 'gzip');
|
|
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
|
|
|
|
return $curl;
|
|
}
|
|
|
|
function urlify($string) {
|
|
$pattern ="{\\b((https?|telnet|gopher|file|wais|ftp) : [\\w/\\#~:.?+=&%@!\\-]+?) (?= [.:?\\-]* (?:[^\\w/\\#~:.?+=&%@!\\-] |$) ) }x";
|
|
return preg_replace($pattern,"<a href=\"$1\">$1</a>", $string);
|
|
}
|
|
|
|
function github_sort($a, $b) {
|
|
return strtotime($a->pushed_at) < strtotime($b->pushed_at);
|
|
}
|
|
|
|
function progression_sort($a, $b) {
|
|
return $a['progression'] < $b['progression'];
|
|
}
|
|
|
|
?>
|