1
0
mirror of https://github.com/e107inc/e107.git synced 2025-07-31 11:50:30 +02:00

Issue #1378 Steam support added.

Fixes #1394 Broken social-login API links .
This commit is contained in:
Cameron
2016-02-28 12:35:26 -08:00
parent b036ea8d25
commit d9bf93f115
2 changed files with 110 additions and 6 deletions

View File

@@ -0,0 +1,104 @@
<?php
/*!
* HybridAuth
* http://hybridauth.sourceforge.net | http://github.com/hybridauth/hybridauth
* (c) 2009-2012, HybridAuth authors | http://hybridauth.sourceforge.net/licenses.html
*/
/**
* Hybrid_Providers_Steam provider adapter based on OpenID protocol
*
* http://hybridauth.sourceforge.net/userguide/IDProvider_info_Steam.html
*
* This class has been entirely reworked for the new Steam API (http://steamcommunity.com/dev)
*/
class Hybrid_Providers_Steam extends Hybrid_Provider_Model_OpenID
{
var $openidIdentifier = "http://steamcommunity.com/openid";
function loginFinish()
{
parent::loginFinish();
$this->user->profile->identifier = str_ireplace("http://steamcommunity.com/openid/id/",
"", $this->user->profile->identifier);
if (!$this->user->profile->identifier) {
throw new Exception("Authentication failed! {$this->providerId} returned an invalid user ID.", 5);
}
// If API key is not provided, use legacy API methods
if (!empty($this->config['keys']['key'])) {
$this->getUserProfileWebAPI($this->config['keys']['key']);
} else {
$this->getUserProfileLegacyAPI();
}
Hybrid_Auth::storage()->set("hauth_session.{$this->providerId}.user", $this->user);
}
function getUserProfileWebAPI($apiKey)
{
$apiUrl = 'http://api.steampowered.com/ISteamUser/GetPlayerSummaries/v0002/?key='
. $apiKey . '&steamids=' . $this->user->profile->identifier;
$data = @file_get_contents($apiUrl);
$data = json_decode($data);
if (!is_object($data) || !isset($data->response->players[0])) {
return false;
}
// Get the first index in 'players' array
$data = $data->response->players[0];
$this->user->profile->displayName = property_exists($data, 'personaname') ? $data->personaname : '';
$this->user->profile->firstName = property_exists($data, 'realname') ? $data->realname : '';
$this->user->profile->photoURL = property_exists($data, 'avatarfull') ? $data->avatarfull : '';
$this->user->profile->profileURL = property_exists($data, 'profileurl') ? $data->profileurl : '';
$this->user->profile->country = property_exists($data, 'loccountrycode') ? $data->loccountrycode : '';
}
function getUserProfileLegacyAPI()
{
$apiUrl = 'http://steamcommunity.com/profiles/' . $this->user->profile->identifier . '/?xml=1';
$data = @file_get_contents($apiUrl);
$data = @ new SimpleXMLElement($data);
if (!is_object($data)) {
return false;
}
# store the user profile.
//$this->user->profile->identifier = "";
if (property_exists($data, 'customURL') && (string) $data->customURL != '') {
$this->user->profile->profileURL = 'http://steamcommunity.com/id/' . (string) $data->customURL . '/';
}
else {
$this->user->profile->profileURL = "http://steamcommunity.com/profiles/{$this->user->profile->identifier}/";
}
$this->user->profile->webSiteURL = "";
$this->user->profile->photoURL = property_exists($data, 'avatarFull') ? (string)$data->avatarFull : '';
$this->user->profile->displayName = property_exists($data, 'steamID') ? (string)$data->steamID : '';
$this->user->profile->description = property_exists($data, 'summary') ? (string)$data->summary : '';
$this->user->profile->firstName = property_exists($data, 'realname') ? (string)$data->realname : '';
$this->user->profile->lastName = "";
$this->user->profile->gender = "";
$this->user->profile->language = "";
$this->user->profile->age = "";
$this->user->profile->birthDay = "";
$this->user->profile->birthMonth = "";
$this->user->profile->birthYear = "";
$this->user->profile->email = "";
$this->user->profile->emailVerified = "";
$this->user->profile->phone = "";
$this->user->profile->address = "";
$this->user->profile->country = "";
$this->user->profile->region = property_exists($data, 'location') ? (string)$data->location : '';
$this->user->profile->city = "";
$this->user->profile->zip = "";
}
}

View File

@@ -188,6 +188,10 @@ class social_ui extends e_admin_ui
"keys" => array ( "key" => "", "secret" => "" )
),
*/
"Steam" => array (
"enabled" => true,
"keys" => array ( "key" => "" )
),
"Twitter" => array (
"enabled" => true,
@@ -196,11 +200,6 @@ class social_ui extends e_admin_ui
);
@@ -212,6 +211,7 @@ class social_ui extends e_admin_ui
"LinkedIn" => "https://www.linkedin.com/secure/developer",
"Foursquare" => "https://www.foursquare.com/oauth/",
"Github" => "https://github.com/settings/applications/new",
"Steam" => "http://steamcommunity.com/dev/apikey",
);
@@ -313,7 +313,7 @@ class social_ui extends e_admin_ui
foreach($this->social_logins as $prov=>$val)
{
$label = varset($this->social_external[$prov]) ? "<a class='e-tip' rel='external' title='Get a key from the provider' href='".$social_external[$prov]."'>".$prov."</a>" : $prov;
$label = varset($this->social_external[$prov]) ? "<a class='e-tip' rel='external' title='Get a key from the provider' href='".$this->social_external[$prov]."'>".$prov."</a>" : $prov;
$radio_label = strtolower($prov);
$text .= "
<tr>