summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/AuthLogServiceProvider.php24
-rw-r--r--src/Models/AuthLog.php47
2 files changed, 71 insertions, 0 deletions
diff --git a/src/AuthLogServiceProvider.php b/src/AuthLogServiceProvider.php
new file mode 100644
index 0000000..55cc2c2
--- /dev/null
+++ b/src/AuthLogServiceProvider.php
@@ -0,0 +1,24 @@
+<?php
+
+namespace Lightscale\LaralightAuthLog;
+
+use Illuminate\Support\ServiceProvider;
+
+class AuthLogServiceProvider extends ServiceProvider
+{
+ public function boot(): void
+ {
+ $ns = "laralight-auth-log";
+ $dir = __DIR__;
+ $root = "{$dir}/..";
+
+ $this->publishesMigrations([
+ "{$root}/database/migrations" => database_path('migrations', "{$ns}:migrations"),
+ ]);
+
+ $this->mergeConfigFrom("$root/config/auth_log.php", 'auth_log');
+ $this->publishes([
+ "{$root}/config/access_log.php" => config_path('auth_log.php'),
+ ], "{$ns}:config");
+ }
+}
diff --git a/src/Models/AuthLog.php b/src/Models/AuthLog.php
new file mode 100644
index 0000000..a5b1280
--- /dev/null
+++ b/src/Models/AuthLog.php
@@ -0,0 +1,47 @@
+<?php
+
+namespace Lightscale\LaralightAuthLog\Models;
+
+use Illuminate\Database\Eloquent\Model;
+use Illuminate\Database\Eloquent\Relations\BelongsTo;
+use Illuminate\Database\Eloquent\Prunable;
+use Illuminate\Database\Eloquent\Builder;
+
+class AuthLog extends Model
+{
+ use Prunable;
+
+ const UPDATED_AT = null;
+
+ protected $guarded = [
+ 'user_id'
+ ];
+
+ public function __construct(array $attributes = [])
+ {
+ $this->setTable(config('auth_log.table_name'));
+
+ parent::__construct($attributes);
+ }
+
+ protected function casts(): array
+ {
+ return [
+ 'properties' => 'collection',
+ ];
+ }
+
+ public function user(): BelongsTo
+ {
+ return $this->belongsTo(config('auth_log.user_model'));
+ }
+
+ public function prunable(): Builder
+ {
+ $days = config('auth_log.max_age_days');
+ if ($days === null) {
+ return static::whereRaw('1 = 0');
+ }
+ else return static::where(static::CREATED_AT, '<=', now()->subDays($days));
+ }
+}