refining api routes with permission callbacks and ip tracking

This commit is contained in:
Antoine M 2024-02-13 19:13:01 +01:00
parent b26f4cf578
commit 5af51603c8

View File

@ -5,36 +5,65 @@ function acf_set_language()
} }
add_action('rest_api_init', function () { add_action('rest_api_init', function () {
// ################ SCREENS ################
register_rest_route('lhoist-datas/screen', '/welcome', array( register_rest_route('lhoist-datas/screen', '/welcome', array(
'methods' => 'GET', 'methods' => 'GET',
'callback' => 'get_interface_welcome_screen_datas', 'callback' => 'get_interface_welcome_screen_datas',
'permission_callback' => '__return_true', 'permission_callback' => '__return_true',
// 'permission_callback' => 'lhoist_datas_permission_callback',
)); ));
register_rest_route('lhoist-datas/screen', '/profile', array( register_rest_route('lhoist-datas/screen', '/profile', array(
'methods' => 'GET', 'methods' => 'GET',
'callback' => 'get_interface_profile_screen_datas', 'callback' => 'get_interface_profile_screen_datas',
'permission_callback' => '__return_true', 'permission_callback' => '__return_true',
)); ));
// ################ GAME ################
register_rest_route('lhoist-datas/screen', '/play/latest', array(
'methods' => 'GET',
'callback' => 'get_interface_play_screen_datas',
'permission_callback' => '__return_true',
));
// ################ UTILS ################
register_rest_route('lhoist-datas', '/available-countries', array( register_rest_route('lhoist-datas', '/available-countries', array(
'methods' => 'GET', 'methods' => 'GET',
'callback' => 'get_interface_available_countries', 'callback' => 'get_interface_available_countries',
'permission_callback' => '__return_true', 'permission_callback' => '__return_true',
)); ));
// ################ POST ################ // ################ POST ################
register_rest_route('lhoist-datas/statistics', '/post', array( register_rest_route('lhoist-datas/statistics', '/post', array(
'methods' => 'POST', 'methods' => 'POST',
'callback' => 'wp_learn_create_database_table', 'callback' => 'lhoist_post_game_datas_statistics',
'permission_callback' => 'lhoist_datas_permission_callback', 'permission_callback' => 'lhoist_datas_permission_callback',
// 'permission_callback' => '__return_true',
)); ));
}); });
function wp_learn_create_database_table(WP_REST_Request $request)
function lhoist_datas_permission_callback(
WP_REST_Request $request
) {
$user_ip = $request->get_header('x_real_ip');
if ($user_ip === API_GILLES_AUTHORIZED_IP || $user_ip === API_ANTOINE_AUTHORIZED_IP) {
return true;
}
return false;
}
// ################ RETURN GAME STATISTICS ################
function lhoist_post_game_datas_statistics(WP_REST_Request $request)
{ {
$data = $request->get_json_params(); // Récupération des données envoyées avec la requête POST $data = $request->get_json_params(); // Récupération des données envoyées avec la requête POST
$user_name = $data['user_name'] ?? null;
$user_locale = $data['user_locale'] ?? null; $user_locale = $data['user_locale'] ?? null;
$user_country = $data['user_country'] ?? null; $user_country = $data['user_country'] ?? null;
$level_post_id = $data['level_post_id'] ?? null; $level_post_id = $data['level_post_id'] ?? null;
@ -43,29 +72,29 @@ function wp_learn_create_database_table(WP_REST_Request $request)
$level_score = $data['level_score'] ?? null; $level_score = $data['level_score'] ?? null;
if (!$data) { if (!$data) {
return rest_ensure_response(array('success' => false, 'message' => 'Erreur lors de l\'enregistrement des données.')); return rest_ensure_response(array('success' => false, 'message' => 'yooo Erreur lors de l\'enregistrement des données.'));
exit; exit;
} }
global $wpdb; global $wpdb;
$table_name = 'wp_app_users_statistics'; $table_name = 'wp_app_users_statistics';
$post_id = uniqid(); $post_id = uniqid();
write_log("user_locale : " . $user_locale); $gameStats = array(
$result_check = $wpdb->insert(
$table_name,
array(
'session_ID' => $post_id, 'session_ID' => $post_id,
'user_name' => $user_name,
'user_locale' => $user_locale, 'user_locale' => $user_locale,
'user_country' => $user_country, 'user_country' => $user_country,
'level_post_id' => $level_post_id, 'level_post_id' => $level_post_id,
'level_is_completed' => $level_is_completed, 'level_is_completed' => $level_is_completed ?? "0",
'level_completion_time' => $level_completion_time, 'level_completion_time' => $level_completion_time,
'level_score' => $level_score, 'level_score' => $level_score,
);
)
$result_check = $wpdb->insert(
$table_name,
$gameStats
); );
if ($result_check) { if ($result_check) {
@ -75,19 +104,17 @@ function wp_learn_create_database_table(WP_REST_Request $request)
} }
} }
function lhoist_datas_permission_callback()
{
if (is_user_logged_in() && current_user_can('administrator')) {
return true;
}
return false;
}
// ################ WELCOME SCREEN ################ // ################ INTERFACE SCREEN DATAS ################
function get_interface_welcome_screen_datas($request) function get_interface_welcome_screen_datas($request)
{ {
$user_ip = $request->get_header('x_real_ip');
write_log("API_TOKEN :" . API_TOKEN);
write_log("API_AUTHORIZED_IP :" . API_AUTHORIZED_IP);
write_log("USER_IP :" . $user_ip);
// write_log($request);
// $language = sanitize_text_field($request['language']); // $language = sanitize_text_field($request['language']);
$currentLanguage = $request->get_param('current-language') ?? 'fr'; $currentLanguage = $request->get_param('current-language') ?? 'fr';
@ -150,6 +177,49 @@ function get_interface_profile_screen_datas($request)
return $response; return $response;
} }
function get_interface_play_screen_datas($request)
{
// $language = sanitize_text_field($request['language']);
$currentLanguage = $request->get_param('current-language') ?? 'fr';
// SWITCH TO CURRENT REQUEST LANGUAGE
do_action('wpml_switch_language', $currentLanguage);
add_filter('acf/settings/current_language', 'acf_set_language');
// GET LATESTS PLAY LEVEL
$args = array(
'post_type' => 'search-and-find',
'posts_per_page' => 1,
);
$searchAndFindsQuery = new WP_Query($args);
// RETURN IF NO GAME DATAS
if (!$searchAndFindsQuery->posts || !$searchAndFindsQuery->posts[0] || !$searchAndFindsQuery->posts[0]->post_content) return rest_ensure_response(array('error' => 'impossible de trouver les données du jeu'));
$lastGamePageBlocks = parse_blocks($searchAndFindsQuery->posts[0]->post_content);
$gameBlock = null;
foreach ($lastGamePageBlocks as $block) {
if ('lhoist-blocks/search-and-find' === $block['blockName']) {
$gameBlock = $block;
break;
}
}
$responseDatas = array(
'gameId' => $searchAndFindsQuery->posts[0]->ID,
'gameHtmlTemplate' => $searchAndFindsQuery->posts[0]->post_content,
'gameBlockDatas' => $gameBlock,
'gameObjects' => $gameBlock['innerBlocks'],
);
$response = new WP_REST_Response($responseDatas);
$response->set_status(200);
return $response;
}
function get_interface_available_countries($request) function get_interface_available_countries($request)
{ {