option('license_id'); $notify = $this->option('notify'); if (! $license_id) { $this->error('ERROR: License ID is required.'); return false; } if (! $license = License::where('id', '=', $license_id)->with('assignedusers')->first()) { $this->error('Invalid license ID'); return false; } $users = User::whereNull('deleted_at')->where('should_autoassign', '==', 0)->with('licenses')->get(); dd($users); if ($users->count() > $license->getAvailSeatsCountAttribute()) { $this->info('You do not have enough free seats to complete this task, so we will check out as many as we can. '); } $this->info('Checking out '.$users->count().' of '.$license->getAvailSeatsCountAttribute().' seats for '.$license->name); if (! $notify) { $this->info('No mail will be sent.'); } foreach ($users as $user) { // Check to make sure this user doesn't already have this license checked out // to them if ($user->licenses->where('id', '=', $license_id)->count()) { $this->info($user->username.' already has this license checked out to them. Skipping... '); continue; } // If the license is valid, check that there is an available seat if ($license->availCount()->count() < 1) { $this->error('ERROR: No available seats'); return false; } $this->info($license->availCount()->count().' seats left'); // Get the seat ID $licenseSeat = $license->freeSeat(); // Update the seat with checkout info, $licenseSeat->assigned_to = $user->id; if ($licenseSeat->save()) { // Temporarily null the user's email address so we don't send mail if we're not supposed to if (! $notify) { $user->email = null; } // Log the checkout $licenseSeat->logCheckout('Checked out via cli tool', $user); $this->info('License '.$license_id.' seat '.$licenseSeat->id.' checked out to '.$user->username); } } } }