mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-02-25 18:45:27 -06:00
Expand Spectre code.
This commit is contained in:
parent
deebdef04d
commit
a14ae02c27
@ -24,6 +24,7 @@ namespace FireflyIII\Import\Routine;
|
|||||||
|
|
||||||
use FireflyIII\Models\ImportJob;
|
use FireflyIII\Models\ImportJob;
|
||||||
use FireflyIII\Services\Spectre\Object\Customer;
|
use FireflyIII\Services\Spectre\Object\Customer;
|
||||||
|
use FireflyIII\Services\Spectre\Request\ListLoginsRequest;
|
||||||
use FireflyIII\Services\Spectre\Request\NewCustomerRequest;
|
use FireflyIII\Services\Spectre\Request\NewCustomerRequest;
|
||||||
use Illuminate\Support\Collection;
|
use Illuminate\Support\Collection;
|
||||||
use Log;
|
use Log;
|
||||||
@ -91,9 +92,34 @@ class SpectreRoutine implements RoutineInterface
|
|||||||
// create customer if user does not have one:
|
// create customer if user does not have one:
|
||||||
$customer = $this->getCustomer();
|
$customer = $this->getCustomer();
|
||||||
|
|
||||||
|
// list all logins present at Spectre
|
||||||
|
$logins = $this->listLogins($customer);
|
||||||
|
|
||||||
|
// use latest (depending on status, and if login exists for selected country + provider)
|
||||||
|
$country = $this->job->configuration['country'];
|
||||||
|
$providerId = $this->job->configuration['provider'];
|
||||||
|
$login = $this->filterLogins($logins, $country, $providerId);
|
||||||
|
|
||||||
|
// create new login if list is empty or no login exists.
|
||||||
|
if (is_null($login)) {
|
||||||
|
$login = $this->createLogin($customer);
|
||||||
|
die('new login');
|
||||||
|
}
|
||||||
|
|
||||||
|
echo '<pre>';
|
||||||
|
print_r($logins);
|
||||||
|
exit;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param Customer $customer
|
||||||
|
*/
|
||||||
|
protected function createLogin(Customer $customer) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param ImportJob $job
|
* @param ImportJob $job
|
||||||
*/
|
*/
|
||||||
@ -104,18 +130,22 @@ class SpectreRoutine implements RoutineInterface
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @return Customer
|
* @return Customer
|
||||||
|
* @throws \FireflyIII\Exceptions\FireflyException
|
||||||
*/
|
*/
|
||||||
protected function createCustomer(): Customer
|
protected function createCustomer(): Customer
|
||||||
{
|
{
|
||||||
$newCustomerRequest = new NewCustomerRequest($this->job->user);
|
$newCustomerRequest = new NewCustomerRequest($this->job->user);
|
||||||
$newCustomerRequest->call();
|
$newCustomerRequest->call();
|
||||||
echo '<pre>';
|
$customer = $newCustomerRequest->getCustomer();
|
||||||
print_r($newCustomerRequest->getCustomer());
|
|
||||||
exit;
|
// store customer. Not sure where. User preference? TODO
|
||||||
|
return $customer;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return Customer
|
* @return Customer
|
||||||
|
* @throws \FireflyIII\Exceptions\FireflyException
|
||||||
*/
|
*/
|
||||||
protected function getCustomer(): Customer
|
protected function getCustomer(): Customer
|
||||||
{
|
{
|
||||||
@ -126,4 +156,40 @@ class SpectreRoutine implements RoutineInterface
|
|||||||
var_dump($preference->data);
|
var_dump($preference->data);
|
||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return login belonging to country and provider
|
||||||
|
* TODO must return Login object, not array
|
||||||
|
*
|
||||||
|
* @param array $logins
|
||||||
|
* @param string $country
|
||||||
|
* @param int $providerId
|
||||||
|
*
|
||||||
|
* @return array|null
|
||||||
|
*/
|
||||||
|
private function filterLogins(array $logins, string $country, int $providerId): ?array
|
||||||
|
{
|
||||||
|
if (count($logins) === 0) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
foreach ($logins as $login) {
|
||||||
|
die('do some filter');
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
private function listLogins(Customer $customer): array
|
||||||
|
{
|
||||||
|
$listLoginRequest = new ListLoginsRequest($this->job->user);
|
||||||
|
$listLoginRequest->setCustomer($customer);
|
||||||
|
$listLoginRequest->call();
|
||||||
|
|
||||||
|
$logins = $listLoginRequest->getLogins();
|
||||||
|
|
||||||
|
return $logins;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -34,6 +34,18 @@ class Customer extends SpectreObject
|
|||||||
/** @var string */
|
/** @var string */
|
||||||
private $secret;
|
private $secret;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Customer constructor.
|
||||||
|
*
|
||||||
|
* @param array $data
|
||||||
|
*/
|
||||||
|
public function __construct(array $data)
|
||||||
|
{
|
||||||
|
$this->id = intval($data['id']);
|
||||||
|
$this->identifier = $data['identifier'];
|
||||||
|
$this->secret = $data['secret'];
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return int
|
* @return int
|
||||||
*/
|
*/
|
||||||
|
101
app/Services/Spectre/Request/ListLoginsRequest.php
Normal file
101
app/Services/Spectre/Request/ListLoginsRequest.php
Normal file
@ -0,0 +1,101 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* ListLoginsRequest.php
|
||||||
|
* Copyright (c) 2017 thegrumpydictator@gmail.com
|
||||||
|
*
|
||||||
|
* This file is part of Firefly III.
|
||||||
|
*
|
||||||
|
* Firefly III is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Firefly III is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with Firefly III. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace FireflyIII\Services\Spectre\Request;
|
||||||
|
|
||||||
|
use FireflyIII\Services\Spectre\Object\Customer;
|
||||||
|
use Log;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class ListLoginsRequest
|
||||||
|
*/
|
||||||
|
class ListLoginsRequest extends SpectreRequest
|
||||||
|
{
|
||||||
|
/** @var Customer */
|
||||||
|
protected $customer;
|
||||||
|
|
||||||
|
/** @var array */
|
||||||
|
protected $logins = [];
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @throws \FireflyIII\Exceptions\FireflyException
|
||||||
|
*/
|
||||||
|
public function call(): void
|
||||||
|
{
|
||||||
|
$hasNextPage = true;
|
||||||
|
$nextId = 0;
|
||||||
|
while ($hasNextPage) {
|
||||||
|
Log::debug(sprintf('Now calling list-logins for next_id %d', $nextId));
|
||||||
|
$parameters = ['customer_id' => $this->customer->getId(), 'from_id' => $nextId];
|
||||||
|
$uri = '/api/v3/logins?' . http_build_query($parameters);
|
||||||
|
$response = $this->sendSignedSpectreGet($uri, []);
|
||||||
|
|
||||||
|
// count entries:
|
||||||
|
Log::debug(sprintf('Found %d entries in data-array', count($response['data'])));
|
||||||
|
|
||||||
|
// extract next ID
|
||||||
|
$hasNextPage = false;
|
||||||
|
if (isset($response['meta']['next_id']) && intval($response['meta']['next_id']) > $nextId) {
|
||||||
|
$hasNextPage = true;
|
||||||
|
$nextId = $response['meta']['next_id'];
|
||||||
|
Log::debug(sprintf('Next ID is now %d.', $nextId));
|
||||||
|
} else {
|
||||||
|
Log::debug('No next page.');
|
||||||
|
}
|
||||||
|
|
||||||
|
// store providers:
|
||||||
|
foreach ($response['data'] as $loginArray) {
|
||||||
|
var_dump($loginArray);
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Customer
|
||||||
|
*/
|
||||||
|
public function getCustomer(): Customer
|
||||||
|
{
|
||||||
|
return $this->customer;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param Customer $customer
|
||||||
|
*/
|
||||||
|
public function setCustomer(Customer $customer): void
|
||||||
|
{
|
||||||
|
$this->customer = $customer;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function getLogins(): array
|
||||||
|
{
|
||||||
|
return $this->logins;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@ -25,7 +25,7 @@ namespace FireflyIII\Services\Spectre\Request;
|
|||||||
use Log;
|
use Log;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class ListUserRequest.
|
* Class ListProvidersRequest
|
||||||
*/
|
*/
|
||||||
class ListProvidersRequest extends SpectreRequest
|
class ListProvidersRequest extends SpectreRequest
|
||||||
{
|
{
|
||||||
|
@ -22,37 +22,44 @@ declare(strict_types=1);
|
|||||||
|
|
||||||
namespace FireflyIII\Services\Spectre\Request;
|
namespace FireflyIII\Services\Spectre\Request;
|
||||||
|
|
||||||
|
use FireflyIII\Services\Spectre\Object\Customer;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class NewCustomerRequest
|
* Class NewCustomerRequest
|
||||||
*/
|
*/
|
||||||
class NewCustomerRequest extends SpectreRequest
|
class NewCustomerRequest extends SpectreRequest
|
||||||
{
|
{
|
||||||
/** @var array */
|
/** @var Customer */
|
||||||
protected $customer = [];
|
protected $customer;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @throws \FireflyIII\Exceptions\FireflyException
|
* @throws \FireflyIII\Exceptions\FireflyException
|
||||||
*/
|
*/
|
||||||
public function call(): void
|
public function call(): void
|
||||||
{
|
{
|
||||||
$data = [
|
$data = [
|
||||||
'data' => [
|
'data' => [
|
||||||
'identifier' => 'default_ff3_customer',
|
'identifier' => 'default_ff3_customer',
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
$uri = '/api/v3/customers/';
|
$uri = '/api/v3/customers/';
|
||||||
$response = $this->sendSignedSpectrePost($uri, $data);
|
//$response = $this->sendSignedSpectrePost($uri, $data);
|
||||||
|
$response = ['data' => [
|
||||||
|
'id' => 527858,
|
||||||
|
'identifier' => 'default_ff3_customer',
|
||||||
|
'secret' => 'qpZjRPJRTb6mMcQgwDkssZ3fQVVDPIH04zBlkKC6MvI',
|
||||||
|
],
|
||||||
|
];
|
||||||
// create customer:
|
// create customer:
|
||||||
$this->customer = $response['data'];
|
$this->customer = new Customer($response['data']);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return Customer
|
||||||
*/
|
*/
|
||||||
public function getCustomer(): array
|
public function getCustomer(): Customer
|
||||||
{
|
{
|
||||||
return $this->customer;
|
return $this->customer;
|
||||||
}
|
}
|
||||||
|
@ -29,8 +29,6 @@ use Requests;
|
|||||||
use Requests_Exception;
|
use Requests_Exception;
|
||||||
use Requests_Response;
|
use Requests_Response;
|
||||||
|
|
||||||
//use FireflyIII\Services\Bunq\Object\ServerPublicKey;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class BunqRequest.
|
* Class BunqRequest.
|
||||||
*/
|
*/
|
||||||
@ -267,7 +265,7 @@ abstract class SpectreRequest
|
|||||||
|
|
||||||
Log::debug('Final headers for spectre signed POST request:', $headers);
|
Log::debug('Final headers for spectre signed POST request:', $headers);
|
||||||
try {
|
try {
|
||||||
$response = Requests::get($fullUri, $headers);
|
$response = Requests::post($fullUri, $headers, $body);
|
||||||
} catch (Requests_Exception $e) {
|
} catch (Requests_Exception $e) {
|
||||||
throw new FireflyException(sprintf('Request Exception: %s', $e->getMessage()));
|
throw new FireflyException(sprintf('Request Exception: %s', $e->getMessage()));
|
||||||
}
|
}
|
||||||
|
@ -63,6 +63,7 @@ class SpectreInformation implements InformationInterface
|
|||||||
* @return array
|
* @return array
|
||||||
*
|
*
|
||||||
* @throws FireflyException
|
* @throws FireflyException
|
||||||
|
* @throws \Exception
|
||||||
*/
|
*/
|
||||||
public function getAccounts(): array
|
public function getAccounts(): array
|
||||||
{
|
{
|
||||||
|
20
app/User.php
20
app/User.php
@ -61,6 +61,7 @@ class User extends Authenticatable
|
|||||||
protected $table = 'users';
|
protected $table = 'users';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Link to accounts.
|
* Link to accounts.
|
||||||
*
|
*
|
||||||
* @return HasMany
|
* @return HasMany
|
||||||
@ -95,6 +96,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Link to attachments
|
* Link to attachments
|
||||||
*
|
*
|
||||||
* @return HasMany
|
* @return HasMany
|
||||||
@ -105,6 +107,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Link to available budgets
|
* Link to available budgets
|
||||||
*
|
*
|
||||||
* @return HasMany
|
* @return HasMany
|
||||||
@ -115,6 +118,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Link to bills.
|
* Link to bills.
|
||||||
*
|
*
|
||||||
* @return HasMany
|
* @return HasMany
|
||||||
@ -125,6 +129,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Link to budgets.
|
* Link to budgets.
|
||||||
*
|
*
|
||||||
* @return HasMany
|
* @return HasMany
|
||||||
@ -135,6 +140,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Link to categories
|
* Link to categories
|
||||||
*
|
*
|
||||||
* @return HasMany
|
* @return HasMany
|
||||||
@ -145,6 +151,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Link to currency exchange rates
|
* Link to currency exchange rates
|
||||||
*
|
*
|
||||||
* @return HasMany
|
* @return HasMany
|
||||||
@ -155,6 +162,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Link to export jobs
|
* Link to export jobs
|
||||||
*
|
*
|
||||||
* @return HasMany
|
* @return HasMany
|
||||||
@ -165,6 +173,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Generates access token.
|
* Generates access token.
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
@ -177,6 +186,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Checks if the user has a role by its name.
|
* Checks if the user has a role by its name.
|
||||||
*
|
*
|
||||||
* Full credit goes to: https://github.com/Zizaco/entrust
|
* Full credit goes to: https://github.com/Zizaco/entrust
|
||||||
@ -197,6 +207,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Link to import jobs.
|
* Link to import jobs.
|
||||||
*
|
*
|
||||||
* @return HasMany
|
* @return HasMany
|
||||||
@ -207,6 +218,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Link to piggy banks.
|
* Link to piggy banks.
|
||||||
*
|
*
|
||||||
* @return HasManyThrough
|
* @return HasManyThrough
|
||||||
@ -217,6 +229,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Link to preferences.
|
* Link to preferences.
|
||||||
*
|
*
|
||||||
* @return HasMany
|
* @return HasMany
|
||||||
@ -227,6 +240,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Link to roles.
|
* Link to roles.
|
||||||
*
|
*
|
||||||
* @return \Illuminate\Database\Eloquent\Relations\BelongsToMany
|
* @return \Illuminate\Database\Eloquent\Relations\BelongsToMany
|
||||||
@ -237,6 +251,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Link to rule groups.
|
* Link to rule groups.
|
||||||
*
|
*
|
||||||
* @return HasMany
|
* @return HasMany
|
||||||
@ -247,6 +262,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Link to rules.
|
* Link to rules.
|
||||||
*
|
*
|
||||||
* @return HasMany
|
* @return HasMany
|
||||||
@ -257,6 +273,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Send the password reset notification.
|
* Send the password reset notification.
|
||||||
*
|
*
|
||||||
* @param string $token
|
* @param string $token
|
||||||
@ -269,6 +286,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Link to tags.
|
* Link to tags.
|
||||||
*
|
*
|
||||||
* @return HasMany
|
* @return HasMany
|
||||||
@ -279,6 +297,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Link to transaction journals.
|
* Link to transaction journals.
|
||||||
*
|
*
|
||||||
* @return HasMany
|
* @return HasMany
|
||||||
@ -289,6 +308,7 @@ class User extends Authenticatable
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @codeCoverageIgnore
|
||||||
* Link to transactions.
|
* Link to transactions.
|
||||||
*
|
*
|
||||||
* @return HasManyThrough
|
* @return HasManyThrough
|
||||||
|
@ -141,6 +141,9 @@ return [
|
|||||||
'column_opposing-number' => 'Opposing account (account number)',
|
'column_opposing-number' => 'Opposing account (account number)',
|
||||||
'column_note' => 'Note(s)',
|
'column_note' => 'Note(s)',
|
||||||
|
|
||||||
|
// prerequisites
|
||||||
|
'prerequisites' => 'Prerequisites',
|
||||||
|
|
||||||
// bunq
|
// bunq
|
||||||
'bunq_prerequisites_title' => 'Prerequisites for an import from bunq',
|
'bunq_prerequisites_title' => 'Prerequisites for an import from bunq',
|
||||||
'bunq_prerequisites_text' => 'In order to import from bunq, you need to obtain an API key. You can do this through the app.',
|
'bunq_prerequisites_text' => 'In order to import from bunq, you need to obtain an API key. You can do this through the app.',
|
||||||
|
@ -573,6 +573,16 @@ Breadcrumbs::register(
|
|||||||
$breadcrumbs->push(trans('import.config_sub_title', ['key' => $job->key]), route('import.configure', [$job->key]));
|
$breadcrumbs->push(trans('import.config_sub_title', ['key' => $job->key]), route('import.configure', [$job->key]));
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
Breadcrumbs::register(
|
||||||
|
'import.prerequisites',
|
||||||
|
function (BreadCrumbsGenerator $breadcrumbs, string $bank) {
|
||||||
|
$breadcrumbs->parent('import.index');
|
||||||
|
$breadcrumbs->push(trans('import.prerequisites'), route('import.prerequisites', [$bank]));
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
Breadcrumbs::register(
|
Breadcrumbs::register(
|
||||||
'import.status',
|
'import.status',
|
||||||
function (BreadCrumbsGenerator $breadcrumbs, ImportJob $job) {
|
function (BreadCrumbsGenerator $breadcrumbs, ImportJob $job) {
|
||||||
@ -581,6 +591,8 @@ Breadcrumbs::register(
|
|||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// PREFERENCES
|
// PREFERENCES
|
||||||
Breadcrumbs::register(
|
Breadcrumbs::register(
|
||||||
'preferences.index',
|
'preferences.index',
|
||||||
|
@ -445,7 +445,7 @@ Route::group(
|
|||||||
Route::get('json/{importJob}', ['uses' => 'Import\StatusController@json', 'as' => 'status.json']);
|
Route::get('json/{importJob}', ['uses' => 'Import\StatusController@json', 'as' => 'status.json']);
|
||||||
|
|
||||||
// start a job
|
// start a job
|
||||||
Route::post('start/{importJob}', ['uses' => 'Import\IndexController@start', 'as' => 'start']);
|
Route::any('start/{importJob}', ['uses' => 'Import\IndexController@start', 'as' => 'start']);
|
||||||
|
|
||||||
// download config
|
// download config
|
||||||
Route::get('download/{importJob}', ['uses' => 'Import\IndexController@download', 'as' => 'download']);
|
Route::get('download/{importJob}', ['uses' => 'Import\IndexController@download', 'as' => 'download']);
|
||||||
|
Loading…
Reference in New Issue
Block a user