mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2025-10-24 01:19:21 -04:00
165 lines
3.8 KiB
PHP
165 lines
3.8 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use App\Models\AccountToken;
|
|
use App\Services\TokenService;
|
|
use Auth;
|
|
use Input;
|
|
use Redirect;
|
|
use Session;
|
|
use URL;
|
|
use Validator;
|
|
use View;
|
|
|
|
/**
|
|
* Class TokenController.
|
|
*/
|
|
class TokenController extends BaseController
|
|
{
|
|
/**
|
|
* @var TokenService
|
|
*/
|
|
protected $tokenService;
|
|
|
|
/**
|
|
* TokenController constructor.
|
|
*
|
|
* @param TokenService $tokenService
|
|
*/
|
|
public function __construct(TokenService $tokenService)
|
|
{
|
|
//parent::__construct();
|
|
|
|
$this->tokenService = $tokenService;
|
|
}
|
|
|
|
/**
|
|
* @return \Illuminate\Http\RedirectResponse
|
|
*/
|
|
public function index()
|
|
{
|
|
return Redirect::to('settings/' . ACCOUNT_API_TOKENS);
|
|
}
|
|
|
|
/**
|
|
* @return \Illuminate\Http\JsonResponse
|
|
*/
|
|
public function getDatatable()
|
|
{
|
|
return $this->tokenService->getDatatable(Auth::user()->id);
|
|
}
|
|
|
|
/**
|
|
* @param $publicId
|
|
*
|
|
* @return \Illuminate\Contracts\View\View
|
|
*/
|
|
public function edit($publicId)
|
|
{
|
|
$token = AccountToken::where('account_id', '=', Auth::user()->account_id)
|
|
->where('public_id', '=', $publicId)->firstOrFail();
|
|
|
|
$data = [
|
|
'token' => $token,
|
|
'method' => 'PUT',
|
|
'url' => 'tokens/'.$publicId,
|
|
'title' => trans('texts.edit_token'),
|
|
];
|
|
|
|
return View::make('accounts.token', $data);
|
|
}
|
|
|
|
/**
|
|
* @param $publicId
|
|
*
|
|
* @return \Illuminate\Http\RedirectResponse
|
|
*/
|
|
public function update($publicId)
|
|
{
|
|
return $this->save($publicId);
|
|
}
|
|
|
|
/**
|
|
* @return \Illuminate\Http\RedirectResponse
|
|
*/
|
|
public function store()
|
|
{
|
|
return $this->save();
|
|
}
|
|
|
|
/**
|
|
* @return \Illuminate\Contracts\View\View
|
|
*/
|
|
public function create()
|
|
{
|
|
$data = [
|
|
'token' => null,
|
|
'method' => 'POST',
|
|
'url' => 'tokens',
|
|
'title' => trans('texts.add_token'),
|
|
];
|
|
|
|
return View::make('accounts.token', $data);
|
|
}
|
|
|
|
/**
|
|
* @return \Illuminate\Http\RedirectResponse
|
|
*/
|
|
public function bulk()
|
|
{
|
|
$action = Input::get('bulk_action');
|
|
$ids = Input::get('bulk_public_id');
|
|
$count = $this->tokenService->bulk($ids, $action);
|
|
|
|
Session::flash('message', trans('texts.archived_token'));
|
|
|
|
return Redirect::to('settings/' . ACCOUNT_API_TOKENS);
|
|
}
|
|
|
|
/**
|
|
* @param bool $tokenPublicId
|
|
*
|
|
* @return $this|\Illuminate\Http\RedirectResponse
|
|
*/
|
|
public function save($tokenPublicId = false)
|
|
{
|
|
if (Auth::user()->account->hasFeature(FEATURE_API)) {
|
|
$rules = [
|
|
'name' => 'required',
|
|
];
|
|
|
|
if ($tokenPublicId) {
|
|
$token = AccountToken::where('account_id', '=', Auth::user()->account_id)
|
|
->where('public_id', '=', $tokenPublicId)->firstOrFail();
|
|
}
|
|
|
|
$validator = Validator::make(Input::all(), $rules);
|
|
|
|
if ($validator->fails()) {
|
|
return Redirect::to($tokenPublicId ? 'tokens/edit' : 'tokens/create')->withInput()->withErrors($validator);
|
|
}
|
|
|
|
if ($tokenPublicId) {
|
|
$token->name = trim(Input::get('name'));
|
|
} else {
|
|
$token = AccountToken::createNew();
|
|
$token->name = trim(Input::get('name'));
|
|
$token->token = str_random(RANDOM_KEY_LENGTH);
|
|
}
|
|
|
|
$token->save();
|
|
|
|
if ($tokenPublicId) {
|
|
$message = trans('texts.updated_token');
|
|
} else {
|
|
$message = trans('texts.created_token');
|
|
}
|
|
|
|
Session::flash('message', $message);
|
|
}
|
|
|
|
return Redirect::to('settings/' . ACCOUNT_API_TOKENS);
|
|
}
|
|
}
|