Webhooks recomendados
Observação
Veja a descrição detalhada dos webhooks e seus parâmetros na documentação.
Aviso
O código exibido abaixo é uma amostra. Para um ambiente de produção, é recomendado usar uma opção que é mais adaptativa para o desenvolvimento e suporte.
- Validação do usuário
Copy
- php
<?php
case Message::USER_VALIDATION:
/** @var Xsolla\SDK\Webhook\Message\UserValidationMessage $message */
$userArray = $message->getUser();
$userId = $message->getUserId();
$messageArray = $message->toArray();
// TODO if user not found, you should throw
Xsolla\SDK\Exception\Webhook\InvalidUserException
break;
user_id
(cadeia de caracteres) — é um ID de usuário exclusivo em seu aplicativo. Ele pode ser um apelido ou outro parâmetro que identifique um usuário. Use o ID do usuário para criar uma solicitação no banco de dados do seu aplicativo. Se já existe um usuário com esse ID, chame o método break
. Caso contrário, lance a exceção InvalidUserException
.
Exemplo:
Copy
- php
<?php
DEFINE('DB_USER', 'root'); // specify
DEFINE('DB_PASSWORD', 'yourpasswordhere'); // specify
DEFINE('DB_HOST', '127.0.0.1'); // specify
DEFINE('DB_NAME','127.0.0.1'); //specify
$callback = function (Message $message) {
$dbc = @mysqli_connect(DB_HOST, DB_USER, DB_PASSWORD, DB_NAME)
OR die('Could not connect to MySQL '. mysqli_connect_error());
switch ($message->getNotificationType()) {
case Message::USER_VALIDATION:
$userId = $message->getUserId();
$query = "SELECT * FROM user_db.users u WHERE userID IN ('{$userId}') ";
$response = @mysqli_query($dbc, $query);
if (mysqli_num_rows($response) == 0){
throw new InvalidUserException('User not found');
}
break;
use Xsolla\SDK\Exception\Webhook\InvalidUserException;
use Xsolla\SDK\Webhook\Message\Message;
DEFINE('DB_USER', 'dbuser'); // specify
DEFINE('DB_PASSWORD', 'dbpassword'); // specify
DEFINE('DB_HOST', '127.0.0.1'); // specify
DEFINE('DB_NAME', 'dbname'); //specify
$callback = function (Message $message) {
$dbc = @mysqli_connect(DB_HOST, DB_USER, DB_PASSWORD, DB_NAME);
if (mysqli_connect_errno()) {
printf("Connect failed: %s\n", mysqli_connect_error());
exit;
}
switch ($message->getNotificationType()) {
case Message::USER_VALIDATION:
$userId = mysqli_real_escape_string($dbc, $message->getUserId());
$query = "SELECT COUNT(user_id) FROM dbname.users WHERE user_id =
'{$userId}'";
$response = @mysqli_query($dbc, $query) or die(mysqli_error($dbc));
if ((int)mysqli_fetch_row($response)[0] === 0) {
throw new InvalidUserException('User not found');
}
break;
default:
break;
}
};
- Pagamento
Copy
- php
<?php
case Message::PAYMENT:
/** @var Xsolla\SDK\Webhook\Message\PaymentMessage $message */
$userArray = $message->getUser();
$paymentArray = $message->getTransaction();
$purchaseArray =$message->getPurchase();
$paymentId = $message->getPaymentId();
$externalPaymentId = $message->getExternalPaymentId();
$paymentDetailsArray = $message->getPaymentDetails();
$customParametersArray = $message->getCustomParameters();
$isDryRun = $message->isDryRun();
$messageArray = $message->toArray();
// TODO if the payment delivery fails for some reason, you should throw
Xsolla\SDK\Exception\Webhook\XsollaWebhookException
break;
Observação
Uma lista dos itens comprados é passada na matriz
purchaseArray
. Suas opções de conteúdo estão disponíveis na descrição dos parâmetros de webhook Pagamento.Este artigo foi útil?
Obrigado pelo seu feedback!
Avaliaremos sua mensagem e a usaremos para melhorar sua experiência.Encontrou um erro de texto ou digitação? Selecione o texto e pressione Ctrl+Enter.