mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-26 18:22:51 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			157 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			157 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Http\Controllers;
 | |
| 
 | |
| use App\Http\Requests\CreateBankAccountRequest;
 | |
| use App\Models\Account;
 | |
| use App\Models\BankAccount;
 | |
| use App\Ninja\Repositories\BankAccountRepository;
 | |
| use App\Services\BankAccountService;
 | |
| use Auth;
 | |
| use Cache;
 | |
| use Crypt;
 | |
| use File;
 | |
| use Illuminate\Http\Request;
 | |
| use Input;
 | |
| use Redirect;
 | |
| use Session;
 | |
| use Utils;
 | |
| use View;
 | |
| 
 | |
| class BankAccountController extends BaseController
 | |
| {
 | |
|     protected $bankAccountService;
 | |
|     protected $bankAccountRepo;
 | |
| 
 | |
|     public function __construct(BankAccountService $bankAccountService, BankAccountRepository $bankAccountRepo)
 | |
|     {
 | |
|         //parent::__construct();
 | |
| 
 | |
|         $this->bankAccountService = $bankAccountService;
 | |
|         $this->bankAccountRepo = $bankAccountRepo;
 | |
|     }
 | |
| 
 | |
|     public function index()
 | |
|     {
 | |
|         return Redirect::to('settings/' . ACCOUNT_BANKS);
 | |
|     }
 | |
| 
 | |
|     public function getDatatable()
 | |
|     {
 | |
|         return $this->bankAccountService->getDatatable(Auth::user()->account_id);
 | |
|     }
 | |
| 
 | |
|     public function edit($publicId)
 | |
|     {
 | |
|         $bankAccount = BankAccount::scope($publicId)->firstOrFail();
 | |
| 
 | |
|         $data = [
 | |
|             'title' => trans('texts.edit_bank_account'),
 | |
|             'banks' => Cache::get('banks'),
 | |
|             'bankAccount' => $bankAccount,
 | |
|         ];
 | |
| 
 | |
|         return View::make('accounts.bank_account', $data);
 | |
|     }
 | |
| 
 | |
|     public function update($publicId)
 | |
|     {
 | |
|         return $this->save($publicId);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Displays the form for account creation.
 | |
|      */
 | |
|     public function create()
 | |
|     {
 | |
|         $data = [
 | |
|             'banks' => Cache::get('banks'),
 | |
|             'bankAccount' => null,
 | |
|         ];
 | |
| 
 | |
|         return View::make('accounts.bank_account', $data);
 | |
|     }
 | |
| 
 | |
|     public function bulk()
 | |
|     {
 | |
|         $action = Input::get('bulk_action');
 | |
|         $ids = Input::get('bulk_public_id');
 | |
|         $count = $this->bankAccountService->bulk($ids, $action);
 | |
| 
 | |
|         Session::flash('message', trans('texts.archived_bank_account'));
 | |
| 
 | |
|         return Redirect::to('settings/' . ACCOUNT_BANKS);
 | |
|     }
 | |
| 
 | |
|     public function validateAccount()
 | |
|     {
 | |
|         $publicId = Input::get('public_id');
 | |
|         $username = trim(Input::get('bank_username'));
 | |
|         $password = trim(Input::get('bank_password'));
 | |
| 
 | |
|         if ($publicId) {
 | |
|             $bankAccount = BankAccount::scope($publicId)->firstOrFail();
 | |
|             if ($username != $bankAccount->username) {
 | |
|                 // TODO update username
 | |
|             }
 | |
|             $username = Crypt::decrypt($username);
 | |
|             $bankId = $bankAccount->bank_id;
 | |
|         } else {
 | |
|             $bankAccount = new BankAccount;
 | |
|             $bankAccount->bank_id = Input::get('bank_id');
 | |
|         }
 | |
| 
 | |
|         $bankAccount->app_version = Input::get('app_version');
 | |
|         $bankAccount->ofx_version = Input::get('ofx_version');
 | |
| 
 | |
|         if ($publicId) {
 | |
|             $bankAccount->save();
 | |
|         }
 | |
| 
 | |
|         return json_encode($this->bankAccountService->loadBankAccounts($bankAccount, $username, $password, $publicId));
 | |
|     }
 | |
| 
 | |
|     public function store(CreateBankAccountRequest $request)
 | |
|     {
 | |
|         $bankAccount = $this->bankAccountRepo->save(Input::all());
 | |
| 
 | |
|         $bankId = Input::get('bank_id');
 | |
|         $username = trim(Input::get('bank_username'));
 | |
|         $password = trim(Input::get('bank_password'));
 | |
| 
 | |
|         return json_encode($this->bankAccountService->loadBankAccounts($bankAccount, $username, $password, true));
 | |
|     }
 | |
| 
 | |
|     public function importExpenses($bankId)
 | |
|     {
 | |
|         return $this->bankAccountService->importExpenses($bankId, Input::all());
 | |
|     }
 | |
| 
 | |
|     public function showImportOFX()
 | |
|     {
 | |
|         return view('accounts.import_ofx');
 | |
|     }
 | |
| 
 | |
|     public function doImportOFX(Request $request)
 | |
|     {
 | |
|         $file = File::get($request->file('ofx_file'));
 | |
| 
 | |
|         try {
 | |
|             $data = $this->bankAccountService->parseOFX($file);
 | |
|         } catch (\Exception $e) {
 | |
|             Session::now('error', trans('texts.ofx_parse_failed'));
 | |
|             Utils::logError($e);
 | |
| 
 | |
|             return view('accounts.import_ofx');
 | |
|         }
 | |
| 
 | |
|         $data = [
 | |
|             'banks' => null,
 | |
|             'bankAccount' => null,
 | |
|             'transactions' => json_encode([$data]),
 | |
|         ];
 | |
| 
 | |
|         return View::make('accounts.bank_account', $data);
 | |
|     }
 | |
| }
 |