]> git.localhorst.tv Git - alttp.git/blobdiff - app/Models/Protocol.php
round titles
[alttp.git] / app / Models / Protocol.php
index 4659665e87ffddeed7adcae097afcd0df81f3cd2..ce081e77dded2c6bf7f92af76381d1a0364e54e6 100644 (file)
@@ -10,6 +10,62 @@ class Protocol extends Model
 {
        use HasFactory;
 
+       public static function applicationAccepted(Tournament $tournament, Application $application, User $user) {
+               $protocol = static::create([
+                       'tournament_id' => $tournament->id,
+                       'user_id' => $user->id,
+                       'type' => 'application.accepted',
+                       'details' => [
+                               'tournament' => static::tournamentMemo($tournament),
+                               'application' => static::applicationMemo($application),
+                               'user' => static::userMemo($application->user),
+                       ],
+               ]);
+               ProtocolAdded::dispatch($protocol);
+       }
+
+       public static function applicationReceived(Tournament $tournament, Application $application, User $user) {
+               $protocol = static::create([
+                       'tournament_id' => $tournament->id,
+                       'user_id' => $user->id,
+                       'type' => 'application.received',
+                       'details' => [
+                               'tournament' => static::tournamentMemo($tournament),
+                               'application' => static::applicationMemo($application),
+                               'user' => static::userMemo($application->user),
+                       ],
+               ]);
+               ProtocolAdded::dispatch($protocol);
+       }
+
+       public static function applicationRejected(Tournament $tournament, Application $application, User $user) {
+               $protocol = static::create([
+                       'tournament_id' => $tournament->id,
+                       'user_id' => $user->id,
+                       'type' => 'application.rejected',
+                       'details' => [
+                               'tournament' => static::tournamentMemo($tournament),
+                               'application' => static::applicationMemo($application),
+                               'user' => static::userMemo($application->user),
+                       ],
+               ]);
+               ProtocolAdded::dispatch($protocol);
+       }
+
+       public static function resultCommented(Tournament $tournament, Result $result, User $user) {
+               $protocol = static::create([
+                       'tournament_id' => $tournament->id,
+                       'user_id' => $user->id,
+                       'type' => 'result.comment',
+                       'details' => [
+                               'tournament' => static::tournamentMemo($tournament),
+                               'result' => static::resultMemo($result),
+                               'round' => static::roundMemo($result->round),
+                       ],
+               ]);
+               ProtocolAdded::dispatch($protocol);
+       }
+
        public static function resultReported(Tournament $tournament, Result $result, User $user) {
                $protocol = static::create([
                        'tournament_id' => $tournament->id,
@@ -18,6 +74,7 @@ class Protocol extends Model
                        'details' => [
                                'tournament' => static::tournamentMemo($tournament),
                                'result' => static::resultMemo($result),
+                               'round' => static::roundMemo($result->round),
                        ],
                ]);
                ProtocolAdded::dispatch($protocol);
@@ -36,6 +93,19 @@ class Protocol extends Model
                ProtocolAdded::dispatch($protocol);
        }
 
+       public static function roundEdited(Tournament $tournament, Round $round, User $user) {
+               $protocol = static::create([
+                       'tournament_id' => $tournament->id,
+                       'user_id' => $user->id,
+                       'type' => 'round.edit',
+                       'details' => [
+                               'tournament' => static::tournamentMemo($tournament),
+                               'round' => static::roundMemo($round),
+                       ],
+               ]);
+               ProtocolAdded::dispatch($protocol);
+       }
+
        public static function roundLocked(Tournament $tournament, Round $round, User $user = null) {
                $protocol = static::create([
                        'tournament_id' => $tournament->id,
@@ -53,7 +123,7 @@ class Protocol extends Model
                $protocol = static::create([
                        'tournament_id' => $tournament->id,
                        'user_id' => $user->id,
-                       'type' => 'round.create',
+                       'type' => 'round.seed',
                        'details' => [
                                'tournament' => static::tournamentMemo($tournament),
                                'round' => static::roundMemo($round),
@@ -75,6 +145,18 @@ class Protocol extends Model
                ProtocolAdded::dispatch($protocol);
        }
 
+       public static function tournamentClosed(Tournament $tournament, User $user = null) {
+               $protocol = static::create([
+                       'tournament_id' => $tournament->id,
+                       'user_id' => $user ? $user->id : null,
+                       'type' => 'tournament.close',
+                       'details' => [
+                               'tournament' => static::tournamentMemo($tournament),
+                       ],
+               ]);
+               ProtocolAdded::dispatch($protocol);
+       }
+
        public static function tournamentCreated(Tournament $tournament, User $user) {
                $protocol = static::create([
                        'tournament_id' => $tournament->id,
@@ -87,6 +169,30 @@ class Protocol extends Model
                ProtocolAdded::dispatch($protocol);
        }
 
+       public static function tournamentDiscord(Tournament $tournament, User $user = null) {
+               $protocol = static::create([
+                       'tournament_id' => $tournament->id,
+                       'user_id' => $user ? $user->id : null,
+                       'type' => 'tournament.discord',
+                       'details' => [
+                               'tournament' => static::tournamentMemo($tournament),
+                       ],
+               ]);
+               ProtocolAdded::dispatch($protocol);
+       }
+
+       public static function tournamentDiscordSettings(Tournament $tournament, User $user = null) {
+               $protocol = static::create([
+                       'tournament_id' => $tournament->id,
+                       'user_id' => $user ? $user->id : null,
+                       'type' => 'tournament.discordSettings',
+                       'details' => [
+                               'tournament' => static::tournamentMemo($tournament),
+                       ],
+               ]);
+               ProtocolAdded::dispatch($protocol);
+       }
+
        public static function tournamentLocked(Tournament $tournament, User $user = null) {
                $protocol = static::create([
                        'tournament_id' => $tournament->id,
@@ -99,10 +205,42 @@ class Protocol extends Model
                ProtocolAdded::dispatch($protocol);
        }
 
+       public static function tournamentOpened(Tournament $tournament, User $user = null) {
+               $protocol = static::create([
+                       'tournament_id' => $tournament->id,
+                       'user_id' => $user ? $user->id : null,
+                       'type' => 'tournament.open',
+                       'details' => [
+                               'tournament' => static::tournamentMemo($tournament),
+                       ],
+               ]);
+               ProtocolAdded::dispatch($protocol);
+       }
+
+       public static function tournamentUnlocked(Tournament $tournament, User $user = null) {
+               $protocol = static::create([
+                       'tournament_id' => $tournament->id,
+                       'user_id' => $user ? $user->id : null,
+                       'type' => 'tournament.unlock',
+                       'details' => [
+                               'tournament' => static::tournamentMemo($tournament),
+                       ],
+               ]);
+               ProtocolAdded::dispatch($protocol);
+       }
+
+
+       protected static function applicationMemo(Application $application) {
+               return [
+                       'id' => $application->id,
+                       'denied' => $application->denied,
+               ];
+       }
 
        protected static function resultMemo(Result $result) {
                return [
                        'id' => $result->id,
+                       'comment' => $result->comment,
                        'forfeit' => $result->forfeit,
                        'time' => $result->time,
                ];
@@ -111,6 +249,8 @@ class Protocol extends Model
        protected static function roundMemo(Round $round) {
                return [
                        'id' => $round->id,
+                       'locked' => $round->locked,
+                       'no_record' => $round->no_record,
                        'number' => $round->number,
                        'seed' => $round->seed,
                ];
@@ -119,6 +259,9 @@ class Protocol extends Model
        protected static function tournamentMemo(Tournament $tournament) {
                return [
                        'id' => $tournament->id,
+                       'accept_applications' => $tournament->accept_applications,
+                       'locked' => $tournament->locked,
+                       'no_record' => $tournament->no_record,
                        'title' => $tournament->title,
                ];
        }
@@ -129,6 +272,7 @@ class Protocol extends Model
                        'username' => $user->username,
                        'discriminator' => $user->discriminator,
                        'avatar' => $user->avatar,
+                       'nickname' => $user->nickname,
                ];
        }