mirror of
https://github.com/RaspbianFrance/raspisms.git
synced 2025-04-20 16:37:48 +02:00
Compare commits
3 commits
3b5733e31a
...
8843df9f46
Author | SHA1 | Date | |
---|---|---|---|
![]() |
8843df9f46 | ||
![]() |
1c0ffc246a | ||
![]() |
b5035101b0 |
1 changed files with 18 additions and 0 deletions
|
@ -13,6 +13,8 @@ namespace controllers\internals;
|
|||
|
||||
class Webhook extends StandardController
|
||||
{
|
||||
const HMAC_ALGO = 'sha256';
|
||||
|
||||
protected $bdd;
|
||||
protected $model;
|
||||
|
||||
|
@ -105,6 +107,7 @@ class Webhook extends StandardController
|
|||
public function trigger(int $id_user, string $type, array $sms)
|
||||
{
|
||||
$internal_setting = new Setting($this->bdd);
|
||||
$internal_user = new User($this->bdd);
|
||||
$settings = $internal_setting->gets_for_user($id_user);
|
||||
|
||||
if (!$settings['webhook'] ?? false)
|
||||
|
@ -112,13 +115,28 @@ class Webhook extends StandardController
|
|||
return false;
|
||||
}
|
||||
|
||||
$user = $internal_user->get($id_user);
|
||||
if (!$user)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
$webhooks = $this->gets_for_type_and_user($id_user, $type);
|
||||
foreach ($webhooks as $webhook)
|
||||
{
|
||||
$timestamp = time();
|
||||
$webhook_random_id = $timestamp . '-' . bin2hex(openssl_random_pseudo_bytes(16));
|
||||
|
||||
//signature is hexa string representing hmac sha256 of webhook_random_id
|
||||
$webhook_signature = hash_hmac(self::HMAC_ALGO, $webhook_random_id, $user['api_key']);
|
||||
|
||||
$message = [
|
||||
'url' => $webhook['url'],
|
||||
'data' => [
|
||||
'webhook_timestamp' => $timestamp,
|
||||
'webhook_type' => $webhook['type'],
|
||||
'webhook_random_id' => $webhook_random_id,
|
||||
'webhook_signature' => $webhook_signature,
|
||||
'id' => $sms['id'],
|
||||
'at' => $sms['at'],
|
||||
'text' => $sms['text'],
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue