invoiceRepo = $invoiceRepo; $this->recurringExpenseRepo = $recurringExpenseRepo; } public function handle() { $this->info(date('r') . ' Running SendRecurringInvoices...'); if ($database = $this->option('database')) { config(['database.default' => $database]); } $this->resetCounters(); $this->createInvoices(); $this->createExpenses(); $this->info(date('r') . ' Done'); } private function resetCounters() { $accounts = Account::where('reset_counter_frequency_id', '>', 0) ->orderBy('id', 'asc') ->get(); foreach ($accounts as $account) { $account->checkCounterReset(); } } private function createInvoices() { $today = new DateTime(); $invoices = Invoice::with('account.timezone', 'invoice_items', 'client', 'user') ->whereRaw('is_deleted IS FALSE AND deleted_at IS NULL AND is_recurring IS TRUE AND is_public IS TRUE AND frequency_id > 0 AND start_date <= ? AND (end_date IS NULL OR end_date >= ?)', [$today, $today]) ->orderBy('id', 'asc') ->cursor(); $this->info(date('r ') . ' Recurring invoice(s) found'); foreach ($invoices as $recurInvoice) { $shouldSendToday = $recurInvoice->shouldSendToday(); if (! $shouldSendToday) { continue; } $this->info(date('r') . ' Processing Invoice: '. $recurInvoice->id); $account = $recurInvoice->account; $account->loadLocalizationSettings($recurInvoice->client); Auth::loginUsingId($recurInvoice->activeUser()->id); try { $invoice = $this->invoiceRepo->createRecurringInvoice($recurInvoice); if ($invoice && ! $invoice->isPaid() && $account->auto_email_invoice) { $this->info(date('r') . ' Not billed - Sending Invoice'); dispatch(new SendInvoiceEmail($invoice, $invoice->user_id)); } elseif ($invoice) { $this->info(date('r') . ' Successfully billed invoice'); } } catch (Exception $exception) { $this->info(date('r') . ' Error: ' . $exception->getMessage()); Utils::logError($exception); } Auth::logout(); } } private function createExpenses() { $today = new DateTime(); $expenses = RecurringExpense::with('client') ->whereRaw('is_deleted IS FALSE AND deleted_at IS NULL AND start_date <= ? AND (end_date IS NULL OR end_date >= ?)', [$today, $today]) ->orderBy('id', 'asc') ->get(); $this->info(date('r ') . $expenses->count() . ' recurring expenses(s) found'); foreach ($expenses as $expense) { $shouldSendToday = $expense->shouldSendToday(); if (! $shouldSendToday) { continue; } $this->info(date('r') . ' Processing Expense: '. $expense->id); $this->recurringExpenseRepo->createRecurringExpense($expense); } } /** * @return array */ protected function getArguments() { return []; } /** * @return array */ protected function getOptions() { return [ ['database', null, InputOption::VALUE_OPTIONAL, 'Database', null], ]; } }