BugFixes: achievements and API key management plugins

This commit is contained in:
shubham_meena 2014-08-14 22:20:05 +05:30
parent 87091a823a
commit fddec32184
5 changed files with 134 additions and 71 deletions

View file

@ -11,11 +11,13 @@
* @author shubham meena mentored by Matthew Lagoe * @author shubham meena mentored by Matthew Lagoe
*/ */
// Global variable to store the data which is
// Global variables to store the data // returned to the templates
$return_set = array(); $return_set = array();
$var_set = array();
// Local variable to store data during
// functionalities of the hooks
$var_set = array();
/** /**
* Display hook for api key management * Display hook for api key management
@ -28,7 +30,7 @@ function api_key_management_hook_display()
} }
/** /**
* Hook to validate the posted data * Local Hook to validate the posted data
*/ */
function hook_validate( $var ) function hook_validate( $var )
{ {
@ -70,9 +72,9 @@ function hook_variables()
/** /**
* Global Hook to create table of the API_key_management * Global Hook to create table of the API_key_management
* if not created.Contains the sql code * if not created.
* Contains the sql code
*/ */
function api_key_management_hook_create_tb() function api_key_management_hook_create_tb()
{ {
$dbl = new DBLayer( "lib" ); $dbl = new DBLayer( "lib" );
@ -157,18 +159,25 @@ function api_key_management_hook_load_db()
$db = new DBLayer( 'lib' ); $db = new DBLayer( 'lib' );
// returns the regestered keys if ( isset( $_SESSION['user'] ) )
$sth = $db -> select( 'ams_api_keys', array( 'user' => $_SESSION['user'] ), 'User = :user' ); {
$row = $sth -> fetchAll(); // returns the registered keys
$return_set['api_keys'] = $row; $sth = $db -> select( 'ams_api_keys', array( 'user' => $_SESSION['user'] ), 'User = :user' );
$row = $sth -> fetchAll();
// returns the characters with respect to the user id in the ring_tool->characters $return_set['api_keys'] = $row;
$db = new DBLayer( 'ring' );
$sth = $db -> selectWithParameter( 'char_name', 'characters' , array(), '1' ); // fetch the character from the array to compare
$row = $sth -> fetchAll(); $com = array_column( $return_set['api_keys'], 'UserCharacter' );
$return_set['characters'] = $row;
// returns the characters with respect to the user id in the ring_tool->characters
} $db = new DBLayer( 'ring' );
$sth = $db -> selectWithParameter( 'char_name', 'characters' , array(), '1' );
$row = $sth -> fetch();
// loop through the character list and remove the character if already have an api key
$return_set['characters'] = array_diff( $row, $com );
}
}
/** /**
* Global Hook to update or delete the data from db * Global Hook to update or delete the data from db
@ -189,7 +198,6 @@ function api_key_management_hook_update_db()
header( "Location: index.php?page=layout_plugin&&name=API_key_management&&success=2" ); header( "Location: index.php?page=layout_plugin&&name=API_key_management&&success=2" );
exit; exit;
} }
} }
/** /**
@ -202,5 +210,4 @@ function api_key_management_hook_return_global()
{ {
global $return_set; global $return_set;
return $return_set; return $return_set;
} }

View file

@ -48,7 +48,7 @@
<div class="controls"> <div class="controls">
<select name="character_name"> <select name="character_name">
{foreach from=$hook_info.API_key_management.characters item=element} {foreach from=$hook_info.API_key_management.characters item=element}
<option value="{$element.char_name}">{$element.char_name}</option> <option value="{$element}">{$element}</option>
{/foreach} {/foreach}
</select> </select>
</div> </div>

View file

@ -15,10 +15,13 @@
*/ */
// Global variables to store the data // Global variable to store the data which is
// returned to the templates
$return_set = array(); $return_set = array();
$var_set = array();
// Local variable to store data during
// functionalities of the hooks
$var_set = array();
/** /**
* Display hook for Achievements plugin * Display hook for Achievements plugin
@ -28,26 +31,64 @@ function achievements_hook_display()
global $return_set; global $return_set;
// to display plugin name in menu bar // to display plugin name in menu bar
$return_set['menu_display'] = 'Achievements'; $return_set['menu_display'] = 'Achievements';
} }
/** /**
* Local Hook to get database content * Local Hook to get database content
* which is called by the global hook * which is called by the global hook
* by passing a parameter * by passing a parameter
* *
* This hook returns the api keys registerd with
* the logged in user
*
* @param $data array with respective information * @param $data array with respective information
* @return $row extracted db content wrt $data * @return $row extracted db content wrt $data
*/ */
function hook_get_db_content( $data ) function hook_get_db_content( $data )
{ {
$db = new DBLayer( 'lib' ); $db = new DBLayer( 'lib' );
$sth = $db -> select( 'ams_api_keys', $data , 'User = :User AND UserCharacter = :UserCharacter' ); $sth = $db -> select( 'ams_api_keys', $data , 'User = :User AND UserCharacter = :UserCharacter' );
$row = $sth -> fetchAll(); $row = $sth -> fetchAll();
return $row; return $row;
}
/**
* Local Hook to get database content
* which is called by the global hook
* by passing a parameter
*
* This hook returns the id of the character
* whose achivements we have to get
*
* @param $data array with respective information
* @return $row extracted db content wrt $data
*/
function hook_get_char_id( $data )
{
// returns the character id with respect to the character name in the ring_tool->characters
$db = new DBLayer( 'ring' );
$sth = $db -> selectWithParameter( 'char_id', 'characters' , array( 'char_name' => $data ), 'char_name=:char_name' );
$row = $sth -> fetch();
return $row['char_id'];
}
/**
* Local Hook to get database content
* which is called by the global hook
* by passing a parameter
*
* Hook to get the player stats of the character
*
* @param $data array with respective information
* @return $row extracted db content wrt $data
*/
function hook_get_player_stat( $data )
{
// returns the character id with respect to the character name in the ring_tool->characters
$db = new DBLayer( 'webig' );
$sth = $db -> select( 'players' , array( 'name' => $data ), 'name=:name' );
$row = $sth -> fetch();
return $row;
} }
/** /**
@ -56,27 +97,44 @@ function hook_get_db_content( $data )
*/ */
function hook_variable_set() function hook_variable_set()
{ {
global $var_set; global $return_set;
$var_set['character'] = $_POST['Character']; global $var_set;
if ( isset( $_POST['Character'] ) && !empty( $_POST['Character'] ) )
// get db content for variable set {
$row = hook_get_db_content( array( 'User' => $_SESSION['user'], 'UserCharacter' => $var_set['character'] ) ); $var_set['character'] = $_POST['Character'];
// access key automatically taken from the database wrt user and character // get char id from ring_open table
@$var_set['app_key'] = $row['AccessToken']; if ( $var_set['character'] != 'All Characters' )
{
// here you can set the host where this plugin is set $var_set['char_id'] = hook_get_char_id( $var_set['character'] );
$var_set['host'] = 'localhost';
}
// here you can set what you are looking for
// when you are requesting encoded in json // get db content for variable set
@$var_set['items'] = json_encode( array( 'Task' => 'Achievements', 'Character' => $var_set['character'] ) ); $row = hook_get_db_content( array( 'User' => $_SESSION['user'], 'UserCharacter' => $var_set['character'] ) );
// url where we have to make request for achievements // access key automatically taken from the database wrt user and character
// it sends get parameter search(what to search) and format(in which format data exchange takes place) @$var_set['app_key'] = $row['AccessToken'];
$var_set['url'] = 'app.domain.org?search=' . $var_set['items'] . '&&format=json';
// here you can set the host where this plugin is set
} $var_set['host'] = 'localhost';
// here we get the stats of the character
$ref_set = hook_get_player_stat( $var_set['character'] );
// here we have set items that are required to get the achivements
// these are player stats from webig->players table
@$var_set['items'] = json_encode( array( 'dev_shard' => $ref_set['dev_shard'] , 'name' => $ref_set['name'] , 'cid' => $ref_set['cid'] , 'lang' => 'en' , 'translater_mode' => '', 'last_played_date' => $ref_set['last_login'] ) );
// url where we have to make request for achievements
// it sends get parameter search(what to search) and format(in which format data exchange takes place)
$var_set['url'] = 'http://localhost6/?search=achievements&&format=json';
}
else
{
$return_set['no_char'] = "Please Generate key for a character before requesting for achievements";
}
}
/** /**
* Global Hook to interact with the REST api * Global Hook to interact with the REST api
@ -99,12 +157,11 @@ function achievements_hook_call_rest()
if ( isset( $_POST['get_data'] ) ) if ( isset( $_POST['get_data'] ) )
{ {
hook_variable_set(); hook_variable_set();
// here we make the REST connection
$rest_api = new Rest_Api(); $rest_api = new Rest_Api();
$ach_data = $rest_api -> request( $var_set['url'], $var_set['app_key'], $var_set['host'] ); $ach_data = $rest_api -> request( $var_set['url'], $var_set['app_key'], $var_set['host'], $var_set['items'] );
print_r( $ach_data ); // here we store the response we get from the server
$return_set['char_achievements'] = $ach_data ;
$return_set['char_achievements'] = json_decode( $ach_data );
} }
} }
@ -119,14 +176,16 @@ function achievements_hook_get_db()
{ {
global $return_set; global $return_set;
$db = new DBLayer( 'lib' ); if ( isset( $_SESSION['user'] ) )
{
// getting content for selecting characters $db = new DBLayer( 'lib' );
$sth = $db -> selectWithParameter( 'UserCharacter', 'ams_api_keys', array( 'User' => $_SESSION['user'] ) , 'User = :User' );
$row = $sth -> fetchAll(); // getting content for selecting characters
$retur_set['Character'] = $row; $sth = $db -> selectWithParameter( 'UserCharacter', 'ams_api_keys', array( 'User' => $_SESSION['user'] ) , 'User = :User' );
$row = $sth -> fetch();
} $return_set['Character'] = $row;
}
}
/** /**
* Global Hook to return global variables which contains * Global Hook to return global variables which contains
@ -138,5 +197,4 @@ function achievements_hook_return_global()
{ {
global $return_set; global $return_set;
return $return_set; return $return_set;
}
}

View file

@ -11,10 +11,8 @@
<a href="#" class="btn btn-close btn-round"><i class="icon-remove"></i></a> <a href="#" class="btn btn-close btn-round"><i class="icon-remove"></i></a>
</div> </div>
</div> </div>
{if isset($smarty.get.success) and $smarty.get.success eq '1'}<div class="alert alert-error"><p>Key added successfully</p></div>{/if}
{if isset($smarty.get.success) and $smarty.get.success eq '2'}<div class="alert alert-error"><p>Key deleted successfully</p></div>{/if}
<div class="box-content"> <div class="box-content">
{if isset($hook_info.Achievements.no_char)}<div class="alert alert-error"><p>{$hook_info.Achievements.no_char}</p></div>{/if}
<div class="row-fluid"> <div class="row-fluid">
{$hook_info.Achievements.char_achievements} {$hook_info.Achievements.char_achievements}
</div> </div>
@ -49,8 +47,8 @@
<label class="control-label">Character:</label> <label class="control-label">Character:</label>
<div class="controls"> <div class="controls">
<select name="Character"> <select name="Character">
{foreach from=$hook_info.Achievements.characters item=element} {foreach from=$hook_info.Achievements.Character item=element}
<option value="{$element.char_name}">{$element.char_name}</option> <option value="{$element}">{$element}</option>
{/foreach} {/foreach}
</select> </select>
</div> </div>

View file

@ -198,7 +198,7 @@
INSERT INTO `plugins` (`Id`, `FileName`, `Name`, `Type`, `Owner`, `Permission`, `Status`, `Weight`, `Info`) VALUES INSERT INTO `plugins` (`Id`, `FileName`, `Name`, `Type`, `Owner`, `Permission`, `Status`, `Weight`, `Info`) VALUES
(1, '../../ams_lib/plugins/API_key_management', 'API_key_management', 'automatic', '', 'admin', 1, 0, '{\"PluginName\":\"API Key Management\",\"Description\":\"Provides public access to the API''s by generating access tokens.\",\"Version\":\"1.0.0\",\"Type\":\"automatic\",\"TemplatePath\":\"..\\/..\\/..\\/ams_lib\\/plugins\\/API_key_management\\/templates\\/index.tpl\",\"\":null}'), (1, '../../ams_lib/plugins/API_key_management', 'API_key_management', 'automatic', '', 'admin', 1, 0, '{\"PluginName\":\"API Key Management\",\"Description\":\"Provides public access to the API''s by generating access tokens.\",\"Version\":\"1.0.0\",\"Type\":\"automatic\",\"TemplatePath\":\"..\\/..\\/..\\/ams_lib\\/plugins\\/API_key_management\\/templates\\/index.tpl\",\"\":null}'),
(2, '../../ams_lib/plugins/Achievements', 'Achievements', 'Manual', '', 'admin', 1, 0, '{\"PluginName\":\"Achievements\",\"Description\":\"Returns the achivements of a user with respect to the character =.\",\"Version\":\"1.0.0\",\"TemplatePath\":\"..\\/..\\/..\\/ams_lib\\/plugins\\/Achievements\\/templates\\/index.tpl\",\"Type\":\"Manual\",\"\":null}'); (2, '../../ams_lib/plugins/Achievements', 'Achievements', 'Manual', '', 'admin', 0, 0, '{\"PluginName\":\"Achievements\",\"Description\":\"Returns the achivements of a user with respect to the character =.\",\"Version\":\"1.0.0\",\"TemplatePath\":\"..\\/..\\/..\\/ams_lib\\/plugins\\/Achievements\\/templates\\/index.tpl\",\"Type\":\"Manual\",\"\":null}');
-- ----------------------------------------------------- -- -----------------------------------------------------