diff --git a/.env.example b/.env.example new file mode 100644 index 00000000..aa6e34c7 --- /dev/null +++ b/.env.example @@ -0,0 +1,58 @@ +APP_NAME="Gander Oceanic OCA" +APP_ENV=local +APP_KEY= +APP_DEBUG=true +APP_URL=http://ganderoceanic.test + +LOG_CHANNEL=discord +LOG_DISCORD_WEBHOOK_URL= + +DB_CONNECTION=mysql +DB_HOST=127.0.0.1 +DB_PORT=3306 +DB_DATABASE=test +DB_USERNAME=root +DB_PASSWORD= +QUEUE_CONNECTION=sync + +#CTP Home page +CTP_HOME_PAGE=false + +#If you want to send mail +MAIL_DRIVER=smtp +MAIL_HOST= +MAIL_PORT= +MAIL_USERNAME= +MAIL_PASSWORD= + +#Channel IDs for Discord channels if you want them to work +DISCORD_WEB_LOGS=753086414811562014 +DISCORD_GUILD_LOGS=482860026831175690 +DISCORD_ANNOUNCEMENTS=488265136696459292 +DISCORD_ENDORSEMENTS=538938024470511648 +DISCORD_MARKETING=557500419614703617 +DISCORD_STAFF=536497946359758863 +DISCORD_INSTRUCTORS=782927909974442015 + +#Discord OAuth keys for linking/server joining +DISCORD_CLIENT_ID= +DISCORD_CLIENT_SECRET= +DISCORD_BOT_TOKEN= +DISCORD_REDIRECT_URI=https://ganderoceanic.ca/my/discord/link/callback +DISCORD_REDIRECT_URI_JOIN=https://ganderoceanic.ca/my/discord/server/join/callback +DISCORD_GUILD_ID=479250337048297483 + +#VATSIM connect +CONNECT_CLIENT_ID= +CONNECT_SECRET= +CONNECT_REDIRECT_URI="http://ganderoceanic.test/auth/connect/validate" + +#Spaces +DIGITALOCEAN_SPACES_KEY= +DIGITALOCEAN_SPACES_SECRET= +DIGITALOCEAN_SPACES_ENDPOINT= +DIGITALOCEAN_SPACES_REGION= +DIGITALOCEAN_SPACES_BUCKET= + +QUOTES_API_TOKEN= + diff --git a/.gitignore b/.gitignore index 20b17a83..25babd87 100644 --- a/.gitignore +++ b/.gitignore @@ -9,6 +9,8 @@ app/storage/ # Laravel 5 & Lumen specific public/storage +public/assets/files/avatars +public/assets/user_uploads public/hot storage/*.key storage/debugbar @@ -22,12 +24,7 @@ Homestead.json app/Http/Controllers/vendor/skymeyer/vatsimphp/app/logs/pilots.log *.zip - - .vscode/ - .idea/ - .DS_Store - training.yaml diff --git a/app/Console/Kernel.php b/app/Console/Kernel.php index deb19af2..87e9d977 100644 --- a/app/Console/Kernel.php +++ b/app/Console/Kernel.php @@ -41,38 +41,38 @@ protected function schedule(Schedule $schedule) $schedule->job(new ProcessRosterInactivity())->cron('00 00 01 JAN,APR,JUL,OCT *'); //CRONS FOR INACTIVITY EMAILS 2 weeks - $schedule->call(function () { - //Loop through controllers - $count = 0; - foreach (RosterMember::all() as $rosterMember) { - //Do they meet the requirements? - if (!$rosterMember->meetsActivityRequirement()) { - $count++; - $rosterMember->user->notify(new TwoWeekInactivityReminder($rosterMember, 'n/a')); - } - } - - //Tell Discord all about it - $discord = new DiscordClient(); - $discord->sendMessage(753086414811562014, 'Sent '.$count.' two-week warning inactivity emails'); - })->cron('00 00 16 MAR,JUN,SEP,DEC *'); // 2 weeks before end of quarter + // $schedule->call(function () { + // //Loop through controllers + // $count = 0; + // foreach (RosterMember::all() as $rosterMember) { + // //Do they meet the requirements? + // if (!$rosterMember->meetsActivityRequirement()) { + // $count++; + // $rosterMember->user->notify(new TwoWeekInactivityReminder($rosterMember, 'n/a')); + // } + // } + + // //Tell Discord all about it + // $discord = new DiscordClient(); + // $discord->sendMessage(753086414811562014, 'Sent '.$count.' two-week warning inactivity emails'); + // })->cron('00 00 16 MAR,JUN,SEP,DEC *'); // 2 weeks before end of quarter // 1 week - $schedule->call(function () { - //Loop through controllers - $count = 0; - foreach (RosterMember::all() as $rosterMember) { - //Do they meet the requirements? - if (!$rosterMember->meetsActivityRequirement()) { - $count++; - $rosterMember->user->notify(new OneWeekInactivityReminder($rosterMember, 'n/a')); - } - } - - //Tell Discord all about it - $discord = new DiscordClient(); - $discord->sendMessage(753086414811562014, 'Sent '.$count.' one-week warning inactivity emails'); - })->cron('00 00 23 MAR,JUN,SEP,DEC *'); // 1 week before end of quarter*/ + // $schedule->call(function () { + // //Loop through controllers + // $count = 0; + // foreach (RosterMember::all() as $rosterMember) { + // //Do they meet the requirements? + // if (!$rosterMember->meetsActivityRequirement()) { + // $count++; + // $rosterMember->user->notify(new OneWeekInactivityReminder($rosterMember, 'n/a')); + // } + // } + + // //Tell Discord all about it + // $discord = new DiscordClient(); + // $discord->sendMessage(753086414811562014, 'Sent '.$count.' one-week warning inactivity emails'); + // })->cron('00 00 23 MAR,JUN,SEP,DEC *'); // 1 week before end of quarter*/ /// Monthly leaderboard wipe $schedule->call(function () { diff --git a/app/Http/Controllers/Auth/AuthController.php b/app/Http/Controllers/Auth/AuthController.php index 05f54f00..74ab9177 100644 --- a/app/Http/Controllers/Auth/AuthController.php +++ b/app/Http/Controllers/Auth/AuthController.php @@ -6,7 +6,6 @@ use App\Models\Users\User; use Illuminate\Support\Str; use Illuminate\Http\Request; -use Illuminate\Support\Facades\Log; use App\Http\Controllers\Controller; use Illuminate\Support\Facades\Auth; use App\Models\Users\UserPreferences; @@ -76,14 +75,13 @@ public function validateConnectLogin(Request $request) session()->put('token', json_decode((string) $response->getBody(), true)); try { - $response = (new \GuzzleHttp\Client())->get(config('connect.endpoint').'/api/user', [ + $response = (new Client())->get(config('connect.endpoint').'/api/user', [ 'headers' => [ 'Accept' => 'application/json', 'Authorization' => 'Bearer '.session()->get('token.access_token'), ], ]); } catch (ClientException $e) { - dd($e); return redirect()->route('index')->with('error-modal', $e->getMessage()); } $response = json_decode($response->getBody()); @@ -93,7 +91,7 @@ public function validateConnectLogin(Request $request) if (!isset($response->data->vatsim->rating)) { return redirect()->route('index')->with('error-modal', 'We cannot create an account without VATSIM details.'); } - User::updateOrCreate(['id' => $response->data->cid], [ + $user = User::updateOrCreate(['id' => $response->data->cid], [ 'email' => isset($response->data->personal->email) ? $response->data->personal->email : 'no-reply@ganderoceanic.ca', 'fname' => isset($response->data->personal->name_first) ? utf8_decode($response->data->personal->name_first) : $response->data->cid, 'lname' => isset($response->data->personal->name_last) ? $response->data->personal->name_last : $response->data->cid, @@ -109,28 +107,28 @@ public function validateConnectLogin(Request $request) 'display_fname' => isset($response->data->personal->name_first) ? utf8_decode($response->data->personal->name_first) : $response->data->cid, 'used_connect' => true, ]); - $user = User::find($response->data->cid); + + if ($user->wasRecentlyCreated) { + UserPreferences::create([ + 'user_id' => $response->data->cid, + 'ui_mode' => 'light' + ]); + UserNotificationPreferences::create([ + 'user_id' => $response->data->cid, + ]); + UserPrivacyPreferences::create([ + 'user_id' => $response->data->cid + ]); + } + + $user->genInitialAvatar(); + if (!isset($response->data->personal->name_first)) { $user->display_cid_only = true; } + $user->save(); Auth::login($user, true); - if (!UserPreferences::where('user_id', $user->id)->first()) { - $prefs = new UserPreferences(); - $prefs->user_id = $user->id; - $prefs->ui_mode = 'light'; - $prefs->save(); - } - if (!UserPrivacyPreferences::where('user_id', $user->id)->first()) { - $priv = new UserPrivacyPreferences(); - $priv->user_id = $user->id; - $priv->save(); - } - if (!UserNotificationPreferences::where('user_id', $user->id)->first()) { - $notif = new UserNotificationPreferences(); - $notif->user_id = $user->id; - $notif->save(); - } return redirect()->route('my.index')->with('success', "Welcome back, {$user->fullName('F')}!"); } diff --git a/app/Http/Controllers/Community/MyCzqoController.php b/app/Http/Controllers/Community/MyCzqoController.php index 8badef89..d418e046 100644 --- a/app/Http/Controllers/Community/MyCzqoController.php +++ b/app/Http/Controllers/Community/MyCzqoController.php @@ -5,7 +5,6 @@ use Illuminate\Http\Request; use App\Services\DiscordClient; use App\Http\Controllers\Controller; -use Illuminate\Support\Facades\Auth; use App\Models\Users\UserPreferences; use App\Notifications\WelcomeNewUser; use Illuminate\Support\Facades\Cache; @@ -30,7 +29,7 @@ class MyCzqoController extends Controller public function acceptPrivacyPolicy(Request $request) { //Get the user - $user = Auth::user(); + $user = auth()->user(); //If they're already initiated... if ($user->init) { @@ -68,7 +67,7 @@ public function acceptPrivacyPolicy(Request $request) public function denyPrivacyPolicy() { //Get the user - $user = Auth::user(); + $user = auth()->user(); //If they're already initiated... if ($user->init) { @@ -77,7 +76,7 @@ public function denyPrivacyPolicy() } //Well lets log them out - Auth::logout($user); + auth()->logout($user); //Delete their privacy, notifs, prefs $notifPrefs = UserNotificationPreferences::where('user_id', $user->id)->first(); @@ -108,7 +107,7 @@ public function saveBiography(Request $request) ]); //Get user - $user = Auth::user(); + $user = auth()->user(); //Get input $input = $request->get('bio'); @@ -147,7 +146,7 @@ public function changeAvatarCustomImage(Request $request) ], $messages); //Get user - $user = Auth::user(); + $user = auth()->user(); //Put it onto disk $path = Storage::put('user_uploads/'.$user->id.'/avatars', $request->file('file')); @@ -169,7 +168,7 @@ public function changeAvatarCustomImage(Request $request) public function changeAvatarDiscord() { //Get user - $user = Auth::user(); + $user = auth()->user(); //They need Discord don't they if (!$user->hasDiscord()) { @@ -195,7 +194,7 @@ public function changeAvatarDiscord() public function changeAvatarInitials() { //Get user - $user = Auth::user(); + $user = auth()->user(); //Change mode and save $user->avatar_mode = 0; @@ -221,7 +220,7 @@ public function changeDisplayName(Request $request) ]); //Get user - $user = Auth::user(); + $user = auth()->user(); //No swear words... give them the new name! $user->display_fname = $request->get('display_fname'); @@ -246,7 +245,7 @@ public function changeDisplayName(Request $request) } //Redirect - return redirect()->back()->with('success', 'Display name saved! If your avatar is set to default, it may take a while for the initials to update.'); + return back()->with('success', 'Display name saved! If your avatar is set to default, it may take a while for the initials to update.'); } /** @@ -257,7 +256,7 @@ public function changeDisplayName(Request $request) public function preferences() { //Get preferences - $preferences = Auth::user()->preferences; + $preferences = auth()->user()->preferences; //return return view('my.preferences', compact('preferences')); @@ -286,13 +285,13 @@ public function preferencesPost(Request $request) //Get user's preferences object switch ($request->get('table')) { case 'main': - $preferences = Auth::user()->preferences; + $preferences = auth()->user()->preferences; break; case 'notifications': - $preferences = UserNotificationPreferences::where('user_id', Auth::id())->first(); + $preferences = UserNotificationPreferences::where('user_id', auth()->id())->first(); break; case 'privacy': - $preferences = UserPrivacyPreferences::where('user_id', Auth::id())->first(); + $preferences = UserPrivacyPreferences::where('user_id', auth()->id())->first(); } //Change variable diff --git a/app/Http/Controllers/News/NewsController.php b/app/Http/Controllers/News/NewsController.php index 7e0c4e12..a421da11 100644 --- a/app/Http/Controllers/News/NewsController.php +++ b/app/Http/Controllers/News/NewsController.php @@ -12,7 +12,6 @@ use App\Models\Settings\AuditLogEntry; use App\Models\Users\StaffMember; use App\Models\Users\User; -use Auth; use Carbon\Carbon; use Illuminate\Http\Request; use Illuminate\Support\Facades\Storage; @@ -82,7 +81,7 @@ public function postArticle(Request $request) //Add to uploaded images $uploadedImg = new UploadedImage(); $uploadedImg->path = Storage::url($path); - $uploadedImg->user_id = Auth::id(); + $uploadedImg->user_id = auth()->id(); $uploadedImg->save(); } @@ -164,7 +163,7 @@ public function adminEditNewsArticle(Request $request, $article_slug) { if ($validator->fails()) { return redirect()->back()->withInput()->withErrors($validator, 'editArticleErrors'); } - + //Get article object $article = News::where('slug', $article_slug)->firstOrFail(); @@ -182,7 +181,7 @@ public function adminEditNewsArticle(Request $request, $article_slug) { //Add to uploaded images $uploadedImg = new UploadedImage(); $uploadedImg->path = Storage::url($path); - $uploadedImg->user_id = Auth::id(); + $uploadedImg->user_id = auth()->id(); $uploadedImg->save(); } @@ -253,7 +252,7 @@ public function viewArticlePublic($slug) { $article = News::where('slug', $slug)->firstOrFail(); if (!$article->visible) { - if (Auth::check() && !Auth::user()->permissions > 3) { + if (auth()->check() && !auth()->user()->permissions > 3) { abort(403, 'This article is hidden.'); } } @@ -278,7 +277,7 @@ public function minutesIndex() public function minutesDelete($id) { $minutes = MeetingMinutes::whereId($id)->firstOrFail(); - AuditLogEntry::insert(Auth::user(), 'Deleted meeting minutes '.$minutes->title, User::find(1), 0); + AuditLogEntry::insert(auth()->user(), 'Deleted meeting minutes '.$minutes->title, User::find(1), 0); $minutes->delete(); return redirect()->back()->with('info', 'Deleted item'); @@ -302,14 +301,14 @@ public function minutesUpload(Request $request) ); $minutes = new MeetingMinutes([ - 'user_id' => Auth::id(), + 'user_id' => auth()->id(), 'title' => $request->get('title'), 'link' => Storage::url('public/files/minutes/'.$fileName), ]); $minutes->save(); - AuditLogEntry::insert(Auth::user(), 'Uploaded meeting minutes '.$minutes->title, User::find(1), 0); + AuditLogEntry::insert(auth()->user(), 'Uploaded meeting minutes '.$minutes->title, User::find(1), 0); return redirect()->back()->with('success', 'Minutes uploaded!'); } @@ -340,18 +339,19 @@ public function createAnnouncementPost(Request $request) //Redirect if fails if ($validator->fails()) { - return redirect()->back()->withInput()->withErrors($validator, 'createAnnouncementErrors'); + return back()->withInput()->withErrors($validator, 'createAnnouncementErrors'); } //Create announcement $announcement = new Announcement([ - 'user_id' => Auth::id(), + 'user_id' => auth()->id(), 'target_group' => $request->get('target_group'), 'title' => $request->get('title'), 'content' => $request->get('content'), 'slug' => Str::slug($request->get('title').'-'.Carbon::now()->toDateString()), 'reason_for_sending' => $request->get('reason_for_sending'), 'notes' => $request->get('notes'), + 'controller_acknowledgement' => is_null($request->get('acknowledgement')) ? false : true ]); $announcement->save(); diff --git a/app/Http/Controllers/Roster/RosterController.php b/app/Http/Controllers/Roster/RosterController.php index ff7ace19..f17b7f24 100644 --- a/app/Http/Controllers/Roster/RosterController.php +++ b/app/Http/Controllers/Roster/RosterController.php @@ -6,12 +6,11 @@ use App\Models\Users\User; use Illuminate\Http\Request; use App\Services\DiscordClient; -use App\Models\Network\SessionLog; +use App\Models\News\Announcement; use App\Models\Roster\RosterMember; use App\Http\Controllers\Controller; use Illuminate\Support\Facades\Auth; use Illuminate\Support\Facades\Session; -use App\Models\Roster\SoloCertification; use Illuminate\Support\Facades\Validator; use App\Models\News\HomeNewControllerCert; use Illuminate\Support\Facades\Notification; @@ -358,4 +357,10 @@ public function homePageNewControllersAddEntry(Request $request) //Return return response()->json(['message' => 'Saved'], 200); } -} \ No newline at end of file + + //Controller Acknowledgement + public function getAcknowledgement(Announcement $announcement) + { + return view('admin.training.acknowledgements.acknowledgement', compact('announcement')); + } +} diff --git a/app/Http/Controllers/Training/ApplicationsController.php b/app/Http/Controllers/Training/ApplicationsController.php index 9edb254e..44f93593 100644 --- a/app/Http/Controllers/Training/ApplicationsController.php +++ b/app/Http/Controllers/Training/ApplicationsController.php @@ -70,8 +70,8 @@ public function apply(Request $request) $hoursObj = json_decode($output); $hoursTotal = (int)$hoursObj->c1 + (int)$hoursObj->c3 + (int)$hoursObj->i1 + (int)$hoursObj->i3; - //Redirect if hours aren't 80 - if ($hoursTotal < 80) { + //Redirect if hours aren't 50 + if ($hoursTotal < 50) { return view('training.applications.apply', compact('hoursTotal'))->with('allowed', 'hours'); } diff --git a/app/Http/Controllers/Training/SoloCertificationsController.php b/app/Http/Controllers/Training/SoloCertificationsController.php index 0cba5c3d..a18092f9 100644 --- a/app/Http/Controllers/Training/SoloCertificationsController.php +++ b/app/Http/Controllers/Training/SoloCertificationsController.php @@ -5,7 +5,6 @@ use App\Http\Controllers\Controller; use App\Models\Roster\RosterMember; use App\Models\Roster\SoloCertification; -use App\Models\Training\Instructing\Students\Student; use App\Models\Training\Instructing\Students\StudentStatusLabel; use App\Notifications\Training\SoloCertifications\SoloCertGranted; use Carbon\Carbon; diff --git a/app/Http/Controllers/Training/TrainingPortalController.php b/app/Http/Controllers/Training/TrainingPortalController.php index e8d6e0e4..5518fe84 100644 --- a/app/Http/Controllers/Training/TrainingPortalController.php +++ b/app/Http/Controllers/Training/TrainingPortalController.php @@ -2,25 +2,27 @@ namespace App\Http\Controllers\Training; -use App\Http\Controllers\Controller; +use App\Models\Training\ControllerAcknowledgement; +use Illuminate\Http\Request; +use App\Services\DiscordClient; +use App\Models\News\Announcement; use App\Models\Publications\Policy; -use App\Models\Training\Instructing\Links\StudentStatusLabelLink; +use App\Http\Controllers\Controller; +use Illuminate\Support\Facades\Validator; use App\Models\Training\Instructing\Records\OTSSession; use App\Models\Training\Instructing\Records\StudentNote; use App\Models\Training\Instructing\Records\TrainingSession; -use App\Models\Training\Instructing\Students\StudentAvailabilitySubmission; use App\Models\Training\Instructing\Students\StudentStatusLabel; -use Illuminate\Http\Request; -use Illuminate\Support\Facades\Auth; -use Illuminate\Support\Facades\Validator; -use App\Services\DiscordClient; +use App\Models\Training\Instructing\Links\StudentStatusLabelLink; +use App\Models\Training\Instructing\Students\StudentAvailabilitySubmission; class TrainingPortalController extends Controller { public function index() { + $user = auth()->user(); //Is the user a student who needs to submit availability? - if (Auth::user()->studentProfile && Auth::user()->studentProfile->current && count(Auth::user()->studentProfile->availability) < 1) { + if ($user->studentProfile && $user->studentProfile->current && count($user->studentProfile->availability) < 1) { return view('training.portal.submit-availability'); } @@ -46,13 +48,13 @@ public function submitAvailabilityPost(Request $request) //Create submission obj $submission = new StudentAvailabilitySubmission([ - 'student_id' => Auth::user()->studentProfile->id, + 'student_id' => auth()->user()->studentProfile->id, 'submission' => $request->get('submission'), ]); $submission->save(); //If they have the "Not Ready" label, process them as new student submitting availability - $student = Auth::user()->studentProfile; + $student = auth()->user()->studentProfile; foreach ($student->labels as $label) { //Find Not Ready label if (strtolower($label->label()->name) == 'not ready') { @@ -79,7 +81,7 @@ public function submitAvailabilityPost(Request $request) } //Return - return redirect()->route('training.portal.index')->with('success', 'Thank you for submitting your availability, ' . Auth::user()->fullName('F') . '!'); + return redirect()->route('training.portal.index')->with('success', 'Thank you for submitting your availability, ' . auth()->user()->fullName('F') . '!'); } public function helpPolicies() @@ -93,10 +95,20 @@ public function helpPolicies() return view('training.portal.help-policies', compact('policies')); } + public function readAcknowledgement(Announcement $announcement) + { + ControllerAcknowledgement::create([ + 'user_id' => auth()->id(), + 'announcement_id' => $announcement->id + ]); + + return back()->withSuccess('Acknowledgement read'); + } + public function viewAvailability() { //get their availability - $availability = Auth::user()->studentProfile->availability; + $availability = auth()->user()->studentProfile->availability; //Return view return view('training.portal.availability', compact('availability')); @@ -105,7 +117,7 @@ public function viewAvailability() public function yourProgress() { //Get their student profile - $studentProfile = Auth::user()->studentProfile; + $studentProfile = auth()->user()->studentProfile; //Return view return view('training.portal.progress', compact('studentProfile')); @@ -114,7 +126,7 @@ public function yourProgress() public function yourInstructor() { //Get their instructor - $instructor = Auth::user()->studentProfile->instructor()->instructor; + $instructor = auth()->user()->studentProfile->instructor()->instructor; //Return view return view('training.portal.your-instructor', compact('instructor')); @@ -123,10 +135,10 @@ public function yourInstructor() public function yourTrainingNotes() { //Get their training notes - $notes = StudentNote::where('staff_only', false)->where('student_id', Auth::user()->studentProfile->id)->get()->sortByDesc('created_at'); + $notes = StudentNote::where('staff_only', false)->where('student_id', auth()->user()->studentProfile->id)->get()->sortByDesc('created_at'); //Get their recommendations - $recommendations = Auth::user()->studentProfile->recommendations->sortByDesc('created_at'); + $recommendations = auth()->user()->studentProfile->recommendations->sortByDesc('created_at'); //Return view return view('training.portal.training-notes', compact('notes', 'recommendations')); @@ -135,10 +147,10 @@ public function yourTrainingNotes() public function yourSessions() { //Get their training sessions - $trainingSessions = Auth::user()->studentProfile->trainingSessions->sortByDesc('scheduled_time'); + $trainingSessions = auth()->user()->studentProfile->trainingSessions->sortByDesc('scheduled_time'); //Get their OTS sessions - $otsSessions = Auth::user()->studentProfile->otsSessions->sortByDesc('scheduled_time'); + $otsSessions = auth()->user()->studentProfile->otsSessions->sortByDesc('scheduled_time'); //Return view return view('training.portal.sessions.index', compact('trainingSessions', 'otsSessions')); @@ -147,7 +159,7 @@ public function yourSessions() public function viewTrainingSession($session_id) { //Get session - $session = TrainingSession::whereId($session_id)->where('student_id', Auth::user()->studentProfile->id)->firstOrFail(); + $session = TrainingSession::whereId($session_id)->where('student_id', auth()->user()->studentProfile->id)->firstOrFail(); //Return view return view('training.portal.sessions.view-training-session', compact('session')); @@ -156,7 +168,7 @@ public function viewTrainingSession($session_id) public function viewOtsSession($session_id) { //Get session - $session = OTSSession::whereId($session_id)->where('student_id', Auth::user()->studentProfile->id)->firstOrFail(); + $session = OTSSession::whereId($session_id)->where('student_id', auth()->user()->studentProfile->id)->firstOrFail(); //Return view return view('training.portal.sessions.view-ots-session', compact('session')); @@ -167,4 +179,4 @@ public function actions() //return view return view('training.portal.actions'); } -} \ No newline at end of file +} diff --git a/app/Jobs/ProcessAnnouncement.php b/app/Jobs/ProcessAnnouncement.php index e9b4a20e..6d6a2e5c 100644 --- a/app/Jobs/ProcessAnnouncement.php +++ b/app/Jobs/ProcessAnnouncement.php @@ -3,8 +3,7 @@ namespace App\Jobs; use App\Models\Roster\RosterMember; -use App\Models\Training\Instructing\Instructor; -use App\Models\Training\Instructing\Student; +use App\Models\Training\Instructing\Students\Student; use App\Models\Users\StaffMember; use App\Models\Users\User; use App\Notifications\News\Announcement as AnnouncementNotification; @@ -78,14 +77,6 @@ public function handle() } $discord->sendMessage(intval(config('services.discord.web_logs')), 'Sent '.count($students).' emails to current students for announcement '.$this->announcement->title); break; - case 'students': - // All active students - $students = Instructor::whereCurrent(true)->get(); - foreach ($students as $member) { - $member->user->notify(new AnnouncementNotification($member->user, $this->announcement)); - } - $discord->sendMessage(intval(config('services.discord.web_logs')), 'Sent '.count($students).' emails to current instructors for announcement '.$this->announcement->title); - break; } } } diff --git a/app/Jobs/ProcessDiscordRoles.php b/app/Jobs/ProcessDiscordRoles.php new file mode 100644 index 00000000..3f31bff9 --- /dev/null +++ b/app/Jobs/ProcessDiscordRoles.php @@ -0,0 +1,59 @@ +guildId = Config::get('services.discord.guild_id'); + $this->token = Config::get('services.discord.token'); + $this->discordId = $discordId; + $this->addRole = $addRole; + $this->roleId = $roleId; + } + + /** + * Execute the job. + * + * @return void + */ + public function handle() + { + sleep(2); + + try { + $client = new Client(); + $client->request($this->addRole ? 'PUT' : 'DELETE', "https://discord.com/api/v10/guilds/" . $this->guildId . "/members/" . $this->discordId . "/roles/" . $this->roleId, [ + 'headers' => [ + 'Authorization' => 'Bot ' . $this->token, + 'Content-Type' => 'application/json' + ], + ]); + } catch (\Exception $e) { + if ($e->getCode() !== 404) { + throw $e; + } + return; + } + } +} diff --git a/app/Jobs/ProcessRosterInactivity.php b/app/Jobs/ProcessRosterInactivity.php index bed865bf..a2ca3790 100644 --- a/app/Jobs/ProcessRosterInactivity.php +++ b/app/Jobs/ProcessRosterInactivity.php @@ -38,7 +38,7 @@ public function __construct() */ public function handle() { - $rosterMembers = RosterMember::all()->whereNotIn('certification', ['not_certified', 'training']); + $rosterMembers = RosterMember::whereNotIn('certification', ['not_certified', 'training'])->get(); foreach ($rosterMembers as $rosterMember) { @@ -56,20 +56,9 @@ public function handle() } } - if ($rosterMember->active) { - if ($rosterMember->currency < 3.0) { - $discord = new DiscordClient(); - $discord_user_id = $rosterMember->user->discord_user_id; - if ($discord_user_id && $rosterMember->user->member_of_czqo){ - sleep(2); //TODO: CREATE A JOB TO HANDLE THIS RATHER SLEEP - $discord->removeRole($discord_user_id, 482819739996127259); - $discord->assignRole($discord_user_id, 482835389640343562); - } - $rosterMember->user->removeRole('Certified Controller'); - $rosterMember->user->assignRole('Guest'); - Notification::send($rosterMember->user, new RemovedFromRoster($rosterMember->user)); - $rosterMember->delete(); - } + if ($rosterMember->active && $rosterMember->currency < 0.25) { + $rosterMember->active = false; + $rosterMember->save(); } } } diff --git a/app/Models/News/Announcement.php b/app/Models/News/Announcement.php index 783a9800..344bbb28 100644 --- a/app/Models/News/Announcement.php +++ b/app/Models/News/Announcement.php @@ -6,8 +6,10 @@ use App\Models\Users\User; use Illuminate\Support\HtmlString; use Spatie\Activitylog\LogOptions; +use App\Models\Roster\RosterMember; use Illuminate\Database\Eloquent\Model; use Spatie\Activitylog\Traits\LogsActivity; +use App\Models\Training\ControllerAcknowledgement; /** * App\Models\News\Announcement @@ -46,9 +48,7 @@ class Announcement extends Model protected $hidden = ['id']; - protected $fillable = [ - 'user_id', 'target_group', 'title', 'content', 'slug', 'reason_for_sending', 'notes', - ]; + protected $guarded = []; public function user() { @@ -65,4 +65,12 @@ public function getActivitylogOptions(): LogOptions return LogOptions::defaults() ->logOnly(['name', 'text']); } + + public function getReadMembers() + { + $rosterMembers = RosterMember::all(); + return $rosterMembers->filter(function ($rosterMember) { + return !ControllerAcknowledgement::where('user_id', $rosterMember->user_id)->where('announcement_id', $this->id)->exists(); + }); + } } diff --git a/app/Models/Training/ControllerAcknowledgement.php b/app/Models/Training/ControllerAcknowledgement.php new file mode 100644 index 00000000..b2b48f58 --- /dev/null +++ b/app/Models/Training/ControllerAcknowledgement.php @@ -0,0 +1,17 @@ +belongsTo(Announcement::class, 'announcement_id', 'id'); + } +} diff --git a/app/Models/Users/User.php b/app/Models/Users/User.php index 23e5bbb3..0497a6d3 100644 --- a/app/Models/Users/User.php +++ b/app/Models/Users/User.php @@ -2,16 +2,15 @@ namespace App\Models\Users; -use Throwable; +use App\Models\News\Announcement; +use App\Models\Training\ControllerAcknowledgement; use App\Models\News\News; use Illuminate\Support\Carbon; use App\Models\Users\StaffMember; use Spatie\Activitylog\LogOptions; use App\Models\Roster\RosterMember; -use Illuminate\Support\Facades\Log; use App\Models\Training\Application; use App\Models\Users\UserPreferences; -use Illuminate\Support\Facades\Cache; use Spatie\Permission\Traits\HasRoles; use Illuminate\Support\Facades\Storage; use Illuminate\Notifications\Notifiable; @@ -330,6 +329,19 @@ public function getDiscordAvatar() return $this->discord_avatar; } + public function genInitialAvatar() + { + $avatar = new InitialAvatar(); + $image = $avatar->name($this->fullName('FL')) + ->size(125) + ->background('#cfeaff') + ->color('#2196f3') + ->generate(); + + Storage::put('files/avatars/'.$this->id.'/initials.png', (string) $image->encode('png')); + return; + } + /** * Returns the user's avatar. * @@ -340,24 +352,7 @@ public function getDiscordAvatar() public function avatar($external = false) { if ($this->avatar_mode == 0) { - $avatar = Cache::remember('users.'.$this->id.'.initialsavatar', 172800, function () { - $avatar = new InitialAvatar(); - $image = $avatar - ->name($this->fullName('FL')) - ->size(125) - ->background('#cfeaff') - ->color('#2196f3') - ->generate(); - Storage::put('public/files/avatars/'.$this->id.'/initials.png', (string) $image->encode('png')); - - return Storage::url('public/files/avatars/'.$this->id.'/initials.png'); - imagedestroy($image); - }); - if ($external) { - return URL('/').$avatar; - } else { - return $avatar; - } + return '/assets/files/avatars/'.$this->id.'/initials.png'; } elseif ($this->avatar_mode == 1) { if ($external) { return URL('/').$this->avatar; @@ -418,4 +413,12 @@ public function getActivitylogOptions(): LogOptions return LogOptions::defaults() ->logOnly(['name', 'text']); } + + public function getUnreadAcknowledgements() + { + $controllerAcknowledgements = Announcement::where('controller_acknowledgement', true)->get(); + return $controllerAcknowledgements->filter(function ($acknowledgement) { + return !ControllerAcknowledgement::where('user_id', $this->id)->where('announcement_id', $acknowledgement->id)->exists(); + }); + } } diff --git a/app/Models/Users/UserNotificationPreferences.php b/app/Models/Users/UserNotificationPreferences.php index f140022c..64221830 100644 --- a/app/Models/Users/UserNotificationPreferences.php +++ b/app/Models/Users/UserNotificationPreferences.php @@ -28,5 +28,5 @@ */ class UserNotificationPreferences extends Model { - // + protected $guarded = []; } diff --git a/app/Models/Users/UserPreferences.php b/app/Models/Users/UserPreferences.php index ab11d083..bf899872 100644 --- a/app/Models/Users/UserPreferences.php +++ b/app/Models/Users/UserPreferences.php @@ -33,9 +33,7 @@ class UserPreferences extends Model { protected $hidden = ['id']; - protected $fillable = [ - 'enable_beta_components', 'ui_mode', 'enable_discord_notifications', 'accent_colour', - ]; + protected $guarded = []; public function user() { diff --git a/app/Models/Users/UserPrivacyPreferences.php b/app/Models/Users/UserPrivacyPreferences.php index 06355b8f..01641732 100644 --- a/app/Models/Users/UserPrivacyPreferences.php +++ b/app/Models/Users/UserPrivacyPreferences.php @@ -30,5 +30,5 @@ */ class UserPrivacyPreferences extends Model { - // + protected $guarded = []; } diff --git a/app/Notifications/News/Announcement.php b/app/Notifications/News/Announcement.php index dd491baf..bf4679b7 100644 --- a/app/Notifications/News/Announcement.php +++ b/app/Notifications/News/Announcement.php @@ -49,7 +49,7 @@ public function toMail($notifiable) ->line(new Htmlstring($this->announcement->html())) ->line("This announcement was sent to you for the following reason: {$this->announcement->reason_for_sending}") ->subject($this->announcement->title) - ->salutation(new HtmlString("Sent by {$this->announcement->user->fullName('FLC')} (".$this->announcement->user->staffProfile->position.')' ?? 'No staff position found'.')')); + ->salutation(new HtmlString("Sent by {$this->announcement->user->fullName('FLC')} (".$this->announcement->user->staffProfile?->position.')')); } /** diff --git a/app/Services/DiscordClient.php b/app/Services/DiscordClient.php index 42314119..ee4a1d48 100644 --- a/app/Services/DiscordClient.php +++ b/app/Services/DiscordClient.php @@ -3,6 +3,7 @@ namespace App\Services; use GuzzleHttp\Client; +use App\Jobs\ProcessDiscordRoles; use GuzzleHttp\Exception\ClientException; class DiscordClient @@ -49,24 +50,16 @@ public function sendMessageWithEmbed($channelId, $title, $description) return $response->getStatusCode() == 200; } - public function assignRole($userId, $roleId) + public function assignRole($discordId, $roleId) { - if ($userId) { - $response = $this->client->put('guilds/' . env('DISCORD_GUILD_ID') . "/members/{$userId}/roles/{$roleId}"); - - return $response->getStatusCode() == 204; - } + ProcessDiscordRoles::dispatch(true, $discordId, $roleId); return; } - public function removeRole($userId, $roleId) + public function removeRole($discordId, $roleId) { - if ($userId) { - $response = $this->client->delete('guilds/' . env('DISCORD_GUILD_ID') . "/members/{$userId}/roles/{$roleId}"); - - return $response->getStatusCode() == 204; - } + ProcessDiscordRoles::dispatch(true, $discordId, $roleId); return; } @@ -89,4 +82,5 @@ public function changeName($userId, $name) } } -} \ No newline at end of file +} + diff --git a/composer.lock b/composer.lock index 4d00a2c3..b0282b9e 100644 --- a/composer.lock +++ b/composer.lock @@ -470,25 +470,94 @@ }, "time": "2022-01-12T11:07:19+00:00" }, + { + "name": "carbonphp/carbon-doctrine-types", + "version": "2.1.0", + "source": { + "type": "git", + "url": "https://github.com/CarbonPHP/carbon-doctrine-types.git", + "reference": "99f76ffa36cce3b70a4a6abce41dba15ca2e84cb" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/CarbonPHP/carbon-doctrine-types/zipball/99f76ffa36cce3b70a4a6abce41dba15ca2e84cb", + "reference": "99f76ffa36cce3b70a4a6abce41dba15ca2e84cb", + "shasum": "" + }, + "require": { + "php": "^7.4 || ^8.0" + }, + "conflict": { + "doctrine/dbal": "<3.7.0 || >=4.0.0" + }, + "require-dev": { + "doctrine/dbal": "^3.7.0", + "nesbot/carbon": "^2.71.0 || ^3.0.0", + "phpunit/phpunit": "^10.3" + }, + "type": "library", + "autoload": { + "psr-4": { + "Carbon\\Doctrine\\": "src/Carbon/Doctrine/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "KyleKatarn", + "email": "kylekatarnls@gmail.com" + } + ], + "description": "Types to use Carbon in Doctrine", + "keywords": [ + "carbon", + "date", + "datetime", + "doctrine", + "time" + ], + "support": { + "issues": "https://github.com/CarbonPHP/carbon-doctrine-types/issues", + "source": "https://github.com/CarbonPHP/carbon-doctrine-types/tree/2.1.0" + }, + "funding": [ + { + "url": "https://github.com/kylekatarnls", + "type": "github" + }, + { + "url": "https://opencollective.com/Carbon", + "type": "open_collective" + }, + { + "url": "https://tidelift.com/funding/github/packagist/nesbot/carbon", + "type": "tidelift" + } + ], + "time": "2023-12-11T17:09:12+00:00" + }, { "name": "clue/stream-filter", - "version": "v1.6.0", + "version": "v1.7.0", "source": { "type": "git", "url": "https://github.com/clue/stream-filter.git", - "reference": "d6169430c7731d8509da7aecd0af756a5747b78e" + "reference": "049509fef80032cb3f051595029ab75b49a3c2f7" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/clue/stream-filter/zipball/d6169430c7731d8509da7aecd0af756a5747b78e", - "reference": "d6169430c7731d8509da7aecd0af756a5747b78e", + "url": "https://api.github.com/repos/clue/stream-filter/zipball/049509fef80032cb3f051595029ab75b49a3c2f7", + "reference": "049509fef80032cb3f051595029ab75b49a3c2f7", "shasum": "" }, "require": { "php": ">=5.3" }, "require-dev": { - "phpunit/phpunit": "^9.3 || ^5.7 || ^4.8.36" + "phpunit/phpunit": "^9.6 || ^5.7 || ^4.8.36" }, "type": "library", "autoload": { @@ -510,7 +579,7 @@ } ], "description": "A simple and modern approach to stream filtering in PHP", - "homepage": "https://github.com/clue/php-stream-filter", + "homepage": "https://github.com/clue/stream-filter", "keywords": [ "bucket brigade", "callback", @@ -522,7 +591,7 @@ ], "support": { "issues": "https://github.com/clue/stream-filter/issues", - "source": "https://github.com/clue/stream-filter/tree/v1.6.0" + "source": "https://github.com/clue/stream-filter/tree/v1.7.0" }, "funding": [ { @@ -534,20 +603,20 @@ "type": "github" } ], - "time": "2022-02-21T13:15:14+00:00" + "time": "2023-12-20T15:40:13+00:00" }, { "name": "composer/ca-bundle", - "version": "1.3.6", + "version": "1.4.0", "source": { "type": "git", "url": "https://github.com/composer/ca-bundle.git", - "reference": "90d087e988ff194065333d16bc5cf649872d9cdb" + "reference": "b66d11b7479109ab547f9405b97205640b17d385" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/composer/ca-bundle/zipball/90d087e988ff194065333d16bc5cf649872d9cdb", - "reference": "90d087e988ff194065333d16bc5cf649872d9cdb", + "url": "https://api.github.com/repos/composer/ca-bundle/zipball/b66d11b7479109ab547f9405b97205640b17d385", + "reference": "b66d11b7479109ab547f9405b97205640b17d385", "shasum": "" }, "require": { @@ -559,7 +628,7 @@ "phpstan/phpstan": "^0.12.55", "psr/log": "^1.0", "symfony/phpunit-bridge": "^4.2 || ^5", - "symfony/process": "^2.5 || ^3.0 || ^4.0 || ^5.0 || ^6.0" + "symfony/process": "^2.5 || ^3.0 || ^4.0 || ^5.0 || ^6.0 || ^7.0" }, "type": "library", "extra": { @@ -594,7 +663,7 @@ "support": { "irc": "irc://irc.freenode.org/composer", "issues": "https://github.com/composer/ca-bundle/issues", - "source": "https://github.com/composer/ca-bundle/tree/1.3.6" + "source": "https://github.com/composer/ca-bundle/tree/1.4.0" }, "funding": [ { @@ -610,7 +679,7 @@ "type": "tidelift" } ], - "time": "2023-06-06T12:02:59+00:00" + "time": "2023-12-18T12:05:55+00:00" }, { "name": "dflydev/dot-access-data", @@ -689,16 +758,16 @@ }, { "name": "doctrine/inflector", - "version": "2.0.8", + "version": "2.0.9", "source": { "type": "git", "url": "https://github.com/doctrine/inflector.git", - "reference": "f9301a5b2fb1216b2b08f02ba04dc45423db6bff" + "reference": "2930cd5ef353871c821d5c43ed030d39ac8cfe65" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/doctrine/inflector/zipball/f9301a5b2fb1216b2b08f02ba04dc45423db6bff", - "reference": "f9301a5b2fb1216b2b08f02ba04dc45423db6bff", + "url": "https://api.github.com/repos/doctrine/inflector/zipball/2930cd5ef353871c821d5c43ed030d39ac8cfe65", + "reference": "2930cd5ef353871c821d5c43ed030d39ac8cfe65", "shasum": "" }, "require": { @@ -760,7 +829,7 @@ ], "support": { "issues": "https://github.com/doctrine/inflector/issues", - "source": "https://github.com/doctrine/inflector/tree/2.0.8" + "source": "https://github.com/doctrine/inflector/tree/2.0.9" }, "funding": [ { @@ -776,7 +845,7 @@ "type": "tidelift" } ], - "time": "2023-06-16T13:40:37+00:00" + "time": "2024-01-15T18:05:13+00:00" }, { "name": "doctrine/lexer", @@ -919,16 +988,16 @@ }, { "name": "dragonmantank/cron-expression", - "version": "v3.3.2", + "version": "v3.3.3", "source": { "type": "git", "url": "https://github.com/dragonmantank/cron-expression.git", - "reference": "782ca5968ab8b954773518e9e49a6f892a34b2a8" + "reference": "adfb1f505deb6384dc8b39804c5065dd3c8c8c0a" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/dragonmantank/cron-expression/zipball/782ca5968ab8b954773518e9e49a6f892a34b2a8", - "reference": "782ca5968ab8b954773518e9e49a6f892a34b2a8", + "url": "https://api.github.com/repos/dragonmantank/cron-expression/zipball/adfb1f505deb6384dc8b39804c5065dd3c8c8c0a", + "reference": "adfb1f505deb6384dc8b39804c5065dd3c8c8c0a", "shasum": "" }, "require": { @@ -968,7 +1037,7 @@ ], "support": { "issues": "https://github.com/dragonmantank/cron-expression/issues", - "source": "https://github.com/dragonmantank/cron-expression/tree/v3.3.2" + "source": "https://github.com/dragonmantank/cron-expression/tree/v3.3.3" }, "funding": [ { @@ -976,20 +1045,20 @@ "type": "github" } ], - "time": "2022-09-10T18:51:20+00:00" + "time": "2023-08-10T19:36:49+00:00" }, { "name": "egulias/email-validator", - "version": "4.0.1", + "version": "4.0.2", "source": { "type": "git", "url": "https://github.com/egulias/EmailValidator.git", - "reference": "3a85486b709bc384dae8eb78fb2eec649bdb64ff" + "reference": "ebaaf5be6c0286928352e054f2d5125608e5405e" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/egulias/EmailValidator/zipball/3a85486b709bc384dae8eb78fb2eec649bdb64ff", - "reference": "3a85486b709bc384dae8eb78fb2eec649bdb64ff", + "url": "https://api.github.com/repos/egulias/EmailValidator/zipball/ebaaf5be6c0286928352e054f2d5125608e5405e", + "reference": "ebaaf5be6c0286928352e054f2d5125608e5405e", "shasum": "" }, "require": { @@ -998,8 +1067,8 @@ "symfony/polyfill-intl-idn": "^1.26" }, "require-dev": { - "phpunit/phpunit": "^9.5.27", - "vimeo/psalm": "^4.30" + "phpunit/phpunit": "^10.2", + "vimeo/psalm": "^5.12" }, "suggest": { "ext-intl": "PHP Internationalization Libraries are required to use the SpoofChecking validation" @@ -1035,7 +1104,7 @@ ], "support": { "issues": "https://github.com/egulias/EmailValidator/issues", - "source": "https://github.com/egulias/EmailValidator/tree/4.0.1" + "source": "https://github.com/egulias/EmailValidator/tree/4.0.2" }, "funding": [ { @@ -1043,7 +1112,7 @@ "type": "github" } ], - "time": "2023-01-14T14:17:03+00:00" + "time": "2023-10-06T06:47:41+00:00" }, { "name": "erusev/parsedown", @@ -1155,21 +1224,21 @@ }, { "name": "fruitcake/php-cors", - "version": "v1.2.0", + "version": "v1.3.0", "source": { "type": "git", "url": "https://github.com/fruitcake/php-cors.git", - "reference": "58571acbaa5f9f462c9c77e911700ac66f446d4e" + "reference": "3d158f36e7875e2f040f37bc0573956240a5a38b" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/fruitcake/php-cors/zipball/58571acbaa5f9f462c9c77e911700ac66f446d4e", - "reference": "58571acbaa5f9f462c9c77e911700ac66f446d4e", + "url": "https://api.github.com/repos/fruitcake/php-cors/zipball/3d158f36e7875e2f040f37bc0573956240a5a38b", + "reference": "3d158f36e7875e2f040f37bc0573956240a5a38b", "shasum": "" }, "require": { "php": "^7.4|^8.0", - "symfony/http-foundation": "^4.4|^5.4|^6" + "symfony/http-foundation": "^4.4|^5.4|^6|^7" }, "require-dev": { "phpstan/phpstan": "^1.4", @@ -1179,7 +1248,7 @@ "type": "library", "extra": { "branch-alias": { - "dev-main": "1.1-dev" + "dev-master": "1.2-dev" } }, "autoload": { @@ -1210,7 +1279,7 @@ ], "support": { "issues": "https://github.com/fruitcake/php-cors/issues", - "source": "https://github.com/fruitcake/php-cors/tree/v1.2.0" + "source": "https://github.com/fruitcake/php-cors/tree/v1.3.0" }, "funding": [ { @@ -1222,28 +1291,28 @@ "type": "github" } ], - "time": "2022-02-20T15:07:15+00:00" + "time": "2023-10-12T05:21:21+00:00" }, { "name": "graham-campbell/result-type", - "version": "v1.1.1", + "version": "v1.1.2", "source": { "type": "git", "url": "https://github.com/GrahamCampbell/Result-Type.git", - "reference": "672eff8cf1d6fe1ef09ca0f89c4b287d6a3eb831" + "reference": "fbd48bce38f73f8a4ec8583362e732e4095e5862" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/GrahamCampbell/Result-Type/zipball/672eff8cf1d6fe1ef09ca0f89c4b287d6a3eb831", - "reference": "672eff8cf1d6fe1ef09ca0f89c4b287d6a3eb831", + "url": "https://api.github.com/repos/GrahamCampbell/Result-Type/zipball/fbd48bce38f73f8a4ec8583362e732e4095e5862", + "reference": "fbd48bce38f73f8a4ec8583362e732e4095e5862", "shasum": "" }, "require": { "php": "^7.2.5 || ^8.0", - "phpoption/phpoption": "^1.9.1" + "phpoption/phpoption": "^1.9.2" }, "require-dev": { - "phpunit/phpunit": "^8.5.32 || ^9.6.3 || ^10.0.12" + "phpunit/phpunit": "^8.5.34 || ^9.6.13 || ^10.4.2" }, "type": "library", "autoload": { @@ -1272,7 +1341,7 @@ ], "support": { "issues": "https://github.com/GrahamCampbell/Result-Type/issues", - "source": "https://github.com/GrahamCampbell/Result-Type/tree/v1.1.1" + "source": "https://github.com/GrahamCampbell/Result-Type/tree/v1.1.2" }, "funding": [ { @@ -1284,7 +1353,7 @@ "type": "tidelift" } ], - "time": "2023-02-25T20:23:15+00:00" + "time": "2023-11-12T22:16:48+00:00" }, { "name": "guzzlehttp/guzzle", @@ -1613,30 +1682,32 @@ }, { "name": "guzzlehttp/uri-template", - "version": "v1.0.1", + "version": "v1.0.3", "source": { "type": "git", "url": "https://github.com/guzzle/uri-template.git", - "reference": "b945d74a55a25a949158444f09ec0d3c120d69e2" + "reference": "ecea8feef63bd4fef1f037ecb288386999ecc11c" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/guzzle/uri-template/zipball/b945d74a55a25a949158444f09ec0d3c120d69e2", - "reference": "b945d74a55a25a949158444f09ec0d3c120d69e2", + "url": "https://api.github.com/repos/guzzle/uri-template/zipball/ecea8feef63bd4fef1f037ecb288386999ecc11c", + "reference": "ecea8feef63bd4fef1f037ecb288386999ecc11c", "shasum": "" }, "require": { "php": "^7.2.5 || ^8.0", - "symfony/polyfill-php80": "^1.17" + "symfony/polyfill-php80": "^1.24" }, "require-dev": { - "phpunit/phpunit": "^8.5.19 || ^9.5.8", + "bamarni/composer-bin-plugin": "^1.8.2", + "phpunit/phpunit": "^8.5.36 || ^9.6.15", "uri-template/tests": "1.0.0" }, "type": "library", "extra": { - "branch-alias": { - "dev-master": "1.0-dev" + "bamarni-bin": { + "bin-links": true, + "forward-command": false } }, "autoload": { @@ -1677,7 +1748,7 @@ ], "support": { "issues": "https://github.com/guzzle/uri-template/issues", - "source": "https://github.com/guzzle/uri-template/tree/v1.0.1" + "source": "https://github.com/guzzle/uri-template/tree/v1.0.3" }, "funding": [ { @@ -1693,7 +1764,7 @@ "type": "tidelift" } ], - "time": "2021-10-07T12:57:01+00:00" + "time": "2023-12-03T19:50:20+00:00" }, { "name": "http-interop/http-factory-guzzle", @@ -1898,16 +1969,16 @@ }, { "name": "laravel-notification-channels/discord", - "version": "v1.5.0", + "version": "v1.5.1", "source": { "type": "git", "url": "https://github.com/laravel-notification-channels/discord.git", - "reference": "a4ef4fc20e8adafce0b3416a3bf7abb9d5d03b95" + "reference": "11ab1bf59a36080cd8833a0d1f335cb50be7c9b6" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/laravel-notification-channels/discord/zipball/a4ef4fc20e8adafce0b3416a3bf7abb9d5d03b95", - "reference": "a4ef4fc20e8adafce0b3416a3bf7abb9d5d03b95", + "url": "https://api.github.com/repos/laravel-notification-channels/discord/zipball/11ab1bf59a36080cd8833a0d1f335cb50be7c9b6", + "reference": "11ab1bf59a36080cd8833a0d1f335cb50be7c9b6", "shasum": "" }, "require": { @@ -1960,22 +2031,22 @@ ], "support": { "issues": "https://github.com/laravel-notification-channels/discord/issues", - "source": "https://github.com/laravel-notification-channels/discord/tree/v1.5.0" + "source": "https://github.com/laravel-notification-channels/discord/tree/v1.5.1" }, - "time": "2023-05-01T00:05:15+00:00" + "time": "2024-01-13T22:27:06+00:00" }, { "name": "laravel/framework", - "version": "v9.52.9", + "version": "v9.52.16", "source": { "type": "git", "url": "https://github.com/laravel/framework.git", - "reference": "c512ece7b1ee393eac5893f37cb2b029a5413b97" + "reference": "082345d76fc6a55b649572efe10b11b03e279d24" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/laravel/framework/zipball/c512ece7b1ee393eac5893f37cb2b029a5413b97", - "reference": "c512ece7b1ee393eac5893f37cb2b029a5413b97", + "url": "https://api.github.com/repos/laravel/framework/zipball/082345d76fc6a55b649572efe10b11b03e279d24", + "reference": "082345d76fc6a55b649572efe10b11b03e279d24", "shasum": "" }, "require": { @@ -2160,20 +2231,20 @@ "issues": "https://github.com/laravel/framework/issues", "source": "https://github.com/laravel/framework" }, - "time": "2023-06-08T20:06:23+00:00" + "time": "2023-10-03T13:02:30+00:00" }, { "name": "laravel/serializable-closure", - "version": "v1.3.0", + "version": "v1.3.3", "source": { "type": "git", "url": "https://github.com/laravel/serializable-closure.git", - "reference": "f23fe9d4e95255dacee1bf3525e0810d1a1b0f37" + "reference": "3dbf8a8e914634c48d389c1234552666b3d43754" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/laravel/serializable-closure/zipball/f23fe9d4e95255dacee1bf3525e0810d1a1b0f37", - "reference": "f23fe9d4e95255dacee1bf3525e0810d1a1b0f37", + "url": "https://api.github.com/repos/laravel/serializable-closure/zipball/3dbf8a8e914634c48d389c1234552666b3d43754", + "reference": "3dbf8a8e914634c48d389c1234552666b3d43754", "shasum": "" }, "require": { @@ -2220,42 +2291,40 @@ "issues": "https://github.com/laravel/serializable-closure/issues", "source": "https://github.com/laravel/serializable-closure" }, - "time": "2023-01-30T18:31:20+00:00" + "time": "2023-11-08T14:08:06+00:00" }, { "name": "laravel/tinker", - "version": "v2.8.1", + "version": "v2.9.0", "source": { "type": "git", "url": "https://github.com/laravel/tinker.git", - "reference": "04a2d3bd0d650c0764f70bf49d1ee39393e4eb10" + "reference": "502e0fe3f0415d06d5db1f83a472f0f3b754bafe" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/laravel/tinker/zipball/04a2d3bd0d650c0764f70bf49d1ee39393e4eb10", - "reference": "04a2d3bd0d650c0764f70bf49d1ee39393e4eb10", + "url": "https://api.github.com/repos/laravel/tinker/zipball/502e0fe3f0415d06d5db1f83a472f0f3b754bafe", + "reference": "502e0fe3f0415d06d5db1f83a472f0f3b754bafe", "shasum": "" }, "require": { - "illuminate/console": "^6.0|^7.0|^8.0|^9.0|^10.0", - "illuminate/contracts": "^6.0|^7.0|^8.0|^9.0|^10.0", - "illuminate/support": "^6.0|^7.0|^8.0|^9.0|^10.0", + "illuminate/console": "^6.0|^7.0|^8.0|^9.0|^10.0|^11.0", + "illuminate/contracts": "^6.0|^7.0|^8.0|^9.0|^10.0|^11.0", + "illuminate/support": "^6.0|^7.0|^8.0|^9.0|^10.0|^11.0", "php": "^7.2.5|^8.0", - "psy/psysh": "^0.10.4|^0.11.1", - "symfony/var-dumper": "^4.3.4|^5.0|^6.0" + "psy/psysh": "^0.11.1|^0.12.0", + "symfony/var-dumper": "^4.3.4|^5.0|^6.0|^7.0" }, "require-dev": { "mockery/mockery": "~1.3.3|^1.4.2", + "phpstan/phpstan": "^1.10", "phpunit/phpunit": "^8.5.8|^9.3.3" }, "suggest": { - "illuminate/database": "The Illuminate Database package (^6.0|^7.0|^8.0|^9.0|^10.0)." + "illuminate/database": "The Illuminate Database package (^6.0|^7.0|^8.0|^9.0|^10.0|^11.0)." }, "type": "library", "extra": { - "branch-alias": { - "dev-master": "2.x-dev" - }, "laravel": { "providers": [ "Laravel\\Tinker\\TinkerServiceProvider" @@ -2286,34 +2355,34 @@ ], "support": { "issues": "https://github.com/laravel/tinker/issues", - "source": "https://github.com/laravel/tinker/tree/v2.8.1" + "source": "https://github.com/laravel/tinker/tree/v2.9.0" }, - "time": "2023-02-15T16:40:09+00:00" + "time": "2024-01-04T16:10:04+00:00" }, { "name": "laravel/ui", - "version": "v4.2.2", + "version": "v4.4.0", "source": { "type": "git", "url": "https://github.com/laravel/ui.git", - "reference": "a58ec468db4a340b33f3426c778784717a2c144b" + "reference": "7335d7049b2cde345c029e9d2de839b80af62bc0" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/laravel/ui/zipball/a58ec468db4a340b33f3426c778784717a2c144b", - "reference": "a58ec468db4a340b33f3426c778784717a2c144b", + "url": "https://api.github.com/repos/laravel/ui/zipball/7335d7049b2cde345c029e9d2de839b80af62bc0", + "reference": "7335d7049b2cde345c029e9d2de839b80af62bc0", "shasum": "" }, "require": { - "illuminate/console": "^9.21|^10.0", - "illuminate/filesystem": "^9.21|^10.0", - "illuminate/support": "^9.21|^10.0", - "illuminate/validation": "^9.21|^10.0", + "illuminate/console": "^9.21|^10.0|^11.0", + "illuminate/filesystem": "^9.21|^10.0|^11.0", + "illuminate/support": "^9.21|^10.0|^11.0", + "illuminate/validation": "^9.21|^10.0|^11.0", "php": "^8.0" }, "require-dev": { - "orchestra/testbench": "^7.0|^8.0", - "phpunit/phpunit": "^9.3" + "orchestra/testbench": "^7.0|^8.0|^9.0", + "phpunit/phpunit": "^9.3|^10.4" }, "type": "library", "extra": { @@ -2348,9 +2417,9 @@ "ui" ], "support": { - "source": "https://github.com/laravel/ui/tree/v4.2.2" + "source": "https://github.com/laravel/ui/tree/v4.4.0" }, - "time": "2023-05-09T19:47:28+00:00" + "time": "2024-01-12T15:56:45+00:00" }, { "name": "laravelcollective/html", @@ -2427,31 +2496,29 @@ }, { "name": "lasserafn/php-initial-avatar-generator", - "version": "4.2.1", + "version": "4.3", "source": { "type": "git", "url": "https://github.com/LasseRafn/php-initial-avatar-generator.git", - "reference": "49d0b10cc8819af831e0f6fb1056a7d5ed9512d0" + "reference": "ffe43d8df3f18646d7b23011272cce2d71400e1f" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/LasseRafn/php-initial-avatar-generator/zipball/49d0b10cc8819af831e0f6fb1056a7d5ed9512d0", - "reference": "49d0b10cc8819af831e0f6fb1056a7d5ed9512d0", + "url": "https://api.github.com/repos/LasseRafn/php-initial-avatar-generator/zipball/ffe43d8df3f18646d7b23011272cce2d71400e1f", + "reference": "ffe43d8df3f18646d7b23011272cce2d71400e1f", "shasum": "" }, "require": { "ext-json": "*", "intervention/image": "^2.3", "lasserafn/php-initials": "^3.0", - "lasserafn/php-string-script-language": "^0.3.0", + "lasserafn/php-string-script-language": "^0.4", "meyfa/php-svg": "^0.9.0", "overtrue/pinyin": "^4.0", - "php": "^7.0|^7.1|^7.2|^7.3|^7.4|^8.0" + "php": "^7.0|^7.1|^7.2|^7.3|^7.4|^8.0|^8.1|^8.2" }, "require-dev": { - "doctrine/instantiator": "1.0.*", - "phpunit/phpunit": "^6.5", - "satooshi/php-coveralls": "^1.0" + "phpunit/phpunit": "^8.5" }, "type": "library", "autoload": { @@ -2478,7 +2545,7 @@ ], "support": { "issues": "https://github.com/LasseRafn/php-initial-avatar-generator/issues", - "source": "https://github.com/LasseRafn/php-initial-avatar-generator/tree/4.2.1" + "source": "https://github.com/LasseRafn/php-initial-avatar-generator/tree/4.3" }, "funding": [ { @@ -2486,7 +2553,7 @@ "type": "open_collective" } ], - "time": "2020-12-24T13:12:12+00:00" + "time": "2023-07-26T19:17:56+00:00" }, { "name": "lasserafn/php-initials", @@ -2538,20 +2605,20 @@ }, { "name": "lasserafn/php-string-script-language", - "version": "0.3", + "version": "0.4", "source": { "type": "git", "url": "https://github.com/LasseRafn/php-string-script-language.git", - "reference": "49a09d4a5e38c1e59a2656ac05b601d615c7cddb" + "reference": "cab5612d4382067de855fcecc7c09108dca77fb5" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/LasseRafn/php-string-script-language/zipball/49a09d4a5e38c1e59a2656ac05b601d615c7cddb", - "reference": "49a09d4a5e38c1e59a2656ac05b601d615c7cddb", + "url": "https://api.github.com/repos/LasseRafn/php-string-script-language/zipball/cab5612d4382067de855fcecc7c09108dca77fb5", + "reference": "cab5612d4382067de855fcecc7c09108dca77fb5", "shasum": "" }, "require": { - "php": "^5.6|^7.0|^7.1|^8.0" + "php": "^5.6|^7.0|^7.1|^8.0|^8.1|^8.2" }, "require-dev": { "doctrine/instantiator": "1.0.5", @@ -2584,22 +2651,22 @@ ], "support": { "issues": "https://github.com/LasseRafn/php-string-script-language/issues", - "source": "https://github.com/LasseRafn/php-string-script-language/tree/0.3" + "source": "https://github.com/LasseRafn/php-string-script-language/tree/0.4" }, - "time": "2020-12-24T12:43:59+00:00" + "time": "2023-07-26T07:23:39+00:00" }, { "name": "league/commonmark", - "version": "2.4.0", + "version": "2.4.2", "source": { "type": "git", "url": "https://github.com/thephpleague/commonmark.git", - "reference": "d44a24690f16b8c1808bf13b1bd54ae4c63ea048" + "reference": "91c24291965bd6d7c46c46a12ba7492f83b1cadf" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/thephpleague/commonmark/zipball/d44a24690f16b8c1808bf13b1bd54ae4c63ea048", - "reference": "d44a24690f16b8c1808bf13b1bd54ae4c63ea048", + "url": "https://api.github.com/repos/thephpleague/commonmark/zipball/91c24291965bd6d7c46c46a12ba7492f83b1cadf", + "reference": "91c24291965bd6d7c46c46a12ba7492f83b1cadf", "shasum": "" }, "require": { @@ -2612,7 +2679,7 @@ }, "require-dev": { "cebe/markdown": "^1.0", - "commonmark/cmark": "0.30.0", + "commonmark/cmark": "0.30.3", "commonmark/commonmark.js": "0.30.0", "composer/package-versions-deprecated": "^1.8", "embed/embed": "^4.4", @@ -2622,10 +2689,10 @@ "michelf/php-markdown": "^1.4 || ^2.0", "nyholm/psr7": "^1.5", "phpstan/phpstan": "^1.8.2", - "phpunit/phpunit": "^9.5.21", + "phpunit/phpunit": "^9.5.21 || ^10.5.9 || ^11.0.0", "scrutinizer/ocular": "^1.8.1", - "symfony/finder": "^5.3 | ^6.0", - "symfony/yaml": "^2.3 | ^3.0 | ^4.0 | ^5.0 | ^6.0", + "symfony/finder": "^5.3 | ^6.0 || ^7.0", + "symfony/yaml": "^2.3 | ^3.0 | ^4.0 | ^5.0 | ^6.0 || ^7.0", "unleashedtech/php-coding-standard": "^3.1.1", "vimeo/psalm": "^4.24.0 || ^5.0.0" }, @@ -2692,7 +2759,7 @@ "type": "tidelift" } ], - "time": "2023-03-24T15:16:10+00:00" + "time": "2024-02-02T11:59:32+00:00" }, { "name": "league/config", @@ -2778,16 +2845,16 @@ }, { "name": "league/flysystem", - "version": "3.15.1", + "version": "3.23.1", "source": { "type": "git", "url": "https://github.com/thephpleague/flysystem.git", - "reference": "a141d430414fcb8bf797a18716b09f759a385bed" + "reference": "199e1aebbe3e62bd39f4d4fc8c61ce0b3786197e" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/thephpleague/flysystem/zipball/a141d430414fcb8bf797a18716b09f759a385bed", - "reference": "a141d430414fcb8bf797a18716b09f759a385bed", + "url": "https://api.github.com/repos/thephpleague/flysystem/zipball/199e1aebbe3e62bd39f4d4fc8c61ce0b3786197e", + "reference": "199e1aebbe3e62bd39f4d4fc8c61ce0b3786197e", "shasum": "" }, "require": { @@ -2796,6 +2863,8 @@ "php": "^8.0.2" }, "conflict": { + "async-aws/core": "<1.19.0", + "async-aws/s3": "<1.14.0", "aws/aws-sdk-php": "3.209.31 || 3.210.0", "guzzlehttp/guzzle": "<7.0", "guzzlehttp/ringphp": "<1.1.1", @@ -2803,8 +2872,8 @@ "symfony/http-client": "<5.2" }, "require-dev": { - "async-aws/s3": "^1.5", - "async-aws/simple-s3": "^1.1", + "async-aws/s3": "^1.5 || ^2.0", + "async-aws/simple-s3": "^1.1 || ^2.0", "aws/aws-sdk-php": "^3.220.0", "composer/semver": "^3.0", "ext-fileinfo": "*", @@ -2813,9 +2882,9 @@ "friendsofphp/php-cs-fixer": "^3.5", "google/cloud-storage": "^1.23", "microsoft/azure-storage-blob": "^1.1", - "phpseclib/phpseclib": "^3.0.14", - "phpstan/phpstan": "^0.12.26", - "phpunit/phpunit": "^9.5.11", + "phpseclib/phpseclib": "^3.0.34", + "phpstan/phpstan": "^1.10", + "phpunit/phpunit": "^9.5.11|^10.0", "sabre/dav": "^4.3.1" }, "type": "library", @@ -2850,7 +2919,7 @@ ], "support": { "issues": "https://github.com/thephpleague/flysystem/issues", - "source": "https://github.com/thephpleague/flysystem/tree/3.15.1" + "source": "https://github.com/thephpleague/flysystem/tree/3.23.1" }, "funding": [ { @@ -2862,20 +2931,20 @@ "type": "github" } ], - "time": "2023-05-04T09:04:26+00:00" + "time": "2024-01-26T18:42:03+00:00" }, { "name": "league/flysystem-aws-s3-v3", - "version": "3.15.0", + "version": "3.23.1", "source": { "type": "git", "url": "https://github.com/thephpleague/flysystem-aws-s3-v3.git", - "reference": "d8de61ee10b6a607e7996cff388c5a3a663e8c8a" + "reference": "97728e7a0d40ec9c6147eb0f4ee4cdc6ff0a8240" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/thephpleague/flysystem-aws-s3-v3/zipball/d8de61ee10b6a607e7996cff388c5a3a663e8c8a", - "reference": "d8de61ee10b6a607e7996cff388c5a3a663e8c8a", + "url": "https://api.github.com/repos/thephpleague/flysystem-aws-s3-v3/zipball/97728e7a0d40ec9c6147eb0f4ee4cdc6ff0a8240", + "reference": "97728e7a0d40ec9c6147eb0f4ee4cdc6ff0a8240", "shasum": "" }, "require": { @@ -2916,7 +2985,7 @@ ], "support": { "issues": "https://github.com/thephpleague/flysystem-aws-s3-v3/issues", - "source": "https://github.com/thephpleague/flysystem-aws-s3-v3/tree/3.15.0" + "source": "https://github.com/thephpleague/flysystem-aws-s3-v3/tree/3.23.1" }, "funding": [ { @@ -2928,20 +2997,20 @@ "type": "github" } ], - "time": "2023-05-02T20:02:14+00:00" + "time": "2024-01-26T18:25:23+00:00" }, { "name": "league/flysystem-local", - "version": "3.15.0", + "version": "3.23.1", "source": { "type": "git", "url": "https://github.com/thephpleague/flysystem-local.git", - "reference": "543f64c397fefdf9cfeac443ffb6beff602796b3" + "reference": "b884d2bf9b53bb4804a56d2df4902bb51e253f00" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/thephpleague/flysystem-local/zipball/543f64c397fefdf9cfeac443ffb6beff602796b3", - "reference": "543f64c397fefdf9cfeac443ffb6beff602796b3", + "url": "https://api.github.com/repos/thephpleague/flysystem-local/zipball/b884d2bf9b53bb4804a56d2df4902bb51e253f00", + "reference": "b884d2bf9b53bb4804a56d2df4902bb51e253f00", "shasum": "" }, "require": { @@ -2976,7 +3045,7 @@ ], "support": { "issues": "https://github.com/thephpleague/flysystem-local/issues", - "source": "https://github.com/thephpleague/flysystem-local/tree/3.15.0" + "source": "https://github.com/thephpleague/flysystem-local/tree/3.23.1" }, "funding": [ { @@ -2988,30 +3057,30 @@ "type": "github" } ], - "time": "2023-05-02T20:02:14+00:00" + "time": "2024-01-26T18:25:23+00:00" }, { "name": "league/mime-type-detection", - "version": "1.11.0", + "version": "1.15.0", "source": { "type": "git", "url": "https://github.com/thephpleague/mime-type-detection.git", - "reference": "ff6248ea87a9f116e78edd6002e39e5128a0d4dd" + "reference": "ce0f4d1e8a6f4eb0ddff33f57c69c50fd09f4301" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/thephpleague/mime-type-detection/zipball/ff6248ea87a9f116e78edd6002e39e5128a0d4dd", - "reference": "ff6248ea87a9f116e78edd6002e39e5128a0d4dd", + "url": "https://api.github.com/repos/thephpleague/mime-type-detection/zipball/ce0f4d1e8a6f4eb0ddff33f57c69c50fd09f4301", + "reference": "ce0f4d1e8a6f4eb0ddff33f57c69c50fd09f4301", "shasum": "" }, "require": { "ext-fileinfo": "*", - "php": "^7.2 || ^8.0" + "php": "^7.4 || ^8.0" }, "require-dev": { "friendsofphp/php-cs-fixer": "^3.2", "phpstan/phpstan": "^0.12.68", - "phpunit/phpunit": "^8.5.8 || ^9.3" + "phpunit/phpunit": "^8.5.8 || ^9.3 || ^10.0" }, "type": "library", "autoload": { @@ -3032,7 +3101,7 @@ "description": "Mime-type detection for Flysystem", "support": { "issues": "https://github.com/thephpleague/mime-type-detection/issues", - "source": "https://github.com/thephpleague/mime-type-detection/tree/1.11.0" + "source": "https://github.com/thephpleague/mime-type-detection/tree/1.15.0" }, "funding": [ { @@ -3044,20 +3113,20 @@ "type": "tidelift" } ], - "time": "2022-04-17T13:12:02+00:00" + "time": "2024-01-28T23:22:08+00:00" }, { "name": "livewire/livewire", - "version": "v2.12.3", + "version": "v2.12.6", "source": { "type": "git", "url": "https://github.com/livewire/livewire.git", - "reference": "019b1e69d8cd8c7e749eba7a38e4fa69ecbc8f74" + "reference": "7d3a57b3193299cf1a0639a3935c696f4da2cf92" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/livewire/livewire/zipball/019b1e69d8cd8c7e749eba7a38e4fa69ecbc8f74", - "reference": "019b1e69d8cd8c7e749eba7a38e4fa69ecbc8f74", + "url": "https://api.github.com/repos/livewire/livewire/zipball/7d3a57b3193299cf1a0639a3935c696f4da2cf92", + "reference": "7d3a57b3193299cf1a0639a3935c696f4da2cf92", "shasum": "" }, "require": { @@ -3109,7 +3178,7 @@ "description": "A front-end framework for Laravel.", "support": { "issues": "https://github.com/livewire/livewire/issues", - "source": "https://github.com/livewire/livewire/tree/v2.12.3" + "source": "https://github.com/livewire/livewire/tree/v2.12.6" }, "funding": [ { @@ -3117,7 +3186,7 @@ "type": "github" } ], - "time": "2023-03-03T20:12:38+00:00" + "time": "2023-08-11T04:02:34+00:00" }, { "name": "marvinlabs/laravel-discord-logger", @@ -3411,16 +3480,16 @@ }, { "name": "monolog/monolog", - "version": "2.9.1", + "version": "2.9.2", "source": { "type": "git", "url": "https://github.com/Seldaek/monolog.git", - "reference": "f259e2b15fb95494c83f52d3caad003bbf5ffaa1" + "reference": "437cb3628f4cf6042cc10ae97fc2b8472e48ca1f" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/Seldaek/monolog/zipball/f259e2b15fb95494c83f52d3caad003bbf5ffaa1", - "reference": "f259e2b15fb95494c83f52d3caad003bbf5ffaa1", + "url": "https://api.github.com/repos/Seldaek/monolog/zipball/437cb3628f4cf6042cc10ae97fc2b8472e48ca1f", + "reference": "437cb3628f4cf6042cc10ae97fc2b8472e48ca1f", "shasum": "" }, "require": { @@ -3497,7 +3566,7 @@ ], "support": { "issues": "https://github.com/Seldaek/monolog/issues", - "source": "https://github.com/Seldaek/monolog/tree/2.9.1" + "source": "https://github.com/Seldaek/monolog/tree/2.9.2" }, "funding": [ { @@ -3509,7 +3578,7 @@ "type": "tidelift" } ], - "time": "2023-02-06T13:44:46+00:00" + "time": "2023-10-27T15:25:26+00:00" }, { "name": "mtdowling/jmespath.php", @@ -3579,28 +3648,33 @@ }, { "name": "nesbot/carbon", - "version": "2.67.0", + "version": "2.72.3", "source": { "type": "git", "url": "https://github.com/briannesbitt/Carbon.git", - "reference": "c1001b3bc75039b07f38a79db5237c4c529e04c8" + "reference": "0c6fd108360c562f6e4fd1dedb8233b423e91c83" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/briannesbitt/Carbon/zipball/c1001b3bc75039b07f38a79db5237c4c529e04c8", - "reference": "c1001b3bc75039b07f38a79db5237c4c529e04c8", + "url": "https://api.github.com/repos/briannesbitt/Carbon/zipball/0c6fd108360c562f6e4fd1dedb8233b423e91c83", + "reference": "0c6fd108360c562f6e4fd1dedb8233b423e91c83", "shasum": "" }, "require": { + "carbonphp/carbon-doctrine-types": "*", "ext-json": "*", "php": "^7.1.8 || ^8.0", + "psr/clock": "^1.0", "symfony/polyfill-mbstring": "^1.0", "symfony/polyfill-php80": "^1.16", "symfony/translation": "^3.4 || ^4.0 || ^5.0 || ^6.0" }, + "provide": { + "psr/clock-implementation": "1.0" + }, "require-dev": { - "doctrine/dbal": "^2.0 || ^3.1.4", - "doctrine/orm": "^2.7", + "doctrine/dbal": "^2.0 || ^3.1.4 || ^4.0", + "doctrine/orm": "^2.7 || ^3.0", "friendsofphp/php-cs-fixer": "^3.0", "kylekatarnls/multi-tester": "^2.0", "ondrejmirtes/better-reflection": "*", @@ -3677,35 +3751,35 @@ "type": "tidelift" } ], - "time": "2023-05-25T22:09:47+00:00" + "time": "2024-01-25T10:35:09+00:00" }, { "name": "nette/schema", - "version": "v1.2.3", + "version": "v1.3.0", "source": { "type": "git", "url": "https://github.com/nette/schema.git", - "reference": "abbdbb70e0245d5f3bf77874cea1dfb0c930d06f" + "reference": "a6d3a6d1f545f01ef38e60f375d1cf1f4de98188" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/nette/schema/zipball/abbdbb70e0245d5f3bf77874cea1dfb0c930d06f", - "reference": "abbdbb70e0245d5f3bf77874cea1dfb0c930d06f", + "url": "https://api.github.com/repos/nette/schema/zipball/a6d3a6d1f545f01ef38e60f375d1cf1f4de98188", + "reference": "a6d3a6d1f545f01ef38e60f375d1cf1f4de98188", "shasum": "" }, "require": { - "nette/utils": "^2.5.7 || ^3.1.5 || ^4.0", - "php": ">=7.1 <8.3" + "nette/utils": "^4.0", + "php": "8.1 - 8.3" }, "require-dev": { - "nette/tester": "^2.3 || ^2.4", + "nette/tester": "^2.4", "phpstan/phpstan-nette": "^1.0", - "tracy/tracy": "^2.7" + "tracy/tracy": "^2.8" }, "type": "library", "extra": { "branch-alias": { - "dev-master": "1.2-dev" + "dev-master": "1.3-dev" } }, "autoload": { @@ -3737,26 +3811,26 @@ ], "support": { "issues": "https://github.com/nette/schema/issues", - "source": "https://github.com/nette/schema/tree/v1.2.3" + "source": "https://github.com/nette/schema/tree/v1.3.0" }, - "time": "2022-10-13T01:24:26+00:00" + "time": "2023-12-11T11:54:22+00:00" }, { "name": "nette/utils", - "version": "v4.0.0", + "version": "v4.0.4", "source": { "type": "git", "url": "https://github.com/nette/utils.git", - "reference": "cacdbf5a91a657ede665c541eda28941d4b09c1e" + "reference": "d3ad0aa3b9f934602cb3e3902ebccf10be34d218" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/nette/utils/zipball/cacdbf5a91a657ede665c541eda28941d4b09c1e", - "reference": "cacdbf5a91a657ede665c541eda28941d4b09c1e", + "url": "https://api.github.com/repos/nette/utils/zipball/d3ad0aa3b9f934602cb3e3902ebccf10be34d218", + "reference": "d3ad0aa3b9f934602cb3e3902ebccf10be34d218", "shasum": "" }, "require": { - "php": ">=8.0 <8.3" + "php": ">=8.0 <8.4" }, "conflict": { "nette/finder": "<3", @@ -3764,7 +3838,7 @@ }, "require-dev": { "jetbrains/phpstorm-attributes": "dev-master", - "nette/tester": "^2.4", + "nette/tester": "^2.5", "phpstan/phpstan": "^1.0", "tracy/tracy": "^2.9" }, @@ -3774,8 +3848,7 @@ "ext-intl": "to use Strings::webalize(), toAscii(), normalize() and compare()", "ext-json": "to use Nette\\Utils\\Json", "ext-mbstring": "to use Strings::lower() etc...", - "ext-tokenizer": "to use Nette\\Utils\\Reflection::getUseStatements()", - "ext-xml": "to use Strings::length() etc. when mbstring is not available" + "ext-tokenizer": "to use Nette\\Utils\\Reflection::getUseStatements()" }, "type": "library", "extra": { @@ -3824,22 +3897,22 @@ ], "support": { "issues": "https://github.com/nette/utils/issues", - "source": "https://github.com/nette/utils/tree/v4.0.0" + "source": "https://github.com/nette/utils/tree/v4.0.4" }, - "time": "2023-02-02T10:41:53+00:00" + "time": "2024-01-17T16:50:36+00:00" }, { "name": "nikic/php-parser", - "version": "v4.15.5", + "version": "v4.18.0", "source": { "type": "git", "url": "https://github.com/nikic/PHP-Parser.git", - "reference": "11e2663a5bc9db5d714eedb4277ee300403b4a9e" + "reference": "1bcbb2179f97633e98bbbc87044ee2611c7d7999" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/nikic/PHP-Parser/zipball/11e2663a5bc9db5d714eedb4277ee300403b4a9e", - "reference": "11e2663a5bc9db5d714eedb4277ee300403b4a9e", + "url": "https://api.github.com/repos/nikic/PHP-Parser/zipball/1bcbb2179f97633e98bbbc87044ee2611c7d7999", + "reference": "1bcbb2179f97633e98bbbc87044ee2611c7d7999", "shasum": "" }, "require": { @@ -3880,9 +3953,9 @@ ], "support": { "issues": "https://github.com/nikic/PHP-Parser/issues", - "source": "https://github.com/nikic/PHP-Parser/tree/v4.15.5" + "source": "https://github.com/nikic/PHP-Parser/tree/v4.18.0" }, - "time": "2023-05-19T20:20:00+00:00" + "time": "2023-12-10T21:03:43+00:00" }, { "name": "nunomaduro/termwind", @@ -3972,16 +4045,16 @@ }, { "name": "nyholm/psr7", - "version": "1.8.0", + "version": "1.8.1", "source": { "type": "git", "url": "https://github.com/Nyholm/psr7.git", - "reference": "3cb4d163b58589e47b35103e8e5e6a6a475b47be" + "reference": "aa5fc277a4f5508013d571341ade0c3886d4d00e" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/Nyholm/psr7/zipball/3cb4d163b58589e47b35103e8e5e6a6a475b47be", - "reference": "3cb4d163b58589e47b35103e8e5e6a6a475b47be", + "url": "https://api.github.com/repos/Nyholm/psr7/zipball/aa5fc277a4f5508013d571341ade0c3886d4d00e", + "reference": "aa5fc277a4f5508013d571341ade0c3886d4d00e", "shasum": "" }, "require": { @@ -4034,7 +4107,7 @@ ], "support": { "issues": "https://github.com/Nyholm/psr7/issues", - "source": "https://github.com/Nyholm/psr7/tree/1.8.0" + "source": "https://github.com/Nyholm/psr7/tree/1.8.1" }, "funding": [ { @@ -4046,7 +4119,7 @@ "type": "github" } ], - "time": "2023-05-02T11:26:24+00:00" + "time": "2023-11-13T09:31:12+00:00" }, { "name": "overtrue/pinyin", @@ -4213,16 +4286,16 @@ }, { "name": "php-http/client-common", - "version": "2.7.0", + "version": "2.7.1", "source": { "type": "git", "url": "https://github.com/php-http/client-common.git", - "reference": "880509727a447474d2a71b7d7fa5d268ddd3db4b" + "reference": "1e19c059b0e4d5f717bf5d524d616165aeab0612" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/php-http/client-common/zipball/880509727a447474d2a71b7d7fa5d268ddd3db4b", - "reference": "880509727a447474d2a71b7d7fa5d268ddd3db4b", + "url": "https://api.github.com/repos/php-http/client-common/zipball/1e19c059b0e4d5f717bf5d524d616165aeab0612", + "reference": "1e19c059b0e4d5f717bf5d524d616165aeab0612", "shasum": "" }, "require": { @@ -4232,7 +4305,7 @@ "psr/http-client": "^1.0", "psr/http-factory": "^1.0", "psr/http-message": "^1.0 || ^2.0", - "symfony/options-resolver": "~4.0.15 || ~4.1.9 || ^4.2.1 || ^5.0 || ^6.0", + "symfony/options-resolver": "~4.0.15 || ~4.1.9 || ^4.2.1 || ^5.0 || ^6.0 || ^7.0", "symfony/polyfill-php80": "^1.17" }, "require-dev": { @@ -4276,22 +4349,22 @@ ], "support": { "issues": "https://github.com/php-http/client-common/issues", - "source": "https://github.com/php-http/client-common/tree/2.7.0" + "source": "https://github.com/php-http/client-common/tree/2.7.1" }, - "time": "2023-05-17T06:46:59+00:00" + "time": "2023-11-30T10:31:25+00:00" }, { "name": "php-http/discovery", - "version": "1.19.0", + "version": "1.19.2", "source": { "type": "git", "url": "https://github.com/php-http/discovery.git", - "reference": "1856a119a0b0ba8da8b5c33c080aa7af8fac25b4" + "reference": "61e1a1eb69c92741f5896d9e05fb8e9d7e8bb0cb" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/php-http/discovery/zipball/1856a119a0b0ba8da8b5c33c080aa7af8fac25b4", - "reference": "1856a119a0b0ba8da8b5c33c080aa7af8fac25b4", + "url": "https://api.github.com/repos/php-http/discovery/zipball/61e1a1eb69c92741f5896d9e05fb8e9d7e8bb0cb", + "reference": "61e1a1eb69c92741f5896d9e05fb8e9d7e8bb0cb", "shasum": "" }, "require": { @@ -4354,9 +4427,9 @@ ], "support": { "issues": "https://github.com/php-http/discovery/issues", - "source": "https://github.com/php-http/discovery/tree/1.19.0" + "source": "https://github.com/php-http/discovery/tree/1.19.2" }, - "time": "2023-06-19T08:45:36+00:00" + "time": "2023-11-30T16:49:05+00:00" }, { "name": "php-http/httplug", @@ -4541,31 +4614,26 @@ }, { "name": "php-http/promise", - "version": "1.1.0", + "version": "1.3.0", "source": { "type": "git", "url": "https://github.com/php-http/promise.git", - "reference": "4c4c1f9b7289a2ec57cde7f1e9762a5789506f88" + "reference": "2916a606d3b390f4e9e8e2b8dd68581508be0f07" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/php-http/promise/zipball/4c4c1f9b7289a2ec57cde7f1e9762a5789506f88", - "reference": "4c4c1f9b7289a2ec57cde7f1e9762a5789506f88", + "url": "https://api.github.com/repos/php-http/promise/zipball/2916a606d3b390f4e9e8e2b8dd68581508be0f07", + "reference": "2916a606d3b390f4e9e8e2b8dd68581508be0f07", "shasum": "" }, "require": { "php": "^7.1 || ^8.0" }, "require-dev": { - "friends-of-phpspec/phpspec-code-coverage": "^4.3.2", - "phpspec/phpspec": "^5.1.2 || ^6.2" + "friends-of-phpspec/phpspec-code-coverage": "^4.3.2 || ^6.3", + "phpspec/phpspec": "^5.1.2 || ^6.2 || ^7.4" }, "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.1-dev" - } - }, "autoload": { "psr-4": { "Http\\Promise\\": "src/" @@ -4592,22 +4660,22 @@ ], "support": { "issues": "https://github.com/php-http/promise/issues", - "source": "https://github.com/php-http/promise/tree/1.1.0" + "source": "https://github.com/php-http/promise/tree/1.3.0" }, - "time": "2020-07-07T09:29:14+00:00" + "time": "2024-01-04T18:49:48+00:00" }, { "name": "phpoption/phpoption", - "version": "1.9.1", + "version": "1.9.2", "source": { "type": "git", "url": "https://github.com/schmittjoh/php-option.git", - "reference": "dd3a383e599f49777d8b628dadbb90cae435b87e" + "reference": "80735db690fe4fc5c76dfa7f9b770634285fa820" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/schmittjoh/php-option/zipball/dd3a383e599f49777d8b628dadbb90cae435b87e", - "reference": "dd3a383e599f49777d8b628dadbb90cae435b87e", + "url": "https://api.github.com/repos/schmittjoh/php-option/zipball/80735db690fe4fc5c76dfa7f9b770634285fa820", + "reference": "80735db690fe4fc5c76dfa7f9b770634285fa820", "shasum": "" }, "require": { @@ -4615,7 +4683,7 @@ }, "require-dev": { "bamarni/composer-bin-plugin": "^1.8.2", - "phpunit/phpunit": "^8.5.32 || ^9.6.3 || ^10.0.12" + "phpunit/phpunit": "^8.5.34 || ^9.6.13 || ^10.4.2" }, "type": "library", "extra": { @@ -4657,7 +4725,7 @@ ], "support": { "issues": "https://github.com/schmittjoh/php-option/issues", - "source": "https://github.com/schmittjoh/php-option/tree/1.9.1" + "source": "https://github.com/schmittjoh/php-option/tree/1.9.2" }, "funding": [ { @@ -4669,7 +4737,55 @@ "type": "tidelift" } ], - "time": "2023-02-25T19:38:58+00:00" + "time": "2023-11-12T21:59:55+00:00" + }, + { + "name": "psr/clock", + "version": "1.0.0", + "source": { + "type": "git", + "url": "https://github.com/php-fig/clock.git", + "reference": "e41a24703d4560fd0acb709162f73b8adfc3aa0d" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/clock/zipball/e41a24703d4560fd0acb709162f73b8adfc3aa0d", + "reference": "e41a24703d4560fd0acb709162f73b8adfc3aa0d", + "shasum": "" + }, + "require": { + "php": "^7.0 || ^8.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Psr\\Clock\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" + } + ], + "description": "Common interface for reading the clock.", + "homepage": "https://github.com/php-fig/clock", + "keywords": [ + "clock", + "now", + "psr", + "psr-20", + "time" + ], + "support": { + "issues": "https://github.com/php-fig/clock/issues", + "source": "https://github.com/php-fig/clock/tree/1.0.0" + }, + "time": "2022-11-25T14:36:26+00:00" }, { "name": "psr/container", @@ -5037,25 +5153,25 @@ }, { "name": "psy/psysh", - "version": "v0.11.18", + "version": "v0.12.0", "source": { "type": "git", "url": "https://github.com/bobthecow/psysh.git", - "reference": "4f00ee9e236fa6a48f4560d1300b9c961a70a7ec" + "reference": "750bf031a48fd07c673dbe3f11f72362ea306d0d" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/bobthecow/psysh/zipball/4f00ee9e236fa6a48f4560d1300b9c961a70a7ec", - "reference": "4f00ee9e236fa6a48f4560d1300b9c961a70a7ec", + "url": "https://api.github.com/repos/bobthecow/psysh/zipball/750bf031a48fd07c673dbe3f11f72362ea306d0d", + "reference": "750bf031a48fd07c673dbe3f11f72362ea306d0d", "shasum": "" }, "require": { "ext-json": "*", "ext-tokenizer": "*", - "nikic/php-parser": "^4.0 || ^3.1", - "php": "^8.0 || ^7.0.8", - "symfony/console": "^6.0 || ^5.0 || ^4.0 || ^3.4", - "symfony/var-dumper": "^6.0 || ^5.0 || ^4.0 || ^3.4" + "nikic/php-parser": "^5.0 || ^4.0", + "php": "^8.0 || ^7.4", + "symfony/console": "^7.0 || ^6.0 || ^5.0 || ^4.0 || ^3.4", + "symfony/var-dumper": "^7.0 || ^6.0 || ^5.0 || ^4.0 || ^3.4" }, "conflict": { "symfony/console": "4.4.37 || 5.3.14 || 5.3.15 || 5.4.3 || 5.4.4 || 6.0.3 || 6.0.4" @@ -5066,8 +5182,7 @@ "suggest": { "ext-pcntl": "Enabling the PCNTL extension makes PsySH a lot happier :)", "ext-pdo-sqlite": "The doc command requires SQLite to work.", - "ext-posix": "If you have PCNTL, you'll want the POSIX extension as well.", - "ext-readline": "Enables support for arrow-key history navigation, and showing and manipulating command history." + "ext-posix": "If you have PCNTL, you'll want the POSIX extension as well." }, "bin": [ "bin/psysh" @@ -5075,7 +5190,11 @@ "type": "library", "extra": { "branch-alias": { - "dev-main": "0.11.x-dev" + "dev-main": "0.12.x-dev" + }, + "bamarni-bin": { + "bin-links": false, + "forward-command": false } }, "autoload": { @@ -5107,9 +5226,9 @@ ], "support": { "issues": "https://github.com/bobthecow/psysh/issues", - "source": "https://github.com/bobthecow/psysh/tree/v0.11.18" + "source": "https://github.com/bobthecow/psysh/tree/v0.12.0" }, - "time": "2023-05-23T02:31:11+00:00" + "time": "2023-12-20T15:28:09+00:00" }, { "name": "ralouphie/getallheaders", @@ -5246,16 +5365,16 @@ }, { "name": "ramsey/uuid", - "version": "4.7.4", + "version": "4.7.5", "source": { "type": "git", "url": "https://github.com/ramsey/uuid.git", - "reference": "60a4c63ab724854332900504274f6150ff26d286" + "reference": "5f0df49ae5ad6efb7afa69e6bfab4e5b1e080d8e" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/ramsey/uuid/zipball/60a4c63ab724854332900504274f6150ff26d286", - "reference": "60a4c63ab724854332900504274f6150ff26d286", + "url": "https://api.github.com/repos/ramsey/uuid/zipball/5f0df49ae5ad6efb7afa69e6bfab4e5b1e080d8e", + "reference": "5f0df49ae5ad6efb7afa69e6bfab4e5b1e080d8e", "shasum": "" }, "require": { @@ -5322,7 +5441,7 @@ ], "support": { "issues": "https://github.com/ramsey/uuid/issues", - "source": "https://github.com/ramsey/uuid/tree/4.7.4" + "source": "https://github.com/ramsey/uuid/tree/4.7.5" }, "funding": [ { @@ -5334,7 +5453,7 @@ "type": "tidelift" } ], - "time": "2023-04-15T23:01:58+00:00" + "time": "2023-11-08T05:53:05+00:00" }, { "name": "sabberworm/php-css-parser", @@ -5396,22 +5515,22 @@ }, { "name": "sentry/sdk", - "version": "3.5.0", + "version": "3.6.0", "source": { "type": "git", "url": "https://github.com/getsentry/sentry-php-sdk.git", - "reference": "cd91b752f07c4bab9fb3b173f81af68a78a78d6d" + "reference": "24c235ff2027401cbea099bf88689e1a1f197c7a" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/getsentry/sentry-php-sdk/zipball/cd91b752f07c4bab9fb3b173f81af68a78a78d6d", - "reference": "cd91b752f07c4bab9fb3b173f81af68a78a78d6d", + "url": "https://api.github.com/repos/getsentry/sentry-php-sdk/zipball/24c235ff2027401cbea099bf88689e1a1f197c7a", + "reference": "24c235ff2027401cbea099bf88689e1a1f197c7a", "shasum": "" }, "require": { "http-interop/http-factory-guzzle": "^1.0", - "sentry/sentry": "^3.19", - "symfony/http-client": "^4.3|^5.0|^6.0" + "sentry/sentry": "^3.22", + "symfony/http-client": "^4.3|^5.0|^6.0|^7.0" }, "type": "metapackage", "notification-url": "https://packagist.org/downloads/", @@ -5437,7 +5556,7 @@ ], "support": { "issues": "https://github.com/getsentry/sentry-php-sdk/issues", - "source": "https://github.com/getsentry/sentry-php-sdk/tree/3.5.0" + "source": "https://github.com/getsentry/sentry-php-sdk/tree/3.6.0" }, "funding": [ { @@ -5449,20 +5568,20 @@ "type": "custom" } ], - "time": "2023-06-12T17:50:36+00:00" + "time": "2023-12-04T10:49:33+00:00" }, { "name": "sentry/sentry", - "version": "3.19.1", + "version": "3.22.1", "source": { "type": "git", "url": "https://github.com/getsentry/sentry-php.git", - "reference": "dd1057fb37d4484ebb2d1bc9b05fa5969c078436" + "reference": "8859631ba5ab15bc1af420b0eeed19ecc6c9d81d" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/getsentry/sentry-php/zipball/dd1057fb37d4484ebb2d1bc9b05fa5969c078436", - "reference": "dd1057fb37d4484ebb2d1bc9b05fa5969c078436", + "url": "https://api.github.com/repos/getsentry/sentry-php/zipball/8859631ba5ab15bc1af420b0eeed19ecc6c9d81d", + "reference": "8859631ba5ab15bc1af420b0eeed19ecc6c9d81d", "shasum": "" }, "require": { @@ -5480,7 +5599,7 @@ "psr/http-factory": "^1.0", "psr/http-factory-implementation": "^1.0", "psr/log": "^1.0|^2.0|^3.0", - "symfony/options-resolver": "^3.4.43|^4.4.30|^5.0.11|^6.0", + "symfony/options-resolver": "^3.4.43|^4.4.30|^5.0.11|^6.0|^7.0", "symfony/polyfill-php80": "^1.17" }, "conflict": { @@ -5506,11 +5625,6 @@ "monolog/monolog": "Allow sending log messages to Sentry by using the included Monolog handler." }, "type": "library", - "extra": { - "branch-alias": { - "dev-master": "3.13.x-dev" - } - }, "autoload": { "files": [ "src/functions.php" @@ -5542,7 +5656,7 @@ ], "support": { "issues": "https://github.com/getsentry/sentry-php/issues", - "source": "https://github.com/getsentry/sentry-php/tree/3.19.1" + "source": "https://github.com/getsentry/sentry-php/tree/3.22.1" }, "funding": [ { @@ -5554,20 +5668,20 @@ "type": "custom" } ], - "time": "2023-05-25T06:19:09+00:00" + "time": "2023-11-13T11:47:28+00:00" }, { "name": "sentry/sentry-laravel", - "version": "3.5.0", + "version": "3.8.2", "source": { "type": "git", "url": "https://github.com/getsentry/sentry-laravel.git", - "reference": "008243af3902e77bf3396a82441c0b491c3d5675" + "reference": "1293e5732f8405e12f000cdf5dee78c927a18de0" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/getsentry/sentry-laravel/zipball/008243af3902e77bf3396a82441c0b491c3d5675", - "reference": "008243af3902e77bf3396a82441c0b491c3d5675", + "url": "https://api.github.com/repos/getsentry/sentry-laravel/zipball/1293e5732f8405e12f000cdf5dee78c927a18de0", + "reference": "1293e5732f8405e12f000cdf5dee78c927a18de0", "shasum": "" }, "require": { @@ -5575,14 +5689,16 @@ "nyholm/psr7": "^1.0", "php": "^7.2 | ^8.0", "sentry/sdk": "^3.4", - "sentry/sentry": "^3.19", + "sentry/sentry": "^3.20.1", "symfony/psr-http-message-bridge": "^1.0 | ^2.0" }, "require-dev": { "friendsofphp/php-cs-fixer": "^3.11", + "laravel/folio": "^1.0", "laravel/framework": "^6.0 | ^7.0 | ^8.0 | ^9.0 | ^10.0", "mockery/mockery": "^1.3", "orchestra/testbench": "^4.7 | ^5.1 | ^6.0 | ^7.0 | ^8.0", + "phpstan/phpstan": "^1.10", "phpunit/phpunit": "^8.4 | ^9.3" }, "type": "library", @@ -5632,7 +5748,7 @@ ], "support": { "issues": "https://github.com/getsentry/sentry-laravel/issues", - "source": "https://github.com/getsentry/sentry-laravel/tree/3.5.0" + "source": "https://github.com/getsentry/sentry-laravel/tree/3.8.2" }, "funding": [ { @@ -5644,7 +5760,7 @@ "type": "custom" } ], - "time": "2023-06-19T12:33:03+00:00" + "time": "2023-10-12T14:38:46+00:00" }, { "name": "spatie/laravel-activitylog", @@ -5817,16 +5933,16 @@ }, { "name": "spatie/laravel-html", - "version": "3.2.1", + "version": "3.4.0", "source": { "type": "git", "url": "https://github.com/spatie/laravel-html.git", - "reference": "bf7bdb55cc5ce15c4ec8134aa1df709c0397c397" + "reference": "20bd3185ae085b2eced952bc5191cb8eb922250e" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/spatie/laravel-html/zipball/bf7bdb55cc5ce15c4ec8134aa1df709c0397c397", - "reference": "bf7bdb55cc5ce15c4ec8134aa1df709c0397c397", + "url": "https://api.github.com/repos/spatie/laravel-html/zipball/20bd3185ae085b2eced952bc5191cb8eb922250e", + "reference": "20bd3185ae085b2eced952bc5191cb8eb922250e", "shasum": "" }, "require": { @@ -5883,7 +5999,7 @@ "spatie" ], "support": { - "source": "https://github.com/spatie/laravel-html/tree/3.2.1" + "source": "https://github.com/spatie/laravel-html/tree/3.4.0" }, "funding": [ { @@ -5891,24 +6007,24 @@ "type": "custom" } ], - "time": "2023-01-24T23:47:16+00:00" + "time": "2024-01-05T16:35:10+00:00" }, { "name": "spatie/laravel-package-tools", - "version": "1.15.0", + "version": "1.16.2", "source": { "type": "git", "url": "https://github.com/spatie/laravel-package-tools.git", - "reference": "efab1844b8826443135201c4443690f032c3d533" + "reference": "e62eeb1fe8a8a0b2e83227a6c279c8c59f7d3a15" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/spatie/laravel-package-tools/zipball/efab1844b8826443135201c4443690f032c3d533", - "reference": "efab1844b8826443135201c4443690f032c3d533", + "url": "https://api.github.com/repos/spatie/laravel-package-tools/zipball/e62eeb1fe8a8a0b2e83227a6c279c8c59f7d3a15", + "reference": "e62eeb1fe8a8a0b2e83227a6c279c8c59f7d3a15", "shasum": "" }, "require": { - "illuminate/contracts": "^9.28|^10.0", + "illuminate/contracts": "^9.28|^10.0|^11.0", "php": "^8.0" }, "require-dev": { @@ -5943,7 +6059,7 @@ ], "support": { "issues": "https://github.com/spatie/laravel-package-tools/issues", - "source": "https://github.com/spatie/laravel-package-tools/tree/1.15.0" + "source": "https://github.com/spatie/laravel-package-tools/tree/1.16.2" }, "funding": [ { @@ -5951,20 +6067,20 @@ "type": "github" } ], - "time": "2023-04-27T08:09:01+00:00" + "time": "2024-01-11T08:43:00+00:00" }, { "name": "spatie/laravel-permission", - "version": "5.10.1", + "version": "5.11.1", "source": { "type": "git", "url": "https://github.com/spatie/laravel-permission.git", - "reference": "d08b3ffc5870cce4a47a39f22174947b33c191ae" + "reference": "7090824cca57e693b880ce3aaf7ef78362e28bbd" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/spatie/laravel-permission/zipball/d08b3ffc5870cce4a47a39f22174947b33c191ae", - "reference": "d08b3ffc5870cce4a47a39f22174947b33c191ae", + "url": "https://api.github.com/repos/spatie/laravel-permission/zipball/7090824cca57e693b880ce3aaf7ef78362e28bbd", + "reference": "7090824cca57e693b880ce3aaf7ef78362e28bbd", "shasum": "" }, "require": { @@ -6025,7 +6141,7 @@ ], "support": { "issues": "https://github.com/spatie/laravel-permission/issues", - "source": "https://github.com/spatie/laravel-permission/tree/5.10.1" + "source": "https://github.com/spatie/laravel-permission/tree/5.11.1" }, "funding": [ { @@ -6033,20 +6149,20 @@ "type": "github" } ], - "time": "2023-04-12T17:08:32+00:00" + "time": "2023-10-25T05:12:01+00:00" }, { "name": "symfony/console", - "version": "v6.3.0", + "version": "v6.4.3", "source": { "type": "git", "url": "https://github.com/symfony/console.git", - "reference": "8788808b07cf0bdd6e4b7fdd23d8ddb1470c83b7" + "reference": "2aaf83b4de5b9d43b93e4aec6f2f8b676f7c567e" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/console/zipball/8788808b07cf0bdd6e4b7fdd23d8ddb1470c83b7", - "reference": "8788808b07cf0bdd6e4b7fdd23d8ddb1470c83b7", + "url": "https://api.github.com/repos/symfony/console/zipball/2aaf83b4de5b9d43b93e4aec6f2f8b676f7c567e", + "reference": "2aaf83b4de5b9d43b93e4aec6f2f8b676f7c567e", "shasum": "" }, "require": { @@ -6054,7 +6170,7 @@ "symfony/deprecation-contracts": "^2.5|^3", "symfony/polyfill-mbstring": "~1.0", "symfony/service-contracts": "^2.5|^3", - "symfony/string": "^5.4|^6.0" + "symfony/string": "^5.4|^6.0|^7.0" }, "conflict": { "symfony/dependency-injection": "<5.4", @@ -6068,12 +6184,16 @@ }, "require-dev": { "psr/log": "^1|^2|^3", - "symfony/config": "^5.4|^6.0", - "symfony/dependency-injection": "^5.4|^6.0", - "symfony/event-dispatcher": "^5.4|^6.0", - "symfony/lock": "^5.4|^6.0", - "symfony/process": "^5.4|^6.0", - "symfony/var-dumper": "^5.4|^6.0" + "symfony/config": "^5.4|^6.0|^7.0", + "symfony/dependency-injection": "^5.4|^6.0|^7.0", + "symfony/event-dispatcher": "^5.4|^6.0|^7.0", + "symfony/http-foundation": "^6.4|^7.0", + "symfony/http-kernel": "^6.4|^7.0", + "symfony/lock": "^5.4|^6.0|^7.0", + "symfony/messenger": "^5.4|^6.0|^7.0", + "symfony/process": "^5.4|^6.0|^7.0", + "symfony/stopwatch": "^5.4|^6.0|^7.0", + "symfony/var-dumper": "^5.4|^6.0|^7.0" }, "type": "library", "autoload": { @@ -6107,7 +6227,7 @@ "terminal" ], "support": { - "source": "https://github.com/symfony/console/tree/v6.3.0" + "source": "https://github.com/symfony/console/tree/v6.4.3" }, "funding": [ { @@ -6123,20 +6243,20 @@ "type": "tidelift" } ], - "time": "2023-05-29T12:49:39+00:00" + "time": "2024-01-23T14:51:35+00:00" }, { "name": "symfony/css-selector", - "version": "v6.3.0", + "version": "v6.4.3", "source": { "type": "git", "url": "https://github.com/symfony/css-selector.git", - "reference": "88453e64cd86c5b60e8d2fb2c6f953bbc353ffbf" + "reference": "ee0f7ed5cf298cc019431bb3b3977ebc52b86229" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/css-selector/zipball/88453e64cd86c5b60e8d2fb2c6f953bbc353ffbf", - "reference": "88453e64cd86c5b60e8d2fb2c6f953bbc353ffbf", + "url": "https://api.github.com/repos/symfony/css-selector/zipball/ee0f7ed5cf298cc019431bb3b3977ebc52b86229", + "reference": "ee0f7ed5cf298cc019431bb3b3977ebc52b86229", "shasum": "" }, "require": { @@ -6172,7 +6292,7 @@ "description": "Converts CSS selectors to XPath expressions", "homepage": "https://symfony.com", "support": { - "source": "https://github.com/symfony/css-selector/tree/v6.3.0" + "source": "https://github.com/symfony/css-selector/tree/v6.4.3" }, "funding": [ { @@ -6188,7 +6308,7 @@ "type": "tidelift" } ], - "time": "2023-03-20T16:43:42+00:00" + "time": "2024-01-23T14:51:35+00:00" }, { "name": "symfony/deprecation-contracts", @@ -6259,30 +6379,31 @@ }, { "name": "symfony/error-handler", - "version": "v6.3.0", + "version": "v6.4.3", "source": { "type": "git", "url": "https://github.com/symfony/error-handler.git", - "reference": "99d2d814a6351461af350ead4d963bd67451236f" + "reference": "6dc3c76a278b77f01d864a6005d640822c6f26a6" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/error-handler/zipball/99d2d814a6351461af350ead4d963bd67451236f", - "reference": "99d2d814a6351461af350ead4d963bd67451236f", + "url": "https://api.github.com/repos/symfony/error-handler/zipball/6dc3c76a278b77f01d864a6005d640822c6f26a6", + "reference": "6dc3c76a278b77f01d864a6005d640822c6f26a6", "shasum": "" }, "require": { "php": ">=8.1", "psr/log": "^1|^2|^3", - "symfony/var-dumper": "^5.4|^6.0" + "symfony/var-dumper": "^5.4|^6.0|^7.0" }, "conflict": { - "symfony/deprecation-contracts": "<2.5" + "symfony/deprecation-contracts": "<2.5", + "symfony/http-kernel": "<6.4" }, "require-dev": { "symfony/deprecation-contracts": "^2.5|^3", - "symfony/http-kernel": "^5.4|^6.0", - "symfony/serializer": "^5.4|^6.0" + "symfony/http-kernel": "^6.4|^7.0", + "symfony/serializer": "^5.4|^6.0|^7.0" }, "bin": [ "Resources/bin/patch-type-declarations" @@ -6313,7 +6434,7 @@ "description": "Provides tools to manage errors and ease debugging PHP code", "homepage": "https://symfony.com", "support": { - "source": "https://github.com/symfony/error-handler/tree/v6.3.0" + "source": "https://github.com/symfony/error-handler/tree/v6.4.3" }, "funding": [ { @@ -6329,20 +6450,20 @@ "type": "tidelift" } ], - "time": "2023-05-10T12:03:13+00:00" + "time": "2024-01-29T15:40:36+00:00" }, { "name": "symfony/event-dispatcher", - "version": "v6.3.0", + "version": "v6.4.3", "source": { "type": "git", "url": "https://github.com/symfony/event-dispatcher.git", - "reference": "3af8ac1a3f98f6dbc55e10ae59c9e44bfc38dfaa" + "reference": "ae9d3a6f3003a6caf56acd7466d8d52378d44fef" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/event-dispatcher/zipball/3af8ac1a3f98f6dbc55e10ae59c9e44bfc38dfaa", - "reference": "3af8ac1a3f98f6dbc55e10ae59c9e44bfc38dfaa", + "url": "https://api.github.com/repos/symfony/event-dispatcher/zipball/ae9d3a6f3003a6caf56acd7466d8d52378d44fef", + "reference": "ae9d3a6f3003a6caf56acd7466d8d52378d44fef", "shasum": "" }, "require": { @@ -6359,13 +6480,13 @@ }, "require-dev": { "psr/log": "^1|^2|^3", - "symfony/config": "^5.4|^6.0", - "symfony/dependency-injection": "^5.4|^6.0", - "symfony/error-handler": "^5.4|^6.0", - "symfony/expression-language": "^5.4|^6.0", - "symfony/http-foundation": "^5.4|^6.0", + "symfony/config": "^5.4|^6.0|^7.0", + "symfony/dependency-injection": "^5.4|^6.0|^7.0", + "symfony/error-handler": "^5.4|^6.0|^7.0", + "symfony/expression-language": "^5.4|^6.0|^7.0", + "symfony/http-foundation": "^5.4|^6.0|^7.0", "symfony/service-contracts": "^2.5|^3", - "symfony/stopwatch": "^5.4|^6.0" + "symfony/stopwatch": "^5.4|^6.0|^7.0" }, "type": "library", "autoload": { @@ -6393,7 +6514,7 @@ "description": "Provides tools that allow your application components to communicate with each other by dispatching events and listening to them", "homepage": "https://symfony.com", "support": { - "source": "https://github.com/symfony/event-dispatcher/tree/v6.3.0" + "source": "https://github.com/symfony/event-dispatcher/tree/v6.4.3" }, "funding": [ { @@ -6409,11 +6530,11 @@ "type": "tidelift" } ], - "time": "2023-04-21T14:41:17+00:00" + "time": "2024-01-23T14:51:35+00:00" }, { "name": "symfony/event-dispatcher-contracts", - "version": "v3.3.0", + "version": "v3.4.0", "source": { "type": "git", "url": "https://github.com/symfony/event-dispatcher-contracts.git", @@ -6469,7 +6590,7 @@ "standards" ], "support": { - "source": "https://github.com/symfony/event-dispatcher-contracts/tree/v3.3.0" + "source": "https://github.com/symfony/event-dispatcher-contracts/tree/v3.4.0" }, "funding": [ { @@ -6489,23 +6610,23 @@ }, { "name": "symfony/finder", - "version": "v6.3.0", + "version": "v6.4.0", "source": { "type": "git", "url": "https://github.com/symfony/finder.git", - "reference": "d9b01ba073c44cef617c7907ce2419f8d00d75e2" + "reference": "11d736e97f116ac375a81f96e662911a34cd50ce" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/finder/zipball/d9b01ba073c44cef617c7907ce2419f8d00d75e2", - "reference": "d9b01ba073c44cef617c7907ce2419f8d00d75e2", + "url": "https://api.github.com/repos/symfony/finder/zipball/11d736e97f116ac375a81f96e662911a34cd50ce", + "reference": "11d736e97f116ac375a81f96e662911a34cd50ce", "shasum": "" }, "require": { "php": ">=8.1" }, "require-dev": { - "symfony/filesystem": "^6.0" + "symfony/filesystem": "^6.0|^7.0" }, "type": "library", "autoload": { @@ -6533,7 +6654,7 @@ "description": "Finds files and directories via an intuitive fluent interface", "homepage": "https://symfony.com", "support": { - "source": "https://github.com/symfony/finder/tree/v6.3.0" + "source": "https://github.com/symfony/finder/tree/v6.4.0" }, "funding": [ { @@ -6549,20 +6670,20 @@ "type": "tidelift" } ], - "time": "2023-04-02T01:25:41+00:00" + "time": "2023-10-31T17:30:12+00:00" }, { "name": "symfony/http-client", - "version": "v6.3.0", + "version": "v6.4.3", "source": { "type": "git", "url": "https://github.com/symfony/http-client.git", - "reference": "b2f892c91e4e02a939edddeb7ef452522d10a424" + "reference": "a9034bc119fab8238f76cf49c770f3135f3ead86" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/http-client/zipball/b2f892c91e4e02a939edddeb7ef452522d10a424", - "reference": "b2f892c91e4e02a939edddeb7ef452522d10a424", + "url": "https://api.github.com/repos/symfony/http-client/zipball/a9034bc119fab8238f76cf49c770f3135f3ead86", + "reference": "a9034bc119fab8238f76cf49c770f3135f3ead86", "shasum": "" }, "require": { @@ -6591,10 +6712,11 @@ "nyholm/psr7": "^1.0", "php-http/httplug": "^1.0|^2.0", "psr/http-client": "^1.0", - "symfony/dependency-injection": "^5.4|^6.0", - "symfony/http-kernel": "^5.4|^6.0", - "symfony/process": "^5.4|^6.0", - "symfony/stopwatch": "^5.4|^6.0" + "symfony/dependency-injection": "^5.4|^6.0|^7.0", + "symfony/http-kernel": "^5.4|^6.0|^7.0", + "symfony/messenger": "^5.4|^6.0|^7.0", + "symfony/process": "^5.4|^6.0|^7.0", + "symfony/stopwatch": "^5.4|^6.0|^7.0" }, "type": "library", "autoload": { @@ -6625,7 +6747,7 @@ "http" ], "support": { - "source": "https://github.com/symfony/http-client/tree/v6.3.0" + "source": "https://github.com/symfony/http-client/tree/v6.4.3" }, "funding": [ { @@ -6641,20 +6763,20 @@ "type": "tidelift" } ], - "time": "2023-05-12T08:49:48+00:00" + "time": "2024-01-29T15:01:07+00:00" }, { "name": "symfony/http-client-contracts", - "version": "v3.3.0", + "version": "v3.4.0", "source": { "type": "git", "url": "https://github.com/symfony/http-client-contracts.git", - "reference": "3b66325d0176b4ec826bffab57c9037d759c31fb" + "reference": "1ee70e699b41909c209a0c930f11034b93578654" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/http-client-contracts/zipball/3b66325d0176b4ec826bffab57c9037d759c31fb", - "reference": "3b66325d0176b4ec826bffab57c9037d759c31fb", + "url": "https://api.github.com/repos/symfony/http-client-contracts/zipball/1ee70e699b41909c209a0c930f11034b93578654", + "reference": "1ee70e699b41909c209a0c930f11034b93578654", "shasum": "" }, "require": { @@ -6703,7 +6825,7 @@ "standards" ], "support": { - "source": "https://github.com/symfony/http-client-contracts/tree/v3.3.0" + "source": "https://github.com/symfony/http-client-contracts/tree/v3.4.0" }, "funding": [ { @@ -6719,20 +6841,20 @@ "type": "tidelift" } ], - "time": "2023-05-23T14:45:45+00:00" + "time": "2023-07-30T20:28:31+00:00" }, { "name": "symfony/http-foundation", - "version": "v6.3.0", + "version": "v6.4.3", "source": { "type": "git", "url": "https://github.com/symfony/http-foundation.git", - "reference": "718a97ed430d34e5c568ea2c44eab708c6efbefb" + "reference": "5677bdf7cade4619cb17fc9e1e7b31ec392244a9" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/http-foundation/zipball/718a97ed430d34e5c568ea2c44eab708c6efbefb", - "reference": "718a97ed430d34e5c568ea2c44eab708c6efbefb", + "url": "https://api.github.com/repos/symfony/http-foundation/zipball/5677bdf7cade4619cb17fc9e1e7b31ec392244a9", + "reference": "5677bdf7cade4619cb17fc9e1e7b31ec392244a9", "shasum": "" }, "require": { @@ -6742,17 +6864,17 @@ "symfony/polyfill-php83": "^1.27" }, "conflict": { - "symfony/cache": "<6.2" + "symfony/cache": "<6.3" }, "require-dev": { - "doctrine/dbal": "^2.13.1|^3.0", + "doctrine/dbal": "^2.13.1|^3|^4", "predis/predis": "^1.1|^2.0", - "symfony/cache": "^5.4|^6.0", - "symfony/dependency-injection": "^5.4|^6.0", - "symfony/expression-language": "^5.4|^6.0", - "symfony/http-kernel": "^5.4.12|^6.0.12|^6.1.4", - "symfony/mime": "^5.4|^6.0", - "symfony/rate-limiter": "^5.2|^6.0" + "symfony/cache": "^6.3|^7.0", + "symfony/dependency-injection": "^5.4|^6.0|^7.0", + "symfony/expression-language": "^5.4|^6.0|^7.0", + "symfony/http-kernel": "^5.4.12|^6.0.12|^6.1.4|^7.0", + "symfony/mime": "^5.4|^6.0|^7.0", + "symfony/rate-limiter": "^5.4|^6.0|^7.0" }, "type": "library", "autoload": { @@ -6780,7 +6902,7 @@ "description": "Defines an object-oriented layer for the HTTP specification", "homepage": "https://symfony.com", "support": { - "source": "https://github.com/symfony/http-foundation/tree/v6.3.0" + "source": "https://github.com/symfony/http-foundation/tree/v6.4.3" }, "funding": [ { @@ -6796,29 +6918,29 @@ "type": "tidelift" } ], - "time": "2023-05-19T12:46:45+00:00" + "time": "2024-01-23T14:51:35+00:00" }, { "name": "symfony/http-kernel", - "version": "v6.3.0", + "version": "v6.4.3", "source": { "type": "git", "url": "https://github.com/symfony/http-kernel.git", - "reference": "241973f3dd900620b1ca052fe409144f11aea748" + "reference": "9c6ec4e543044f7568a53a76ab1484ecd30637a2" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/http-kernel/zipball/241973f3dd900620b1ca052fe409144f11aea748", - "reference": "241973f3dd900620b1ca052fe409144f11aea748", + "url": "https://api.github.com/repos/symfony/http-kernel/zipball/9c6ec4e543044f7568a53a76ab1484ecd30637a2", + "reference": "9c6ec4e543044f7568a53a76ab1484ecd30637a2", "shasum": "" }, "require": { "php": ">=8.1", "psr/log": "^1|^2|^3", "symfony/deprecation-contracts": "^2.5|^3", - "symfony/error-handler": "^6.3", - "symfony/event-dispatcher": "^5.4|^6.0", - "symfony/http-foundation": "^6.2.7", + "symfony/error-handler": "^6.4|^7.0", + "symfony/event-dispatcher": "^5.4|^6.0|^7.0", + "symfony/http-foundation": "^6.4|^7.0", "symfony/polyfill-ctype": "^1.8" }, "conflict": { @@ -6826,7 +6948,7 @@ "symfony/cache": "<5.4", "symfony/config": "<6.1", "symfony/console": "<5.4", - "symfony/dependency-injection": "<6.3", + "symfony/dependency-injection": "<6.4", "symfony/doctrine-bridge": "<5.4", "symfony/form": "<5.4", "symfony/http-client": "<5.4", @@ -6836,7 +6958,7 @@ "symfony/translation": "<5.4", "symfony/translation-contracts": "<2.5", "symfony/twig-bridge": "<5.4", - "symfony/validator": "<5.4", + "symfony/validator": "<6.4", "symfony/var-dumper": "<6.3", "twig/twig": "<2.13" }, @@ -6845,26 +6967,26 @@ }, "require-dev": { "psr/cache": "^1.0|^2.0|^3.0", - "symfony/browser-kit": "^5.4|^6.0", - "symfony/clock": "^6.2", - "symfony/config": "^6.1", - "symfony/console": "^5.4|^6.0", - "symfony/css-selector": "^5.4|^6.0", - "symfony/dependency-injection": "^6.3", - "symfony/dom-crawler": "^5.4|^6.0", - "symfony/expression-language": "^5.4|^6.0", - "symfony/finder": "^5.4|^6.0", + "symfony/browser-kit": "^5.4|^6.0|^7.0", + "symfony/clock": "^6.2|^7.0", + "symfony/config": "^6.1|^7.0", + "symfony/console": "^5.4|^6.0|^7.0", + "symfony/css-selector": "^5.4|^6.0|^7.0", + "symfony/dependency-injection": "^6.4|^7.0", + "symfony/dom-crawler": "^5.4|^6.0|^7.0", + "symfony/expression-language": "^5.4|^6.0|^7.0", + "symfony/finder": "^5.4|^6.0|^7.0", "symfony/http-client-contracts": "^2.5|^3", - "symfony/process": "^5.4|^6.0", - "symfony/property-access": "^5.4.5|^6.0.5", - "symfony/routing": "^5.4|^6.0", - "symfony/serializer": "^6.3", - "symfony/stopwatch": "^5.4|^6.0", - "symfony/translation": "^5.4|^6.0", + "symfony/process": "^5.4|^6.0|^7.0", + "symfony/property-access": "^5.4.5|^6.0.5|^7.0", + "symfony/routing": "^5.4|^6.0|^7.0", + "symfony/serializer": "^6.3|^7.0", + "symfony/stopwatch": "^5.4|^6.0|^7.0", + "symfony/translation": "^5.4|^6.0|^7.0", "symfony/translation-contracts": "^2.5|^3", - "symfony/uid": "^5.4|^6.0", - "symfony/validator": "^6.3", - "symfony/var-exporter": "^6.2", + "symfony/uid": "^5.4|^6.0|^7.0", + "symfony/validator": "^6.4|^7.0", + "symfony/var-exporter": "^6.2|^7.0", "twig/twig": "^2.13|^3.0.4" }, "type": "library", @@ -6893,7 +7015,7 @@ "description": "Provides a structured process for converting a Request into a Response", "homepage": "https://symfony.com", "support": { - "source": "https://github.com/symfony/http-kernel/tree/v6.3.0" + "source": "https://github.com/symfony/http-kernel/tree/v6.4.3" }, "funding": [ { @@ -6909,20 +7031,20 @@ "type": "tidelift" } ], - "time": "2023-05-30T19:03:32+00:00" + "time": "2024-01-31T07:21:29+00:00" }, { "name": "symfony/mailer", - "version": "v6.3.0", + "version": "v6.4.3", "source": { "type": "git", "url": "https://github.com/symfony/mailer.git", - "reference": "7b03d9be1dea29bfec0a6c7b603f5072a4c97435" + "reference": "74412c62f88a85a41b61f0b71ab0afcaad6f03ee" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/mailer/zipball/7b03d9be1dea29bfec0a6c7b603f5072a4c97435", - "reference": "7b03d9be1dea29bfec0a6c7b603f5072a4c97435", + "url": "https://api.github.com/repos/symfony/mailer/zipball/74412c62f88a85a41b61f0b71ab0afcaad6f03ee", + "reference": "74412c62f88a85a41b61f0b71ab0afcaad6f03ee", "shasum": "" }, "require": { @@ -6930,8 +7052,8 @@ "php": ">=8.1", "psr/event-dispatcher": "^1", "psr/log": "^1|^2|^3", - "symfony/event-dispatcher": "^5.4|^6.0", - "symfony/mime": "^6.2", + "symfony/event-dispatcher": "^5.4|^6.0|^7.0", + "symfony/mime": "^6.2|^7.0", "symfony/service-contracts": "^2.5|^3" }, "conflict": { @@ -6942,10 +7064,10 @@ "symfony/twig-bridge": "<6.2.1" }, "require-dev": { - "symfony/console": "^5.4|^6.0", - "symfony/http-client": "^5.4|^6.0", - "symfony/messenger": "^6.2", - "symfony/twig-bridge": "^6.2" + "symfony/console": "^5.4|^6.0|^7.0", + "symfony/http-client": "^5.4|^6.0|^7.0", + "symfony/messenger": "^6.2|^7.0", + "symfony/twig-bridge": "^6.2|^7.0" }, "type": "library", "autoload": { @@ -6973,7 +7095,7 @@ "description": "Helps sending emails", "homepage": "https://symfony.com", "support": { - "source": "https://github.com/symfony/mailer/tree/v6.3.0" + "source": "https://github.com/symfony/mailer/tree/v6.4.3" }, "funding": [ { @@ -6989,24 +7111,25 @@ "type": "tidelift" } ], - "time": "2023-05-29T12:49:39+00:00" + "time": "2024-01-29T15:01:07+00:00" }, { "name": "symfony/mime", - "version": "v6.3.0", + "version": "v6.4.3", "source": { "type": "git", "url": "https://github.com/symfony/mime.git", - "reference": "7b5d2121858cd6efbed778abce9cfdd7ab1f62ad" + "reference": "5017e0a9398c77090b7694be46f20eb796262a34" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/mime/zipball/7b5d2121858cd6efbed778abce9cfdd7ab1f62ad", - "reference": "7b5d2121858cd6efbed778abce9cfdd7ab1f62ad", + "url": "https://api.github.com/repos/symfony/mime/zipball/5017e0a9398c77090b7694be46f20eb796262a34", + "reference": "5017e0a9398c77090b7694be46f20eb796262a34", "shasum": "" }, "require": { "php": ">=8.1", + "symfony/deprecation-contracts": "^2.5|^3", "symfony/polyfill-intl-idn": "^1.10", "symfony/polyfill-mbstring": "^1.0" }, @@ -7015,16 +7138,16 @@ "phpdocumentor/reflection-docblock": "<3.2.2", "phpdocumentor/type-resolver": "<1.4.0", "symfony/mailer": "<5.4", - "symfony/serializer": "<6.2" + "symfony/serializer": "<6.3.2" }, "require-dev": { "egulias/email-validator": "^2.1.10|^3.1|^4", "league/html-to-markdown": "^5.0", "phpdocumentor/reflection-docblock": "^3.0|^4.0|^5.0", - "symfony/dependency-injection": "^5.4|^6.0", - "symfony/property-access": "^5.4|^6.0", - "symfony/property-info": "^5.4|^6.0", - "symfony/serializer": "^6.2" + "symfony/dependency-injection": "^5.4|^6.0|^7.0", + "symfony/property-access": "^5.4|^6.0|^7.0", + "symfony/property-info": "^5.4|^6.0|^7.0", + "symfony/serializer": "^6.3.2|^7.0" }, "type": "library", "autoload": { @@ -7056,7 +7179,7 @@ "mime-type" ], "support": { - "source": "https://github.com/symfony/mime/tree/v6.3.0" + "source": "https://github.com/symfony/mime/tree/v6.4.3" }, "funding": [ { @@ -7072,20 +7195,20 @@ "type": "tidelift" } ], - "time": "2023-04-28T15:57:00+00:00" + "time": "2024-01-30T08:32:12+00:00" }, { "name": "symfony/options-resolver", - "version": "v6.3.0", + "version": "v6.4.0", "source": { "type": "git", "url": "https://github.com/symfony/options-resolver.git", - "reference": "a10f19f5198d589d5c33333cffe98dc9820332dd" + "reference": "22301f0e7fdeaacc14318928612dee79be99860e" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/options-resolver/zipball/a10f19f5198d589d5c33333cffe98dc9820332dd", - "reference": "a10f19f5198d589d5c33333cffe98dc9820332dd", + "url": "https://api.github.com/repos/symfony/options-resolver/zipball/22301f0e7fdeaacc14318928612dee79be99860e", + "reference": "22301f0e7fdeaacc14318928612dee79be99860e", "shasum": "" }, "require": { @@ -7123,7 +7246,7 @@ "options" ], "support": { - "source": "https://github.com/symfony/options-resolver/tree/v6.3.0" + "source": "https://github.com/symfony/options-resolver/tree/v6.4.0" }, "funding": [ { @@ -7139,20 +7262,20 @@ "type": "tidelift" } ], - "time": "2023-05-12T14:21:09+00:00" + "time": "2023-08-08T10:16:24+00:00" }, { "name": "symfony/polyfill-ctype", - "version": "v1.27.0", + "version": "v1.28.0", "source": { "type": "git", "url": "https://github.com/symfony/polyfill-ctype.git", - "reference": "5bbc823adecdae860bb64756d639ecfec17b050a" + "reference": "ea208ce43cbb04af6867b4fdddb1bdbf84cc28cb" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-ctype/zipball/5bbc823adecdae860bb64756d639ecfec17b050a", - "reference": "5bbc823adecdae860bb64756d639ecfec17b050a", + "url": "https://api.github.com/repos/symfony/polyfill-ctype/zipball/ea208ce43cbb04af6867b4fdddb1bdbf84cc28cb", + "reference": "ea208ce43cbb04af6867b4fdddb1bdbf84cc28cb", "shasum": "" }, "require": { @@ -7167,7 +7290,7 @@ "type": "library", "extra": { "branch-alias": { - "dev-main": "1.27-dev" + "dev-main": "1.28-dev" }, "thanks": { "name": "symfony/polyfill", @@ -7205,7 +7328,7 @@ "portable" ], "support": { - "source": "https://github.com/symfony/polyfill-ctype/tree/v1.27.0" + "source": "https://github.com/symfony/polyfill-ctype/tree/v1.28.0" }, "funding": [ { @@ -7221,20 +7344,20 @@ "type": "tidelift" } ], - "time": "2022-11-03T14:55:06+00:00" + "time": "2023-01-26T09:26:14+00:00" }, { "name": "symfony/polyfill-intl-grapheme", - "version": "v1.27.0", + "version": "v1.28.0", "source": { "type": "git", "url": "https://github.com/symfony/polyfill-intl-grapheme.git", - "reference": "511a08c03c1960e08a883f4cffcacd219b758354" + "reference": "875e90aeea2777b6f135677f618529449334a612" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-intl-grapheme/zipball/511a08c03c1960e08a883f4cffcacd219b758354", - "reference": "511a08c03c1960e08a883f4cffcacd219b758354", + "url": "https://api.github.com/repos/symfony/polyfill-intl-grapheme/zipball/875e90aeea2777b6f135677f618529449334a612", + "reference": "875e90aeea2777b6f135677f618529449334a612", "shasum": "" }, "require": { @@ -7246,7 +7369,7 @@ "type": "library", "extra": { "branch-alias": { - "dev-main": "1.27-dev" + "dev-main": "1.28-dev" }, "thanks": { "name": "symfony/polyfill", @@ -7286,7 +7409,7 @@ "shim" ], "support": { - "source": "https://github.com/symfony/polyfill-intl-grapheme/tree/v1.27.0" + "source": "https://github.com/symfony/polyfill-intl-grapheme/tree/v1.28.0" }, "funding": [ { @@ -7302,20 +7425,20 @@ "type": "tidelift" } ], - "time": "2022-11-03T14:55:06+00:00" + "time": "2023-01-26T09:26:14+00:00" }, { "name": "symfony/polyfill-intl-idn", - "version": "v1.27.0", + "version": "v1.28.0", "source": { "type": "git", "url": "https://github.com/symfony/polyfill-intl-idn.git", - "reference": "639084e360537a19f9ee352433b84ce831f3d2da" + "reference": "ecaafce9f77234a6a449d29e49267ba10499116d" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-intl-idn/zipball/639084e360537a19f9ee352433b84ce831f3d2da", - "reference": "639084e360537a19f9ee352433b84ce831f3d2da", + "url": "https://api.github.com/repos/symfony/polyfill-intl-idn/zipball/ecaafce9f77234a6a449d29e49267ba10499116d", + "reference": "ecaafce9f77234a6a449d29e49267ba10499116d", "shasum": "" }, "require": { @@ -7329,7 +7452,7 @@ "type": "library", "extra": { "branch-alias": { - "dev-main": "1.27-dev" + "dev-main": "1.28-dev" }, "thanks": { "name": "symfony/polyfill", @@ -7373,7 +7496,7 @@ "shim" ], "support": { - "source": "https://github.com/symfony/polyfill-intl-idn/tree/v1.27.0" + "source": "https://github.com/symfony/polyfill-intl-idn/tree/v1.28.0" }, "funding": [ { @@ -7389,20 +7512,20 @@ "type": "tidelift" } ], - "time": "2022-11-03T14:55:06+00:00" + "time": "2023-01-26T09:30:37+00:00" }, { "name": "symfony/polyfill-intl-normalizer", - "version": "v1.27.0", + "version": "v1.28.0", "source": { "type": "git", "url": "https://github.com/symfony/polyfill-intl-normalizer.git", - "reference": "19bd1e4fcd5b91116f14d8533c57831ed00571b6" + "reference": "8c4ad05dd0120b6a53c1ca374dca2ad0a1c4ed92" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-intl-normalizer/zipball/19bd1e4fcd5b91116f14d8533c57831ed00571b6", - "reference": "19bd1e4fcd5b91116f14d8533c57831ed00571b6", + "url": "https://api.github.com/repos/symfony/polyfill-intl-normalizer/zipball/8c4ad05dd0120b6a53c1ca374dca2ad0a1c4ed92", + "reference": "8c4ad05dd0120b6a53c1ca374dca2ad0a1c4ed92", "shasum": "" }, "require": { @@ -7414,7 +7537,7 @@ "type": "library", "extra": { "branch-alias": { - "dev-main": "1.27-dev" + "dev-main": "1.28-dev" }, "thanks": { "name": "symfony/polyfill", @@ -7457,7 +7580,7 @@ "shim" ], "support": { - "source": "https://github.com/symfony/polyfill-intl-normalizer/tree/v1.27.0" + "source": "https://github.com/symfony/polyfill-intl-normalizer/tree/v1.28.0" }, "funding": [ { @@ -7473,7 +7596,7 @@ "type": "tidelift" } ], - "time": "2022-11-03T14:55:06+00:00" + "time": "2023-01-26T09:26:14+00:00" }, { "name": "symfony/polyfill-mbstring", @@ -7560,16 +7683,16 @@ }, { "name": "symfony/polyfill-php72", - "version": "v1.27.0", + "version": "v1.28.0", "source": { "type": "git", "url": "https://github.com/symfony/polyfill-php72.git", - "reference": "869329b1e9894268a8a61dabb69153029b7a8c97" + "reference": "70f4aebd92afca2f865444d30a4d2151c13c3179" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-php72/zipball/869329b1e9894268a8a61dabb69153029b7a8c97", - "reference": "869329b1e9894268a8a61dabb69153029b7a8c97", + "url": "https://api.github.com/repos/symfony/polyfill-php72/zipball/70f4aebd92afca2f865444d30a4d2151c13c3179", + "reference": "70f4aebd92afca2f865444d30a4d2151c13c3179", "shasum": "" }, "require": { @@ -7578,7 +7701,7 @@ "type": "library", "extra": { "branch-alias": { - "dev-main": "1.27-dev" + "dev-main": "1.28-dev" }, "thanks": { "name": "symfony/polyfill", @@ -7616,7 +7739,7 @@ "shim" ], "support": { - "source": "https://github.com/symfony/polyfill-php72/tree/v1.27.0" + "source": "https://github.com/symfony/polyfill-php72/tree/v1.28.0" }, "funding": [ { @@ -7632,20 +7755,20 @@ "type": "tidelift" } ], - "time": "2022-11-03T14:55:06+00:00" + "time": "2023-01-26T09:26:14+00:00" }, { "name": "symfony/polyfill-php80", - "version": "v1.27.0", + "version": "v1.28.0", "source": { "type": "git", "url": "https://github.com/symfony/polyfill-php80.git", - "reference": "7a6ff3f1959bb01aefccb463a0f2cd3d3d2fd936" + "reference": "6caa57379c4aec19c0a12a38b59b26487dcfe4b5" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-php80/zipball/7a6ff3f1959bb01aefccb463a0f2cd3d3d2fd936", - "reference": "7a6ff3f1959bb01aefccb463a0f2cd3d3d2fd936", + "url": "https://api.github.com/repos/symfony/polyfill-php80/zipball/6caa57379c4aec19c0a12a38b59b26487dcfe4b5", + "reference": "6caa57379c4aec19c0a12a38b59b26487dcfe4b5", "shasum": "" }, "require": { @@ -7654,7 +7777,7 @@ "type": "library", "extra": { "branch-alias": { - "dev-main": "1.27-dev" + "dev-main": "1.28-dev" }, "thanks": { "name": "symfony/polyfill", @@ -7699,7 +7822,7 @@ "shim" ], "support": { - "source": "https://github.com/symfony/polyfill-php80/tree/v1.27.0" + "source": "https://github.com/symfony/polyfill-php80/tree/v1.28.0" }, "funding": [ { @@ -7715,20 +7838,20 @@ "type": "tidelift" } ], - "time": "2022-11-03T14:55:06+00:00" + "time": "2023-01-26T09:26:14+00:00" }, { "name": "symfony/polyfill-php83", - "version": "v1.27.0", + "version": "v1.28.0", "source": { "type": "git", "url": "https://github.com/symfony/polyfill-php83.git", - "reference": "508c652ba3ccf69f8c97f251534f229791b52a57" + "reference": "b0f46ebbeeeda3e9d2faebdfbf4b4eae9b59fa11" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-php83/zipball/508c652ba3ccf69f8c97f251534f229791b52a57", - "reference": "508c652ba3ccf69f8c97f251534f229791b52a57", + "url": "https://api.github.com/repos/symfony/polyfill-php83/zipball/b0f46ebbeeeda3e9d2faebdfbf4b4eae9b59fa11", + "reference": "b0f46ebbeeeda3e9d2faebdfbf4b4eae9b59fa11", "shasum": "" }, "require": { @@ -7738,7 +7861,7 @@ "type": "library", "extra": { "branch-alias": { - "dev-main": "1.27-dev" + "dev-main": "1.28-dev" }, "thanks": { "name": "symfony/polyfill", @@ -7751,7 +7874,10 @@ ], "psr-4": { "Symfony\\Polyfill\\Php83\\": "" - } + }, + "classmap": [ + "Resources/stubs" + ] }, "notification-url": "https://packagist.org/downloads/", "license": [ @@ -7776,7 +7902,7 @@ "shim" ], "support": { - "source": "https://github.com/symfony/polyfill-php83/tree/v1.27.0" + "source": "https://github.com/symfony/polyfill-php83/tree/v1.28.0" }, "funding": [ { @@ -7792,20 +7918,20 @@ "type": "tidelift" } ], - "time": "2022-11-03T14:55:06+00:00" + "time": "2023-08-16T06:22:46+00:00" }, { "name": "symfony/polyfill-uuid", - "version": "v1.27.0", + "version": "v1.28.0", "source": { "type": "git", "url": "https://github.com/symfony/polyfill-uuid.git", - "reference": "f3cf1a645c2734236ed1e2e671e273eeb3586166" + "reference": "9c44518a5aff8da565c8a55dbe85d2769e6f630e" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-uuid/zipball/f3cf1a645c2734236ed1e2e671e273eeb3586166", - "reference": "f3cf1a645c2734236ed1e2e671e273eeb3586166", + "url": "https://api.github.com/repos/symfony/polyfill-uuid/zipball/9c44518a5aff8da565c8a55dbe85d2769e6f630e", + "reference": "9c44518a5aff8da565c8a55dbe85d2769e6f630e", "shasum": "" }, "require": { @@ -7820,7 +7946,7 @@ "type": "library", "extra": { "branch-alias": { - "dev-main": "1.27-dev" + "dev-main": "1.28-dev" }, "thanks": { "name": "symfony/polyfill", @@ -7858,7 +7984,7 @@ "uuid" ], "support": { - "source": "https://github.com/symfony/polyfill-uuid/tree/v1.27.0" + "source": "https://github.com/symfony/polyfill-uuid/tree/v1.28.0" }, "funding": [ { @@ -7874,20 +8000,20 @@ "type": "tidelift" } ], - "time": "2022-11-03T14:55:06+00:00" + "time": "2023-01-26T09:26:14+00:00" }, { "name": "symfony/process", - "version": "v6.3.0", + "version": "v6.4.3", "source": { "type": "git", "url": "https://github.com/symfony/process.git", - "reference": "8741e3ed7fe2e91ec099e02446fb86667a0f1628" + "reference": "31642b0818bfcff85930344ef93193f8c607e0a3" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/process/zipball/8741e3ed7fe2e91ec099e02446fb86667a0f1628", - "reference": "8741e3ed7fe2e91ec099e02446fb86667a0f1628", + "url": "https://api.github.com/repos/symfony/process/zipball/31642b0818bfcff85930344ef93193f8c607e0a3", + "reference": "31642b0818bfcff85930344ef93193f8c607e0a3", "shasum": "" }, "require": { @@ -7919,7 +8045,7 @@ "description": "Executes commands in sub-processes", "homepage": "https://symfony.com", "support": { - "source": "https://github.com/symfony/process/tree/v6.3.0" + "source": "https://github.com/symfony/process/tree/v6.4.3" }, "funding": [ { @@ -7935,25 +8061,26 @@ "type": "tidelift" } ], - "time": "2023-05-19T08:06:44+00:00" + "time": "2024-01-23T14:51:35+00:00" }, { "name": "symfony/psr-http-message-bridge", - "version": "v2.2.0", + "version": "v2.3.1", "source": { "type": "git", "url": "https://github.com/symfony/psr-http-message-bridge.git", - "reference": "28a732c05bbad801304ad5a5c674cf2970508993" + "reference": "581ca6067eb62640de5ff08ee1ba6850a0ee472e" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/psr-http-message-bridge/zipball/28a732c05bbad801304ad5a5c674cf2970508993", - "reference": "28a732c05bbad801304ad5a5c674cf2970508993", + "url": "https://api.github.com/repos/symfony/psr-http-message-bridge/zipball/581ca6067eb62640de5ff08ee1ba6850a0ee472e", + "reference": "581ca6067eb62640de5ff08ee1ba6850a0ee472e", "shasum": "" }, "require": { "php": ">=7.2.5", "psr/http-message": "^1.0 || ^2.0", + "symfony/deprecation-contracts": "^2.5 || ^3.0", "symfony/http-foundation": "^5.4 || ^6.0" }, "require-dev": { @@ -7972,7 +8099,7 @@ "type": "symfony-bridge", "extra": { "branch-alias": { - "dev-main": "2.2-dev" + "dev-main": "2.3-dev" } }, "autoload": { @@ -8007,7 +8134,7 @@ ], "support": { "issues": "https://github.com/symfony/psr-http-message-bridge/issues", - "source": "https://github.com/symfony/psr-http-message-bridge/tree/v2.2.0" + "source": "https://github.com/symfony/psr-http-message-bridge/tree/v2.3.1" }, "funding": [ { @@ -8023,24 +8150,25 @@ "type": "tidelift" } ], - "time": "2023-04-21T08:40:19+00:00" + "time": "2023-07-26T11:53:26+00:00" }, { "name": "symfony/routing", - "version": "v6.3.0", + "version": "v6.4.3", "source": { "type": "git", "url": "https://github.com/symfony/routing.git", - "reference": "827f59fdc67eecfc4dfff81f9c93bf4d98f0c89b" + "reference": "3b2957ad54902f0f544df83e3d58b38d7e8e5842" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/routing/zipball/827f59fdc67eecfc4dfff81f9c93bf4d98f0c89b", - "reference": "827f59fdc67eecfc4dfff81f9c93bf4d98f0c89b", + "url": "https://api.github.com/repos/symfony/routing/zipball/3b2957ad54902f0f544df83e3d58b38d7e8e5842", + "reference": "3b2957ad54902f0f544df83e3d58b38d7e8e5842", "shasum": "" }, "require": { - "php": ">=8.1" + "php": ">=8.1", + "symfony/deprecation-contracts": "^2.5|^3" }, "conflict": { "doctrine/annotations": "<1.12", @@ -8051,11 +8179,11 @@ "require-dev": { "doctrine/annotations": "^1.12|^2", "psr/log": "^1|^2|^3", - "symfony/config": "^6.2", - "symfony/dependency-injection": "^5.4|^6.0", - "symfony/expression-language": "^5.4|^6.0", - "symfony/http-foundation": "^5.4|^6.0", - "symfony/yaml": "^5.4|^6.0" + "symfony/config": "^6.2|^7.0", + "symfony/dependency-injection": "^5.4|^6.0|^7.0", + "symfony/expression-language": "^5.4|^6.0|^7.0", + "symfony/http-foundation": "^5.4|^6.0|^7.0", + "symfony/yaml": "^5.4|^6.0|^7.0" }, "type": "library", "autoload": { @@ -8089,7 +8217,7 @@ "url" ], "support": { - "source": "https://github.com/symfony/routing/tree/v6.3.0" + "source": "https://github.com/symfony/routing/tree/v6.4.3" }, "funding": [ { @@ -8105,25 +8233,25 @@ "type": "tidelift" } ], - "time": "2023-04-28T15:57:00+00:00" + "time": "2024-01-30T13:55:02+00:00" }, { "name": "symfony/service-contracts", - "version": "v3.3.0", + "version": "v3.4.1", "source": { "type": "git", "url": "https://github.com/symfony/service-contracts.git", - "reference": "40da9cc13ec349d9e4966ce18b5fbcd724ab10a4" + "reference": "fe07cbc8d837f60caf7018068e350cc5163681a0" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/service-contracts/zipball/40da9cc13ec349d9e4966ce18b5fbcd724ab10a4", - "reference": "40da9cc13ec349d9e4966ce18b5fbcd724ab10a4", + "url": "https://api.github.com/repos/symfony/service-contracts/zipball/fe07cbc8d837f60caf7018068e350cc5163681a0", + "reference": "fe07cbc8d837f60caf7018068e350cc5163681a0", "shasum": "" }, "require": { "php": ">=8.1", - "psr/container": "^2.0" + "psr/container": "^1.1|^2.0" }, "conflict": { "ext-psr": "<1.1|>=2" @@ -8171,7 +8299,7 @@ "standards" ], "support": { - "source": "https://github.com/symfony/service-contracts/tree/v3.3.0" + "source": "https://github.com/symfony/service-contracts/tree/v3.4.1" }, "funding": [ { @@ -8187,20 +8315,20 @@ "type": "tidelift" } ], - "time": "2023-05-23T14:45:45+00:00" + "time": "2023-12-26T14:02:43+00:00" }, { "name": "symfony/string", - "version": "v6.3.0", + "version": "v6.4.3", "source": { "type": "git", "url": "https://github.com/symfony/string.git", - "reference": "f2e190ee75ff0f5eced645ec0be5c66fac81f51f" + "reference": "7a14736fb179876575464e4658fce0c304e8c15b" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/string/zipball/f2e190ee75ff0f5eced645ec0be5c66fac81f51f", - "reference": "f2e190ee75ff0f5eced645ec0be5c66fac81f51f", + "url": "https://api.github.com/repos/symfony/string/zipball/7a14736fb179876575464e4658fce0c304e8c15b", + "reference": "7a14736fb179876575464e4658fce0c304e8c15b", "shasum": "" }, "require": { @@ -8214,11 +8342,11 @@ "symfony/translation-contracts": "<2.5" }, "require-dev": { - "symfony/error-handler": "^5.4|^6.0", - "symfony/http-client": "^5.4|^6.0", - "symfony/intl": "^6.2", + "symfony/error-handler": "^5.4|^6.0|^7.0", + "symfony/http-client": "^5.4|^6.0|^7.0", + "symfony/intl": "^6.2|^7.0", "symfony/translation-contracts": "^2.5|^3.0", - "symfony/var-exporter": "^5.4|^6.0" + "symfony/var-exporter": "^5.4|^6.0|^7.0" }, "type": "library", "autoload": { @@ -8257,7 +8385,7 @@ "utf8" ], "support": { - "source": "https://github.com/symfony/string/tree/v6.3.0" + "source": "https://github.com/symfony/string/tree/v6.4.3" }, "funding": [ { @@ -8273,24 +8401,25 @@ "type": "tidelift" } ], - "time": "2023-03-21T21:06:29+00:00" + "time": "2024-01-25T09:26:29+00:00" }, { "name": "symfony/translation", - "version": "v6.3.0", + "version": "v6.4.3", "source": { "type": "git", "url": "https://github.com/symfony/translation.git", - "reference": "f72b2cba8f79dd9d536f534f76874b58ad37876f" + "reference": "637c51191b6b184184bbf98937702bcf554f7d04" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/translation/zipball/f72b2cba8f79dd9d536f534f76874b58ad37876f", - "reference": "f72b2cba8f79dd9d536f534f76874b58ad37876f", + "url": "https://api.github.com/repos/symfony/translation/zipball/637c51191b6b184184bbf98937702bcf554f7d04", + "reference": "637c51191b6b184184bbf98937702bcf554f7d04", "shasum": "" }, "require": { "php": ">=8.1", + "symfony/deprecation-contracts": "^2.5|^3", "symfony/polyfill-mbstring": "~1.0", "symfony/translation-contracts": "^2.5|^3.0" }, @@ -8308,19 +8437,19 @@ "symfony/translation-implementation": "2.3|3.0" }, "require-dev": { - "nikic/php-parser": "^4.13", + "nikic/php-parser": "^4.18|^5.0", "psr/log": "^1|^2|^3", - "symfony/config": "^5.4|^6.0", - "symfony/console": "^5.4|^6.0", - "symfony/dependency-injection": "^5.4|^6.0", - "symfony/finder": "^5.4|^6.0", + "symfony/config": "^5.4|^6.0|^7.0", + "symfony/console": "^5.4|^6.0|^7.0", + "symfony/dependency-injection": "^5.4|^6.0|^7.0", + "symfony/finder": "^5.4|^6.0|^7.0", "symfony/http-client-contracts": "^2.5|^3.0", - "symfony/http-kernel": "^5.4|^6.0", - "symfony/intl": "^5.4|^6.0", + "symfony/http-kernel": "^5.4|^6.0|^7.0", + "symfony/intl": "^5.4|^6.0|^7.0", "symfony/polyfill-intl-icu": "^1.21", - "symfony/routing": "^5.4|^6.0", + "symfony/routing": "^5.4|^6.0|^7.0", "symfony/service-contracts": "^2.5|^3", - "symfony/yaml": "^5.4|^6.0" + "symfony/yaml": "^5.4|^6.0|^7.0" }, "type": "library", "autoload": { @@ -8351,7 +8480,7 @@ "description": "Provides tools to internationalize your application", "homepage": "https://symfony.com", "support": { - "source": "https://github.com/symfony/translation/tree/v6.3.0" + "source": "https://github.com/symfony/translation/tree/v6.4.3" }, "funding": [ { @@ -8367,20 +8496,20 @@ "type": "tidelift" } ], - "time": "2023-05-19T12:46:45+00:00" + "time": "2024-01-29T13:11:52+00:00" }, { "name": "symfony/translation-contracts", - "version": "v3.3.0", + "version": "v3.4.1", "source": { "type": "git", "url": "https://github.com/symfony/translation-contracts.git", - "reference": "02c24deb352fb0d79db5486c0c79905a85e37e86" + "reference": "06450585bf65e978026bda220cdebca3f867fde7" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/translation-contracts/zipball/02c24deb352fb0d79db5486c0c79905a85e37e86", - "reference": "02c24deb352fb0d79db5486c0c79905a85e37e86", + "url": "https://api.github.com/repos/symfony/translation-contracts/zipball/06450585bf65e978026bda220cdebca3f867fde7", + "reference": "06450585bf65e978026bda220cdebca3f867fde7", "shasum": "" }, "require": { @@ -8429,7 +8558,7 @@ "standards" ], "support": { - "source": "https://github.com/symfony/translation-contracts/tree/v3.3.0" + "source": "https://github.com/symfony/translation-contracts/tree/v3.4.1" }, "funding": [ { @@ -8445,20 +8574,20 @@ "type": "tidelift" } ], - "time": "2023-05-30T17:17:10+00:00" + "time": "2023-12-26T14:02:43+00:00" }, { "name": "symfony/uid", - "version": "v6.3.0", + "version": "v6.4.3", "source": { "type": "git", "url": "https://github.com/symfony/uid.git", - "reference": "01b0f20b1351d997711c56f1638f7a8c3061e384" + "reference": "1d31267211cc3a2fff32bcfc7c1818dac41b6fc0" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/uid/zipball/01b0f20b1351d997711c56f1638f7a8c3061e384", - "reference": "01b0f20b1351d997711c56f1638f7a8c3061e384", + "url": "https://api.github.com/repos/symfony/uid/zipball/1d31267211cc3a2fff32bcfc7c1818dac41b6fc0", + "reference": "1d31267211cc3a2fff32bcfc7c1818dac41b6fc0", "shasum": "" }, "require": { @@ -8466,7 +8595,7 @@ "symfony/polyfill-uuid": "^1.15" }, "require-dev": { - "symfony/console": "^5.4|^6.0" + "symfony/console": "^5.4|^6.0|^7.0" }, "type": "library", "autoload": { @@ -8503,7 +8632,7 @@ "uuid" ], "support": { - "source": "https://github.com/symfony/uid/tree/v6.3.0" + "source": "https://github.com/symfony/uid/tree/v6.4.3" }, "funding": [ { @@ -8519,24 +8648,25 @@ "type": "tidelift" } ], - "time": "2023-04-08T07:25:02+00:00" + "time": "2024-01-23T14:51:35+00:00" }, { "name": "symfony/var-dumper", - "version": "v6.3.0", + "version": "v6.4.3", "source": { "type": "git", "url": "https://github.com/symfony/var-dumper.git", - "reference": "6acdcd5c122074ee9f7b051e4fb177025c277a0e" + "reference": "0435a08f69125535336177c29d56af3abc1f69da" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/var-dumper/zipball/6acdcd5c122074ee9f7b051e4fb177025c277a0e", - "reference": "6acdcd5c122074ee9f7b051e4fb177025c277a0e", + "url": "https://api.github.com/repos/symfony/var-dumper/zipball/0435a08f69125535336177c29d56af3abc1f69da", + "reference": "0435a08f69125535336177c29d56af3abc1f69da", "shasum": "" }, "require": { "php": ">=8.1", + "symfony/deprecation-contracts": "^2.5|^3", "symfony/polyfill-mbstring": "~1.0" }, "conflict": { @@ -8544,9 +8674,11 @@ }, "require-dev": { "ext-iconv": "*", - "symfony/console": "^5.4|^6.0", - "symfony/process": "^5.4|^6.0", - "symfony/uid": "^5.4|^6.0", + "symfony/console": "^5.4|^6.0|^7.0", + "symfony/error-handler": "^6.3|^7.0", + "symfony/http-kernel": "^5.4|^6.0|^7.0", + "symfony/process": "^5.4|^6.0|^7.0", + "symfony/uid": "^5.4|^6.0|^7.0", "twig/twig": "^2.13|^3.0.4" }, "bin": [ @@ -8585,7 +8717,7 @@ "dump" ], "support": { - "source": "https://github.com/symfony/var-dumper/tree/v6.3.0" + "source": "https://github.com/symfony/var-dumper/tree/v6.4.3" }, "funding": [ { @@ -8601,7 +8733,7 @@ "type": "tidelift" } ], - "time": "2023-05-25T13:09:35+00:00" + "time": "2024-01-23T14:53:30+00:00" }, { "name": "textalk/websocket", @@ -8654,23 +8786,23 @@ }, { "name": "tijsverkoyen/css-to-inline-styles", - "version": "2.2.6", + "version": "v2.2.7", "source": { "type": "git", "url": "https://github.com/tijsverkoyen/CssToInlineStyles.git", - "reference": "c42125b83a4fa63b187fdf29f9c93cb7733da30c" + "reference": "83ee6f38df0a63106a9e4536e3060458b74ccedb" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/tijsverkoyen/CssToInlineStyles/zipball/c42125b83a4fa63b187fdf29f9c93cb7733da30c", - "reference": "c42125b83a4fa63b187fdf29f9c93cb7733da30c", + "url": "https://api.github.com/repos/tijsverkoyen/CssToInlineStyles/zipball/83ee6f38df0a63106a9e4536e3060458b74ccedb", + "reference": "83ee6f38df0a63106a9e4536e3060458b74ccedb", "shasum": "" }, "require": { "ext-dom": "*", "ext-libxml": "*", "php": "^5.5 || ^7.0 || ^8.0", - "symfony/css-selector": "^2.7 || ^3.0 || ^4.0 || ^5.0 || ^6.0" + "symfony/css-selector": "^2.7 || ^3.0 || ^4.0 || ^5.0 || ^6.0 || ^7.0" }, "require-dev": { "phpunit/phpunit": "^4.8.35 || ^5.7 || ^6.0 || ^7.5 || ^8.5.21 || ^9.5.10" @@ -8701,37 +8833,37 @@ "homepage": "https://github.com/tijsverkoyen/CssToInlineStyles", "support": { "issues": "https://github.com/tijsverkoyen/CssToInlineStyles/issues", - "source": "https://github.com/tijsverkoyen/CssToInlineStyles/tree/2.2.6" + "source": "https://github.com/tijsverkoyen/CssToInlineStyles/tree/v2.2.7" }, - "time": "2023-01-03T09:29:04+00:00" + "time": "2023-12-08T13:03:43+00:00" }, { "name": "vlucas/phpdotenv", - "version": "v5.5.0", + "version": "v5.6.0", "source": { "type": "git", "url": "https://github.com/vlucas/phpdotenv.git", - "reference": "1a7ea2afc49c3ee6d87061f5a233e3a035d0eae7" + "reference": "2cf9fb6054c2bb1d59d1f3817706ecdb9d2934c4" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/vlucas/phpdotenv/zipball/1a7ea2afc49c3ee6d87061f5a233e3a035d0eae7", - "reference": "1a7ea2afc49c3ee6d87061f5a233e3a035d0eae7", + "url": "https://api.github.com/repos/vlucas/phpdotenv/zipball/2cf9fb6054c2bb1d59d1f3817706ecdb9d2934c4", + "reference": "2cf9fb6054c2bb1d59d1f3817706ecdb9d2934c4", "shasum": "" }, "require": { "ext-pcre": "*", - "graham-campbell/result-type": "^1.0.2", - "php": "^7.1.3 || ^8.0", - "phpoption/phpoption": "^1.8", - "symfony/polyfill-ctype": "^1.23", - "symfony/polyfill-mbstring": "^1.23.1", - "symfony/polyfill-php80": "^1.23.1" + "graham-campbell/result-type": "^1.1.2", + "php": "^7.2.5 || ^8.0", + "phpoption/phpoption": "^1.9.2", + "symfony/polyfill-ctype": "^1.24", + "symfony/polyfill-mbstring": "^1.24", + "symfony/polyfill-php80": "^1.24" }, "require-dev": { - "bamarni/composer-bin-plugin": "^1.4.1", + "bamarni/composer-bin-plugin": "^1.8.2", "ext-filter": "*", - "phpunit/phpunit": "^7.5.20 || ^8.5.30 || ^9.5.25" + "phpunit/phpunit": "^8.5.34 || ^9.6.13 || ^10.4.2" }, "suggest": { "ext-filter": "Required to use the boolean validator." @@ -8743,7 +8875,7 @@ "forward-command": true }, "branch-alias": { - "dev-master": "5.5-dev" + "dev-master": "5.6-dev" } }, "autoload": { @@ -8775,7 +8907,7 @@ ], "support": { "issues": "https://github.com/vlucas/phpdotenv/issues", - "source": "https://github.com/vlucas/phpdotenv/tree/v5.5.0" + "source": "https://github.com/vlucas/phpdotenv/tree/v5.6.0" }, "funding": [ { @@ -8787,7 +8919,7 @@ "type": "tidelift" } ], - "time": "2022-10-16T01:01:54+00:00" + "time": "2023-11-12T22:43:29+00:00" }, { "name": "voku/portable-ascii", @@ -8925,16 +9057,16 @@ "packages-dev": [ { "name": "barryvdh/laravel-debugbar", - "version": "v3.8.1", + "version": "v3.9.2", "source": { "type": "git", "url": "https://github.com/barryvdh/laravel-debugbar.git", - "reference": "aff3235fecb4104203b1e62c32239c56530eee32" + "reference": "bfd0131c146973cab164e50f5cdd8a67cc60cab1" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/barryvdh/laravel-debugbar/zipball/aff3235fecb4104203b1e62c32239c56530eee32", - "reference": "aff3235fecb4104203b1e62c32239c56530eee32", + "url": "https://api.github.com/repos/barryvdh/laravel-debugbar/zipball/bfd0131c146973cab164e50f5cdd8a67cc60cab1", + "reference": "bfd0131c146973cab164e50f5cdd8a67cc60cab1", "shasum": "" }, "require": { @@ -8993,7 +9125,7 @@ ], "support": { "issues": "https://github.com/barryvdh/laravel-debugbar/issues", - "source": "https://github.com/barryvdh/laravel-debugbar/tree/v3.8.1" + "source": "https://github.com/barryvdh/laravel-debugbar/tree/v3.9.2" }, "funding": [ { @@ -9005,7 +9137,7 @@ "type": "github" } ], - "time": "2023-02-21T14:21:02+00:00" + "time": "2023-08-25T18:43:57+00:00" }, { "name": "barryvdh/laravel-ide-helper", @@ -9103,16 +9235,16 @@ }, { "name": "barryvdh/reflection-docblock", - "version": "v2.1.0", + "version": "v2.1.1", "source": { "type": "git", "url": "https://github.com/barryvdh/ReflectionDocBlock.git", - "reference": "bf44b757feb8ba1734659029357646466ded673e" + "reference": "e6811e927f0ecc37cc4deaa6627033150343e597" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/barryvdh/ReflectionDocBlock/zipball/bf44b757feb8ba1734659029357646466ded673e", - "reference": "bf44b757feb8ba1734659029357646466ded673e", + "url": "https://api.github.com/repos/barryvdh/ReflectionDocBlock/zipball/e6811e927f0ecc37cc4deaa6627033150343e597", + "reference": "e6811e927f0ecc37cc4deaa6627033150343e597", "shasum": "" }, "require": { @@ -9149,28 +9281,28 @@ } ], "support": { - "source": "https://github.com/barryvdh/ReflectionDocBlock/tree/v2.1.0" + "source": "https://github.com/barryvdh/ReflectionDocBlock/tree/v2.1.1" }, - "time": "2022-10-31T15:35:43+00:00" + "time": "2023-06-14T05:06:27+00:00" }, { "name": "composer/class-map-generator", - "version": "1.0.0", + "version": "1.1.0", "source": { "type": "git", "url": "https://github.com/composer/class-map-generator.git", - "reference": "1e1cb2b791facb2dfe32932a7718cf2571187513" + "reference": "953cc4ea32e0c31f2185549c7d216d7921f03da9" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/composer/class-map-generator/zipball/1e1cb2b791facb2dfe32932a7718cf2571187513", - "reference": "1e1cb2b791facb2dfe32932a7718cf2571187513", + "url": "https://api.github.com/repos/composer/class-map-generator/zipball/953cc4ea32e0c31f2185549c7d216d7921f03da9", + "reference": "953cc4ea32e0c31f2185549c7d216d7921f03da9", "shasum": "" }, "require": { - "composer/pcre": "^2 || ^3", + "composer/pcre": "^2.1 || ^3.1", "php": "^7.2 || ^8.0", - "symfony/finder": "^4.4 || ^5.3 || ^6" + "symfony/finder": "^4.4 || ^5.3 || ^6 || ^7" }, "require-dev": { "phpstan/phpstan": "^1.6", @@ -9208,7 +9340,7 @@ ], "support": { "issues": "https://github.com/composer/class-map-generator/issues", - "source": "https://github.com/composer/class-map-generator/tree/1.0.0" + "source": "https://github.com/composer/class-map-generator/tree/1.1.0" }, "funding": [ { @@ -9224,20 +9356,20 @@ "type": "tidelift" } ], - "time": "2022-06-19T11:31:27+00:00" + "time": "2023-06-30T13:58:57+00:00" }, { "name": "composer/pcre", - "version": "3.1.0", + "version": "3.1.1", "source": { "type": "git", "url": "https://github.com/composer/pcre.git", - "reference": "4bff79ddd77851fe3cdd11616ed3f92841ba5bd2" + "reference": "00104306927c7a0919b4ced2aaa6782c1e61a3c9" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/composer/pcre/zipball/4bff79ddd77851fe3cdd11616ed3f92841ba5bd2", - "reference": "4bff79ddd77851fe3cdd11616ed3f92841ba5bd2", + "url": "https://api.github.com/repos/composer/pcre/zipball/00104306927c7a0919b4ced2aaa6782c1e61a3c9", + "reference": "00104306927c7a0919b4ced2aaa6782c1e61a3c9", "shasum": "" }, "require": { @@ -9279,7 +9411,7 @@ ], "support": { "issues": "https://github.com/composer/pcre/issues", - "source": "https://github.com/composer/pcre/tree/3.1.0" + "source": "https://github.com/composer/pcre/tree/3.1.1" }, "funding": [ { @@ -9295,7 +9427,7 @@ "type": "tidelift" } ], - "time": "2022-11-17T09:50:14+00:00" + "time": "2023-10-11T07:11:09+00:00" }, { "name": "doctrine/cache", @@ -9392,16 +9524,16 @@ }, { "name": "doctrine/dbal", - "version": "3.6.3", + "version": "3.8.1", "source": { "type": "git", "url": "https://github.com/doctrine/dbal.git", - "reference": "9a747d29e7e6b39509b8f1847e37a23a0163ea6a" + "reference": "c9ea252cdce4da324ede3d6c5913dd89f769afd2" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/doctrine/dbal/zipball/9a747d29e7e6b39509b8f1847e37a23a0163ea6a", - "reference": "9a747d29e7e6b39509b8f1847e37a23a0163ea6a", + "url": "https://api.github.com/repos/doctrine/dbal/zipball/c9ea252cdce4da324ede3d6c5913dd89f769afd2", + "reference": "c9ea252cdce4da324ede3d6c5913dd89f769afd2", "shasum": "" }, "require": { @@ -9416,14 +9548,15 @@ "require-dev": { "doctrine/coding-standard": "12.0.0", "fig/log-test": "^1", - "jetbrains/phpstorm-stubs": "2022.3", - "phpstan/phpstan": "1.10.14", + "jetbrains/phpstorm-stubs": "2023.1", + "phpstan/phpstan": "1.10.57", "phpstan/phpstan-strict-rules": "^1.5", - "phpunit/phpunit": "9.6.7", + "phpunit/phpunit": "9.6.16", "psalm/plugin-phpunit": "0.18.4", - "squizlabs/php_codesniffer": "3.7.2", - "symfony/cache": "^5.4|^6.0", - "symfony/console": "^4.4|^5.4|^6.0", + "slevomat/coding-standard": "8.13.1", + "squizlabs/php_codesniffer": "3.8.1", + "symfony/cache": "^5.4|^6.0|^7.0", + "symfony/console": "^4.4|^5.4|^6.0|^7.0", "vimeo/psalm": "4.30.0" }, "suggest": { @@ -9484,7 +9617,7 @@ ], "support": { "issues": "https://github.com/doctrine/dbal/issues", - "source": "https://github.com/doctrine/dbal/tree/3.6.3" + "source": "https://github.com/doctrine/dbal/tree/3.8.1" }, "funding": [ { @@ -9500,20 +9633,20 @@ "type": "tidelift" } ], - "time": "2023-06-01T05:46:46+00:00" + "time": "2024-02-03T17:33:49+00:00" }, { "name": "doctrine/deprecations", - "version": "v1.1.1", + "version": "1.1.3", "source": { "type": "git", "url": "https://github.com/doctrine/deprecations.git", - "reference": "612a3ee5ab0d5dd97b7cf3874a6efe24325efac3" + "reference": "dfbaa3c2d2e9a9df1118213f3b8b0c597bb99fab" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/doctrine/deprecations/zipball/612a3ee5ab0d5dd97b7cf3874a6efe24325efac3", - "reference": "612a3ee5ab0d5dd97b7cf3874a6efe24325efac3", + "url": "https://api.github.com/repos/doctrine/deprecations/zipball/dfbaa3c2d2e9a9df1118213f3b8b0c597bb99fab", + "reference": "dfbaa3c2d2e9a9df1118213f3b8b0c597bb99fab", "shasum": "" }, "require": { @@ -9545,9 +9678,9 @@ "homepage": "https://www.doctrine-project.org/", "support": { "issues": "https://github.com/doctrine/deprecations/issues", - "source": "https://github.com/doctrine/deprecations/tree/v1.1.1" + "source": "https://github.com/doctrine/deprecations/tree/1.1.3" }, - "time": "2023-06-03T09:27:29+00:00" + "time": "2024-01-30T19:34:25+00:00" }, { "name": "doctrine/event-manager", @@ -9712,16 +9845,16 @@ }, { "name": "filp/whoops", - "version": "2.15.2", + "version": "2.15.4", "source": { "type": "git", "url": "https://github.com/filp/whoops.git", - "reference": "aac9304c5ed61bf7b1b7a6064bf9806ab842ce73" + "reference": "a139776fa3f5985a50b509f2a02ff0f709d2a546" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/filp/whoops/zipball/aac9304c5ed61bf7b1b7a6064bf9806ab842ce73", - "reference": "aac9304c5ed61bf7b1b7a6064bf9806ab842ce73", + "url": "https://api.github.com/repos/filp/whoops/zipball/a139776fa3f5985a50b509f2a02ff0f709d2a546", + "reference": "a139776fa3f5985a50b509f2a02ff0f709d2a546", "shasum": "" }, "require": { @@ -9771,7 +9904,7 @@ ], "support": { "issues": "https://github.com/filp/whoops/issues", - "source": "https://github.com/filp/whoops/tree/2.15.2" + "source": "https://github.com/filp/whoops/tree/2.15.4" }, "funding": [ { @@ -9779,7 +9912,7 @@ "type": "github" } ], - "time": "2023-04-12T12:00:00+00:00" + "time": "2023-11-03T12:00:00+00:00" }, { "name": "hamcrest/hamcrest-php", @@ -9834,16 +9967,16 @@ }, { "name": "maximebf/debugbar", - "version": "v1.18.2", + "version": "v1.19.1", "source": { "type": "git", "url": "https://github.com/maximebf/php-debugbar.git", - "reference": "17dcf3f6ed112bb85a37cf13538fd8de49f5c274" + "reference": "03dd40a1826f4d585ef93ef83afa2a9874a00523" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/maximebf/php-debugbar/zipball/17dcf3f6ed112bb85a37cf13538fd8de49f5c274", - "reference": "17dcf3f6ed112bb85a37cf13538fd8de49f5c274", + "url": "https://api.github.com/repos/maximebf/php-debugbar/zipball/03dd40a1826f4d585ef93ef83afa2a9874a00523", + "reference": "03dd40a1826f4d585ef93ef83afa2a9874a00523", "shasum": "" }, "require": { @@ -9894,43 +10027,37 @@ ], "support": { "issues": "https://github.com/maximebf/php-debugbar/issues", - "source": "https://github.com/maximebf/php-debugbar/tree/v1.18.2" + "source": "https://github.com/maximebf/php-debugbar/tree/v1.19.1" }, - "time": "2023-02-04T15:27:00+00:00" + "time": "2023-10-12T08:10:52+00:00" }, { "name": "mockery/mockery", - "version": "1.6.2", + "version": "1.6.7", "source": { "type": "git", "url": "https://github.com/mockery/mockery.git", - "reference": "13a7fa2642c76c58fa2806ef7f565344c817a191" + "reference": "0cc058854b3195ba21dc6b1f7b1f60f4ef3a9c06" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/mockery/mockery/zipball/13a7fa2642c76c58fa2806ef7f565344c817a191", - "reference": "13a7fa2642c76c58fa2806ef7f565344c817a191", + "url": "https://api.github.com/repos/mockery/mockery/zipball/0cc058854b3195ba21dc6b1f7b1f60f4ef3a9c06", + "reference": "0cc058854b3195ba21dc6b1f7b1f60f4ef3a9c06", "shasum": "" }, "require": { "hamcrest/hamcrest-php": "^2.0.1", "lib-pcre": ">=7.0", - "php": "^7.4 || ^8.0" + "php": ">=7.3" }, "conflict": { "phpunit/phpunit": "<8.0" }, "require-dev": { - "phpunit/phpunit": "^8.5 || ^9.3", - "psalm/plugin-phpunit": "^0.18", - "vimeo/psalm": "^5.9" + "phpunit/phpunit": "^8.5 || ^9.6.10", + "symplify/easy-coding-standard": "^12.0.8" }, "type": "library", - "extra": { - "branch-alias": { - "dev-main": "1.6.x-dev" - } - }, "autoload": { "files": [ "library/helpers.php", @@ -9948,12 +10075,20 @@ { "name": "Pádraic Brady", "email": "padraic.brady@gmail.com", - "homepage": "http://blog.astrumfutura.com" + "homepage": "https://github.com/padraic", + "role": "Author" }, { "name": "Dave Marshall", "email": "dave.marshall@atstsolutions.co.uk", - "homepage": "http://davedevelopment.co.uk" + "homepage": "https://davedevelopment.co.uk", + "role": "Developer" + }, + { + "name": "Nathanael Esayeas", + "email": "nathanael.esayeas@protonmail.com", + "homepage": "https://github.com/ghostwriter", + "role": "Lead Developer" } ], "description": "Mockery is a simple yet flexible PHP mock object framework", @@ -9971,10 +10106,13 @@ "testing" ], "support": { + "docs": "https://docs.mockery.io/", "issues": "https://github.com/mockery/mockery/issues", - "source": "https://github.com/mockery/mockery/tree/1.6.2" + "rss": "https://github.com/mockery/mockery/releases.atom", + "security": "https://github.com/mockery/mockery/security/advisories", + "source": "https://github.com/mockery/mockery" }, - "time": "2023-06-07T09:07:52+00:00" + "time": "2023-12-10T02:24:34+00:00" }, { "name": "myclabs/deep-copy", @@ -10289,16 +10427,16 @@ }, { "name": "phpdocumentor/type-resolver", - "version": "1.7.2", + "version": "1.8.0", "source": { "type": "git", "url": "https://github.com/phpDocumentor/TypeResolver.git", - "reference": "b2fe4d22a5426f38e014855322200b97b5362c0d" + "reference": "fad452781b3d774e3337b0c0b245dd8e5a4455fc" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/phpDocumentor/TypeResolver/zipball/b2fe4d22a5426f38e014855322200b97b5362c0d", - "reference": "b2fe4d22a5426f38e014855322200b97b5362c0d", + "url": "https://api.github.com/repos/phpDocumentor/TypeResolver/zipball/fad452781b3d774e3337b0c0b245dd8e5a4455fc", + "reference": "fad452781b3d774e3337b0c0b245dd8e5a4455fc", "shasum": "" }, "require": { @@ -10341,22 +10479,22 @@ "description": "A PSR-5 based resolver of Class names, Types and Structural Element Names", "support": { "issues": "https://github.com/phpDocumentor/TypeResolver/issues", - "source": "https://github.com/phpDocumentor/TypeResolver/tree/1.7.2" + "source": "https://github.com/phpDocumentor/TypeResolver/tree/1.8.0" }, - "time": "2023-05-30T18:13:47+00:00" + "time": "2024-01-11T11:49:22+00:00" }, { "name": "phpstan/phpdoc-parser", - "version": "1.22.0", + "version": "1.25.0", "source": { "type": "git", "url": "https://github.com/phpstan/phpdoc-parser.git", - "reference": "ec58baf7b3c7f1c81b3b00617c953249fb8cf30c" + "reference": "bd84b629c8de41aa2ae82c067c955e06f1b00240" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/phpstan/phpdoc-parser/zipball/ec58baf7b3c7f1c81b3b00617c953249fb8cf30c", - "reference": "ec58baf7b3c7f1c81b3b00617c953249fb8cf30c", + "url": "https://api.github.com/repos/phpstan/phpdoc-parser/zipball/bd84b629c8de41aa2ae82c067c955e06f1b00240", + "reference": "bd84b629c8de41aa2ae82c067c955e06f1b00240", "shasum": "" }, "require": { @@ -10388,9 +10526,9 @@ "description": "PHPDoc parser with support for nullable, intersection and generic types", "support": { "issues": "https://github.com/phpstan/phpdoc-parser/issues", - "source": "https://github.com/phpstan/phpdoc-parser/tree/1.22.0" + "source": "https://github.com/phpstan/phpdoc-parser/tree/1.25.0" }, - "time": "2023-06-01T12:35:21+00:00" + "time": "2024-01-04T17:06:16+00:00" }, { "name": "phpunit/php-code-coverage", @@ -10691,16 +10829,16 @@ }, { "name": "phpunit/phpunit", - "version": "8.5.33", + "version": "8.5.36", "source": { "type": "git", "url": "https://github.com/sebastianbergmann/phpunit.git", - "reference": "7d1ff0e8c6b35db78ff13e3e05517d7cbf7aa32e" + "reference": "9652df58e06a681429d8cfdaec3c43d6de581d5a" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/7d1ff0e8c6b35db78ff13e3e05517d7cbf7aa32e", - "reference": "7d1ff0e8c6b35db78ff13e3e05517d7cbf7aa32e", + "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/9652df58e06a681429d8cfdaec3c43d6de581d5a", + "reference": "9652df58e06a681429d8cfdaec3c43d6de581d5a", "shasum": "" }, "require": { @@ -10730,9 +10868,9 @@ "sebastian/version": "^2.0.1" }, "suggest": { - "ext-soap": "*", - "ext-xdebug": "*", - "phpunit/php-invoker": "^2.0.0" + "ext-soap": "To be able to generate mocks based on WSDL files", + "ext-xdebug": "PHP extension that provides line coverage as well as branch and path coverage", + "phpunit/php-invoker": "To allow enforcing time limits" }, "bin": [ "phpunit" @@ -10768,7 +10906,8 @@ ], "support": { "issues": "https://github.com/sebastianbergmann/phpunit/issues", - "source": "https://github.com/sebastianbergmann/phpunit/tree/8.5.33" + "security": "https://github.com/sebastianbergmann/phpunit/security/policy", + "source": "https://github.com/sebastianbergmann/phpunit/tree/8.5.36" }, "funding": [ { @@ -10784,7 +10923,7 @@ "type": "tidelift" } ], - "time": "2023-02-27T13:04:50+00:00" + "time": "2023-12-01T16:52:15+00:00" }, { "name": "psr/cache", @@ -11172,16 +11311,16 @@ }, { "name": "sebastian/global-state", - "version": "3.0.2", + "version": "3.0.3", "source": { "type": "git", "url": "https://github.com/sebastianbergmann/global-state.git", - "reference": "de036ec91d55d2a9e0db2ba975b512cdb1c23921" + "reference": "66783ce213de415b451b904bfef9dda0cf9aeae0" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/global-state/zipball/de036ec91d55d2a9e0db2ba975b512cdb1c23921", - "reference": "de036ec91d55d2a9e0db2ba975b512cdb1c23921", + "url": "https://api.github.com/repos/sebastianbergmann/global-state/zipball/66783ce213de415b451b904bfef9dda0cf9aeae0", + "reference": "66783ce213de415b451b904bfef9dda0cf9aeae0", "shasum": "" }, "require": { @@ -11224,7 +11363,7 @@ ], "support": { "issues": "https://github.com/sebastianbergmann/global-state/issues", - "source": "https://github.com/sebastianbergmann/global-state/tree/3.0.2" + "source": "https://github.com/sebastianbergmann/global-state/tree/3.0.3" }, "funding": [ { @@ -11232,7 +11371,7 @@ "type": "github" } ], - "time": "2022-02-10T06:55:38+00:00" + "time": "2023-08-02T09:23:32+00:00" }, { "name": "sebastian/object-enumerator", @@ -11566,16 +11705,16 @@ }, { "name": "spatie/backtrace", - "version": "1.4.1", + "version": "1.5.3", "source": { "type": "git", "url": "https://github.com/spatie/backtrace.git", - "reference": "47794d19e3215ace9e005a8f200cd7cc7be52572" + "reference": "483f76a82964a0431aa836b6ed0edde0c248e3ab" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/spatie/backtrace/zipball/47794d19e3215ace9e005a8f200cd7cc7be52572", - "reference": "47794d19e3215ace9e005a8f200cd7cc7be52572", + "url": "https://api.github.com/repos/spatie/backtrace/zipball/483f76a82964a0431aa836b6ed0edde0c248e3ab", + "reference": "483f76a82964a0431aa836b6ed0edde0c248e3ab", "shasum": "" }, "require": { @@ -11612,7 +11751,7 @@ "spatie" ], "support": { - "source": "https://github.com/spatie/backtrace/tree/1.4.1" + "source": "https://github.com/spatie/backtrace/tree/1.5.3" }, "funding": [ { @@ -11624,43 +11763,43 @@ "type": "other" } ], - "time": "2023-06-13T14:35:04+00:00" + "time": "2023-06-28T12:59:17+00:00" }, { "name": "spatie/flare-client-php", - "version": "1.3.6", + "version": "1.4.4", "source": { "type": "git", "url": "https://github.com/spatie/flare-client-php.git", - "reference": "530ac81255af79f114344286e4275f8869c671e2" + "reference": "17082e780752d346c2db12ef5d6bee8e835e399c" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/spatie/flare-client-php/zipball/530ac81255af79f114344286e4275f8869c671e2", - "reference": "530ac81255af79f114344286e4275f8869c671e2", + "url": "https://api.github.com/repos/spatie/flare-client-php/zipball/17082e780752d346c2db12ef5d6bee8e835e399c", + "reference": "17082e780752d346c2db12ef5d6bee8e835e399c", "shasum": "" }, "require": { - "illuminate/pipeline": "^8.0|^9.0|^10.0", + "illuminate/pipeline": "^8.0|^9.0|^10.0|^11.0", "php": "^8.0", - "spatie/backtrace": "^1.2", - "symfony/http-foundation": "^5.0|^6.0", - "symfony/mime": "^5.2|^6.0", - "symfony/process": "^5.2|^6.0", - "symfony/var-dumper": "^5.2|^6.0" + "spatie/backtrace": "^1.5.2", + "symfony/http-foundation": "^5.2|^6.0|^7.0", + "symfony/mime": "^5.2|^6.0|^7.0", + "symfony/process": "^5.2|^6.0|^7.0", + "symfony/var-dumper": "^5.2|^6.0|^7.0" }, "require-dev": { - "dms/phpunit-arraysubset-asserts": "^0.3.0", - "pestphp/pest": "^1.20", + "dms/phpunit-arraysubset-asserts": "^0.5.0", + "pestphp/pest": "^1.20|^2.0", "phpstan/extension-installer": "^1.1", "phpstan/phpstan-deprecation-rules": "^1.0", "phpstan/phpstan-phpunit": "^1.0", - "spatie/phpunit-snapshot-assertions": "^4.0" + "spatie/phpunit-snapshot-assertions": "^4.0|^5.0" }, "type": "library", "extra": { "branch-alias": { - "dev-main": "1.1.x-dev" + "dev-main": "1.3.x-dev" } }, "autoload": { @@ -11685,7 +11824,7 @@ ], "support": { "issues": "https://github.com/spatie/flare-client-php/issues", - "source": "https://github.com/spatie/flare-client-php/tree/1.3.6" + "source": "https://github.com/spatie/flare-client-php/tree/1.4.4" }, "funding": [ { @@ -11693,41 +11832,41 @@ "type": "github" } ], - "time": "2023-04-12T07:57:12+00:00" + "time": "2024-01-31T14:18:45+00:00" }, { "name": "spatie/ignition", - "version": "1.8.1", + "version": "1.12.0", "source": { "type": "git", "url": "https://github.com/spatie/ignition.git", - "reference": "d8eb8ea1ed27f48a694405cff363746ffd37f13e" + "reference": "5b6f801c605a593106b623e45ca41496a6e7d56d" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/spatie/ignition/zipball/d8eb8ea1ed27f48a694405cff363746ffd37f13e", - "reference": "d8eb8ea1ed27f48a694405cff363746ffd37f13e", + "url": "https://api.github.com/repos/spatie/ignition/zipball/5b6f801c605a593106b623e45ca41496a6e7d56d", + "reference": "5b6f801c605a593106b623e45ca41496a6e7d56d", "shasum": "" }, "require": { "ext-json": "*", "ext-mbstring": "*", "php": "^8.0", - "spatie/backtrace": "^1.4", - "spatie/flare-client-php": "^1.1", - "symfony/console": "^5.4|^6.0", - "symfony/var-dumper": "^5.4|^6.0" + "spatie/backtrace": "^1.5.3", + "spatie/flare-client-php": "^1.4.0", + "symfony/console": "^5.4|^6.0|^7.0", + "symfony/var-dumper": "^5.4|^6.0|^7.0" }, "require-dev": { - "illuminate/cache": "^9.52", + "illuminate/cache": "^9.52|^10.0|^11.0", "mockery/mockery": "^1.4", - "pestphp/pest": "^1.20", + "pestphp/pest": "^1.20|^2.0", "phpstan/extension-installer": "^1.1", "phpstan/phpstan-deprecation-rules": "^1.0", "phpstan/phpstan-phpunit": "^1.0", "psr/simple-cache-implementation": "*", - "symfony/cache": "^6.2", - "symfony/process": "^5.4|^6.0", + "symfony/cache": "^5.4|^6.0|^7.0", + "symfony/process": "^5.4|^6.0|^7.0", "vlucas/phpdotenv": "^5.5" }, "suggest": { @@ -11776,7 +11915,7 @@ "type": "github" } ], - "time": "2023-06-06T14:14:58+00:00" + "time": "2024-01-03T15:49:39+00:00" }, { "name": "spatie/laravel-ignition", @@ -11870,16 +12009,16 @@ }, { "name": "theseer/tokenizer", - "version": "1.2.1", + "version": "1.2.2", "source": { "type": "git", "url": "https://github.com/theseer/tokenizer.git", - "reference": "34a41e998c2183e22995f158c581e7b5e755ab9e" + "reference": "b2ad5003ca10d4ee50a12da31de12a5774ba6b96" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/theseer/tokenizer/zipball/34a41e998c2183e22995f158c581e7b5e755ab9e", - "reference": "34a41e998c2183e22995f158c581e7b5e755ab9e", + "url": "https://api.github.com/repos/theseer/tokenizer/zipball/b2ad5003ca10d4ee50a12da31de12a5774ba6b96", + "reference": "b2ad5003ca10d4ee50a12da31de12a5774ba6b96", "shasum": "" }, "require": { @@ -11908,7 +12047,7 @@ "description": "A small library for converting tokenized PHP source code into XML and potentially other formats", "support": { "issues": "https://github.com/theseer/tokenizer/issues", - "source": "https://github.com/theseer/tokenizer/tree/1.2.1" + "source": "https://github.com/theseer/tokenizer/tree/1.2.2" }, "funding": [ { @@ -11916,7 +12055,7 @@ "type": "github" } ], - "time": "2021-07-28T10:34:58+00:00" + "time": "2023-11-20T00:12:19+00:00" } ], "aliases": [], diff --git a/database/migrations/2024_02_10_065508_add_controller_acknowledgement_to_announcements_table.php b/database/migrations/2024_02_10_065508_add_controller_acknowledgement_to_announcements_table.php new file mode 100644 index 00000000..8e5ae960 --- /dev/null +++ b/database/migrations/2024_02_10_065508_add_controller_acknowledgement_to_announcements_table.php @@ -0,0 +1,32 @@ +boolean('controller_acknowledgement')->default(false); + }); + } + + /** + * Reverse the migrations. + * + * @return void + */ + public function down() + { + Schema::table('announcements', function (Blueprint $table) { + $table->dropColumn('controller_ackowledgement'); + }); + } +}; diff --git a/database/migrations/2024_02_10_071548_create_controller_acknowledgements_table.php b/database/migrations/2024_02_10_071548_create_controller_acknowledgements_table.php new file mode 100644 index 00000000..909da79a --- /dev/null +++ b/database/migrations/2024_02_10_071548_create_controller_acknowledgements_table.php @@ -0,0 +1,36 @@ +id(); + $table->unsignedInteger('user_id'); + $table->unsignedInteger('announcement_id'); + + $table->foreign('user_id')->references('id')->on('users'); + $table->foreign('announcement_id')->references('id')->on('announcements'); + $table->timestamps(); + }); + } + + /** + * Reverse the migrations. + * + * @return void + */ + public function down() + { + Schema::dropIfExists('controller_acknowledgements'); + } +}; diff --git a/database/seeds/TrainingPermissionsSeeder.php b/database/seeds/TrainingPermissionsSeeder.php index 36e4dfe2..3cf0a49f 100644 --- a/database/seeds/TrainingPermissionsSeeder.php +++ b/database/seeds/TrainingPermissionsSeeder.php @@ -59,6 +59,8 @@ public function run() $instructor->givePermissionTo('edit training records'); $instructor->givePermissionTo('assign instructor to student'); $instructor->givePermissionTo('edit training sessions'); + $instructor->givePermissionTo('view roster admin'); + $instructor->givePermissionTo('edit roster'); $guest = Role::where('name', 'Guest')->first(); $guest->givePermissionTo('start applications'); diff --git a/public/assets/resources/files/atc/CZQO_CZQM_LOA_v1.1.pdf b/public/assets/resources/files/atc/CZQO_CZQM_LOA_v1.1.pdf new file mode 100644 index 00000000..124037a7 Binary files /dev/null and b/public/assets/resources/files/atc/CZQO_CZQM_LOA_v1.1.pdf differ diff --git a/public/assets/resources/files/atc/CZQO_ZWY_LOA_final.pdf b/public/assets/resources/files/atc/CZQO_ZWY_LOA_final.pdf new file mode 100644 index 00000000..98d4194d Binary files /dev/null and b/public/assets/resources/files/atc/CZQO_ZWY_LOA_final.pdf differ diff --git a/public/assets/resources/files/atc/Gander_Oceanic_Phraseology_Sheet_1.1.pdf b/public/assets/resources/files/atc/Gander_Oceanic_Phraseology_Sheet_1.1.pdf new file mode 100644 index 00000000..d7e65588 Binary files /dev/null and b/public/assets/resources/files/atc/Gander_Oceanic_Phraseology_Sheet_1.1.pdf differ diff --git a/public/assets/resources/files/atc/ShanwickEGGXGanderCZQOOceanicControlProcedures.pdf b/public/assets/resources/files/atc/ShanwickEGGXGanderCZQOOceanicControlProcedures.pdf new file mode 100644 index 00000000..5ffdaf32 Binary files /dev/null and b/public/assets/resources/files/atc/ShanwickEGGXGanderCZQOOceanicControlProcedures.pdf differ diff --git a/public/assets/resources/files/policies/CZQOP1_General.pdf b/public/assets/resources/files/policies/CZQOP1_General.pdf new file mode 100644 index 00000000..e9e22eef Binary files /dev/null and b/public/assets/resources/files/policies/CZQOP1_General.pdf differ diff --git a/public/assets/resources/files/policies/CZQOP2_Training.pdf b/public/assets/resources/files/policies/CZQOP2_Training.pdf new file mode 100644 index 00000000..a6a079ee Binary files /dev/null and b/public/assets/resources/files/policies/CZQOP2_Training.pdf differ diff --git a/public/assets/resources/media/img/brand/bnr/ZQO_BNR_TSPBLUE.png b/public/assets/resources/media/img/brand/bnr/ZQO_BNR_TSPBLUE.png new file mode 100644 index 00000000..331976b9 Binary files /dev/null and b/public/assets/resources/media/img/brand/bnr/ZQO_BNR_TSPBLUE.png differ diff --git a/public/assets/resources/media/img/brand/bnr/ZQO_BNR_TSPWHITE.png b/public/assets/resources/media/img/brand/bnr/ZQO_BNR_TSPWHITE.png new file mode 100644 index 00000000..ec9647de Binary files /dev/null and b/public/assets/resources/media/img/brand/bnr/ZQO_BNR_TSPWHITE.png differ diff --git a/public/assets/resources/media/img/brand/bnr/ZQO_BNR_WHITE.png b/public/assets/resources/media/img/brand/bnr/ZQO_BNR_WHITE.png new file mode 100644 index 00000000..a97db9db Binary files /dev/null and b/public/assets/resources/media/img/brand/bnr/ZQO_BNR_WHITE.png differ diff --git a/public/assets/resources/media/img/brand/sqr/ZQO_SQ_TSPBLUE.png b/public/assets/resources/media/img/brand/sqr/ZQO_SQ_TSPBLUE.png new file mode 100644 index 00000000..d4bb7d41 Binary files /dev/null and b/public/assets/resources/media/img/brand/sqr/ZQO_SQ_TSPBLUE.png differ diff --git a/resources/views/about/branding.blade.php b/resources/views/about/branding.blade.php index 3e8ec264..3a9edeaf 100644 --- a/resources/views/about/branding.blade.php +++ b/resources/views/about/branding.blade.php @@ -1,90 +1,123 @@ @extends('layouts.primary') @section('title', 'Branding - ') @section('content') -
-

Branding

-
-

Access our logos and social media icons here. You may use these logos in their published form at your discretion. - We ask however that you do not modify the images from their original, published form. Resizing is permitted, provided the aspect ratio remains unadjusted. Please aim to, wherever possible, use the - blue logo versions (either white on blue or blue on white), and only use the plain white where it is not possible or practical to use the blue versions. - Please contact our Deputy OCA Chief with any queries: deputy@ganderoceanic.ca -

- The hex colour codes used for our branding are #0080C9 (Blue) and #FFFFFF (White). - The font is Avenir Lt Std.

-

Banners

-
-
-
- -
- White on Blue -
-
- -
- Blue on White -
- -
- -
- White on Transparent +
+

Branding

+
+

Access our logos and social media icons here. You may use these logos in their published form at your + discretion. + We ask however that you do not modify the images from their original, published form. Resizing is permitted, + provided the aspect ratio remains unadjusted. Please aim to, wherever possible, use the + blue logo versions (either white on blue or blue on white), and only use the plain white where it is not + possible or practical to use the blue versions. + Please contact our Deputy OCA Chief with any queries: deputy@ganderoceanic.ca +

+ The hex colour codes used for our branding are #0080C9 + (Blue) and #FFFFFF (White). + The font is Avenir Lt Std. +

