Initial Commit
This commit is contained in:
75
app/Models/NotificationLog.php
Normal file
75
app/Models/NotificationLog.php
Normal file
@@ -0,0 +1,75 @@
|
||||
<?php
|
||||
|
||||
namespace App\Models;
|
||||
|
||||
use Core\Model;
|
||||
|
||||
class NotificationLog extends Model
|
||||
{
|
||||
protected static string $table = 'notification_logs';
|
||||
|
||||
/**
|
||||
* Log a notification
|
||||
*/
|
||||
public function log(int $domainId, string $type, string $channel, string $message, bool $success, ?string $error = null): int
|
||||
{
|
||||
return $this->create([
|
||||
'domain_id' => $domainId,
|
||||
'notification_type' => $type,
|
||||
'channel_type' => $channel,
|
||||
'message' => $message,
|
||||
'status' => $success ? 'sent' : 'failed',
|
||||
'error_message' => $error
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get logs for a domain
|
||||
*/
|
||||
public function getByDomain(int $domainId, int $limit = 50): array
|
||||
{
|
||||
$sql = "SELECT * FROM notification_logs
|
||||
WHERE domain_id = ?
|
||||
ORDER BY sent_at DESC
|
||||
LIMIT ?";
|
||||
|
||||
$stmt = $this->db->prepare($sql);
|
||||
$stmt->execute([$domainId, $limit]);
|
||||
return $stmt->fetchAll();
|
||||
}
|
||||
|
||||
/**
|
||||
* Get recent logs
|
||||
*/
|
||||
public function getRecent(int $limit = 100): array
|
||||
{
|
||||
$sql = "SELECT nl.*, d.domain_name
|
||||
FROM notification_logs nl
|
||||
JOIN domains d ON nl.domain_id = d.id
|
||||
ORDER BY nl.sent_at DESC
|
||||
LIMIT ?";
|
||||
|
||||
$stmt = $this->db->prepare($sql);
|
||||
$stmt->execute([$limit]);
|
||||
return $stmt->fetchAll();
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if notification was sent recently
|
||||
*/
|
||||
public function wasSentRecently(int $domainId, string $type, int $hoursAgo = 24): bool
|
||||
{
|
||||
$sql = "SELECT COUNT(*) as count FROM notification_logs
|
||||
WHERE domain_id = ?
|
||||
AND notification_type = ?
|
||||
AND status = 'sent'
|
||||
AND sent_at >= DATE_SUB(NOW(), INTERVAL ? HOUR)";
|
||||
|
||||
$stmt = $this->db->prepare($sql);
|
||||
$stmt->execute([$domainId, $type, $hoursAgo]);
|
||||
$result = $stmt->fetch();
|
||||
|
||||
return $result['count'] > 0;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user