+

Banners

+ -
-

Squares

-
-
-
- -
- White on Blue -
-
- -
- Blue on White -
- -
- -
- White on Transparent +

Squares

+ -
-

Social

-
-
-
- -
- White on Blue -
-
- -
- Blue on White -
- -
- -
- White on Transparent +

Social

+
+
+
+ +
+ White on Blue +
+
+ +
+ Blue on White +
+ +
-
@endsection diff --git a/resources/views/admin/news/announcements/create.blade.php b/resources/views/admin/news/announcements/create.blade.php index f895a929..76dbd18e 100644 --- a/resources/views/admin/news/announcements/create.blade.php +++ b/resources/views/admin/news/announcements/create.blade.php @@ -34,16 +34,26 @@
- - +
+
  • @@ -81,4 +91,16 @@
  • + @endsection diff --git a/resources/views/admin/training/acknowledgements/acknowledgement.blade.php b/resources/views/admin/training/acknowledgements/acknowledgement.blade.php new file mode 100644 index 00000000..32c068e6 --- /dev/null +++ b/resources/views/admin/training/acknowledgements/acknowledgement.blade.php @@ -0,0 +1,30 @@ +@extends('admin.training.layouts.main') +@section('training-content') +

    {{ $announcement->title }}

    + + + + + + + + + + + + + +
    Read AcknowledgementUnread Acknowledgement
    +
      + @foreach (\App\Models\Training\ControllerAcknowledgement::where('announcement_id', $announcement->id)->get() as $readAcknowledgement) +
    • {{ $readAcknowledgement->user_id }}
    • + @endforeach +
    +
    +
      + @foreach ($announcement->getReadMembers() as $readMembers) +
    • {{ $readMembers->user_id }}
    • + @endforeach +
    +
    +@endsection diff --git a/resources/views/admin/training/acknowledgements/index.blade.php b/resources/views/admin/training/acknowledgements/index.blade.php new file mode 100644 index 00000000..ce8a5458 --- /dev/null +++ b/resources/views/admin/training/acknowledgements/index.blade.php @@ -0,0 +1,29 @@ +@extends('admin.training.layouts.main') +@section('training-content') +

    Controller Acknowledgements

    +

    Select an announcement to view a list of controllers who have acknowledged it and those who haven't.

    + + + + + + + @foreach (\App\Models\News\Announcement::where('controller_acknowledgement', true)->get() as $announcement) + + + + + @endforeach + +
    AnnouncementAction
    + {{ $announcement->title }} + +  View +
    + + +@endsection diff --git a/resources/views/admin/training/instructing/students/student.blade.php b/resources/views/admin/training/instructing/students/student.blade.php index 938caae2..6bd750a2 100644 --- a/resources/views/admin/training/instructing/students/student.blade.php +++ b/resources/views/admin/training/instructing/students/student.blade.php @@ -150,11 +150,6 @@ @else
    Already recommended for solo certification/solo certification in progress
    @endif - @if (!$student->setAsReadyForAssessment()) - Recommend for Assessment - @else -
    Already recommended for assessment/assessment in progress
    - @endif
    @endif
    diff --git a/resources/views/admin/training/layouts/main.blade.php b/resources/views/admin/training/layouts/main.blade.php index 971b4dc0..15047436 100644 --- a/resources/views/admin/training/layouts/main.blade.php +++ b/resources/views/admin/training/layouts/main.blade.php @@ -114,6 +114,14 @@ + +
  • +
    + + Controller Acknowledgements +
    +
  • +
    @endcan @can('view applications')
  • diff --git a/resources/views/layouts/email.blade.php b/resources/views/layouts/email.blade.php index 8656acaa..e71ca7f1 100644 --- a/resources/views/layouts/email.blade.php +++ b/resources/views/layouts/email.blade.php @@ -134,7 +134,7 @@
    -Image +Image
    diff --git a/resources/views/layouts/master.blade.php b/resources/views/layouts/master.blade.php index 6dd081ee..096f43f4 100644 --- a/resources/views/layouts/master.blade.php +++ b/resources/views/layouts/master.blade.php @@ -14,7 +14,7 @@ - + @@ -297,7 +297,7 @@
  • - +

    Chat with our Gander Oceanic controller and pilot community

    diff --git a/resources/views/layouts/primary.blade.php b/resources/views/layouts/primary.blade.php index 8ebe6260..eb7ca5a3 100644 --- a/resources/views/layouts/primary.blade.php +++ b/resources/views/layouts/primary.blade.php @@ -17,7 +17,7 @@ - + diff --git a/resources/views/my/index.blade.php b/resources/views/my/index.blade.php index 788547d7..9a53f739 100644 --- a/resources/views/my/index.blade.php +++ b/resources/views/my/index.blade.php @@ -1,6 +1,10 @@ @extends('layouts.primary', ['solidNavBar' => false]) @section('title', 'myCZQO - ') @section('content') + @php + $user = auth()->user(); + @endphp +
    @@ -15,9 +19,9 @@ function randomArrayVar($array) } return $array[array_rand($array)]; } - + //list of grettings as arary - + $greeting = [ 'aloha' => 'Aloha', 'ahoy' => 'Ahoy', @@ -31,18 +35,18 @@ function randomArrayVar($array) 'guten_tag' => 'Guten Tag', 'grüß_dich' => 'Grüß Dich', ]; - + //echo greeting echo randomArrayVar($greeting); ?> - {{ auth()->user()->fullName('F') }}! + {{ $user->fullName('F') }}! @if (isset($quote))

    {{ $quote[0]->quote }} ~ {{ $quote[0]->author }}

    @endif
    - @if (auth()->user()->created_at->diffInDays(Carbon\Carbon::now()) < 14) + @if ($user->created_at->diffInDays(Carbon\Carbon::now()) < 14)

    @@ -56,7 +60,7 @@ function randomArrayVar($array)

    myCZQO

    - @if (auth()->user()->rating_id >= 5) + @if ($user->rating_id >= 5) @endif
    @role('Restricted') @@ -72,7 +76,7 @@ function randomArrayVar($array)
  • - {{ auth()->user()->fullName('F') }} + {{ $user->fullName('F') }}
  • @@ -176,7 +180,7 @@ function randomArrayVar($array)
    -
    @@ -186,21 +190,21 @@ function randomArrayVar($array)
    - {{ auth()->user()->fullName('FLC') }} fullName('FLC') }}
    - {{ auth()->user()->rating_GRP }} ({{ auth()->user()->rating_short }}) + {{ $user->rating_GRP }} ({{ $user->rating_short }})
    - Region: {{ auth()->user()->region_name }}
    - Division: {{ auth()->user()->division_name }}
    - @if (auth()->user()->subdivision_name) - vACC/ARTCC: {{ auth()->user()->subdivision_name }}
    + Region: {{ $user->region_name }}
    + Division: {{ $user->division_name }}
    + @if ($user->subdivision_name) + vACC/ARTCC: {{ $user->subdivision_name }}
    @endif - Role: {{ auth()->user()->highestRole()->name }}
    - @if (auth()->user()->staffProfile) - Staff Role: {{ auth()->user()->staffProfile->position }} + Role: {{ $user->highestRole()->name }}
    + @if ($user->staffProfile) + Staff Role: {{ $user->staffProfile->position }} @endif
    @@ -208,7 +212,7 @@ class="ml-1 far fa-edit text-muted">

    Discord

    - @if (!auth()->user()->hasDiscord()) + @if (!$user->hasDiscord())

    You have not linked your Discord account.

    @@ -223,9 +227,9 @@ class="ml-1 far fa-edit text-muted"> @else

      {{ auth()->user()->discord_username }}

    - @if (!auth()->user()->member_of_czqo) + src="{{ $user->getDiscordAvatar() }}" + alt="">  {{ $user->discord_username }}

    + @if (!$user->member_of_czqo)
    @@ -250,8 +254,8 @@ class="ml-1 far fa-edit text-muted"> @endif

    Biography

    - @if (auth()->user()->bio) - {{ auth()->user()->bio }} + @if ($user->bio) + {{ $user->bio }} @else You have no biography. @endif @@ -269,19 +273,19 @@ class="ml-1 far fa-edit text-muted">

    - @if (auth()->user()->pendingApplication()) - pendingApplication()) +

    You have a pending application for Gander Oceanic

    - #{{ auth()->user()->pendingApplication()->reference_id }} - submitted - {{ auth()->user()->pendingApplication()->created_at->diffForHumans() }}

    + #{{ $user->pendingApplication()->reference_id }} - submitted + {{ $user->pendingApplication()->created_at->diffForHumans() }}

    @endif @if ( $studentProfile = - auth()->user()->studentProfile && - ($cert = auth()->user()->studentProfile->soloCertification())) + $user->studentProfile && + ($cert = $user->studentProfile->soloCertification()))

    {{ $cert->expires->diffInDays(Carbon\Carbon::now()) <= 2 ? 'Your solo certification is about to expire' : 'Your active solo certification' }} @@ -296,8 +300,8 @@ class="list-group-item list-group-item-action p-4 z-depth-1 shadow-none mb-3"> @endif @if ( $studentProfile = - auth()->user()->studentProfile && - ($session = auth()->user()->studentProfile->upcomingTrainingSession())) + $user->studentProfile && + ($session = $user->studentProfile->upcomingTrainingSession()))

    Your upcoming training session

    Scheduled for @@ -308,8 +312,8 @@ class="list-group-item list-group-item-action p-4 z-depth-1 shadow-none mb-3"> @endif @if ( $studentProfile = - auth()->user()->studentProfile && - ($session = auth()->user()->studentProfile->upcomingOtsSession())) + $user->studentProfile && + ($session = $user->studentProfile->upcomingOtsSession()))

    Your upcoming OTS session

    Scheduled for @@ -343,10 +347,10 @@ class="list-group-item list-group-item-action p-4 z-depth-1 shadow-none mb-3">
    - @if (auth()->user()->hasDiscord()) + @if ($user->hasDiscord()) or use your Discord avatar (refreshes every 6 hours)
    Use Discord Avatar @@ -622,9 +623,9 @@ class="" id=""> autoRefresh: true, element: document.getElementById("contentMD"), toolbar: false, - initialValue: '{{ auth()->user()->bio }}' + initialValue: '{{ $user->bio }}' }); - simplemde.value('{{ auth()->user()->bio }}') + simplemde.value('{{ $user->bio }}')

    Wonder what the purpose of a biography is? Find out @@ -659,7 +660,7 @@ class="" id=""> names must comply with section A4 of the VATSIM Code of Conduct.

    -
    @@ -667,7 +668,7 @@ class="" id=""> style="color: #000">Reset to your CERT first name
    @@ -675,9 +676,9 @@ function resetToCertFirstName() { @@ -697,7 +698,7 @@ function resetToCertFirstName() { + @endforeach + + @foreach (\App\Models\Training\ControllerAcknowledgement::where('user_id', auth()->id())->get() as $readAcknowledgements) + @if ($loop->first) +

    Read Acknowledgements

    + @endif + @php + $readAcknowledgement = $readAcknowledgements->getAcknowledgement; + @endphp +
    +
    +
    +
    {{ $readAcknowledgement->title }}
    + +
    +
    +

    Read on: {{ $readAcknowledgement->created_at->format('d M Y') }}

    +
    + {{-- MODALS FOR READ --}} + + @endforeach +@endsection diff --git a/resources/views/training/portal/layouts/main.blade.php b/resources/views/training/portal/layouts/main.blade.php index 4f7e5998..651558bf 100644 --- a/resources/views/training/portal/layouts/main.blade.php +++ b/resources/views/training/portal/layouts/main.blade.php @@ -46,6 +46,14 @@
    + +
  • +
    + + Controller Acknowledgements +
    +
  • +
  • APPLY diff --git a/routes/web.php b/routes/web.php index bc82ea43..9b2e1196 100644 --- a/routes/web.php +++ b/routes/web.php @@ -54,6 +54,7 @@ Route::get('/privacy', fn() => redirect(route('policies'), 301))->name('privacy'); Route::get('/events', [EventController::class, 'index'])->name('events.index'); Route::get('/events/{slug}', [EventController::class, 'viewEvent'])->name('events.view'); +Route::view('/branding', 'about.branding')->name('branding'); // About Route::prefix('about')->group(function () { @@ -110,8 +111,8 @@ Route::post('/users/changedisplayname', [MyCzqoController::class, 'changeDisplayName'])->name('users.changedisplayname'); // Notification - Route::get('/notification/{id}', [NotificationRedirectController::class, 'notificationRedirect'])->name('notification.redirect'); - Route::get('/notificationclear', [NotificationRedirectController::class, 'clearAll']); + // Route::get('/notification/{id}', [NotificationRedirectController::class, 'notificationRedirect'])->name('notification.redirect'); + // Route::get('/notificationclear', [NotificationRedirectController::class, 'clearAll']); // Email prefs Route::get('/dashboard/emailpref', [DataController::class, 'emailPref'])->name('dashboard.emailpref'); @@ -161,6 +162,9 @@ Route::name('training.portal.')->group(function () { Route::get('portal', [TrainingPortalController::class, 'index'])->name('index'); Route::get('portal/help-policies', [TrainingPortalController::class, 'helpPolicies'])->name('help-policies'); + //Acknowledgements + Route::view('portal/acknowledgements', 'training.portal.acknowledgements')->name('controller-acknowledgements'); + Route::post('portal/acknowledgements/read/{announcement}', [TrainingPortalController::class, 'readAcknowledgement'])->name('controller-acknowledgements.read'); // Training availability Route::get('portal/availability', [TrainingPortalController::class, 'viewAvailability'])->name('availability'); Route::post('portal/availability', [TrainingPortalController::class, 'submitAvailabilityPost'])->name('availability.submit.post'); @@ -238,6 +242,10 @@ Route::post('/solocertifications/add', [SoloCertificationsController::class, 'addSoloCertificationPost'])->name('solocertifications.add')->middleware('can:edit roster'); Route::get('/solocertifications/{cert_id}/revoke', [SoloCertificationsController::class, 'revokeSoloCert'])->name('solocertifications.revoke')->middleware('can:edit roster'); + //Controller Acknowledgements + Route::view('/acknowledgements', 'admin.training.acknowledgements.index')->name('acknowledgements'); + Route::get('/acknowledgement/{announcement}', [RosterController::class, 'getAcknowledgement'])->name('acknowledgement.find'); + //Applications Route::get('/applications', [ApplicationsController::class, 'admin'])->name('applications')->middleware('can:view applications'); Route::get('/applications/processed', [ApplicationsController::class, 'adminProcessedApplications'])->name('applications.processed')->middleware('can:view applications'); @@ -371,4 +379,4 @@ //Custom pages Route::get('/{page_slug}', [CustomPagesController::class, 'viewPage'])->name('publications.custompages.view'); -Route::post('/{page_slug}/response-submit', [CustomPagesController::class, 'submitResponse'])->name('publications.custompages.response-submit'); \ No newline at end of file +Route::post('/{page_slug}/response-submit', [CustomPagesController::class, 'submitResponse'])->name('publications.custompages.response-submit');