mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2025-07-07 18:34:30 -04:00
Merge remote-tracking branch 'upstream/develop' into payments-changes
This commit is contained in:
commit
41f4c98e08
138
.htaccess
138
.htaccess
@ -6,3 +6,141 @@
|
|||||||
# https://coderwall.com/p/erbaig/laravel-s-htaccess-to-remove-public-from-url
|
# https://coderwall.com/p/erbaig/laravel-s-htaccess-to-remove-public-from-url
|
||||||
# RewriteRule ^(.*)$ public/$1 [L]
|
# RewriteRule ^(.*)$ public/$1 [L]
|
||||||
</IfModule>
|
</IfModule>
|
||||||
|
|
||||||
|
# https://github.com/h5bp/server-configs-apache/blob/master/dist/.htaccess
|
||||||
|
|
||||||
|
|
||||||
|
# ######################################################################
|
||||||
|
# # INTERNET EXPLORER #
|
||||||
|
# ######################################################################
|
||||||
|
|
||||||
|
# ----------------------------------------------------------------------
|
||||||
|
# | Iframes cookies |
|
||||||
|
# ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
# Allow cookies to be set from iframes in Internet Explorer.
|
||||||
|
#
|
||||||
|
# https://msdn.microsoft.com/en-us/library/ms537343.aspx
|
||||||
|
# http://www.w3.org/TR/2000/CR-P3P-20001215/
|
||||||
|
|
||||||
|
<IfModule mod_headers.c>
|
||||||
|
Header set P3P "policyref=\"/w3c/p3p.xml\", CP=\"IDC DSP COR ADM DEVi TAIi PSA PSD IVAi IVDi CONi HIS OUR IND CNT\""
|
||||||
|
</IfModule>
|
||||||
|
|
||||||
|
|
||||||
|
# ######################################################################
|
||||||
|
# # MEDIA TYPES AND CHARACTER ENCODINGS #
|
||||||
|
# ######################################################################
|
||||||
|
|
||||||
|
# ----------------------------------------------------------------------
|
||||||
|
# | Character encodings |
|
||||||
|
# ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
# Serve all resources labeled as `text/html` or `text/plain`
|
||||||
|
# with the media type `charset` parameter set to `UTF-8`.
|
||||||
|
#
|
||||||
|
# https://httpd.apache.org/docs/current/mod/core.html#adddefaultcharset
|
||||||
|
|
||||||
|
AddDefaultCharset utf-8
|
||||||
|
|
||||||
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
||||||
|
# Serve the following file types with the media type `charset`
|
||||||
|
# parameter set to `UTF-8`.
|
||||||
|
#
|
||||||
|
# https://httpd.apache.org/docs/current/mod/mod_mime.html#addcharset
|
||||||
|
|
||||||
|
<IfModule mod_mime.c>
|
||||||
|
AddCharset utf-8 .atom \
|
||||||
|
.bbaw \
|
||||||
|
.css \
|
||||||
|
.geojson \
|
||||||
|
.js \
|
||||||
|
.json \
|
||||||
|
.jsonld \
|
||||||
|
.manifest \
|
||||||
|
.rdf \
|
||||||
|
.rss \
|
||||||
|
.topojson \
|
||||||
|
.vtt \
|
||||||
|
.webapp \
|
||||||
|
.webmanifest \
|
||||||
|
.xloc \
|
||||||
|
.xml
|
||||||
|
</IfModule>
|
||||||
|
|
||||||
|
|
||||||
|
# ######################################################################
|
||||||
|
# # WEB PERFORMANCE #
|
||||||
|
# ######################################################################
|
||||||
|
|
||||||
|
# ----------------------------------------------------------------------
|
||||||
|
# | Compression |
|
||||||
|
# ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
<IfModule mod_deflate.c>
|
||||||
|
|
||||||
|
# Force compression for mangled headers.
|
||||||
|
# https://developer.yahoo.com/blogs/ydn/pushing-beyond-gzipping-25601.html
|
||||||
|
|
||||||
|
<IfModule mod_setenvif.c>
|
||||||
|
<IfModule mod_headers.c>
|
||||||
|
SetEnvIfNoCase ^(Accept-EncodXng|X-cept-Encoding|X{15}|~{15}|-{15})$ ^((gzip|deflate)\s*,?\s*)+|[X~-]{4,13}$ HAVE_Accept-Encoding
|
||||||
|
RequestHeader append Accept-Encoding "gzip,deflate" env=HAVE_Accept-Encoding
|
||||||
|
</IfModule>
|
||||||
|
</IfModule>
|
||||||
|
|
||||||
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
||||||
|
# Map certain file types to the specified encoding type in order to
|
||||||
|
# make Apache serve them with the appropriate `Content-Encoding` HTTP
|
||||||
|
# response header (this will NOT make Apache compress them!).
|
||||||
|
|
||||||
|
# If the following file types wouldn't be served without the appropriate
|
||||||
|
# `Content-Enable` HTTP response header, client applications (e.g.:
|
||||||
|
# browsers) wouldn't know that they first need to uncompress the response,
|
||||||
|
# and thus, wouldn't be able to understand the content.
|
||||||
|
|
||||||
|
# http://httpd.apache.org/docs/current/mod/mod_mime.html#addencoding
|
||||||
|
|
||||||
|
<IfModule mod_mime.c>
|
||||||
|
AddEncoding gzip svgz
|
||||||
|
</IfModule>
|
||||||
|
|
||||||
|
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
||||||
|
# Compress all output labeled with one of the following media types.
|
||||||
|
|
||||||
|
# IMPORTANT: For Apache versions below 2.3.7 you don't need to enable
|
||||||
|
# `mod_filter` and can remove the `<IfModule mod_filter.c>` & `</IfModule>`
|
||||||
|
# lines as `AddOutputFilterByType` is still in the core directives.
|
||||||
|
|
||||||
|
<IfModule mod_filter.c>
|
||||||
|
AddOutputFilterByType DEFLATE "application/atom+xml" \
|
||||||
|
"application/javascript" \
|
||||||
|
"application/json" \
|
||||||
|
"application/ld+json" \
|
||||||
|
"application/manifest+json" \
|
||||||
|
"application/rdf+xml" \
|
||||||
|
"application/rss+xml" \
|
||||||
|
"application/schema+json" \
|
||||||
|
"application/vnd.geo+json" \
|
||||||
|
"application/vnd.ms-fontobject" \
|
||||||
|
"application/x-font-ttf" \
|
||||||
|
"application/x-web-app-manifest+json" \
|
||||||
|
"application/xhtml+xml" \
|
||||||
|
"application/xml" \
|
||||||
|
"font/opentype" \
|
||||||
|
"image/svg+xml" \
|
||||||
|
"image/x-icon" \
|
||||||
|
"text/cache-manifest" \
|
||||||
|
"text/css" \
|
||||||
|
"text/html" \
|
||||||
|
"text/javascript" \
|
||||||
|
"text/plain" \
|
||||||
|
"text/vtt" \
|
||||||
|
"text/x-component" \
|
||||||
|
"text/xml"
|
||||||
|
</IfModule>
|
||||||
|
|
||||||
|
</IfModule>
|
@ -45,7 +45,8 @@ before_script:
|
|||||||
- php artisan key:generate --no-interaction
|
- php artisan key:generate --no-interaction
|
||||||
- sed -i 's/APP_ENV=production/APP_ENV=development/g' .env
|
- sed -i 's/APP_ENV=production/APP_ENV=development/g' .env
|
||||||
- sed -i 's/APP_DEBUG=false/APP_DEBUG=true/g' .env
|
- sed -i 's/APP_DEBUG=false/APP_DEBUG=true/g' .env
|
||||||
- sed -i 's/REQUIRE_HTTPS=false/NINJA_DEV=true/g' .env
|
- sed -i '$a NINJA_DEV=true' .env
|
||||||
|
- sed -i '$a TRAVIS=true' .env
|
||||||
# create the database and user
|
# create the database and user
|
||||||
- mysql -u root -e "create database IF NOT EXISTS ninja;"
|
- mysql -u root -e "create database IF NOT EXISTS ninja;"
|
||||||
- mysql -u root -e "GRANT ALL PRIVILEGES ON ninja.* To 'ninja'@'localhost' IDENTIFIED BY 'ninja'; FLUSH PRIVILEGES;"
|
- mysql -u root -e "GRANT ALL PRIVILEGES ON ninja.* To 'ninja'@'localhost' IDENTIFIED BY 'ninja'; FLUSH PRIVILEGES;"
|
||||||
@ -89,7 +90,8 @@ after_script:
|
|||||||
- mysql -u root -e 'select * from invoice_items;' ninja
|
- mysql -u root -e 'select * from invoice_items;' ninja
|
||||||
- mysql -u root -e 'select * from payments;' ninja
|
- mysql -u root -e 'select * from payments;' ninja
|
||||||
- mysql -u root -e 'select * from credits;' ninja
|
- mysql -u root -e 'select * from credits;' ninja
|
||||||
- cat storage/logs/laravel.log
|
- cat storage/logs/laravel-error.log
|
||||||
|
- cat storage/logs/laravel-info.log
|
||||||
|
|
||||||
notifications:
|
notifications:
|
||||||
email:
|
email:
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Commands;
|
<?php namespace App\Commands;
|
||||||
|
|
||||||
abstract class Command
|
abstract class Command
|
||||||
{
|
{
|
||||||
|
172
app/Console/Commands/CreateTestData.php
Normal file
172
app/Console/Commands/CreateTestData.php
Normal file
@ -0,0 +1,172 @@
|
|||||||
|
<?php namespace App\Console\Commands;
|
||||||
|
|
||||||
|
use stdClass;
|
||||||
|
use Auth;
|
||||||
|
use DB;
|
||||||
|
use Utils;
|
||||||
|
use Artisan;
|
||||||
|
use Illuminate\Console\Command;
|
||||||
|
use Faker\Factory;
|
||||||
|
use App\Models\User;
|
||||||
|
|
||||||
|
use App\Ninja\Repositories\ClientRepository;
|
||||||
|
use App\Ninja\Repositories\InvoiceRepository;
|
||||||
|
use App\Ninja\Repositories\PaymentRepository;
|
||||||
|
use App\Ninja\Repositories\VendorRepository;
|
||||||
|
use App\Ninja\Repositories\ExpenseRepository;
|
||||||
|
|
||||||
|
class CreateTestData extends Command
|
||||||
|
{
|
||||||
|
//protected $name = 'ninja:create-test-data';
|
||||||
|
protected $description = 'Create Test Data';
|
||||||
|
protected $signature = 'ninja:create-test-data {count=1}';
|
||||||
|
|
||||||
|
protected $token;
|
||||||
|
|
||||||
|
public function __construct(
|
||||||
|
ClientRepository $clientRepo,
|
||||||
|
InvoiceRepository $invoiceRepo,
|
||||||
|
PaymentRepository $paymentRepo,
|
||||||
|
VendorRepository $vendorRepo,
|
||||||
|
ExpenseRepository $expenseRepo)
|
||||||
|
{
|
||||||
|
parent::__construct();
|
||||||
|
|
||||||
|
$this->faker = Factory::create();
|
||||||
|
|
||||||
|
$this->clientRepo = $clientRepo;
|
||||||
|
$this->invoiceRepo = $invoiceRepo;
|
||||||
|
$this->paymentRepo = $paymentRepo;
|
||||||
|
$this->vendorRepo = $vendorRepo;
|
||||||
|
$this->expenseRepo = $expenseRepo;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function fire()
|
||||||
|
{
|
||||||
|
if (Utils::isNinjaProd()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->info(date('Y-m-d').' Running CreateTestData...');
|
||||||
|
|
||||||
|
Auth::loginUsingId(1);
|
||||||
|
$this->count = $this->argument('count');
|
||||||
|
|
||||||
|
$this->createClients();
|
||||||
|
$this->createVendors();
|
||||||
|
|
||||||
|
$this->info('Done');
|
||||||
|
}
|
||||||
|
|
||||||
|
private function createClients()
|
||||||
|
{
|
||||||
|
for ($i=0; $i<$this->count; $i++) {
|
||||||
|
$data = [
|
||||||
|
'name' => $this->faker->name,
|
||||||
|
'address1' => $this->faker->streetAddress,
|
||||||
|
'address2' => $this->faker->secondaryAddress,
|
||||||
|
'city' => $this->faker->city,
|
||||||
|
'state' => $this->faker->state,
|
||||||
|
'postal_code' => $this->faker->postcode,
|
||||||
|
'contacts' => [[
|
||||||
|
'first_name' => $this->faker->firstName,
|
||||||
|
'last_name' => $this->faker->lastName,
|
||||||
|
'email' => $this->faker->safeEmail,
|
||||||
|
'phone' => $this->faker->phoneNumber,
|
||||||
|
]]
|
||||||
|
];
|
||||||
|
|
||||||
|
$client = $this->clientRepo->save($data);
|
||||||
|
$this->info('Client: ' . $client->name);
|
||||||
|
|
||||||
|
$this->createInvoices($client);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private function createInvoices($client)
|
||||||
|
{
|
||||||
|
for ($i=0; $i<$this->count; $i++) {
|
||||||
|
$data = [
|
||||||
|
'client_id' => $client->id,
|
||||||
|
'invoice_items' => [[
|
||||||
|
'product_key' => $this->faker->word,
|
||||||
|
'qty' => $this->faker->randomDigit + 1,
|
||||||
|
'cost' => $this->faker->randomFloat(2, 1, 10),
|
||||||
|
'notes' => $this->faker->text($this->faker->numberBetween(50, 300))
|
||||||
|
]]
|
||||||
|
];
|
||||||
|
|
||||||
|
$invoice = $this->invoiceRepo->save($data);
|
||||||
|
$this->info('Invoice: ' . $invoice->invoice_number);
|
||||||
|
|
||||||
|
$this->createPayment($client, $invoice);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private function createPayment($client, $invoice)
|
||||||
|
{
|
||||||
|
$data = [
|
||||||
|
'invoice_id' => $invoice->id,
|
||||||
|
'client_id' => $client->id,
|
||||||
|
'amount' => $this->faker->randomFloat(2, 0, $invoice->amount)
|
||||||
|
];
|
||||||
|
|
||||||
|
$payment = $this->paymentRepo->save($data);
|
||||||
|
|
||||||
|
$this->info('Payment: ' . $payment->amount);
|
||||||
|
}
|
||||||
|
|
||||||
|
private function createVendors()
|
||||||
|
{
|
||||||
|
for ($i=0; $i<$this->count; $i++) {
|
||||||
|
$data = [
|
||||||
|
'name' => $this->faker->name,
|
||||||
|
'address1' => $this->faker->streetAddress,
|
||||||
|
'address2' => $this->faker->secondaryAddress,
|
||||||
|
'city' => $this->faker->city,
|
||||||
|
'state' => $this->faker->state,
|
||||||
|
'postal_code' => $this->faker->postcode,
|
||||||
|
'vendor_contacts' => [[
|
||||||
|
'first_name' => $this->faker->firstName,
|
||||||
|
'last_name' => $this->faker->lastName,
|
||||||
|
'email' => $this->faker->safeEmail,
|
||||||
|
'phone' => $this->faker->phoneNumber,
|
||||||
|
]]
|
||||||
|
];
|
||||||
|
|
||||||
|
$vendor = $this->vendorRepo->save($data);
|
||||||
|
$this->info('Vendor: ' . $vendor->name);
|
||||||
|
|
||||||
|
$this->createExpense($vendor);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private function createExpense($vendor)
|
||||||
|
{
|
||||||
|
for ($i=0; $i<$this->count; $i++) {
|
||||||
|
$data = [
|
||||||
|
'vendor_id' => $vendor->id,
|
||||||
|
'amount' => $this->faker->randomFloat(2, 1, 10),
|
||||||
|
'expense_date' => null,
|
||||||
|
'public_notes' => null,
|
||||||
|
];
|
||||||
|
|
||||||
|
$expense = $this->expenseRepo->save($data);
|
||||||
|
$this->info('Expense: ' . $expense->amount);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getArguments()
|
||||||
|
{
|
||||||
|
return array(
|
||||||
|
//array('example', InputArgument::REQUIRED, 'An example argument.'),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getOptions()
|
||||||
|
{
|
||||||
|
return array(
|
||||||
|
//array('example', null, InputOption::VALUE_OPTIONAL, 'An example option.', null),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Console\Commands;
|
<?php namespace App\Console\Commands;
|
||||||
|
|
||||||
use File;
|
use File;
|
||||||
use Illuminate\Console\Command;
|
use Illuminate\Console\Command;
|
||||||
|
@ -62,8 +62,12 @@ class SendRenewalInvoices extends Command
|
|||||||
$invoice->due_date = date('Y-m-d', strtotime('+ 10 days'));
|
$invoice->due_date = date('Y-m-d', strtotime('+ 10 days'));
|
||||||
$invoice->save();
|
$invoice->save();
|
||||||
|
|
||||||
|
if ($term == PLAN_TERM_YEARLY) {
|
||||||
$this->mailer->sendInvoice($invoice);
|
$this->mailer->sendInvoice($invoice);
|
||||||
$this->info("Sent invoice to {$client->getDisplayName()}");
|
$this->info("Sent {$term}ly {$plan} invoice to {$client->getDisplayName()}");
|
||||||
|
} else {
|
||||||
|
$this->info("Created {$term}ly {$plan} invoice for {$client->getDisplayName()}");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->info('Done');
|
$this->info('Done');
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Console\Commands;
|
<?php namespace App\Console\Commands;
|
||||||
|
|
||||||
use Illuminate\Console\Command;
|
use Illuminate\Console\Command;
|
||||||
use App\Services\BankAccountService;
|
use App\Services\BankAccountService;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Console;
|
<?php namespace App\Console;
|
||||||
|
|
||||||
use Utils;
|
use Utils;
|
||||||
use Illuminate\Console\Scheduling\Schedule;
|
use Illuminate\Console\Scheduling\Schedule;
|
||||||
@ -17,6 +17,7 @@ class Kernel extends ConsoleKernel
|
|||||||
'App\Console\Commands\ResetData',
|
'App\Console\Commands\ResetData',
|
||||||
'App\Console\Commands\CheckData',
|
'App\Console\Commands\CheckData',
|
||||||
'App\Console\Commands\PruneData',
|
'App\Console\Commands\PruneData',
|
||||||
|
'App\Console\Commands\CreateTestData',
|
||||||
'App\Console\Commands\SendRenewalInvoices',
|
'App\Console\Commands\SendRenewalInvoices',
|
||||||
'App\Console\Commands\ChargeRenewalInvoices',
|
'App\Console\Commands\ChargeRenewalInvoices',
|
||||||
'App\Console\Commands\SendReminders',
|
'App\Console\Commands\SendReminders',
|
||||||
|
@ -39,7 +39,7 @@ class Handler extends ExceptionHandler {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Utils::isNinja()) {
|
if (Utils::isNinja() && ! Utils::isTravis()) {
|
||||||
Utils::logError(Utils::getErrorString($e));
|
Utils::logError(Utils::getErrorString($e));
|
||||||
return false;
|
return false;
|
||||||
} else {
|
} else {
|
||||||
|
@ -34,6 +34,13 @@ class AccountApiController extends BaseAPIController
|
|||||||
$this->accountRepo = $accountRepo;
|
$this->accountRepo = $accountRepo;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function ping()
|
||||||
|
{
|
||||||
|
$headers = Utils::getApiHeaders();
|
||||||
|
|
||||||
|
return Response::make(RESULT_SUCCESS, 200, $headers);
|
||||||
|
}
|
||||||
|
|
||||||
public function register(RegisterRequest $request)
|
public function register(RegisterRequest $request)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
@ -246,8 +246,7 @@ class AccountController extends BaseController
|
|||||||
|
|
||||||
public function getSearchData()
|
public function getSearchData()
|
||||||
{
|
{
|
||||||
$account = Auth::user()->account;
|
$data = $this->accountRepo->getSearchData(Auth::user());
|
||||||
$data = $this->accountRepo->getSearchData($account);
|
|
||||||
|
|
||||||
return Response::json($data);
|
return Response::json($data);
|
||||||
}
|
}
|
||||||
@ -1294,4 +1293,37 @@ class AccountController extends BaseController
|
|||||||
|
|
||||||
return Redirect::to("/settings/$section/", 301);
|
return Redirect::to("/settings/$section/", 301);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function previewEmail(\App\Services\TemplateService $templateService)
|
||||||
|
{
|
||||||
|
$template = Input::get('template');
|
||||||
|
$invoice = Invoice::scope()
|
||||||
|
->invoices()
|
||||||
|
->withTrashed()
|
||||||
|
->first();
|
||||||
|
|
||||||
|
if ( ! $invoice) {
|
||||||
|
return trans('texts.create_invoice_for_sample');
|
||||||
|
}
|
||||||
|
|
||||||
|
$account = Auth::user()->account;
|
||||||
|
|
||||||
|
// replace the variables with sample data
|
||||||
|
$data = [
|
||||||
|
'account' => $account,
|
||||||
|
'invoice' => $invoice,
|
||||||
|
'invitation' => $invoice->invitations->first(),
|
||||||
|
'client' => $invoice->client,
|
||||||
|
'amount' => $invoice->amount
|
||||||
|
];
|
||||||
|
|
||||||
|
// create the email view
|
||||||
|
$view = 'emails.' . $account->getTemplateView(ENTITY_INVOICE) . '_html';
|
||||||
|
$data = array_merge($data, [
|
||||||
|
'body' => $templateService->processVariables($template, $data),
|
||||||
|
'entityType' => ENTITY_INVOICE,
|
||||||
|
]);
|
||||||
|
|
||||||
|
return Response::view($view, $data);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -266,18 +266,7 @@ class AppController extends BaseController
|
|||||||
Cache::flush();
|
Cache::flush();
|
||||||
Session::flush();
|
Session::flush();
|
||||||
Artisan::call('migrate', array('--force' => true));
|
Artisan::call('migrate', array('--force' => true));
|
||||||
foreach ([
|
Artisan::call('db:seed', array('--force' => true, '--class' => "UpdateSeeder"));
|
||||||
'PaymentLibraries',
|
|
||||||
'Fonts',
|
|
||||||
'Banks',
|
|
||||||
'InvoiceStatus',
|
|
||||||
'Currencies',
|
|
||||||
'DateFormats',
|
|
||||||
'InvoiceDesigns',
|
|
||||||
'PaymentTerms',
|
|
||||||
] as $seeder) {
|
|
||||||
Artisan::call('db:seed', array('--force' => true, '--class' => "{$seeder}Seeder"));
|
|
||||||
}
|
|
||||||
Event::fire(new UserSettingsChanged());
|
Event::fire(new UserSettingsChanged());
|
||||||
Session::flash('message', trans('texts.processed_updates'));
|
Session::flash('message', trans('texts.processed_updates'));
|
||||||
} catch (Exception $e) {
|
} catch (Exception $e) {
|
||||||
@ -306,7 +295,7 @@ class AppController extends BaseController
|
|||||||
|
|
||||||
public function stats()
|
public function stats()
|
||||||
{
|
{
|
||||||
if (Input::get('password') != env('RESELLER_PASSWORD')) {
|
if ( ! hash_equals(Input::get('password'), env('RESELLER_PASSWORD'))) {
|
||||||
sleep(3);
|
sleep(3);
|
||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
|
@ -2,6 +2,9 @@
|
|||||||
|
|
||||||
use Session;
|
use Session;
|
||||||
use Utils;
|
use Utils;
|
||||||
|
use Auth;
|
||||||
|
use Log;
|
||||||
|
use Input;
|
||||||
use Response;
|
use Response;
|
||||||
use Request;
|
use Request;
|
||||||
use League\Fractal;
|
use League\Fractal;
|
||||||
@ -9,8 +12,10 @@ use League\Fractal\Manager;
|
|||||||
use League\Fractal\Resource\Item;
|
use League\Fractal\Resource\Item;
|
||||||
use League\Fractal\Resource\Collection;
|
use League\Fractal\Resource\Collection;
|
||||||
use League\Fractal\Pagination\IlluminatePaginatorAdapter;
|
use League\Fractal\Pagination\IlluminatePaginatorAdapter;
|
||||||
|
use App\Models\EntityModel;
|
||||||
use App\Ninja\Serializers\ArraySerializer;
|
use App\Ninja\Serializers\ArraySerializer;
|
||||||
use League\Fractal\Serializer\JsonApiSerializer;
|
use League\Fractal\Serializer\JsonApiSerializer;
|
||||||
|
use Illuminate\Pagination\LengthAwarePaginator;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @SWG\Swagger(
|
* @SWG\Swagger(
|
||||||
@ -62,6 +67,74 @@ class BaseAPIController extends Controller
|
|||||||
} else {
|
} else {
|
||||||
$this->manager->setSerializer(new ArraySerializer());
|
$this->manager->setSerializer(new ArraySerializer());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (Utils::isNinjaDev()) {
|
||||||
|
\DB::enableQueryLog();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function handleAction($request)
|
||||||
|
{
|
||||||
|
$entity = $request->entity();
|
||||||
|
$action = $request->action;
|
||||||
|
|
||||||
|
$repo = Utils::toCamelCase($this->entityType) . 'Repo';
|
||||||
|
|
||||||
|
$this->$repo->$action($entity);
|
||||||
|
|
||||||
|
return $this->itemResponse($entity);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function listResponse($query)
|
||||||
|
{
|
||||||
|
$transformerClass = EntityModel::getTransformerName($this->entityType);
|
||||||
|
$transformer = new $transformerClass(Auth::user()->account, Input::get('serializer'));
|
||||||
|
|
||||||
|
$includes = $transformer->getDefaultIncludes();
|
||||||
|
$includes = $this->getRequestIncludes($includes);
|
||||||
|
|
||||||
|
$query->with($includes);
|
||||||
|
|
||||||
|
if ($updatedAt = Input::get('updated_at')) {
|
||||||
|
$updatedAt = date('Y-m-d H:i:s', $updatedAt);
|
||||||
|
$query->where(function($query) use ($includes, $updatedAt) {
|
||||||
|
$query->where('updated_at', '>=', $updatedAt);
|
||||||
|
foreach ($includes as $include) {
|
||||||
|
$query->orWhereHas($include, function($query) use ($updatedAt) {
|
||||||
|
$query->where('updated_at', '>=', $updatedAt);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($clientPublicId = Input::get('client_id')) {
|
||||||
|
$filter = function($query) use ($clientPublicId) {
|
||||||
|
$query->where('public_id', '=', $clientPublicId);
|
||||||
|
};
|
||||||
|
$query->whereHas('client', $filter);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ! Utils::hasPermission('view_all')){
|
||||||
|
if ($this->entityType == ENTITY_USER) {
|
||||||
|
$query->where('id', '=', Auth::user()->id);
|
||||||
|
} else {
|
||||||
|
$query->where('user_id', '=', Auth::user()->id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = $this->createCollection($query, $transformer, $this->entityType);
|
||||||
|
|
||||||
|
return $this->response($data);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function itemResponse($item)
|
||||||
|
{
|
||||||
|
$transformerClass = EntityModel::getTransformerName($this->entityType);
|
||||||
|
$transformer = new $transformerClass(Auth::user()->account, Input::get('serializer'));
|
||||||
|
|
||||||
|
$data = $this->createItem($item, $transformer, $this->entityType);
|
||||||
|
|
||||||
|
return $this->response($data);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function createItem($data, $transformer, $entityType)
|
protected function createItem($data, $transformer, $entityType)
|
||||||
@ -74,16 +147,18 @@ class BaseAPIController extends Controller
|
|||||||
return $this->manager->createData($resource)->toArray();
|
return $this->manager->createData($resource)->toArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function createCollection($data, $transformer, $entityType, $paginator = false)
|
protected function createCollection($query, $transformer, $entityType)
|
||||||
{
|
{
|
||||||
if ($this->serializer && $this->serializer != API_SERIALIZER_JSON) {
|
if ($this->serializer && $this->serializer != API_SERIALIZER_JSON) {
|
||||||
$entityType = null;
|
$entityType = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
$resource = new Collection($data, $transformer, $entityType);
|
if (is_a($query, "Illuminate\Database\Eloquent\Builder")) {
|
||||||
|
$limit = min(MAX_API_PAGE_SIZE, Input::get('per_page', DEFAULT_API_PAGE_SIZE));
|
||||||
if ($paginator) {
|
$resource = new Collection($query->get(), $transformer, $entityType);
|
||||||
$resource->setPaginator(new IlluminatePaginatorAdapter($paginator));
|
$resource->setPaginator(new IlluminatePaginatorAdapter($query->paginate($limit)));
|
||||||
|
} else {
|
||||||
|
$resource = new Collection($query, $transformer, $entityType);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this->manager->createData($resource)->toArray();
|
return $this->manager->createData($resource)->toArray();
|
||||||
@ -91,6 +166,12 @@ class BaseAPIController extends Controller
|
|||||||
|
|
||||||
protected function response($response)
|
protected function response($response)
|
||||||
{
|
{
|
||||||
|
if (Utils::isNinjaDev()) {
|
||||||
|
$count = count(\DB::getQueryLog());
|
||||||
|
Log::info(Request::method() . ' - ' . Request::url() . ": $count queries");
|
||||||
|
Log::info(json_encode(\DB::getQueryLog()));
|
||||||
|
}
|
||||||
|
|
||||||
$index = Request::get('index') ?: 'data';
|
$index = Request::get('index') ?: 'data';
|
||||||
|
|
||||||
if ($index == 'none') {
|
if ($index == 'none') {
|
||||||
@ -123,26 +204,21 @@ class BaseAPIController extends Controller
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function getRequestIncludes($data)
|
||||||
protected function getIncluded()
|
|
||||||
{
|
{
|
||||||
$data = ['user'];
|
|
||||||
|
|
||||||
$included = Request::get('include');
|
$included = Request::get('include');
|
||||||
$included = explode(',', $included);
|
$included = explode(',', $included);
|
||||||
|
|
||||||
foreach ($included as $include) {
|
foreach ($included as $include) {
|
||||||
if ($include == 'invoices') {
|
if ($include == 'invoices') {
|
||||||
$data[] = 'invoices.invoice_items';
|
$data[] = 'invoices.invoice_items';
|
||||||
$data[] = 'invoices.user';
|
} elseif ($include == 'client') {
|
||||||
|
$data[] = 'client.contacts';
|
||||||
} elseif ($include == 'clients') {
|
} elseif ($include == 'clients') {
|
||||||
$data[] = 'clients.contacts';
|
$data[] = 'clients.contacts';
|
||||||
$data[] = 'clients.user';
|
|
||||||
} elseif ($include == 'vendors') {
|
} elseif ($include == 'vendors') {
|
||||||
$data[] = 'vendors.vendorcontacts';
|
$data[] = 'vendors.vendor_contacts';
|
||||||
$data[] = 'vendors.user';
|
} elseif ($include) {
|
||||||
}
|
|
||||||
elseif ($include) {
|
|
||||||
$data[] = $include;
|
$data[] = $include;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
use App\Http\Middleware\PermissionsRequired;
|
use App\Http\Middleware\PermissionsRequired;
|
||||||
use Illuminate\Foundation\Bus\DispatchesJobs;
|
use Illuminate\Foundation\Bus\DispatchesJobs;
|
||||||
use Illuminate\Foundation\Auth\Access\AuthorizesRequests;
|
use Illuminate\Foundation\Auth\Access\AuthorizesRequests;
|
||||||
|
use Input;
|
||||||
use Auth;
|
use Auth;
|
||||||
use Utils;
|
use Utils;
|
||||||
|
|
||||||
@ -10,7 +11,7 @@ class BaseController extends Controller
|
|||||||
{
|
{
|
||||||
use DispatchesJobs, AuthorizesRequests;
|
use DispatchesJobs, AuthorizesRequests;
|
||||||
|
|
||||||
protected $entity;
|
protected $entityType;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Setup the layout used by the controller.
|
* Setup the layout used by the controller.
|
||||||
@ -23,22 +24,4 @@ class BaseController extends Controller
|
|||||||
$this->layout = View::make($this->layout);
|
$this->layout = View::make($this->layout);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function authorizeCreate() {
|
|
||||||
$this->authorize('create', $this->entity);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function authorizeUpdate($input){
|
|
||||||
$creating = empty($input['public_id']) || $input['public_id'] == '-1';
|
|
||||||
|
|
||||||
if($creating){
|
|
||||||
$this->authorize('create', $this->entity);
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
$className = Utils::getEntityName($this->entity);
|
|
||||||
|
|
||||||
$object = call_user_func(array("App\\Models\\{$className}", 'scope'), $input['public_id'])->firstOrFail();
|
|
||||||
$this->authorize('edit', $object);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -10,27 +10,19 @@ use App\Ninja\Repositories\ClientRepository;
|
|||||||
use App\Http\Requests\CreateClientRequest;
|
use App\Http\Requests\CreateClientRequest;
|
||||||
use App\Http\Controllers\BaseAPIController;
|
use App\Http\Controllers\BaseAPIController;
|
||||||
use App\Ninja\Transformers\ClientTransformer;
|
use App\Ninja\Transformers\ClientTransformer;
|
||||||
use App\Services\ClientService;
|
|
||||||
use App\Http\Requests\UpdateClientRequest;
|
use App\Http\Requests\UpdateClientRequest;
|
||||||
|
|
||||||
class ClientApiController extends BaseAPIController
|
class ClientApiController extends BaseAPIController
|
||||||
{
|
{
|
||||||
protected $clientRepo;
|
protected $clientRepo;
|
||||||
protected $clientService;
|
|
||||||
|
|
||||||
public function __construct(ClientRepository $clientRepo, ClientService $clientService)
|
protected $entityType = ENTITY_CLIENT;
|
||||||
|
|
||||||
|
public function __construct(ClientRepository $clientRepo)
|
||||||
{
|
{
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
|
|
||||||
$this->clientRepo = $clientRepo;
|
$this->clientRepo = $clientRepo;
|
||||||
$this->clientService = $clientService;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function ping()
|
|
||||||
{
|
|
||||||
$headers = Utils::getApiHeaders();
|
|
||||||
|
|
||||||
return Response::make('', 200, $headers);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -52,27 +44,17 @@ class ClientApiController extends BaseAPIController
|
|||||||
public function index()
|
public function index()
|
||||||
{
|
{
|
||||||
$clients = Client::scope()
|
$clients = Client::scope()
|
||||||
->with($this->getIncluded())
|
->orderBy('created_at', 'desc')
|
||||||
->orderBy('created_at', 'desc')->withTrashed();
|
->withTrashed();
|
||||||
|
|
||||||
// Filter by email
|
// Filter by email
|
||||||
if (Input::has('email')) {
|
if ($email = Input::get('email')) {
|
||||||
|
|
||||||
$email = Input::get('email');
|
|
||||||
$clients = $clients->whereHas('contacts', function ($query) use ($email) {
|
$clients = $clients->whereHas('contacts', function ($query) use ($email) {
|
||||||
$query->where('email', $email);
|
$query->where('email', $email);
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$clients = $clients->paginate();
|
return $this->listResponse($clients);
|
||||||
|
|
||||||
$transformer = new ClientTransformer(Auth::user()->account, Input::get('serializer'));
|
|
||||||
$paginator = Client::scope()->withTrashed()->paginate();
|
|
||||||
|
|
||||||
$data = $this->createCollection($clients, $transformer, ENTITY_CLIENT, $paginator);
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -100,14 +82,7 @@ class ClientApiController extends BaseAPIController
|
|||||||
{
|
{
|
||||||
$client = $this->clientRepo->save($request->input());
|
$client = $this->clientRepo->save($request->input());
|
||||||
|
|
||||||
$client = Client::scope($client->public_id)
|
return $this->itemResponse($client);
|
||||||
->with('country', 'contacts', 'industry', 'size', 'currency')
|
|
||||||
->first();
|
|
||||||
|
|
||||||
$transformer = new ClientTransformer(Auth::user()->account, Input::get('serializer'));
|
|
||||||
$data = $this->createItem($client, $transformer, ENTITY_CLIENT);
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -134,51 +109,15 @@ class ClientApiController extends BaseAPIController
|
|||||||
|
|
||||||
public function update(UpdateClientRequest $request, $publicId)
|
public function update(UpdateClientRequest $request, $publicId)
|
||||||
{
|
{
|
||||||
if ($request->action == ACTION_ARCHIVE) {
|
if ($request->action) {
|
||||||
|
return $this->handleAction($request);
|
||||||
|
|
||||||
$client = Client::scope($publicId)->withTrashed()->first();
|
|
||||||
|
|
||||||
if(!$client)
|
|
||||||
return $this->errorResponse(['message'=>'Record not found'], 400);
|
|
||||||
|
|
||||||
$this->clientRepo->archive($client);
|
|
||||||
|
|
||||||
$transformer = new ClientTransformer(Auth::user()->account, Input::get('serializer'));
|
|
||||||
$data = $this->createItem($client, $transformer, ENTITY_CLIENT);
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
|
||||||
else if ($request->action == ACTION_RESTORE){
|
|
||||||
|
|
||||||
$client = Client::scope($publicId)->withTrashed()->first();
|
|
||||||
|
|
||||||
if(!$client)
|
|
||||||
return $this->errorResponse(['message'=>'Client not found.'], 400);
|
|
||||||
|
|
||||||
$this->clientRepo->restore($client);
|
|
||||||
|
|
||||||
$transformer = new ClientTransformer(Auth::user()->account, Input::get('serializer'));
|
|
||||||
$data = $this->createItem($client, $transformer, ENTITY_CLIENT);
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$data = $request->input();
|
$data = $request->input();
|
||||||
$data['public_id'] = $publicId;
|
$data['public_id'] = $publicId;
|
||||||
$this->clientRepo->save($data);
|
$client = $this->clientRepo->save($data, $request->entity());
|
||||||
|
|
||||||
$client = Client::scope($publicId)
|
return $this->itemResponse($client);
|
||||||
->with('country', 'contacts', 'industry', 'size', 'currency')
|
|
||||||
->first();
|
|
||||||
|
|
||||||
if(!$client)
|
|
||||||
return $this->errorResponse(['message'=>'Client not found.'],400);
|
|
||||||
|
|
||||||
$transformer = new ClientTransformer(Auth::user()->account, Input::get('serializer'));
|
|
||||||
$data = $this->createItem($client, $transformer, ENTITY_CLIENT);
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -204,23 +143,13 @@ class ClientApiController extends BaseAPIController
|
|||||||
* )
|
* )
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public function destroy($publicId)
|
public function destroy(UpdateClientRequest $request)
|
||||||
{
|
{
|
||||||
|
$client = $request->entity();
|
||||||
|
|
||||||
$client = Client::scope($publicId)->withTrashed()->first();
|
|
||||||
$this->clientRepo->delete($client);
|
$this->clientRepo->delete($client);
|
||||||
|
|
||||||
$client = Client::scope($publicId)
|
return $this->itemResponse($client);
|
||||||
->with('country', 'contacts', 'industry', 'size', 'currency')
|
|
||||||
->withTrashed()
|
|
||||||
->first();
|
|
||||||
|
|
||||||
$transformer = new ClientTransformer(Auth::user()->account, Input::get('serializer'));
|
|
||||||
$data = $this->createItem($client, $transformer, ENTITY_CLIENT);
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
@ -28,6 +28,7 @@ use App\Models\Task;
|
|||||||
use App\Ninja\Repositories\ClientRepository;
|
use App\Ninja\Repositories\ClientRepository;
|
||||||
use App\Services\ClientService;
|
use App\Services\ClientService;
|
||||||
|
|
||||||
|
use App\Http\Requests\ClientRequest;
|
||||||
use App\Http\Requests\CreateClientRequest;
|
use App\Http\Requests\CreateClientRequest;
|
||||||
use App\Http\Requests\UpdateClientRequest;
|
use App\Http\Requests\UpdateClientRequest;
|
||||||
|
|
||||||
@ -35,7 +36,7 @@ class ClientController extends BaseController
|
|||||||
{
|
{
|
||||||
protected $clientService;
|
protected $clientService;
|
||||||
protected $clientRepo;
|
protected $clientRepo;
|
||||||
protected $entity = ENTITY_CLIENT;
|
protected $entityType = ENTITY_CLIENT;
|
||||||
|
|
||||||
public function __construct(ClientRepository $clientRepo, ClientService $clientService)
|
public function __construct(ClientRepository $clientRepo, ClientService $clientService)
|
||||||
{
|
{
|
||||||
@ -81,11 +82,7 @@ class ClientController extends BaseController
|
|||||||
*/
|
*/
|
||||||
public function store(CreateClientRequest $request)
|
public function store(CreateClientRequest $request)
|
||||||
{
|
{
|
||||||
$data = $request->input();
|
$client = $this->clientService->save($request->input());
|
||||||
|
|
||||||
$this->authorizeUpdate($data);
|
|
||||||
|
|
||||||
$client = $this->clientService->save($data);
|
|
||||||
|
|
||||||
Session::flash('message', trans('texts.created_client'));
|
Session::flash('message', trans('texts.created_client'));
|
||||||
|
|
||||||
@ -98,11 +95,9 @@ class ClientController extends BaseController
|
|||||||
* @param int $id
|
* @param int $id
|
||||||
* @return Response
|
* @return Response
|
||||||
*/
|
*/
|
||||||
public function show($publicId)
|
public function show(ClientRequest $request)
|
||||||
{
|
{
|
||||||
$client = Client::withTrashed()->scope($publicId)->with('contacts', 'size', 'industry')->firstOrFail();
|
$client = $request->entity();
|
||||||
|
|
||||||
$this->authorize('view', $client);
|
|
||||||
|
|
||||||
$user = Auth::user();
|
$user = Auth::user();
|
||||||
Utils::trackViewed($client->getDisplayName(), ENTITY_CLIENT);
|
Utils::trackViewed($client->getDisplayName(), ENTITY_CLIENT);
|
||||||
@ -152,10 +147,8 @@ class ClientController extends BaseController
|
|||||||
*
|
*
|
||||||
* @return Response
|
* @return Response
|
||||||
*/
|
*/
|
||||||
public function create()
|
public function create(ClientRequest $request)
|
||||||
{
|
{
|
||||||
$this->authorizeCreate();
|
|
||||||
|
|
||||||
if (Client::scope()->withTrashed()->count() > Auth::user()->getMaxNumClients()) {
|
if (Client::scope()->withTrashed()->count() > Auth::user()->getMaxNumClients()) {
|
||||||
return View::make('error', ['hideHeader' => true, 'error' => "Sorry, you've exceeded the limit of ".Auth::user()->getMaxNumClients()." clients"]);
|
return View::make('error', ['hideHeader' => true, 'error' => "Sorry, you've exceeded the limit of ".Auth::user()->getMaxNumClients()." clients"]);
|
||||||
}
|
}
|
||||||
@ -178,16 +171,14 @@ class ClientController extends BaseController
|
|||||||
* @param int $id
|
* @param int $id
|
||||||
* @return Response
|
* @return Response
|
||||||
*/
|
*/
|
||||||
public function edit($publicId)
|
public function edit(ClientRequest $request)
|
||||||
{
|
{
|
||||||
$client = Client::scope($publicId)->with('contacts')->firstOrFail();
|
$client = $request->entity();
|
||||||
|
|
||||||
$this->authorize('edit', $client);
|
|
||||||
|
|
||||||
$data = [
|
$data = [
|
||||||
'client' => $client,
|
'client' => $client,
|
||||||
'method' => 'PUT',
|
'method' => 'PUT',
|
||||||
'url' => 'clients/'.$publicId,
|
'url' => 'clients/'.$client->public_id,
|
||||||
'title' => trans('texts.edit_client'),
|
'title' => trans('texts.edit_client'),
|
||||||
];
|
];
|
||||||
|
|
||||||
@ -226,11 +217,7 @@ class ClientController extends BaseController
|
|||||||
*/
|
*/
|
||||||
public function update(UpdateClientRequest $request)
|
public function update(UpdateClientRequest $request)
|
||||||
{
|
{
|
||||||
$data = $request->input();
|
$client = $this->clientService->save($request->input(), $request->entity());
|
||||||
|
|
||||||
$this->authorizeUpdate($data);
|
|
||||||
|
|
||||||
$client = $this->clientService->save($data);
|
|
||||||
|
|
||||||
Session::flash('message', trans('texts.updated_client'));
|
Session::flash('message', trans('texts.updated_client'));
|
||||||
|
|
||||||
|
@ -12,12 +12,13 @@ use App\Models\Client;
|
|||||||
use App\Services\CreditService;
|
use App\Services\CreditService;
|
||||||
use App\Ninja\Repositories\CreditRepository;
|
use App\Ninja\Repositories\CreditRepository;
|
||||||
use App\Http\Requests\CreateCreditRequest;
|
use App\Http\Requests\CreateCreditRequest;
|
||||||
|
use App\Http\Requests\CreditRequest;
|
||||||
|
|
||||||
class CreditController extends BaseController
|
class CreditController extends BaseController
|
||||||
{
|
{
|
||||||
protected $creditRepo;
|
protected $creditRepo;
|
||||||
protected $creditService;
|
protected $creditService;
|
||||||
protected $entity = ENTITY_CREDIT;
|
protected $entityType = ENTITY_CREDIT;
|
||||||
|
|
||||||
public function __construct(CreditRepository $creditRepo, CreditService $creditService)
|
public function __construct(CreditRepository $creditRepo, CreditService $creditService)
|
||||||
{
|
{
|
||||||
@ -55,23 +56,21 @@ class CreditController extends BaseController
|
|||||||
return $this->creditService->getDatatable($clientPublicId, Input::get('sSearch'));
|
return $this->creditService->getDatatable($clientPublicId, Input::get('sSearch'));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function create($clientPublicId = 0)
|
public function create(CreditRequest $request)
|
||||||
{
|
{
|
||||||
$this->authorizeCreate();
|
|
||||||
|
|
||||||
$data = array(
|
$data = array(
|
||||||
'clientPublicId' => Input::old('client') ? Input::old('client') : $clientPublicId,
|
'clientPublicId' => Input::old('client') ? Input::old('client') : ($request->client_id ?: 0),
|
||||||
//'invoicePublicId' => Input::old('invoice') ? Input::old('invoice') : $invoicePublicId,
|
|
||||||
'credit' => null,
|
'credit' => null,
|
||||||
'method' => 'POST',
|
'method' => 'POST',
|
||||||
'url' => 'credits',
|
'url' => 'credits',
|
||||||
'title' => trans('texts.new_credit'),
|
'title' => trans('texts.new_credit'),
|
||||||
//'invoices' => Invoice::scope()->with('client', 'invoice_status')->orderBy('invoice_number')->get(),
|
'clients' => Client::scope()->with('contacts')->orderBy('name')->get(),
|
||||||
'clients' => Client::scope()->with('contacts')->orderBy('name')->get(), );
|
);
|
||||||
|
|
||||||
return View::make('credits.edit', $data);
|
return View::make('credits.edit', $data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
public function edit($publicId)
|
public function edit($publicId)
|
||||||
{
|
{
|
||||||
$credit = Credit::scope($publicId)->firstOrFail();
|
$credit = Credit::scope($publicId)->firstOrFail();
|
||||||
@ -90,6 +89,7 @@ class CreditController extends BaseController
|
|||||||
|
|
||||||
return View::make('credit.edit', $data);
|
return View::make('credit.edit', $data);
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
public function store(CreateCreditRequest $request)
|
public function store(CreateCreditRequest $request)
|
||||||
{
|
{
|
||||||
|
@ -12,10 +12,13 @@ use Response;
|
|||||||
use App\Models\Document;
|
use App\Models\Document;
|
||||||
use App\Ninja\Repositories\DocumentRepository;
|
use App\Ninja\Repositories\DocumentRepository;
|
||||||
|
|
||||||
|
use App\Http\Requests\DocumentRequest;
|
||||||
|
use App\Http\Requests\CreateDocumentRequest;
|
||||||
|
|
||||||
class DocumentController extends BaseController
|
class DocumentController extends BaseController
|
||||||
{
|
{
|
||||||
protected $documentRepo;
|
protected $documentRepo;
|
||||||
protected $entity = ENTITY_DOCUMENT;
|
protected $entityType = ENTITY_DOCUMENT;
|
||||||
|
|
||||||
public function __construct(DocumentRepository $documentRepo)
|
public function __construct(DocumentRepository $documentRepo)
|
||||||
{
|
{
|
||||||
@ -24,14 +27,9 @@ class DocumentController extends BaseController
|
|||||||
$this->documentRepo = $documentRepo;
|
$this->documentRepo = $documentRepo;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function get($publicId)
|
public function get(DocumentRequest $request)
|
||||||
{
|
{
|
||||||
$document = Document::scope($publicId)
|
return static::getDownloadResponse($request->entity());
|
||||||
->firstOrFail();
|
|
||||||
|
|
||||||
$this->authorize('view', $document);
|
|
||||||
|
|
||||||
return static::getDownloadResponse($document);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function getDownloadResponse($document){
|
public static function getDownloadResponse($document){
|
||||||
@ -60,12 +58,9 @@ class DocumentController extends BaseController
|
|||||||
return $response;
|
return $response;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getPreview($publicId)
|
public function getPreview(DocumentRequest $request)
|
||||||
{
|
{
|
||||||
$document = Document::scope($publicId)
|
$document = $request->entity();
|
||||||
->firstOrFail();
|
|
||||||
|
|
||||||
$this->authorize('view', $document);
|
|
||||||
|
|
||||||
if(empty($document->preview)){
|
if(empty($document->preview)){
|
||||||
return Response::view('error', array('error'=>'Preview does not exist!'), 404);
|
return Response::view('error', array('error'=>'Preview does not exist!'), 404);
|
||||||
@ -83,16 +78,14 @@ class DocumentController extends BaseController
|
|||||||
return $response;
|
return $response;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getVFSJS($publicId, $name){
|
public function getVFSJS(DocumentRequest $request, $publicId, $name)
|
||||||
$document = Document::scope($publicId)
|
{
|
||||||
->firstOrFail();
|
$document = $request->entity();
|
||||||
|
|
||||||
if(substr($name, -3)=='.js'){
|
if(substr($name, -3)=='.js'){
|
||||||
$name = substr($name, 0, -3);
|
$name = substr($name, 0, -3);
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->authorize('view', $document);
|
|
||||||
|
|
||||||
if(!$document->isPDFEmbeddable()){
|
if(!$document->isPDFEmbeddable()){
|
||||||
return Response::view('error', array('error'=>'Image does not exist!'), 404);
|
return Response::view('error', array('error'=>'Image does not exist!'), 404);
|
||||||
}
|
}
|
||||||
@ -106,14 +99,12 @@ class DocumentController extends BaseController
|
|||||||
return $response;
|
return $response;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function postUpload()
|
public function postUpload(CreateDocumentRequest $request)
|
||||||
{
|
{
|
||||||
if (!Utils::hasFeature(FEATURE_DOCUMENTS)) {
|
if (!Utils::hasFeature(FEATURE_DOCUMENTS)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->authorizeCreate();
|
|
||||||
|
|
||||||
$result = $this->documentRepo->upload(Input::all()['file'], $doc_array);
|
$result = $this->documentRepo->upload(Input::all()['file'], $doc_array);
|
||||||
|
|
||||||
if(is_string($result)){
|
if(is_string($result)){
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
<?php namespace App\Http\Controllers;
|
<?php namespace App\Http\Controllers;
|
||||||
// vendor
|
|
||||||
use App\Models\Expense;
|
use App\Models\Expense;
|
||||||
use app\Ninja\Repositories\ExpenseRepository;
|
use app\Ninja\Repositories\ExpenseRepository;
|
||||||
use App\Ninja\Transformers\ExpenseTransformer;
|
use App\Ninja\Transformers\ExpenseTransformer;
|
||||||
@ -16,6 +16,8 @@ class ExpenseApiController extends BaseAPIController
|
|||||||
protected $expenseRepo;
|
protected $expenseRepo;
|
||||||
protected $expenseService;
|
protected $expenseService;
|
||||||
|
|
||||||
|
protected $entityType = ENTITY_EXPENSE;
|
||||||
|
|
||||||
public function __construct(ExpenseRepository $expenseRepo, ExpenseService $expenseService)
|
public function __construct(ExpenseRepository $expenseRepo, ExpenseService $expenseService)
|
||||||
{
|
{
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
@ -26,20 +28,12 @@ class ExpenseApiController extends BaseAPIController
|
|||||||
|
|
||||||
public function index()
|
public function index()
|
||||||
{
|
{
|
||||||
|
|
||||||
$expenses = Expense::scope()
|
$expenses = Expense::scope()
|
||||||
->withTrashed()
|
->withTrashed()
|
||||||
|
->with('client', 'invoice', 'vendor')
|
||||||
->orderBy('created_at','desc');
|
->orderBy('created_at','desc');
|
||||||
|
|
||||||
$expenses = $expenses->paginate();
|
return $this->listResponse($expenses);
|
||||||
|
|
||||||
$transformer = new ExpenseTransformer(Auth::user()->account, Input::get('serializer'));
|
|
||||||
$paginator = Expense::scope()->withTrashed()->paginate();
|
|
||||||
|
|
||||||
$data = $this->createCollection($expenses, $transformer, ENTITY_EXPENSE, $paginator);
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function update()
|
public function update()
|
||||||
|
@ -17,6 +17,8 @@ use App\Models\Expense;
|
|||||||
use App\Models\Client;
|
use App\Models\Client;
|
||||||
use App\Services\ExpenseService;
|
use App\Services\ExpenseService;
|
||||||
use App\Ninja\Repositories\ExpenseRepository;
|
use App\Ninja\Repositories\ExpenseRepository;
|
||||||
|
|
||||||
|
use App\Http\Requests\ExpenseRequest;
|
||||||
use App\Http\Requests\CreateExpenseRequest;
|
use App\Http\Requests\CreateExpenseRequest;
|
||||||
use App\Http\Requests\UpdateExpenseRequest;
|
use App\Http\Requests\UpdateExpenseRequest;
|
||||||
|
|
||||||
@ -25,7 +27,7 @@ class ExpenseController extends BaseController
|
|||||||
// Expenses
|
// Expenses
|
||||||
protected $expenseRepo;
|
protected $expenseRepo;
|
||||||
protected $expenseService;
|
protected $expenseService;
|
||||||
protected $entity = ENTITY_EXPENSE;
|
protected $entityType = ENTITY_EXPENSE;
|
||||||
|
|
||||||
public function __construct(ExpenseRepository $expenseRepo, ExpenseService $expenseService)
|
public function __construct(ExpenseRepository $expenseRepo, ExpenseService $expenseService)
|
||||||
{
|
{
|
||||||
@ -69,25 +71,24 @@ class ExpenseController extends BaseController
|
|||||||
return $this->expenseService->getDatatableVendor($vendorPublicId);
|
return $this->expenseService->getDatatableVendor($vendorPublicId);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function create($vendorPublicId = null, $clientPublicId = null)
|
public function create(ExpenseRequest $request)
|
||||||
{
|
{
|
||||||
$this->authorizeCreate();
|
if ($request->vendor_id != 0) {
|
||||||
|
$vendor = Vendor::scope($request->vendor_id)->with('vendor_contacts')->firstOrFail();
|
||||||
if($vendorPublicId != 0) {
|
|
||||||
$vendor = Vendor::scope($vendorPublicId)->with('vendorcontacts')->firstOrFail();
|
|
||||||
} else {
|
} else {
|
||||||
$vendor = null;
|
$vendor = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
$data = array(
|
$data = array(
|
||||||
'vendorPublicId' => Input::old('vendor') ? Input::old('vendor') : $vendorPublicId,
|
'vendorPublicId' => Input::old('vendor') ? Input::old('vendor') : $request->vendor_id,
|
||||||
'expense' => null,
|
'expense' => null,
|
||||||
'method' => 'POST',
|
'method' => 'POST',
|
||||||
'url' => 'expenses',
|
'url' => 'expenses',
|
||||||
'title' => trans('texts.new_expense'),
|
'title' => trans('texts.new_expense'),
|
||||||
'vendors' => Vendor::scope()->with('vendorcontacts')->orderBy('name')->get(),
|
'vendors' => Vendor::scope()->with('vendor_contacts')->orderBy('name')->get(),
|
||||||
'vendor' => $vendor,
|
'vendor' => $vendor,
|
||||||
'clients' => Client::scope()->with('contacts')->orderBy('name')->get(),
|
'clients' => Client::scope()->with('contacts')->orderBy('name')->get(),
|
||||||
'clientPublicId' => $clientPublicId,
|
'clientPublicId' => $request->client_id,
|
||||||
);
|
);
|
||||||
|
|
||||||
$data = array_merge($data, self::getViewModel());
|
$data = array_merge($data, self::getViewModel());
|
||||||
@ -95,11 +96,9 @@ class ExpenseController extends BaseController
|
|||||||
return View::make('expenses.edit', $data);
|
return View::make('expenses.edit', $data);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function edit($publicId)
|
public function edit(ExpenseRequest $request)
|
||||||
{
|
{
|
||||||
$expense = Expense::scope($publicId)->with('documents')->firstOrFail();
|
$expense = $request->entity();
|
||||||
|
|
||||||
$this->authorize('edit', $expense);
|
|
||||||
|
|
||||||
$expense->expense_date = Utils::fromSqlDate($expense->expense_date);
|
$expense->expense_date = Utils::fromSqlDate($expense->expense_date);
|
||||||
|
|
||||||
@ -108,15 +107,6 @@ class ExpenseController extends BaseController
|
|||||||
$actions[] = ['url' => URL::to("invoices/{$expense->invoice->public_id}/edit"), 'label' => trans("texts.view_invoice")];
|
$actions[] = ['url' => URL::to("invoices/{$expense->invoice->public_id}/edit"), 'label' => trans("texts.view_invoice")];
|
||||||
} else {
|
} else {
|
||||||
$actions[] = ['url' => 'javascript:submitAction("invoice")', 'label' => trans("texts.invoice_expense")];
|
$actions[] = ['url' => 'javascript:submitAction("invoice")', 'label' => trans("texts.invoice_expense")];
|
||||||
|
|
||||||
/*
|
|
||||||
// check for any open invoices
|
|
||||||
$invoices = $task->client_id ? $this->invoiceRepo->findOpenInvoices($task->client_id) : [];
|
|
||||||
|
|
||||||
foreach ($invoices as $invoice) {
|
|
||||||
$actions[] = ['url' => 'javascript:submitAction("add_to_invoice", '.$invoice->public_id.')', 'label' => trans("texts.add_to_invoice", ["invoice" => $invoice->invoice_number])];
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$actions[] = \DropdownButton::DIVIDER;
|
$actions[] = \DropdownButton::DIVIDER;
|
||||||
@ -131,10 +121,10 @@ class ExpenseController extends BaseController
|
|||||||
'vendor' => null,
|
'vendor' => null,
|
||||||
'expense' => $expense,
|
'expense' => $expense,
|
||||||
'method' => 'PUT',
|
'method' => 'PUT',
|
||||||
'url' => 'expenses/'.$publicId,
|
'url' => 'expenses/'.$expense->public_id,
|
||||||
'title' => 'Edit Expense',
|
'title' => 'Edit Expense',
|
||||||
'actions' => $actions,
|
'actions' => $actions,
|
||||||
'vendors' => Vendor::scope()->with('vendorcontacts')->orderBy('name')->get(),
|
'vendors' => Vendor::scope()->with('vendor_contacts')->orderBy('name')->get(),
|
||||||
'vendorPublicId' => $expense->vendor ? $expense->vendor->public_id : null,
|
'vendorPublicId' => $expense->vendor ? $expense->vendor->public_id : null,
|
||||||
'clients' => Client::scope()->with('contacts')->orderBy('name')->get(),
|
'clients' => Client::scope()->with('contacts')->orderBy('name')->get(),
|
||||||
'clientPublicId' => $expense->client ? $expense->client->public_id : null,
|
'clientPublicId' => $expense->client ? $expense->client->public_id : null,
|
||||||
@ -156,9 +146,7 @@ class ExpenseController extends BaseController
|
|||||||
$data = $request->input();
|
$data = $request->input();
|
||||||
$data['documents'] = $request->file('documents');
|
$data['documents'] = $request->file('documents');
|
||||||
|
|
||||||
$this->authorizeUpdate($data);
|
$expense = $this->expenseService->save($data, $request->entity());
|
||||||
|
|
||||||
$expense = $this->expenseService->save($data, true);
|
|
||||||
|
|
||||||
Session::flash('message', trans('texts.updated_expense'));
|
Session::flash('message', trans('texts.updated_expense'));
|
||||||
|
|
||||||
@ -175,8 +163,6 @@ class ExpenseController extends BaseController
|
|||||||
$data = $request->input();
|
$data = $request->input();
|
||||||
$data['documents'] = $request->file('documents');
|
$data['documents'] = $request->file('documents');
|
||||||
|
|
||||||
$this->authorizeUpdate($data);
|
|
||||||
|
|
||||||
$expense = $this->expenseService->save($data);
|
$expense = $this->expenseService->save($data);
|
||||||
|
|
||||||
Session::flash('message', trans('texts.created_expense'));
|
Session::flash('message', trans('texts.created_expense'));
|
||||||
|
@ -164,12 +164,12 @@ class ExportController extends BaseController
|
|||||||
|
|
||||||
if ($request->input(ENTITY_VENDOR)) {
|
if ($request->input(ENTITY_VENDOR)) {
|
||||||
$data['clients'] = Vendor::scope()
|
$data['clients'] = Vendor::scope()
|
||||||
->with('user', 'vendorcontacts', 'country')
|
->with('user', 'vendor_contacts', 'country')
|
||||||
->withArchived()
|
->withArchived()
|
||||||
->get();
|
->get();
|
||||||
|
|
||||||
$data['vendor_contacts'] = VendorContact::scope()
|
$data['vendor_contacts'] = VendorContact::scope()
|
||||||
->with('user', 'vendor.contacts')
|
->with('user', 'vendor.vendor_contacts')
|
||||||
->withTrashed()
|
->withTrashed()
|
||||||
->get();
|
->get();
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Http\Controllers;
|
<?php namespace App\Http\Controllers;
|
||||||
|
|
||||||
use Utils;
|
use Utils;
|
||||||
use View;
|
use View;
|
||||||
|
@ -18,14 +18,17 @@ use App\Ninja\Repositories\InvoiceRepository;
|
|||||||
use App\Ninja\Mailers\ContactMailer as Mailer;
|
use App\Ninja\Mailers\ContactMailer as Mailer;
|
||||||
use App\Http\Controllers\BaseAPIController;
|
use App\Http\Controllers\BaseAPIController;
|
||||||
use App\Ninja\Transformers\InvoiceTransformer;
|
use App\Ninja\Transformers\InvoiceTransformer;
|
||||||
use App\Http\Requests\CreateInvoiceRequest;
|
use App\Http\Requests\InvoiceRequest;
|
||||||
use App\Http\Requests\UpdateInvoiceRequest;
|
use App\Http\Requests\CreateInvoiceAPIRequest;
|
||||||
|
use App\Http\Requests\UpdateInvoiceAPIRequest;
|
||||||
use App\Services\InvoiceService;
|
use App\Services\InvoiceService;
|
||||||
|
|
||||||
class InvoiceApiController extends BaseAPIController
|
class InvoiceApiController extends BaseAPIController
|
||||||
{
|
{
|
||||||
protected $invoiceRepo;
|
protected $invoiceRepo;
|
||||||
|
|
||||||
|
protected $entityType = ENTITY_INVOICE;
|
||||||
|
|
||||||
public function __construct(InvoiceService $invoiceService, InvoiceRepository $invoiceRepo, ClientRepository $clientRepo, PaymentRepository $paymentRepo, Mailer $mailer)
|
public function __construct(InvoiceService $invoiceService, InvoiceRepository $invoiceRepo, ClientRepository $clientRepo, PaymentRepository $paymentRepo, Mailer $mailer)
|
||||||
{
|
{
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
@ -55,36 +58,12 @@ class InvoiceApiController extends BaseAPIController
|
|||||||
*/
|
*/
|
||||||
public function index()
|
public function index()
|
||||||
{
|
{
|
||||||
$paginator = Invoice::scope()->withTrashed();
|
$invoices = Invoice::scope()
|
||||||
$invoices = Invoice::scope()->withTrashed()
|
->withTrashed()
|
||||||
->with(array_merge(['invoice_items'], $this->getIncluded()));
|
->with('invoice_items', 'client')
|
||||||
|
->orderBy('created_at', 'desc');
|
||||||
|
|
||||||
if ($clientPublicId = Input::get('client_id')) {
|
return $this->listResponse($invoices);
|
||||||
$filter = function($query) use ($clientPublicId) {
|
|
||||||
$query->where('public_id', '=', $clientPublicId);
|
|
||||||
};
|
|
||||||
$invoices->whereHas('client', $filter);
|
|
||||||
$paginator->whereHas('client', $filter);
|
|
||||||
}
|
|
||||||
|
|
||||||
$invoices = $invoices->orderBy('created_at', 'desc')->paginate();
|
|
||||||
|
|
||||||
/*
|
|
||||||
// Add the first invitation link to the data
|
|
||||||
foreach ($invoices as $key => $invoice) {
|
|
||||||
foreach ($invoice->invitations as $subKey => $invitation) {
|
|
||||||
$invoices[$key]['link'] = $invitation->getLink();
|
|
||||||
}
|
|
||||||
unset($invoice['invitations']);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
$transformer = new InvoiceTransformer(Auth::user()->account, Input::get('serializer'));
|
|
||||||
$paginator = $paginator->paginate();
|
|
||||||
|
|
||||||
$data = $this->createCollection($invoices, $transformer, 'invoices', $paginator);
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -104,18 +83,9 @@ class InvoiceApiController extends BaseAPIController
|
|||||||
* )
|
* )
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public function show($publicId)
|
public function show(InvoiceRequest $request)
|
||||||
{
|
{
|
||||||
|
return $this->itemResponse($request->entity());
|
||||||
$invoice = Invoice::scope($publicId)->withTrashed()->first();
|
|
||||||
|
|
||||||
if(!$invoice)
|
|
||||||
return $this->errorResponse(['message'=>'Invoice does not exist!'], 404);
|
|
||||||
|
|
||||||
$transformer = new InvoiceTransformer(\Auth::user()->account, Input::get('serializer'));
|
|
||||||
$data = $this->createItem($invoice, $transformer, 'invoice');
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -139,7 +109,7 @@ class InvoiceApiController extends BaseAPIController
|
|||||||
* )
|
* )
|
||||||
* )
|
* )
|
||||||
*/
|
*/
|
||||||
public function store(CreateInvoiceRequest $request)
|
public function store(CreateInvoiceAPIRequest $request)
|
||||||
{
|
{
|
||||||
$data = Input::all();
|
$data = Input::all();
|
||||||
$error = null;
|
$error = null;
|
||||||
@ -210,11 +180,11 @@ class InvoiceApiController extends BaseAPIController
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$invoice = Invoice::scope($invoice->public_id)->with('client', 'invoice_items', 'invitations')->first();
|
$invoice = Invoice::scope($invoice->public_id)
|
||||||
$transformer = new InvoiceTransformer(\Auth::user()->account, Input::get('serializer'));
|
->with('client', 'invoice_items', 'invitations')
|
||||||
$data = $this->createItem($invoice, $transformer, 'invoice');
|
->first();
|
||||||
|
|
||||||
return $this->response($data);
|
return $this->itemResponse($invoice);
|
||||||
}
|
}
|
||||||
|
|
||||||
private function prepareData($data, $client)
|
private function prepareData($data, $client)
|
||||||
@ -304,32 +274,17 @@ class InvoiceApiController extends BaseAPIController
|
|||||||
return $item;
|
return $item;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function emailInvoice()
|
public function emailInvoice(InvoiceRequest $request)
|
||||||
{
|
{
|
||||||
$data = Input::all();
|
$invoice = $request->entity();
|
||||||
$error = null;
|
|
||||||
|
|
||||||
$invoice = Invoice::scope($data['id'])->withTrashed()->first();
|
$this->mailer->sendInvoice($invoice);
|
||||||
|
|
||||||
if(!$invoice)
|
|
||||||
return $this->errorResponse(['message'=>'Invoice does not exist.'], 400);
|
|
||||||
|
|
||||||
|
|
||||||
$this->mailer->sendInvoice($invoice, false, false);
|
|
||||||
|
|
||||||
|
|
||||||
if($error) {
|
|
||||||
return $this->errorResponse(['message'=>'There was an error sending the invoice'], 400);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
$response = json_encode(RESULT_SUCCESS, JSON_PRETTY_PRINT);
|
$response = json_encode(RESULT_SUCCESS, JSON_PRETTY_PRINT);
|
||||||
}
|
|
||||||
|
|
||||||
$headers = Utils::getApiHeaders();
|
$headers = Utils::getApiHeaders();
|
||||||
return Response::make($response, $error ? 400 : 200, $headers);
|
return Response::make($response, 200, $headers);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @SWG\Put(
|
* @SWG\Put(
|
||||||
* path="/invoices",
|
* path="/invoices",
|
||||||
@ -351,45 +306,25 @@ class InvoiceApiController extends BaseAPIController
|
|||||||
* )
|
* )
|
||||||
* )
|
* )
|
||||||
*/
|
*/
|
||||||
public function update(UpdateInvoiceRequest $request, $publicId)
|
public function update(UpdateInvoiceAPIRequest $request, $publicId)
|
||||||
{
|
{
|
||||||
if ($request->action == ACTION_ARCHIVE) {
|
if ($request->action == ACTION_CONVERT) {
|
||||||
$invoice = Invoice::scope($publicId)->firstOrFail();
|
$quote = $request->entity();
|
||||||
$this->invoiceRepo->archive($invoice);
|
|
||||||
|
|
||||||
$transformer = new InvoiceTransformer(\Auth::user()->account, Input::get('serializer'));
|
|
||||||
$data = $this->createItem($invoice, $transformer, 'invoice');
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
|
||||||
else if ($request->action == ACTION_CONVERT) {
|
|
||||||
$quote = Invoice::scope($publicId)->firstOrFail();
|
|
||||||
$invoice = $this->invoiceRepo->cloneInvoice($quote, $quote->id);
|
$invoice = $this->invoiceRepo->cloneInvoice($quote, $quote->id);
|
||||||
|
return $this->itemResponse($invoice);
|
||||||
$transformer = new InvoiceTransformer(\Auth::user()->account, Input::get('serializer'));
|
} elseif ($request->action) {
|
||||||
$data = $this->createItem($invoice, $transformer, 'invoice');
|
return $this->handleAction($request);
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
|
||||||
else if ($request->action == ACTION_RESTORE) {
|
|
||||||
$invoice = Invoice::scope($publicId)->withTrashed()->firstOrFail();
|
|
||||||
$this->invoiceRepo->restore($invoice);
|
|
||||||
|
|
||||||
$transformer = new InvoiceTransformer(\Auth::user()->account, Input::get('serializer'));
|
|
||||||
$data = $this->createItem($invoice, $transformer, 'invoice');
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$data = $request->input();
|
$data = $request->input();
|
||||||
$data['public_id'] = $publicId;
|
$data['public_id'] = $publicId;
|
||||||
$this->invoiceService->save($data);
|
$this->invoiceService->save($data, $request->entity());
|
||||||
|
|
||||||
$invoice = Invoice::scope($publicId)->with('client', 'invoice_items', 'invitations')->firstOrFail();
|
$invoice = Invoice::scope($publicId)
|
||||||
$transformer = new InvoiceTransformer(\Auth::user()->account, Input::get('serializer'));
|
->with('client', 'invoice_items', 'invitations')
|
||||||
$data = $this->createItem($invoice, $transformer, 'invoice');
|
->firstOrFail();
|
||||||
|
|
||||||
return $this->response($data);
|
return $this->itemResponse($invoice);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -414,18 +349,13 @@ class InvoiceApiController extends BaseAPIController
|
|||||||
* )
|
* )
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public function destroy($publicId)
|
public function destroy(UpdateInvoiceAPIRequest $request)
|
||||||
{
|
{
|
||||||
$data['public_id'] = $publicId;
|
$invoice = $request->entity();
|
||||||
$invoice = Invoice::scope($publicId)->firstOrFail();
|
|
||||||
|
|
||||||
$this->invoiceRepo->delete($invoice);
|
$this->invoiceRepo->delete($invoice);
|
||||||
|
|
||||||
$transformer = new InvoiceTransformer(\Auth::user()->account, Input::get('serializer'));
|
return $this->itemResponse($invoice);
|
||||||
$data = $this->createItem($invoice, $transformer, 'invoice');
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -27,7 +27,10 @@ use App\Ninja\Repositories\ClientRepository;
|
|||||||
use App\Ninja\Repositories\DocumentRepository;
|
use App\Ninja\Repositories\DocumentRepository;
|
||||||
use App\Services\InvoiceService;
|
use App\Services\InvoiceService;
|
||||||
use App\Services\RecurringInvoiceService;
|
use App\Services\RecurringInvoiceService;
|
||||||
use App\Http\Requests\SaveInvoiceWithClientRequest;
|
|
||||||
|
use App\Http\Requests\InvoiceRequest;
|
||||||
|
use App\Http\Requests\CreateInvoiceRequest;
|
||||||
|
use App\Http\Requests\UpdateInvoiceRequest;
|
||||||
|
|
||||||
class InvoiceController extends BaseController
|
class InvoiceController extends BaseController
|
||||||
{
|
{
|
||||||
@ -37,7 +40,7 @@ class InvoiceController extends BaseController
|
|||||||
protected $documentRepo;
|
protected $documentRepo;
|
||||||
protected $invoiceService;
|
protected $invoiceService;
|
||||||
protected $recurringInvoiceService;
|
protected $recurringInvoiceService;
|
||||||
protected $entity = ENTITY_INVOICE;
|
protected $entityType = ENTITY_INVOICE;
|
||||||
|
|
||||||
public function __construct(Mailer $mailer, InvoiceRepository $invoiceRepo, ClientRepository $clientRepo, InvoiceService $invoiceService, DocumentRepository $documentRepo, RecurringInvoiceService $recurringInvoiceService)
|
public function __construct(Mailer $mailer, InvoiceRepository $invoiceRepo, ClientRepository $clientRepo, InvoiceService $invoiceService, DocumentRepository $documentRepo, RecurringInvoiceService $recurringInvoiceService)
|
||||||
{
|
{
|
||||||
@ -88,15 +91,10 @@ class InvoiceController extends BaseController
|
|||||||
return $this->recurringInvoiceService->getDatatable($accountId, $clientPublicId, ENTITY_RECURRING_INVOICE, $search);
|
return $this->recurringInvoiceService->getDatatable($accountId, $clientPublicId, ENTITY_RECURRING_INVOICE, $search);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function edit($publicId, $clone = false)
|
public function edit(InvoiceRequest $request, $publicId, $clone = false)
|
||||||
{
|
{
|
||||||
$account = Auth::user()->account;
|
$account = Auth::user()->account;
|
||||||
$invoice = Invoice::scope($publicId)
|
$invoice = $request->entity()->load('invitations', 'account.country', 'client.contacts', 'client.country', 'invoice_items', 'documents', 'expenses', 'expenses.documents', 'payments');
|
||||||
->with('invitations', 'account.country', 'client.contacts', 'client.country', 'invoice_items', 'documents', 'expenses', 'expenses.documents', 'payments')
|
|
||||||
->withTrashed()
|
|
||||||
->firstOrFail();
|
|
||||||
|
|
||||||
$this->authorize('edit', $invoice);
|
|
||||||
|
|
||||||
$entityType = $invoice->getEntityType();
|
$entityType = $invoice->getEntityType();
|
||||||
|
|
||||||
@ -120,7 +118,7 @@ class InvoiceController extends BaseController
|
|||||||
} else {
|
} else {
|
||||||
Utils::trackViewed($invoice->getDisplayName().' - '.$invoice->client->getDisplayName(), $invoice->getEntityType());
|
Utils::trackViewed($invoice->getDisplayName().' - '.$invoice->client->getDisplayName(), $invoice->getEntityType());
|
||||||
$method = 'PUT';
|
$method = 'PUT';
|
||||||
$url = "{$entityType}s/{$publicId}";
|
$url = "{$entityType}s/{$invoice->public_id}";
|
||||||
$clients->whereId($invoice->client_id);
|
$clients->whereId($invoice->client_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -229,28 +227,27 @@ class InvoiceController extends BaseController
|
|||||||
return View::make('invoices.edit', $data);
|
return View::make('invoices.edit', $data);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function create($clientPublicId = 0, $isRecurring = false)
|
public function create(InvoiceRequest $request, $clientPublicId = 0, $isRecurring = false)
|
||||||
{
|
{
|
||||||
$this->authorizeCreate();
|
|
||||||
|
|
||||||
$account = Auth::user()->account;
|
$account = Auth::user()->account;
|
||||||
|
|
||||||
$entityType = $isRecurring ? ENTITY_RECURRING_INVOICE : ENTITY_INVOICE;
|
$entityType = $isRecurring ? ENTITY_RECURRING_INVOICE : ENTITY_INVOICE;
|
||||||
$clientId = null;
|
$clientId = null;
|
||||||
|
|
||||||
if ($clientPublicId) {
|
if ($request->client_id) {
|
||||||
$clientId = Client::getPrivateId($clientPublicId);
|
$clientId = Client::getPrivateId($request->client_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
$invoice = $account->createInvoice($entityType, $clientId);
|
$invoice = $account->createInvoice($entityType, $clientId);
|
||||||
$invoice->public_id = 0;
|
$invoice->public_id = 0;
|
||||||
|
|
||||||
if(Session::get('expenses')){
|
if (Session::get('expenses')) {
|
||||||
$invoice->expenses = Expense::scope(Session::get('expenses'))->with('documents')->get();
|
$invoice->expenses = Expense::scope(Session::get('expenses'))->with('documents')->get();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
$clients = Client::scope()->with('contacts', 'country')->orderBy('name');
|
$clients = Client::scope()->with('contacts', 'country')->orderBy('name');
|
||||||
if(!Auth::user()->hasPermission('view_all')){
|
if (!Auth::user()->hasPermission('view_all')) {
|
||||||
$clients = $clients->where('clients.user_id', '=', Auth::user()->id);
|
$clients = $clients->where('clients.user_id', '=', Auth::user()->id);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -267,9 +264,9 @@ class InvoiceController extends BaseController
|
|||||||
return View::make('invoices.edit', $data);
|
return View::make('invoices.edit', $data);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function createRecurring($clientPublicId = 0)
|
public function createRecurring(InvoiceRequest $request, $clientPublicId = 0)
|
||||||
{
|
{
|
||||||
return self::create($clientPublicId, true);
|
return self::create($request, $clientPublicId, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static function getViewModel($invoice)
|
private static function getViewModel($invoice)
|
||||||
@ -395,17 +392,15 @@ class InvoiceController extends BaseController
|
|||||||
*
|
*
|
||||||
* @return Response
|
* @return Response
|
||||||
*/
|
*/
|
||||||
public function store(SaveInvoiceWithClientRequest $request)
|
public function store(CreateInvoiceRequest $request)
|
||||||
{
|
{
|
||||||
$data = $request->input();
|
$data = $request->input();
|
||||||
$data['documents'] = $request->file('documents');
|
$data['documents'] = $request->file('documents');
|
||||||
|
|
||||||
$this->authorizeUpdate($data);
|
|
||||||
|
|
||||||
$action = Input::get('action');
|
$action = Input::get('action');
|
||||||
$entityType = Input::get('entityType');
|
$entityType = Input::get('entityType');
|
||||||
|
|
||||||
$invoice = $this->invoiceService->save($data, true);
|
$invoice = $this->invoiceService->save($data);
|
||||||
$entityType = $invoice->getEntityType();
|
$entityType = $invoice->getEntityType();
|
||||||
$message = trans("texts.created_{$entityType}");
|
$message = trans("texts.created_{$entityType}");
|
||||||
|
|
||||||
@ -434,25 +429,23 @@ class InvoiceController extends BaseController
|
|||||||
* @param int $id
|
* @param int $id
|
||||||
* @return Response
|
* @return Response
|
||||||
*/
|
*/
|
||||||
public function update(SaveInvoiceWithClientRequest $request)
|
public function update(UpdateInvoiceRequest $request)
|
||||||
{
|
{
|
||||||
$data = $request->input();
|
$data = $request->input();
|
||||||
$data['documents'] = $request->file('documents');
|
$data['documents'] = $request->file('documents');
|
||||||
|
|
||||||
$this->authorizeUpdate($data);
|
|
||||||
|
|
||||||
$action = Input::get('action');
|
$action = Input::get('action');
|
||||||
$entityType = Input::get('entityType');
|
$entityType = Input::get('entityType');
|
||||||
|
|
||||||
$invoice = $this->invoiceService->save($data, true);
|
$invoice = $this->invoiceService->save($data, $request->entity());
|
||||||
$entityType = $invoice->getEntityType();
|
$entityType = $invoice->getEntityType();
|
||||||
$message = trans("texts.updated_{$entityType}");
|
$message = trans("texts.updated_{$entityType}");
|
||||||
Session::flash('message', $message);
|
Session::flash('message', $message);
|
||||||
|
|
||||||
if ($action == 'clone') {
|
if ($action == 'clone') {
|
||||||
return $this->cloneInvoice($invoice->public_id);
|
return $this->cloneInvoice($request, $invoice->public_id);
|
||||||
} elseif ($action == 'convert') {
|
} elseif ($action == 'convert') {
|
||||||
return $this->convertQuote($invoice->public_id);
|
return $this->convertQuote($request, $invoice->public_id);
|
||||||
} elseif ($action == 'email') {
|
} elseif ($action == 'email') {
|
||||||
return $this->emailInvoice($invoice, Input::get('pdfupload'));
|
return $this->emailInvoice($invoice, Input::get('pdfupload'));
|
||||||
}
|
}
|
||||||
@ -521,7 +514,7 @@ class InvoiceController extends BaseController
|
|||||||
{
|
{
|
||||||
Session::reflash();
|
Session::reflash();
|
||||||
|
|
||||||
return Redirect::to("invoices/{$publicId}/edit");
|
return Redirect::to("invoices/$publicId/edit");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -549,23 +542,23 @@ class InvoiceController extends BaseController
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function convertQuote($publicId)
|
public function convertQuote(InvoiceRequest $request)
|
||||||
{
|
{
|
||||||
$invoice = Invoice::with('invoice_items')->scope($publicId)->firstOrFail();
|
$clone = $this->invoiceService->convertQuote($request->entity());
|
||||||
$clone = $this->invoiceService->convertQuote($invoice);
|
|
||||||
|
|
||||||
Session::flash('message', trans('texts.converted_to_invoice'));
|
Session::flash('message', trans('texts.converted_to_invoice'));
|
||||||
return Redirect::to('invoices/'.$clone->public_id);
|
|
||||||
|
return Redirect::to('invoices/' . $clone->public_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function cloneInvoice($publicId)
|
public function cloneInvoice(InvoiceRequest $request, $publicId)
|
||||||
{
|
{
|
||||||
return self::edit($publicId, true);
|
return self::edit($request, $publicId, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function invoiceHistory($publicId)
|
public function invoiceHistory(InvoiceRequest $request)
|
||||||
{
|
{
|
||||||
$invoice = Invoice::withTrashed()->scope($publicId)->firstOrFail();
|
$invoice = $request->entity();
|
||||||
$invoice->load('user', 'invoice_items', 'documents', 'expenses', 'expenses.documents', 'account.country', 'client.contacts', 'client.country');
|
$invoice->load('user', 'invoice_items', 'documents', 'expenses', 'expenses.documents', 'account.country', 'client.contacts', 'client.country');
|
||||||
$invoice->invoice_date = Utils::fromSqlDate($invoice->invoice_date);
|
$invoice->invoice_date = Utils::fromSqlDate($invoice->invoice_date);
|
||||||
$invoice->due_date = Utils::fromSqlDate($invoice->due_date);
|
$invoice->due_date = Utils::fromSqlDate($invoice->due_date);
|
||||||
@ -591,7 +584,7 @@ class InvoiceController extends BaseController
|
|||||||
$backup = json_decode($activity->json_backup);
|
$backup = json_decode($activity->json_backup);
|
||||||
$backup->invoice_date = Utils::fromSqlDate($backup->invoice_date);
|
$backup->invoice_date = Utils::fromSqlDate($backup->invoice_date);
|
||||||
$backup->due_date = Utils::fromSqlDate($backup->due_date);
|
$backup->due_date = Utils::fromSqlDate($backup->due_date);
|
||||||
$invoice->features = [
|
$backup->features = [
|
||||||
'customize_invoice_design' => Auth::user()->hasFeature(FEATURE_CUSTOMIZE_INVOICE_DESIGN),
|
'customize_invoice_design' => Auth::user()->hasFeature(FEATURE_CUSTOMIZE_INVOICE_DESIGN),
|
||||||
'remove_created_by' => Auth::user()->hasFeature(FEATURE_REMOVE_CREATED_BY),
|
'remove_created_by' => Auth::user()->hasFeature(FEATURE_REMOVE_CREATED_BY),
|
||||||
'invoice_settings' => Auth::user()->hasFeature(FEATURE_INVOICE_SETTINGS),
|
'invoice_settings' => Auth::user()->hasFeature(FEATURE_INVOICE_SETTINGS),
|
||||||
|
@ -12,18 +12,21 @@ use App\Ninja\Repositories\PaymentRepository;
|
|||||||
use App\Http\Controllers\BaseAPIController;
|
use App\Http\Controllers\BaseAPIController;
|
||||||
use App\Ninja\Transformers\PaymentTransformer;
|
use App\Ninja\Transformers\PaymentTransformer;
|
||||||
use App\Ninja\Transformers\InvoiceTransformer;
|
use App\Ninja\Transformers\InvoiceTransformer;
|
||||||
|
use App\Http\Requests\UpdatePaymentRequest;
|
||||||
|
use App\Http\Requests\CreatePaymentAPIRequest;
|
||||||
|
|
||||||
class PaymentApiController extends BaseAPIController
|
class PaymentApiController extends BaseAPIController
|
||||||
{
|
{
|
||||||
protected $paymentRepo;
|
protected $paymentRepo;
|
||||||
|
|
||||||
|
protected $entityType = ENTITY_PAYMENT;
|
||||||
|
|
||||||
public function __construct(PaymentRepository $paymentRepo, ContactMailer $contactMailer)
|
public function __construct(PaymentRepository $paymentRepo, ContactMailer $contactMailer)
|
||||||
{
|
{
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
|
|
||||||
$this->paymentRepo = $paymentRepo;
|
$this->paymentRepo = $paymentRepo;
|
||||||
$this->contactMailer = $contactMailer;
|
$this->contactMailer = $contactMailer;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -44,28 +47,14 @@ class PaymentApiController extends BaseAPIController
|
|||||||
*/
|
*/
|
||||||
public function index()
|
public function index()
|
||||||
{
|
{
|
||||||
$paginator = Payment::scope();
|
|
||||||
$payments = Payment::scope()
|
$payments = Payment::scope()
|
||||||
->with('client.contacts', 'invitation', 'user', 'invoice')->withTrashed();
|
->withTrashed()
|
||||||
|
->with(['invoice'])
|
||||||
|
->orderBy('created_at', 'desc');
|
||||||
|
|
||||||
if ($clientPublicId = Input::get('client_id')) {
|
return $this->listResponse($payments);
|
||||||
$filter = function($query) use ($clientPublicId) {
|
|
||||||
$query->where('public_id', '=', $clientPublicId);
|
|
||||||
};
|
|
||||||
$payments->whereHas('client', $filter);
|
|
||||||
$paginator->whereHas('client', $filter);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$payments = $payments->orderBy('created_at', 'desc')->paginate();
|
|
||||||
$paginator = $paginator->paginate();
|
|
||||||
|
|
||||||
$transformer = new PaymentTransformer(Auth::user()->account, Input::get('serializer'));
|
|
||||||
$data = $this->createCollection($payments, $transformer, 'payments', $paginator);
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @SWG\Put(
|
* @SWG\Put(
|
||||||
* path="/payments/{payment_id",
|
* path="/payments/{payment_id",
|
||||||
@ -88,39 +77,17 @@ class PaymentApiController extends BaseAPIController
|
|||||||
* )
|
* )
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public function update(Request $request, $publicId)
|
public function update(UpdatePaymentRequest $request, $publicId)
|
||||||
{
|
{
|
||||||
$data = Input::all();
|
if ($request->action) {
|
||||||
|
return $this->handleAction($request);
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = $request->input();
|
||||||
$data['public_id'] = $publicId;
|
$data['public_id'] = $publicId;
|
||||||
$error = false;
|
$payment = $this->paymentRepo->save($data, $request->entity());
|
||||||
|
|
||||||
if ($request->action == ACTION_ARCHIVE) {
|
|
||||||
$payment = Payment::scope($publicId)->withTrashed()->firstOrFail();
|
|
||||||
$this->paymentRepo->archive($payment);
|
|
||||||
|
|
||||||
$transformer = new PaymentTransformer(\Auth::user()->account, Input::get('serializer'));
|
|
||||||
$data = $this->createItem($payment, $transformer, 'invoice');
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
|
||||||
|
|
||||||
$payment = $this->paymentRepo->save($data);
|
|
||||||
|
|
||||||
if ($error) {
|
|
||||||
return $error;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
$invoice = Invoice::scope($data['invoice_id'])->with('client', 'invoice_items', 'invitations')->with(['payments' => function($query) {
|
|
||||||
$query->withTrashed();
|
|
||||||
}])->withTrashed()->first();
|
|
||||||
*/
|
|
||||||
|
|
||||||
$transformer = new PaymentTransformer(\Auth::user()->account, Input::get('serializer'));
|
|
||||||
$data = $this->createItem($payment, $transformer, 'invoice');
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
|
|
||||||
|
return $this->itemResponse($payment);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -145,49 +112,15 @@ class PaymentApiController extends BaseAPIController
|
|||||||
* )
|
* )
|
||||||
* )
|
* )
|
||||||
*/
|
*/
|
||||||
public function store()
|
public function store(CreatePaymentAPIRequest $request)
|
||||||
{
|
{
|
||||||
$data = Input::all();
|
$payment = $this->paymentRepo->save($request->input());
|
||||||
$error = false;
|
|
||||||
|
|
||||||
if (isset($data['invoice_id'])) {
|
|
||||||
$invoice = Invoice::scope($data['invoice_id'])->with('client')->first();
|
|
||||||
|
|
||||||
if ($invoice) {
|
|
||||||
$data['invoice_id'] = $invoice->id;
|
|
||||||
$data['client_id'] = $invoice->client->id;
|
|
||||||
} else {
|
|
||||||
$error = trans('validation.not_in', ['attribute' => 'invoice_id']);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$error = trans('validation.not_in', ['attribute' => 'invoice_id']);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!isset($data['transaction_reference'])) {
|
|
||||||
$data['transaction_reference'] = '';
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($error) {
|
|
||||||
return $error;
|
|
||||||
}
|
|
||||||
|
|
||||||
$payment = $this->paymentRepo->save($data);
|
|
||||||
|
|
||||||
if (Input::get('email_receipt')) {
|
if (Input::get('email_receipt')) {
|
||||||
$this->contactMailer->sendPaymentConfirmation($payment);
|
$this->contactMailer->sendPaymentConfirmation($payment);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
return $this->itemResponse($payment);
|
||||||
$invoice = Invoice::scope($invoice->public_id)->with('client', 'invoice_items', 'invitations')->with(['payments' => function($query) {
|
|
||||||
$query->withTrashed();
|
|
||||||
}])->first();
|
|
||||||
*/
|
|
||||||
|
|
||||||
$transformer = new PaymentTransformer(\Auth::user()->account, Input::get('serializer'));
|
|
||||||
$data = $this->createItem($payment, $transformer, 'invoice');
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -212,22 +145,13 @@ class PaymentApiController extends BaseAPIController
|
|||||||
* )
|
* )
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public function destroy($publicId)
|
public function destroy(UpdatePaymentRequest $request)
|
||||||
{
|
{
|
||||||
|
$payment = $request->entity();
|
||||||
|
|
||||||
$payment = Payment::scope($publicId)->withTrashed()->first();
|
$this->clientRepo->delete($payment);
|
||||||
$invoiceId = $payment->invoice->public_id;
|
|
||||||
|
|
||||||
$this->paymentRepo->delete($payment);
|
return $this->itemResponse($payment);
|
||||||
|
|
||||||
/*
|
|
||||||
$invoice = Invoice::scope($invoiceId)->with('client', 'invoice_items', 'invitations')->with(['payments' => function($query) {
|
|
||||||
$query->withTrashed();
|
|
||||||
}])->first();
|
|
||||||
*/
|
|
||||||
$transformer = new PaymentTransformer(\Auth::user()->account, Input::get('serializer'));
|
|
||||||
$data = $this->createItem($payment, $transformer, 'invoice');
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -27,12 +27,13 @@ use App\Ninja\Mailers\ContactMailer;
|
|||||||
use App\Ninja\Mailers\UserMailer;
|
use App\Ninja\Mailers\UserMailer;
|
||||||
use App\Services\PaymentService;
|
use App\Services\PaymentService;
|
||||||
|
|
||||||
|
use App\Http\Requests\PaymentRequest;
|
||||||
use App\Http\Requests\CreatePaymentRequest;
|
use App\Http\Requests\CreatePaymentRequest;
|
||||||
use App\Http\Requests\UpdatePaymentRequest;
|
use App\Http\Requests\UpdatePaymentRequest;
|
||||||
|
|
||||||
class PaymentController extends BaseController
|
class PaymentController extends BaseController
|
||||||
{
|
{
|
||||||
protected $entity = ENTITY_PAYMENT;
|
protected $entityType = ENTITY_PAYMENT;
|
||||||
|
|
||||||
public function __construct(PaymentRepository $paymentRepo, InvoiceRepository $invoiceRepo, AccountRepository $accountRepo, ContactMailer $contactMailer, PaymentService $paymentService, UserMailer $userMailer)
|
public function __construct(PaymentRepository $paymentRepo, InvoiceRepository $invoiceRepo, AccountRepository $accountRepo, ContactMailer $contactMailer, PaymentService $paymentService, UserMailer $userMailer)
|
||||||
{
|
{
|
||||||
@ -72,10 +73,8 @@ class PaymentController extends BaseController
|
|||||||
return $this->paymentService->getDatatable($clientPublicId, Input::get('sSearch'));
|
return $this->paymentService->getDatatable($clientPublicId, Input::get('sSearch'));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function create($clientPublicId = 0, $invoicePublicId = 0)
|
public function create(PaymentRequest $request)
|
||||||
{
|
{
|
||||||
$this->authorizeCreate();
|
|
||||||
|
|
||||||
$invoices = Invoice::scope()
|
$invoices = Invoice::scope()
|
||||||
->where('is_recurring', '=', false)
|
->where('is_recurring', '=', false)
|
||||||
->where('is_quote', '=', false)
|
->where('is_quote', '=', false)
|
||||||
@ -84,8 +83,8 @@ class PaymentController extends BaseController
|
|||||||
->orderBy('invoice_number')->get();
|
->orderBy('invoice_number')->get();
|
||||||
|
|
||||||
$data = array(
|
$data = array(
|
||||||
'clientPublicId' => Input::old('client') ? Input::old('client') : $clientPublicId,
|
'clientPublicId' => Input::old('client') ? Input::old('client') : ($request->client_id ?: 0),
|
||||||
'invoicePublicId' => Input::old('invoice') ? Input::old('invoice') : $invoicePublicId,
|
'invoicePublicId' => Input::old('invoice') ? Input::old('invoice') : ($request->invoice_id ?: 0),
|
||||||
'invoice' => null,
|
'invoice' => null,
|
||||||
'invoices' => $invoices,
|
'invoices' => $invoices,
|
||||||
'payment' => null,
|
'payment' => null,
|
||||||
@ -99,11 +98,9 @@ class PaymentController extends BaseController
|
|||||||
return View::make('payments.edit', $data);
|
return View::make('payments.edit', $data);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function edit($publicId)
|
public function edit(PaymentRequest $request)
|
||||||
{
|
{
|
||||||
$payment = Payment::scope($publicId)->firstOrFail();
|
$payment = $request->entity();
|
||||||
|
|
||||||
$this->authorize('edit', $payment);
|
|
||||||
|
|
||||||
$payment->payment_date = Utils::fromSqlDate($payment->payment_date);
|
$payment->payment_date = Utils::fromSqlDate($payment->payment_date);
|
||||||
|
|
||||||
@ -114,7 +111,7 @@ class PaymentController extends BaseController
|
|||||||
->with('client', 'invoice_status')->orderBy('invoice_number')->get(),
|
->with('client', 'invoice_status')->orderBy('invoice_number')->get(),
|
||||||
'payment' => $payment,
|
'payment' => $payment,
|
||||||
'method' => 'PUT',
|
'method' => 'PUT',
|
||||||
'url' => 'payments/'.$publicId,
|
'url' => 'payments/'.$payment->public_id,
|
||||||
'title' => trans('texts.edit_payment'),
|
'title' => trans('texts.edit_payment'),
|
||||||
'paymentTypes' => Cache::get('paymentTypes'),
|
'paymentTypes' => Cache::get('paymentTypes'),
|
||||||
'clients' => Client::scope()->with('contacts')->orderBy('name')->get(), );
|
'clients' => Client::scope()->with('contacts')->orderBy('name')->get(), );
|
||||||
@ -386,9 +383,18 @@ class PaymentController extends BaseController
|
|||||||
$license->save();
|
$license->save();
|
||||||
}
|
}
|
||||||
|
|
||||||
return $productId == PRODUCT_INVOICE_DESIGNS ? file_get_contents(storage_path() . '/invoice_designs.txt') : 'valid';
|
if ($productId == PRODUCT_INVOICE_DESIGNS) {
|
||||||
|
return file_get_contents(storage_path() . '/invoice_designs.txt');
|
||||||
} else {
|
} else {
|
||||||
return 'invalid';
|
// temporary fix to enable previous version to work
|
||||||
|
if (Input::get('get_date')) {
|
||||||
|
return $license->created_at->format('Y-m-d');
|
||||||
|
} else {
|
||||||
|
return 'valid';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return RESULT_FAILURE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -563,6 +569,7 @@ class PaymentController extends BaseController
|
|||||||
if ($account->account_key == NINJA_ACCOUNT_KEY) {
|
if ($account->account_key == NINJA_ACCOUNT_KEY) {
|
||||||
Session::flash('trackEventCategory', '/account');
|
Session::flash('trackEventCategory', '/account');
|
||||||
Session::flash('trackEventAction', '/buy_pro_plan');
|
Session::flash('trackEventAction', '/buy_pro_plan');
|
||||||
|
Session::flash('trackEventAmount', $payment->amount);
|
||||||
}
|
}
|
||||||
|
|
||||||
return Redirect::to('view/'.$payment->invitation->invitation_key);
|
return Redirect::to('view/'.$payment->invitation->invitation_key);
|
||||||
@ -637,7 +644,8 @@ class PaymentController extends BaseController
|
|||||||
$payment = $this->paymentService->createPayment($invitation, $accountGateway, $token, $payerId);
|
$payment = $this->paymentService->createPayment($invitation, $accountGateway, $token, $payerId);
|
||||||
Session::flash('message', trans('texts.applied_payment'));
|
Session::flash('message', trans('texts.applied_payment'));
|
||||||
} else {
|
} else {
|
||||||
Session::flash('error', Input::get('message'));
|
$message = Input::get('message') . ': ' . Input::get('invalid_fields');
|
||||||
|
Session::flash('error', $message);
|
||||||
}
|
}
|
||||||
return Redirect::to($invitation->getLink());
|
return Redirect::to($invitation->getLink());
|
||||||
} elseif (method_exists($gateway, 'completePurchase')
|
} elseif (method_exists($gateway, 'completePurchase')
|
||||||
@ -673,8 +681,6 @@ class PaymentController extends BaseController
|
|||||||
{
|
{
|
||||||
$input = $request->input();
|
$input = $request->input();
|
||||||
|
|
||||||
$this->authorizeUpdate($data);
|
|
||||||
|
|
||||||
$input['invoice_id'] = Invoice::getPrivateId($input['invoice']);
|
$input['invoice_id'] = Invoice::getPrivateId($input['invoice']);
|
||||||
$input['client_id'] = Client::getPrivateId($input['client']);
|
$input['client_id'] = Client::getPrivateId($input['client']);
|
||||||
$payment = $this->paymentRepo->save($input);
|
$payment = $this->paymentRepo->save($input);
|
||||||
@ -691,11 +697,7 @@ class PaymentController extends BaseController
|
|||||||
|
|
||||||
public function update(UpdatePaymentRequest $request)
|
public function update(UpdatePaymentRequest $request)
|
||||||
{
|
{
|
||||||
$input = $request->input();
|
$payment = $this->paymentRepo->save($request->input(), $request->entity());
|
||||||
|
|
||||||
$this->authorizeUpdate($data);
|
|
||||||
|
|
||||||
$payment = $this->paymentRepo->save($input);
|
|
||||||
|
|
||||||
Session::flash('message', trans('texts.updated_payment'));
|
Session::flash('message', trans('texts.updated_payment'));
|
||||||
|
|
||||||
|
@ -1,103 +1,54 @@
|
|||||||
<?php namespace App\Http\Controllers;
|
<?php namespace App\Http\Controllers;
|
||||||
|
|
||||||
use App\Ninja\Repositories\ProductRepository;
|
|
||||||
use App\Ninja\Transformers\ProductTransformer;
|
|
||||||
use Auth;
|
|
||||||
use Str;
|
|
||||||
use DB;
|
|
||||||
use Datatable;
|
|
||||||
use Utils;
|
|
||||||
use URL;
|
|
||||||
use View;
|
|
||||||
use Input;
|
|
||||||
use Session;
|
|
||||||
use Redirect;
|
|
||||||
|
|
||||||
use App\Models\Product;
|
use App\Models\Product;
|
||||||
use App\Models\TaxRate;
|
use App\Ninja\Repositories\ProductRepository;
|
||||||
use App\Services\ProductService;
|
use App\Http\Requests\CreateProductRequest;
|
||||||
|
use App\Http\Requests\UpdateProductRequest;
|
||||||
|
|
||||||
class ProductApiController extends BaseAPIController
|
class ProductApiController extends BaseAPIController
|
||||||
{
|
{
|
||||||
protected $productService;
|
|
||||||
|
|
||||||
protected $productRepo;
|
protected $productRepo;
|
||||||
|
|
||||||
public function __construct(ProductService $productService, ProductRepository $productRepo)
|
protected $entityType = ENTITY_PRODUCT;
|
||||||
|
|
||||||
|
public function __construct(ProductRepository $productRepo)
|
||||||
{
|
{
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
|
|
||||||
$this->productService = $productService;
|
|
||||||
$this->productRepo = $productRepo;
|
$this->productRepo = $productRepo;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function index()
|
public function index()
|
||||||
{
|
{
|
||||||
|
$products = Product::scope()
|
||||||
|
->withTrashed()
|
||||||
|
->orderBy('created_at', 'desc');
|
||||||
|
|
||||||
$products = Product::scope()->withTrashed();
|
return $this->listResponse($products);
|
||||||
$products = $products->paginate();
|
|
||||||
|
|
||||||
$paginator = Product::scope()->withTrashed()->paginate();
|
|
||||||
|
|
||||||
$transformer = new ProductTransformer(\Auth::user()->account, $this->serializer);
|
|
||||||
$data = $this->createCollection($products, $transformer, 'products', $paginator);
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getDatatable()
|
public function store(CreateProductRequest $request)
|
||||||
{
|
{
|
||||||
return $this->productService->getDatatable(Auth::user()->account_id);
|
$product = $this->productRepo->save($request->input());
|
||||||
|
|
||||||
|
return $this->itemResponse($product);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function store()
|
public function update(UpdateProductRequest $request, $publicId)
|
||||||
{
|
{
|
||||||
return $this->save();
|
if ($request->action) {
|
||||||
|
return $this->handleAction($request);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function update(\Illuminate\Http\Request $request, $publicId)
|
$data = $request->input();
|
||||||
{
|
$data['public_id'] = $publicId;
|
||||||
|
$product = $this->productRepo->save($data, $request->entity());
|
||||||
|
|
||||||
if ($request->action == ACTION_ARCHIVE) {
|
return $this->itemResponse($product);
|
||||||
$product = Product::scope($publicId)->withTrashed()->firstOrFail();
|
|
||||||
$this->productRepo->archive($product);
|
|
||||||
|
|
||||||
$transformer = new ProductTransformer(\Auth::user()->account, Input::get('serializer'));
|
|
||||||
$data = $this->createItem($product, $transformer, 'products');
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
return $this->save($publicId);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function destroy($publicId)
|
public function destroy($publicId)
|
||||||
{
|
{
|
||||||
//stub
|
//stub
|
||||||
}
|
}
|
||||||
|
|
||||||
private function save($productPublicId = false)
|
|
||||||
{
|
|
||||||
if ($productPublicId) {
|
|
||||||
$product = Product::scope($productPublicId)->firstOrFail();
|
|
||||||
} else {
|
|
||||||
$product = Product::createNew();
|
|
||||||
}
|
|
||||||
|
|
||||||
$product->product_key = trim(Input::get('product_key'));
|
|
||||||
$product->notes = trim(Input::get('notes'));
|
|
||||||
$product->cost = trim(Input::get('cost'));
|
|
||||||
//$product->default_tax_rate_id = Input::get('default_tax_rate_id');
|
|
||||||
|
|
||||||
$product->save();
|
|
||||||
|
|
||||||
$transformer = new ProductTransformer(\Auth::user()->account, Input::get('serializer'));
|
|
||||||
$data = $this->createItem($product, $transformer, 'products');
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,75 +0,0 @@
|
|||||||
<?php namespace App\Http\Controllers;
|
|
||||||
|
|
||||||
use Auth;
|
|
||||||
use Input;
|
|
||||||
use Utils;
|
|
||||||
use Response;
|
|
||||||
use App\Models\Invoice;
|
|
||||||
use App\Ninja\Repositories\InvoiceRepository;
|
|
||||||
use App\Http\Controllers\BaseAPIController;
|
|
||||||
use App\Ninja\Transformers\InvoiceTransformer;
|
|
||||||
|
|
||||||
class QuoteApiController extends BaseAPIController
|
|
||||||
{
|
|
||||||
protected $invoiceRepo;
|
|
||||||
|
|
||||||
public function __construct(InvoiceRepository $invoiceRepo)
|
|
||||||
{
|
|
||||||
parent::__construct();
|
|
||||||
|
|
||||||
$this->invoiceRepo = $invoiceRepo;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @SWG\Get(
|
|
||||||
* path="/quotes",
|
|
||||||
* tags={"quote"},
|
|
||||||
* summary="List of quotes",
|
|
||||||
* @SWG\Response(
|
|
||||||
* response=200,
|
|
||||||
* description="A list with quotes",
|
|
||||||
* @SWG\Schema(type="array", @SWG\Items(ref="#/definitions/Invoice"))
|
|
||||||
* ),
|
|
||||||
* @SWG\Response(
|
|
||||||
* response="default",
|
|
||||||
* description="an ""unexpected"" error"
|
|
||||||
* )
|
|
||||||
* )
|
|
||||||
*/
|
|
||||||
public function index()
|
|
||||||
{
|
|
||||||
$paginator = Invoice::scope();
|
|
||||||
$invoices = Invoice::scope()
|
|
||||||
->with('client', 'invitations', 'user', 'invoice_items')
|
|
||||||
->where('invoices.is_quote', '=', true);
|
|
||||||
|
|
||||||
if ($clientPublicId = Input::get('client_id')) {
|
|
||||||
$filter = function($query) use ($clientPublicId) {
|
|
||||||
$query->where('public_id', '=', $clientPublicId);
|
|
||||||
};
|
|
||||||
$invoices->whereHas('client', $filter);
|
|
||||||
$paginator->whereHas('client', $filter);
|
|
||||||
}
|
|
||||||
|
|
||||||
$invoices = $invoices->orderBy('created_at', 'desc')->paginate();
|
|
||||||
|
|
||||||
$transformer = new InvoiceTransformer(\Auth::user()->account, Input::get('serializer'));
|
|
||||||
$paginator = $paginator->paginate();
|
|
||||||
|
|
||||||
$data = $this->createCollection($invoices, $transformer, 'quotes', $paginator);
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
public function store()
|
|
||||||
{
|
|
||||||
$data = Input::all();
|
|
||||||
$invoice = $this->invoiceRepo->save(false, $data, false);
|
|
||||||
|
|
||||||
$response = json_encode($invoice, JSON_PRETTY_PRINT);
|
|
||||||
$headers = Utils::getApiHeaders();
|
|
||||||
return Response::make($response, 200, $headers);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
}
|
|
@ -26,6 +26,7 @@ use App\Ninja\Repositories\InvoiceRepository;
|
|||||||
use App\Ninja\Repositories\ClientRepository;
|
use App\Ninja\Repositories\ClientRepository;
|
||||||
use App\Events\QuoteInvitationWasApproved;
|
use App\Events\QuoteInvitationWasApproved;
|
||||||
use App\Services\InvoiceService;
|
use App\Services\InvoiceService;
|
||||||
|
use App\Http\Requests\InvoiceRequest;
|
||||||
|
|
||||||
class QuoteController extends BaseController
|
class QuoteController extends BaseController
|
||||||
{
|
{
|
||||||
@ -33,7 +34,7 @@ class QuoteController extends BaseController
|
|||||||
protected $invoiceRepo;
|
protected $invoiceRepo;
|
||||||
protected $clientRepo;
|
protected $clientRepo;
|
||||||
protected $invoiceService;
|
protected $invoiceService;
|
||||||
protected $entity = ENTITY_INVOICE;
|
protected $entityType = ENTITY_INVOICE;
|
||||||
|
|
||||||
public function __construct(Mailer $mailer, InvoiceRepository $invoiceRepo, ClientRepository $clientRepo, InvoiceService $invoiceService)
|
public function __construct(Mailer $mailer, InvoiceRepository $invoiceRepo, ClientRepository $clientRepo, InvoiceService $invoiceService)
|
||||||
{
|
{
|
||||||
@ -78,10 +79,8 @@ class QuoteController extends BaseController
|
|||||||
return $this->invoiceService->getDatatable($accountId, $clientPublicId, ENTITY_QUOTE, $search);
|
return $this->invoiceService->getDatatable($accountId, $clientPublicId, ENTITY_QUOTE, $search);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function create($clientPublicId = 0)
|
public function create(InvoiceRequest $request, $clientPublicId = 0)
|
||||||
{
|
{
|
||||||
$this->authorizeCreate();
|
|
||||||
|
|
||||||
if (!Utils::hasFeature(FEATURE_QUOTES)) {
|
if (!Utils::hasFeature(FEATURE_QUOTES)) {
|
||||||
return Redirect::to('/invoices/create');
|
return Redirect::to('/invoices/create');
|
||||||
}
|
}
|
||||||
|
@ -13,6 +13,8 @@ class TaskApiController extends BaseAPIController
|
|||||||
{
|
{
|
||||||
protected $taskRepo;
|
protected $taskRepo;
|
||||||
|
|
||||||
|
protected $entityType = ENTITY_TASK;
|
||||||
|
|
||||||
public function __construct(TaskRepository $taskRepo)
|
public function __construct(TaskRepository $taskRepo)
|
||||||
{
|
{
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
@ -38,25 +40,11 @@ class TaskApiController extends BaseAPIController
|
|||||||
*/
|
*/
|
||||||
public function index()
|
public function index()
|
||||||
{
|
{
|
||||||
$paginator = Task::scope();
|
$payments = Task::scope()
|
||||||
$tasks = Task::scope()
|
->withTrashed()
|
||||||
->with($this->getIncluded());
|
->orderBy('created_at', 'desc');
|
||||||
|
|
||||||
if ($clientPublicId = Input::get('client_id')) {
|
return $this->listResponse($payments);
|
||||||
$filter = function($query) use ($clientPublicId) {
|
|
||||||
$query->where('public_id', '=', $clientPublicId);
|
|
||||||
};
|
|
||||||
$tasks->whereHas('client', $filter);
|
|
||||||
$paginator->whereHas('client', $filter);
|
|
||||||
}
|
|
||||||
|
|
||||||
$tasks = $tasks->orderBy('created_at', 'desc')->paginate();
|
|
||||||
$paginator = $paginator->paginate();
|
|
||||||
$transformer = new TaskTransformer(\Auth::user()->account, Input::get('serializer'));
|
|
||||||
|
|
||||||
$data = $this->createCollection($tasks, $transformer, 'tasks', $paginator);
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -18,11 +18,15 @@ use App\Ninja\Repositories\TaskRepository;
|
|||||||
use App\Ninja\Repositories\InvoiceRepository;
|
use App\Ninja\Repositories\InvoiceRepository;
|
||||||
use App\Services\TaskService;
|
use App\Services\TaskService;
|
||||||
|
|
||||||
|
use App\Http\Requests\TaskRequest;
|
||||||
|
use App\Http\Requests\CreateTaskRequest;
|
||||||
|
use App\Http\Requests\UpdateTaskRequest;
|
||||||
|
|
||||||
class TaskController extends BaseController
|
class TaskController extends BaseController
|
||||||
{
|
{
|
||||||
protected $taskRepo;
|
protected $taskRepo;
|
||||||
protected $taskService;
|
protected $taskService;
|
||||||
protected $entity = ENTITY_TASK;
|
protected $entityType = ENTITY_TASK;
|
||||||
|
|
||||||
public function __construct(TaskRepository $taskRepo, InvoiceRepository $invoiceRepo, TaskService $taskService)
|
public function __construct(TaskRepository $taskRepo, InvoiceRepository $invoiceRepo, TaskService $taskService)
|
||||||
{
|
{
|
||||||
@ -66,7 +70,7 @@ class TaskController extends BaseController
|
|||||||
*
|
*
|
||||||
* @return Response
|
* @return Response
|
||||||
*/
|
*/
|
||||||
public function store()
|
public function store(CreateTaskRequest $request)
|
||||||
{
|
{
|
||||||
return $this->save();
|
return $this->save();
|
||||||
}
|
}
|
||||||
@ -83,14 +87,13 @@ class TaskController extends BaseController
|
|||||||
*
|
*
|
||||||
* @return Response
|
* @return Response
|
||||||
*/
|
*/
|
||||||
public function create($clientPublicId = 0)
|
public function create(TaskRequest $request)
|
||||||
{
|
{
|
||||||
$this->authorizeCreate();
|
|
||||||
$this->checkTimezone();
|
$this->checkTimezone();
|
||||||
|
|
||||||
$data = [
|
$data = [
|
||||||
'task' => null,
|
'task' => null,
|
||||||
'clientPublicId' => Input::old('client') ? Input::old('client') : $clientPublicId,
|
'clientPublicId' => Input::old('client') ? Input::old('client') : ($request->client_id ?: 0),
|
||||||
'method' => 'POST',
|
'method' => 'POST',
|
||||||
'url' => 'tasks',
|
'url' => 'tasks',
|
||||||
'title' => trans('texts.new_task'),
|
'title' => trans('texts.new_task'),
|
||||||
@ -109,13 +112,11 @@ class TaskController extends BaseController
|
|||||||
* @param int $id
|
* @param int $id
|
||||||
* @return Response
|
* @return Response
|
||||||
*/
|
*/
|
||||||
public function edit($publicId)
|
public function edit(TaskRequest $request)
|
||||||
{
|
{
|
||||||
$this->checkTimezone();
|
$this->checkTimezone();
|
||||||
|
|
||||||
$task = Task::scope($publicId)->with('client', 'invoice')->withTrashed()->firstOrFail();
|
$task = $request->entity();
|
||||||
|
|
||||||
$this->authorize('edit', $task);
|
|
||||||
|
|
||||||
$actions = [];
|
$actions = [];
|
||||||
if ($task->invoice) {
|
if ($task->invoice) {
|
||||||
@ -143,7 +144,7 @@ class TaskController extends BaseController
|
|||||||
'task' => $task,
|
'task' => $task,
|
||||||
'clientPublicId' => $task->client ? $task->client->public_id : 0,
|
'clientPublicId' => $task->client ? $task->client->public_id : 0,
|
||||||
'method' => 'PUT',
|
'method' => 'PUT',
|
||||||
'url' => 'tasks/'.$publicId,
|
'url' => 'tasks/'.$task->public_id,
|
||||||
'title' => trans('texts.edit_task'),
|
'title' => trans('texts.edit_task'),
|
||||||
'duration' => $task->is_running ? $task->getCurrentDuration() : $task->getDuration(),
|
'duration' => $task->is_running ? $task->getCurrentDuration() : $task->getDuration(),
|
||||||
'actions' => $actions,
|
'actions' => $actions,
|
||||||
@ -163,9 +164,11 @@ class TaskController extends BaseController
|
|||||||
* @param int $id
|
* @param int $id
|
||||||
* @return Response
|
* @return Response
|
||||||
*/
|
*/
|
||||||
public function update($publicId)
|
public function update(UpdateTaskRequest $request)
|
||||||
{
|
{
|
||||||
return $this->save($publicId);
|
$task = $request->entity();
|
||||||
|
|
||||||
|
return $this->save($task->public_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static function getViewModel()
|
private static function getViewModel()
|
||||||
@ -180,20 +183,10 @@ class TaskController extends BaseController
|
|||||||
{
|
{
|
||||||
$action = Input::get('action');
|
$action = Input::get('action');
|
||||||
|
|
||||||
$this->authorizeUpdate(array('public_id'=>$publicId)/* Hacky, but works */);
|
|
||||||
|
|
||||||
if (in_array($action, ['archive', 'delete', 'restore'])) {
|
if (in_array($action, ['archive', 'delete', 'restore'])) {
|
||||||
return self::bulk();
|
return self::bulk();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($validator = $this->taskRepo->getErrors(Input::all())) {
|
|
||||||
$url = $publicId ? 'tasks/'.$publicId.'/edit' : 'tasks/create';
|
|
||||||
Session::flash('error', trans('texts.task_errors'));
|
|
||||||
return Redirect::to($url)
|
|
||||||
->withErrors($validator)
|
|
||||||
->withInput();
|
|
||||||
}
|
|
||||||
|
|
||||||
$task = $this->taskRepo->save($publicId, Input::all());
|
$task = $this->taskRepo->save($publicId, Input::all());
|
||||||
Session::flash('message', trans($publicId ? 'texts.updated_task' : 'texts.created_task'));
|
Session::flash('message', trans($publicId ? 'texts.updated_task' : 'texts.created_task'));
|
||||||
|
|
||||||
|
@ -1,68 +1,54 @@
|
|||||||
<?php namespace App\Http\Controllers;
|
<?php namespace App\Http\Controllers;
|
||||||
|
|
||||||
use App\Services\TaxRateService;
|
|
||||||
use App\Ninja\Repositories\TaxRateRepository;
|
|
||||||
use App\Ninja\Transformers\TaxRateTransformer;
|
|
||||||
use Auth;
|
|
||||||
use App\Models\TaxRate;
|
use App\Models\TaxRate;
|
||||||
|
use App\Ninja\Repositories\TaxRateRepository;
|
||||||
use App\Http\Requests\CreateTaxRateRequest;
|
use App\Http\Requests\CreateTaxRateRequest;
|
||||||
use App\Http\Requests\UpdateTaxRateRequest;
|
use App\Http\Requests\UpdateTaxRateRequest;
|
||||||
|
|
||||||
class TaxRateApiController extends BaseAPIController
|
class TaxRateApiController extends BaseAPIController
|
||||||
{
|
{
|
||||||
protected $taxRateService;
|
|
||||||
protected $taxRateRepo;
|
protected $taxRateRepo;
|
||||||
|
|
||||||
public function __construct(TaxRateService $taxRateService, TaxRateRepository $taxRateRepo)
|
protected $entityType = ENTITY_TAX_RATE;
|
||||||
|
|
||||||
|
public function __construct(TaxRateRepository $taxRateRepo)
|
||||||
{
|
{
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
|
|
||||||
$this->taxRateService = $taxRateService;
|
|
||||||
$this->taxRateRepo = $taxRateRepo;
|
$this->taxRateRepo = $taxRateRepo;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function index()
|
public function index()
|
||||||
{
|
{
|
||||||
$taxRates = TaxRate::scope()->withTrashed();
|
$taxRates = TaxRate::scope()
|
||||||
$taxRates = $taxRates->paginate();
|
->withTrashed()
|
||||||
|
->orderBy('created_at', 'desc');
|
||||||
|
|
||||||
$paginator = TaxRate::scope()->withTrashed()->paginate();
|
return $this->listResponse($taxRates);
|
||||||
|
|
||||||
$transformer = new TaxRateTransformer(Auth::user()->account, $this->serializer);
|
|
||||||
$data = $this->createCollection($taxRates, $transformer, 'tax_rates', $paginator);
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function store(CreateTaxRateRequest $request)
|
public function store(CreateTaxRateRequest $request)
|
||||||
{
|
{
|
||||||
return $this->save($request);
|
$taxRate = $this->taxRateRepo->save($request->input());
|
||||||
|
|
||||||
|
return $this->itemResponse($taxRate);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function update(UpdateTaxRateRequest $request, $taxRatePublicId)
|
public function update(UpdateTaxRateRequest $request, $publicId)
|
||||||
{
|
{
|
||||||
$taxRate = TaxRate::scope($taxRatePublicId)->firstOrFail();
|
if ($request->action) {
|
||||||
|
return $this->handleAction($request);
|
||||||
if ($request->action == ACTION_ARCHIVE) {
|
|
||||||
$this->taxRateRepo->archive($taxRate);
|
|
||||||
|
|
||||||
$transformer = new TaxRateTransformer(Auth::user()->account, $request->serializer);
|
|
||||||
$data = $this->createItem($taxRate, $transformer, 'tax_rates');
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
} else {
|
|
||||||
return $this->save($request, $taxRate);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private function save($request, $taxRate = false)
|
$data = $request->input();
|
||||||
|
$data['public_id'] = $publicId;
|
||||||
|
$taxRate = $this->taxRateRepo->save($data, $request->entity());
|
||||||
|
|
||||||
|
return $this->itemResponse($taxRate);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function destroy($publicId)
|
||||||
{
|
{
|
||||||
$taxRate = $this->taxRateRepo->save($request->input(), $taxRate);
|
//stub
|
||||||
|
|
||||||
$transformer = new TaxRateTransformer(\Auth::user()->account, $request->serializer);
|
|
||||||
$data = $this->createItem($taxRate, $transformer, 'tax_rates');
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -75,9 +75,7 @@ class TaxRateController extends BaseController
|
|||||||
|
|
||||||
public function update(UpdateTaxRateRequest $request, $publicId)
|
public function update(UpdateTaxRateRequest $request, $publicId)
|
||||||
{
|
{
|
||||||
$taxRate = TaxRate::scope($publicId)->firstOrFail();
|
$this->taxRateRepo->save($request->input(), $request->entity());
|
||||||
|
|
||||||
$this->taxRateRepo->save($request->input(), $taxRate);
|
|
||||||
|
|
||||||
Session::flash('message', trans('texts.updated_tax_rate'));
|
Session::flash('message', trans('texts.updated_tax_rate'));
|
||||||
return Redirect::to('settings/' . ACCOUNT_TAX_RATES);
|
return Redirect::to('settings/' . ACCOUNT_TAX_RATES);
|
||||||
|
@ -32,7 +32,7 @@ class TokenController extends BaseController
|
|||||||
|
|
||||||
public function getDatatable()
|
public function getDatatable()
|
||||||
{
|
{
|
||||||
return $this->tokenService->getDatatable(Auth::user()->account_id);
|
return $this->tokenService->getDatatable(Auth::user()->id);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function edit($publicId)
|
public function edit($publicId)
|
||||||
|
@ -14,6 +14,8 @@ class UserApiController extends BaseAPIController
|
|||||||
protected $userService;
|
protected $userService;
|
||||||
protected $userRepo;
|
protected $userRepo;
|
||||||
|
|
||||||
|
protected $entityType = ENTITY_USER;
|
||||||
|
|
||||||
public function __construct(UserService $userService, UserRepository $userRepo)
|
public function __construct(UserService $userService, UserRepository $userRepo)
|
||||||
{
|
{
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
@ -24,16 +26,11 @@ class UserApiController extends BaseAPIController
|
|||||||
|
|
||||||
public function index()
|
public function index()
|
||||||
{
|
{
|
||||||
$user = Auth::user();
|
$users = User::whereAccountId(Auth::user()->account_id)
|
||||||
$users = User::whereAccountId($user->account_id)->withTrashed();
|
->withTrashed()
|
||||||
$users = $users->paginate();
|
->orderBy('created_at', 'desc');
|
||||||
|
|
||||||
$paginator = User::whereAccountId($user->account_id)->withTrashed()->paginate();
|
return $this->listResponse($users);
|
||||||
|
|
||||||
$transformer = new UserTransformer(Auth::user()->account, $this->serializer);
|
|
||||||
$data = $this->createCollection($users, $transformer, 'users', $paginator);
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -45,11 +42,6 @@ class UserApiController extends BaseAPIController
|
|||||||
|
|
||||||
public function update(UpdateUserRequest $request, $userPublicId)
|
public function update(UpdateUserRequest $request, $userPublicId)
|
||||||
{
|
{
|
||||||
/*
|
|
||||||
// temporary fix for ids starting at 0
|
|
||||||
$userPublicId -= 1;
|
|
||||||
$user = User::scope($userPublicId)->firstOrFail();
|
|
||||||
*/
|
|
||||||
$user = Auth::user();
|
$user = Auth::user();
|
||||||
|
|
||||||
if ($request->action == ACTION_ARCHIVE) {
|
if ($request->action == ACTION_ARCHIVE) {
|
||||||
|
@ -14,6 +14,8 @@ class VendorApiController extends BaseAPIController
|
|||||||
{
|
{
|
||||||
protected $vendorRepo;
|
protected $vendorRepo;
|
||||||
|
|
||||||
|
protected $entityType = ENTITY_VENDOR;
|
||||||
|
|
||||||
public function __construct(VendorRepository $vendorRepo)
|
public function __construct(VendorRepository $vendorRepo)
|
||||||
{
|
{
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
@ -47,16 +49,10 @@ class VendorApiController extends BaseAPIController
|
|||||||
public function index()
|
public function index()
|
||||||
{
|
{
|
||||||
$vendors = Vendor::scope()
|
$vendors = Vendor::scope()
|
||||||
->with($this->getIncluded())
|
|
||||||
->withTrashed()
|
->withTrashed()
|
||||||
->orderBy('created_at', 'desc')
|
->orderBy('created_at', 'desc');
|
||||||
->paginate();
|
|
||||||
|
|
||||||
$transformer = new VendorTransformer(Auth::user()->account, Input::get('serializer'));
|
return $this->listResponse($vendors);
|
||||||
$paginator = Vendor::scope()->paginate();
|
|
||||||
$data = $this->createCollection($vendors, $transformer, ENTITY_VENDOR, $paginator);
|
|
||||||
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -85,11 +81,9 @@ class VendorApiController extends BaseAPIController
|
|||||||
$vendor = $this->vendorRepo->save($request->input());
|
$vendor = $this->vendorRepo->save($request->input());
|
||||||
|
|
||||||
$vendor = Vendor::scope($vendor->public_id)
|
$vendor = Vendor::scope($vendor->public_id)
|
||||||
->with('country', 'vendorcontacts', 'industry', 'size', 'currency')
|
->with('country', 'vendor_contacts', 'industry', 'size', 'currency')
|
||||||
->first();
|
->first();
|
||||||
|
|
||||||
$transformer = new VendorTransformer(Auth::user()->account, Input::get('serializer'));
|
return $this->itemResponse($vendor);
|
||||||
$data = $this->createItem($vendor, $transformer, ENTITY_VENDOR);
|
|
||||||
return $this->response($data);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -23,14 +23,15 @@ use App\Models\Country;
|
|||||||
use App\Ninja\Repositories\VendorRepository;
|
use App\Ninja\Repositories\VendorRepository;
|
||||||
use App\Services\VendorService;
|
use App\Services\VendorService;
|
||||||
|
|
||||||
|
use App\Http\Requests\VendorRequest;
|
||||||
use App\Http\Requests\CreateVendorRequest;
|
use App\Http\Requests\CreateVendorRequest;
|
||||||
use App\Http\Requests\UpdateVendorRequest;
|
use App\Http\Requests\UpdateVendorRequest;
|
||||||
// vendor
|
|
||||||
class VendorController extends BaseController
|
class VendorController extends BaseController
|
||||||
{
|
{
|
||||||
protected $vendorService;
|
protected $vendorService;
|
||||||
protected $vendorRepo;
|
protected $vendorRepo;
|
||||||
protected $entity = ENTITY_VENDOR;
|
protected $entityType = ENTITY_VENDOR;
|
||||||
|
|
||||||
public function __construct(VendorRepository $vendorRepo, VendorService $vendorService)
|
public function __construct(VendorRepository $vendorRepo, VendorService $vendorService)
|
||||||
{
|
{
|
||||||
@ -38,8 +39,6 @@ class VendorController extends BaseController
|
|||||||
|
|
||||||
$this->vendorRepo = $vendorRepo;
|
$this->vendorRepo = $vendorRepo;
|
||||||
$this->vendorService = $vendorService;
|
$this->vendorService = $vendorService;
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -77,11 +76,7 @@ class VendorController extends BaseController
|
|||||||
*/
|
*/
|
||||||
public function store(CreateVendorRequest $request)
|
public function store(CreateVendorRequest $request)
|
||||||
{
|
{
|
||||||
$data = $request->input();
|
$vendor = $this->vendorService->save($request->input());
|
||||||
|
|
||||||
$this->authorizeUpdate($data);
|
|
||||||
|
|
||||||
$vendor = $this->vendorService->save($data);
|
|
||||||
|
|
||||||
Session::flash('message', trans('texts.created_vendor'));
|
Session::flash('message', trans('texts.created_vendor'));
|
||||||
|
|
||||||
@ -94,11 +89,9 @@ class VendorController extends BaseController
|
|||||||
* @param int $id
|
* @param int $id
|
||||||
* @return Response
|
* @return Response
|
||||||
*/
|
*/
|
||||||
public function show($publicId)
|
public function show(VendorRequest $request)
|
||||||
{
|
{
|
||||||
$vendor = Vendor::withTrashed()->scope($publicId)->with('vendorcontacts', 'size', 'industry')->firstOrFail();
|
$vendor = $request->entity();
|
||||||
|
|
||||||
$this->authorize('view', $vendor);
|
|
||||||
|
|
||||||
Utils::trackViewed($vendor->getDisplayName(), 'vendor');
|
Utils::trackViewed($vendor->getDisplayName(), 'vendor');
|
||||||
|
|
||||||
@ -125,10 +118,8 @@ class VendorController extends BaseController
|
|||||||
*
|
*
|
||||||
* @return Response
|
* @return Response
|
||||||
*/
|
*/
|
||||||
public function create()
|
public function create(VendorRequest $request)
|
||||||
{
|
{
|
||||||
$this->authorizeCreate();
|
|
||||||
|
|
||||||
if (Vendor::scope()->count() > Auth::user()->getMaxNumVendors()) {
|
if (Vendor::scope()->count() > Auth::user()->getMaxNumVendors()) {
|
||||||
return View::make('error', ['hideHeader' => true, 'error' => "Sorry, you've exceeded the limit of ".Auth::user()->getMaxNumVendors()." vendors"]);
|
return View::make('error', ['hideHeader' => true, 'error' => "Sorry, you've exceeded the limit of ".Auth::user()->getMaxNumVendors()." vendors"]);
|
||||||
}
|
}
|
||||||
@ -151,16 +142,14 @@ class VendorController extends BaseController
|
|||||||
* @param int $id
|
* @param int $id
|
||||||
* @return Response
|
* @return Response
|
||||||
*/
|
*/
|
||||||
public function edit($publicId)
|
public function edit(VendorRequest $request)
|
||||||
{
|
{
|
||||||
$vendor = Vendor::scope($publicId)->with('vendorcontacts')->firstOrFail();
|
$vendor = $request->entity();
|
||||||
|
|
||||||
$this->authorize('edit', $vendor)
|
|
||||||
|
|
||||||
$data = [
|
$data = [
|
||||||
'vendor' => $vendor,
|
'vendor' => $vendor,
|
||||||
'method' => 'PUT',
|
'method' => 'PUT',
|
||||||
'url' => 'vendors/'.$publicId,
|
'url' => 'vendors/'.$vendor->public_id,
|
||||||
'title' => trans('texts.edit_vendor'),
|
'title' => trans('texts.edit_vendor'),
|
||||||
];
|
];
|
||||||
|
|
||||||
@ -193,11 +182,7 @@ class VendorController extends BaseController
|
|||||||
*/
|
*/
|
||||||
public function update(UpdateVendorRequest $request)
|
public function update(UpdateVendorRequest $request)
|
||||||
{
|
{
|
||||||
$data = $request->input();
|
$vendor = $this->vendorService->save($request->input(), $request->entity());
|
||||||
|
|
||||||
$this->authorizeUpdate($data);
|
|
||||||
|
|
||||||
$vendor = $this->vendorService->save($data);
|
|
||||||
|
|
||||||
Session::flash('message', trans('texts.updated_vendor'));
|
Session::flash('message', trans('texts.updated_vendor'));
|
||||||
|
|
||||||
|
@ -34,7 +34,8 @@ class ApiCheck {
|
|||||||
// check for a valid token
|
// check for a valid token
|
||||||
$token = AccountToken::where('token', '=', Request::header('X-Ninja-Token'))->first(['id', 'user_id']);
|
$token = AccountToken::where('token', '=', Request::header('X-Ninja-Token'))->first(['id', 'user_id']);
|
||||||
|
|
||||||
if ($token) {
|
// check if user is archived
|
||||||
|
if ($token && $token->user) {
|
||||||
Auth::loginUsingId($token->user_id);
|
Auth::loginUsingId($token->user_id);
|
||||||
Session::set('token_id', $token->id);
|
Session::set('token_id', $token->id);
|
||||||
} else {
|
} else {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Http\Middleware;
|
<?php namespace App\Http\Middleware;
|
||||||
|
|
||||||
use Closure;
|
use Closure;
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Http\Middleware;
|
<?php namespace App\Http\Middleware;
|
||||||
|
|
||||||
use Request;
|
use Request;
|
||||||
use Closure;
|
use Closure;
|
||||||
@ -124,7 +124,8 @@ class StartupCheck
|
|||||||
$licenseKey = Input::get('license_key');
|
$licenseKey = Input::get('license_key');
|
||||||
$productId = Input::get('product_id');
|
$productId = Input::get('product_id');
|
||||||
|
|
||||||
$data = trim(file_get_contents((Utils::isNinjaDev() ? SITE_URL : NINJA_APP_URL)."/claim_license?license_key={$licenseKey}&product_id={$productId}"));
|
$url = (Utils::isNinjaDev() ? SITE_URL : NINJA_APP_URL) . "/claim_license?license_key={$licenseKey}&product_id={$productId}&get_date=true";
|
||||||
|
$data = trim(file_get_contents($url));
|
||||||
|
|
||||||
if ($productId == PRODUCT_INVOICE_DESIGNS) {
|
if ($productId == PRODUCT_INVOICE_DESIGNS) {
|
||||||
if ($data = json_decode($data)) {
|
if ($data = json_decode($data)) {
|
||||||
@ -140,9 +141,11 @@ class StartupCheck
|
|||||||
Session::flash('message', trans('texts.bought_designs'));
|
Session::flash('message', trans('texts.bought_designs'));
|
||||||
}
|
}
|
||||||
} elseif ($productId == PRODUCT_WHITE_LABEL) {
|
} elseif ($productId == PRODUCT_WHITE_LABEL) {
|
||||||
if ($data == 'valid') {
|
if ($data && $data != RESULT_FAILURE) {
|
||||||
$company = Auth::user()->account->company;
|
$company = Auth::user()->account->company;
|
||||||
$company->plan_paid = date_create()->format('Y-m-d');
|
$company->plan_term = PLAN_TERM_YEARLY;
|
||||||
|
$company->plan_paid = $data;
|
||||||
|
$company->plan_expires = date_create($data)->modify('+1 year')->format('Y-m-d');
|
||||||
$company->plan = PLAN_WHITE_LABEL;
|
$company->plan = PLAN_WHITE_LABEL;
|
||||||
$company->save();
|
$company->save();
|
||||||
|
|
||||||
|
18
app/Http/Requests/ClientRequest.php
Normal file
18
app/Http/Requests/ClientRequest.php
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
|
class ClientRequest extends EntityRequest {
|
||||||
|
|
||||||
|
protected $entityType = ENTITY_CLIENT;
|
||||||
|
|
||||||
|
public function entity()
|
||||||
|
{
|
||||||
|
$client = parent::entity();
|
||||||
|
|
||||||
|
// eager load the contacts
|
||||||
|
if ($client && ! $client->relationLoaded('contacts')) {
|
||||||
|
$client->load('contacts');
|
||||||
|
}
|
||||||
|
|
||||||
|
return $client;
|
||||||
|
}
|
||||||
|
}
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
use App\Http\Requests\Request;
|
use App\Http\Requests\Request;
|
||||||
use Illuminate\Validation\Factory;
|
use Illuminate\Validation\Factory;
|
||||||
|
@ -1,9 +1,6 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
use App\Http\Requests\Request;
|
class CreateClientRequest extends ClientRequest
|
||||||
use Illuminate\Validation\Factory;
|
|
||||||
|
|
||||||
class CreateClientRequest extends Request
|
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Determine if the user is authorized to make this request.
|
* Determine if the user is authorized to make this request.
|
||||||
@ -12,7 +9,7 @@ class CreateClientRequest extends Request
|
|||||||
*/
|
*/
|
||||||
public function authorize()
|
public function authorize()
|
||||||
{
|
{
|
||||||
return true;
|
return $this->user()->can('create', ENTITY_CLIENT);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,9 +1,6 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
use App\Http\Requests\Request;
|
class CreateCreditRequest extends CreditRequest
|
||||||
use Illuminate\Validation\Factory;
|
|
||||||
|
|
||||||
class CreateCreditRequest extends Request
|
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Determine if the user is authorized to make this request.
|
* Determine if the user is authorized to make this request.
|
||||||
@ -12,7 +9,7 @@ class CreateCreditRequest extends Request
|
|||||||
*/
|
*/
|
||||||
public function authorize()
|
public function authorize()
|
||||||
{
|
{
|
||||||
return true;
|
return $this->user()->can('create', ENTITY_CREDIT);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,9 +1,6 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
use App\Http\Requests\Request;
|
class CreateDocumentRequest extends DocumentRequest
|
||||||
use Illuminate\Validation\Factory;
|
|
||||||
|
|
||||||
class UpdateExpenseRequest extends Request
|
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Determine if the user is authorized to make this request.
|
* Determine if the user is authorized to make this request.
|
||||||
@ -12,7 +9,7 @@ class UpdateExpenseRequest extends Request
|
|||||||
*/
|
*/
|
||||||
public function authorize()
|
public function authorize()
|
||||||
{
|
{
|
||||||
return true;
|
return $this->user()->can('create', ENTITY_DOCUMENT);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -23,8 +20,7 @@ class UpdateExpenseRequest extends Request
|
|||||||
public function rules()
|
public function rules()
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
'amount' => 'required|positive',
|
|
||||||
];
|
|
||||||
|
|
||||||
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,9 +1,6 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
use App\Http\Requests\Request;
|
class CreateExpenseRequest extends ExpenseRequest
|
||||||
use Illuminate\Validation\Factory;
|
|
||||||
|
|
||||||
class CreateExpenseRequest extends Request
|
|
||||||
{
|
{
|
||||||
// Expenses
|
// Expenses
|
||||||
/**
|
/**
|
||||||
@ -13,7 +10,7 @@ class CreateExpenseRequest extends Request
|
|||||||
*/
|
*/
|
||||||
public function authorize()
|
public function authorize()
|
||||||
{
|
{
|
||||||
return true;
|
return $this->user()->can('create', ENTITY_EXPENSE);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
32
app/Http/Requests/CreateInvoiceAPIRequest.php
Normal file
32
app/Http/Requests/CreateInvoiceAPIRequest.php
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
|
class CreateInvoiceAPIRequest extends InvoiceRequest
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Determine if the user is authorized to make this request.
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function authorize()
|
||||||
|
{
|
||||||
|
return $this->user()->can('create', ENTITY_INVOICE);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the validation rules that apply to the request.
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function rules()
|
||||||
|
{
|
||||||
|
$rules = [
|
||||||
|
'email' => 'required_without:client_id',
|
||||||
|
'client_id' => 'required_without:email',
|
||||||
|
'invoice_items' => 'valid_invoice_items',
|
||||||
|
'invoice_number' => 'unique:invoices,invoice_number,,id,account_id,' . $this->user()->account_id,
|
||||||
|
'discount' => 'positive',
|
||||||
|
];
|
||||||
|
|
||||||
|
return $rules;
|
||||||
|
}
|
||||||
|
}
|
@ -1,11 +1,6 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
use Auth;
|
class CreateInvoiceRequest extends InvoiceRequest
|
||||||
use App\Http\Requests\Request;
|
|
||||||
use Illuminate\Validation\Factory;
|
|
||||||
use App\Models\Invoice;
|
|
||||||
|
|
||||||
class CreateInvoiceRequest extends Request
|
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Determine if the user is authorized to make this request.
|
* Determine if the user is authorized to make this request.
|
||||||
@ -14,7 +9,7 @@ class CreateInvoiceRequest extends Request
|
|||||||
*/
|
*/
|
||||||
public function authorize()
|
public function authorize()
|
||||||
{
|
{
|
||||||
return true;
|
return $this->user()->can('create', ENTITY_INVOICE);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -25,13 +20,18 @@ class CreateInvoiceRequest extends Request
|
|||||||
public function rules()
|
public function rules()
|
||||||
{
|
{
|
||||||
$rules = [
|
$rules = [
|
||||||
'email' => 'required_without:client_id',
|
'client.contacts' => 'valid_contacts',
|
||||||
'client_id' => 'required_without:email',
|
|
||||||
'invoice_items' => 'valid_invoice_items',
|
'invoice_items' => 'valid_invoice_items',
|
||||||
'invoice_number' => 'unique:invoices,invoice_number,,id,account_id,'.Auth::user()->account_id,
|
'invoice_number' => 'required|unique:invoices,invoice_number,,id,account_id,' . $this->user()->account_id,
|
||||||
'discount' => 'positive',
|
'discount' => 'positive',
|
||||||
];
|
];
|
||||||
|
|
||||||
|
/* There's a problem parsing the dates
|
||||||
|
if (Request::get('is_recurring') && Request::get('start_date') && Request::get('end_date')) {
|
||||||
|
$rules['end_date'] = 'after' . Request::get('start_date');
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
return $rules;
|
return $rules;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
48
app/Http/Requests/CreatePaymentAPIRequest.php
Normal file
48
app/Http/Requests/CreatePaymentAPIRequest.php
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
|
use App\Models\Invoice;
|
||||||
|
|
||||||
|
class CreatePaymentAPIRequest extends PaymentRequest
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Determine if the user is authorized to make this request.
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function authorize()
|
||||||
|
{
|
||||||
|
return $this->user()->can('create', ENTITY_PAYMENT);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the validation rules that apply to the request.
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function rules()
|
||||||
|
{
|
||||||
|
if ( ! $this->invoice_id || ! $this->amount) {
|
||||||
|
return [
|
||||||
|
'invoice_id' => 'required',
|
||||||
|
'amount' => 'required',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
$invoice = Invoice::scope($this->invoice_id)->firstOrFail();
|
||||||
|
|
||||||
|
$this->merge([
|
||||||
|
'invoice_id' => $invoice->id,
|
||||||
|
'client_id' => $invoice->client->id,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$rules = array(
|
||||||
|
'amount' => "required|less_than:{$invoice->balance}|positive",
|
||||||
|
);
|
||||||
|
|
||||||
|
if ($this->payment_type_id == PAYMENT_TYPE_CREDIT) {
|
||||||
|
$rules['payment_type_id'] = 'has_credit:' . $invoice->client->public_id . ',' . $this->amount;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $rules;
|
||||||
|
}
|
||||||
|
}
|
@ -1,10 +1,8 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
use App\Http\Requests\Request;
|
|
||||||
use Illuminate\Validation\Factory;
|
|
||||||
use App\Models\Invoice;
|
use App\Models\Invoice;
|
||||||
|
|
||||||
class CreatePaymentRequest extends Request
|
class CreatePaymentRequest extends PaymentRequest
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Determine if the user is authorized to make this request.
|
* Determine if the user is authorized to make this request.
|
||||||
@ -13,7 +11,7 @@ class CreatePaymentRequest extends Request
|
|||||||
*/
|
*/
|
||||||
public function authorize()
|
public function authorize()
|
||||||
{
|
{
|
||||||
return true;
|
return $this->user()->can('create', ENTITY_PAYMENT);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,9 +1,6 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
use App\Http\Requests\Request;
|
class CreateProductRequest extends ProductRequest
|
||||||
use Illuminate\Validation\Factory;
|
|
||||||
|
|
||||||
class CreatePaymentTermRequest extends Request
|
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Determine if the user is authorized to make this request.
|
* Determine if the user is authorized to make this request.
|
||||||
@ -12,7 +9,7 @@ class CreatePaymentTermRequest extends Request
|
|||||||
*/
|
*/
|
||||||
public function authorize()
|
public function authorize()
|
||||||
{
|
{
|
||||||
return true;
|
return $this->user()->can('create', ENTITY_PRODUCT);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -23,8 +20,7 @@ class CreatePaymentTermRequest extends Request
|
|||||||
public function rules()
|
public function rules()
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
'num_days' => 'required',
|
'product_key' => 'required',
|
||||||
'name' => 'required',
|
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
26
app/Http/Requests/CreateTaskRequest.php
Normal file
26
app/Http/Requests/CreateTaskRequest.php
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
|
class CreateTaskRequest extends TaskRequest
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Determine if the user is authorized to make this request.
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function authorize()
|
||||||
|
{
|
||||||
|
return $this->user()->can('create', ENTITY_TASK);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the validation rules that apply to the request.
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function rules()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'time_log' => 'time_log',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
@ -1,9 +1,9 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
use App\Http\Requests\Request;
|
use App\Http\Requests\Request;
|
||||||
use Illuminate\Validation\Factory;
|
use Illuminate\Validation\Factory;
|
||||||
|
|
||||||
class CreateTaxRateRequest extends Request
|
class CreateTaxRateRequest extends TaxRateRequest
|
||||||
{
|
{
|
||||||
// Expenses
|
// Expenses
|
||||||
/**
|
/**
|
||||||
@ -13,7 +13,7 @@ class CreateTaxRateRequest extends Request
|
|||||||
*/
|
*/
|
||||||
public function authorize()
|
public function authorize()
|
||||||
{
|
{
|
||||||
return true;
|
return $this->user()->can('create', ENTITY_TAX_RATE);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,9 +1,6 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
// vendor
|
|
||||||
use App\Http\Requests\Request;
|
|
||||||
use Illuminate\Validation\Factory;
|
|
||||||
|
|
||||||
class CreateVendorRequest extends Request
|
class CreateVendorRequest extends VendorRequest
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Determine if the user is authorized to make this request.
|
* Determine if the user is authorized to make this request.
|
||||||
@ -12,7 +9,7 @@ class CreateVendorRequest extends Request
|
|||||||
*/
|
*/
|
||||||
public function authorize()
|
public function authorize()
|
||||||
{
|
{
|
||||||
return true;
|
return $this->user()->can('create', ENTITY_VENDOR);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
7
app/Http/Requests/CreditRequest.php
Normal file
7
app/Http/Requests/CreditRequest.php
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
|
class CreditRequest extends EntityRequest {
|
||||||
|
|
||||||
|
protected $entityType = ENTITY_CREDIT;
|
||||||
|
|
||||||
|
}
|
7
app/Http/Requests/DocumentRequest.php
Normal file
7
app/Http/Requests/DocumentRequest.php
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
|
class DocumentRequest extends EntityRequest {
|
||||||
|
|
||||||
|
protected $entityType = ENTITY_DOCUMENT;
|
||||||
|
|
||||||
|
}
|
57
app/Http/Requests/EntityRequest.php
Normal file
57
app/Http/Requests/EntityRequest.php
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
|
use App\Http\Requests\Request;
|
||||||
|
use Input;
|
||||||
|
use Utils;
|
||||||
|
|
||||||
|
class EntityRequest extends Request {
|
||||||
|
|
||||||
|
protected $entityType;
|
||||||
|
private $entity;
|
||||||
|
|
||||||
|
public function entity()
|
||||||
|
{
|
||||||
|
if ($this->entity) {
|
||||||
|
return $this->entity;
|
||||||
|
}
|
||||||
|
|
||||||
|
// The entity id can appear as invoices, invoice_id, public_id or id
|
||||||
|
$publicId = false;
|
||||||
|
foreach (['_id', 's'] as $suffix) {
|
||||||
|
$field = $this->entityType . $suffix;
|
||||||
|
if ($this->$field) {
|
||||||
|
$publicId= $this->$field;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ( ! $publicId) {
|
||||||
|
$publicId = Input::get('public_id') ?: Input::get('id');
|
||||||
|
}
|
||||||
|
if ( ! $publicId) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
$class = Utils::getEntityClass($this->entityType);
|
||||||
|
|
||||||
|
if (method_exists($class, 'withTrashed')) {
|
||||||
|
$this->entity = $class::scope($publicId)->withTrashed()->firstOrFail();
|
||||||
|
} else {
|
||||||
|
$this->entity = $class::scope($publicId)->firstOrFail();
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->entity;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function authorize()
|
||||||
|
{
|
||||||
|
if ($this->entity()) {
|
||||||
|
return $this->user()->can('view', $this->entity());
|
||||||
|
} else {
|
||||||
|
return $this->user()->can('create', $this->entityType);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function rules()
|
||||||
|
{
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
}
|
18
app/Http/Requests/ExpenseRequest.php
Normal file
18
app/Http/Requests/ExpenseRequest.php
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
|
class ExpenseRequest extends EntityRequest {
|
||||||
|
|
||||||
|
protected $entityType = ENTITY_EXPENSE;
|
||||||
|
|
||||||
|
public function entity()
|
||||||
|
{
|
||||||
|
$expense = parent::entity();
|
||||||
|
|
||||||
|
// eager load the documents
|
||||||
|
if ($expense && ! $expense->relationLoaded('documents')) {
|
||||||
|
$expense->load('documents');
|
||||||
|
}
|
||||||
|
|
||||||
|
return $expense;
|
||||||
|
}
|
||||||
|
}
|
19
app/Http/Requests/InvoiceRequest.php
Normal file
19
app/Http/Requests/InvoiceRequest.php
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
|
class InvoiceRequest extends EntityRequest {
|
||||||
|
|
||||||
|
protected $entityType = ENTITY_INVOICE;
|
||||||
|
|
||||||
|
public function entity()
|
||||||
|
{
|
||||||
|
$invoice = parent::entity();
|
||||||
|
|
||||||
|
// eager load the invoice items
|
||||||
|
if ($invoice && ! $invoice->relationLoaded('invoice_items')) {
|
||||||
|
$invoice->load('invoice_items');
|
||||||
|
}
|
||||||
|
|
||||||
|
return $invoice;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
7
app/Http/Requests/PaymentRequest.php
Normal file
7
app/Http/Requests/PaymentRequest.php
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
|
class PaymentRequest extends EntityRequest {
|
||||||
|
|
||||||
|
protected $entityType = ENTITY_PAYMENT;
|
||||||
|
|
||||||
|
}
|
6
app/Http/Requests/ProductRequest.php
Normal file
6
app/Http/Requests/ProductRequest.php
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
|
class ProductRequest extends EntityRequest {
|
||||||
|
|
||||||
|
protected $entityType = ENTITY_PRODUCT;
|
||||||
|
}
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
use Auth;
|
use Auth;
|
||||||
use App\Http\Requests\Request;
|
use App\Http\Requests\Request;
|
||||||
|
@ -1,45 +0,0 @@
|
|||||||
<?php namespace app\Http\Requests;
|
|
||||||
|
|
||||||
use Auth;
|
|
||||||
use App\Http\Requests\Request;
|
|
||||||
use Illuminate\Validation\Factory;
|
|
||||||
use App\Models\Invoice;
|
|
||||||
|
|
||||||
class SaveInvoiceWithClientRequest extends Request
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Determine if the user is authorized to make this request.
|
|
||||||
*
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
public function authorize()
|
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the validation rules that apply to the request.
|
|
||||||
*
|
|
||||||
* @return array
|
|
||||||
*/
|
|
||||||
public function rules()
|
|
||||||
{
|
|
||||||
$publicId = Request::get('public_id');
|
|
||||||
$invoiceId = $publicId ? Invoice::getPrivateId($publicId) : '';
|
|
||||||
|
|
||||||
$rules = [
|
|
||||||
'client.contacts' => 'valid_contacts',
|
|
||||||
'invoice_items' => 'valid_invoice_items',
|
|
||||||
'invoice_number' => 'required|unique:invoices,invoice_number,'.$invoiceId.',id,account_id,'.Auth::user()->account_id,
|
|
||||||
'discount' => 'positive',
|
|
||||||
];
|
|
||||||
|
|
||||||
/* There's a problem parsing the dates
|
|
||||||
if (Request::get('is_recurring') && Request::get('start_date') && Request::get('end_date')) {
|
|
||||||
$rules['end_date'] = 'after' . Request::get('start_date');
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
return $rules;
|
|
||||||
}
|
|
||||||
}
|
|
7
app/Http/Requests/TaskRequest.php
Normal file
7
app/Http/Requests/TaskRequest.php
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
|
class TaskRequest extends EntityRequest {
|
||||||
|
|
||||||
|
protected $entityType = ENTITY_TASK;
|
||||||
|
|
||||||
|
}
|
7
app/Http/Requests/TaxRateRequest.php
Normal file
7
app/Http/Requests/TaxRateRequest.php
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
|
class TaxRateRequest extends EntityRequest {
|
||||||
|
|
||||||
|
protected $entityType = ENTITY_TAX_RATE;
|
||||||
|
|
||||||
|
}
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
use App\Http\Requests\Request;
|
use App\Http\Requests\Request;
|
||||||
use Illuminate\Validation\Factory;
|
use Illuminate\Validation\Factory;
|
||||||
|
@ -1,9 +1,6 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
use App\Http\Requests\Request;
|
class UpdateClientRequest extends ClientRequest
|
||||||
use Illuminate\Validation\Factory;
|
|
||||||
|
|
||||||
class UpdateClientRequest extends Request
|
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Determine if the user is authorized to make this request.
|
* Determine if the user is authorized to make this request.
|
||||||
@ -12,7 +9,7 @@ class UpdateClientRequest extends Request
|
|||||||
*/
|
*/
|
||||||
public function authorize()
|
public function authorize()
|
||||||
{
|
{
|
||||||
return true;
|
return $this->user()->can('edit', $this->entity());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,10 +1,6 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
use App\Http\Requests\Request;
|
class UpdateExpenseRequest extends ExpenseRequest
|
||||||
use Illuminate\Validation\Factory;
|
|
||||||
|
|
||||||
|
|
||||||
class UpdateExpenseRequest extends Request
|
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Determine if the user is authorized to make this request.
|
* Determine if the user is authorized to make this request.
|
||||||
@ -13,7 +9,7 @@ class UpdateExpenseRequest extends Request
|
|||||||
*/
|
*/
|
||||||
public function authorize()
|
public function authorize()
|
||||||
{
|
{
|
||||||
return true;
|
return $this->user()->can('edit', $this->entity());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
36
app/Http/Requests/UpdateInvoiceAPIRequest.php
Normal file
36
app/Http/Requests/UpdateInvoiceAPIRequest.php
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
|
class UpdateInvoiceAPIRequest extends InvoiceRequest
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Determine if the user is authorized to make this request.
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function authorize()
|
||||||
|
{
|
||||||
|
return $this->user()->can('edit', $this->entity());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the validation rules that apply to the request.
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function rules()
|
||||||
|
{
|
||||||
|
if ($this->action == ACTION_ARCHIVE) {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
|
||||||
|
$invoiceId = $this->entity()->id;
|
||||||
|
|
||||||
|
$rules = [
|
||||||
|
'invoice_items' => 'valid_invoice_items',
|
||||||
|
'invoice_number' => 'unique:invoices,invoice_number,' . $invoiceId . ',id,account_id,' . $this->user()->account_id,
|
||||||
|
'discount' => 'positive',
|
||||||
|
];
|
||||||
|
|
||||||
|
return $rules;
|
||||||
|
}
|
||||||
|
}
|
@ -1,11 +1,6 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
use Auth;
|
class UpdateInvoiceRequest extends InvoiceRequest
|
||||||
use App\Http\Requests\Request;
|
|
||||||
use Illuminate\Validation\Factory;
|
|
||||||
use App\Models\Invoice;
|
|
||||||
|
|
||||||
class UpdateInvoiceRequest extends Request
|
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Determine if the user is authorized to make this request.
|
* Determine if the user is authorized to make this request.
|
||||||
@ -14,7 +9,7 @@ class UpdateInvoiceRequest extends Request
|
|||||||
*/
|
*/
|
||||||
public function authorize()
|
public function authorize()
|
||||||
{
|
{
|
||||||
return true;
|
return $this->user()->can('edit', $this->entity());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -24,19 +19,21 @@ class UpdateInvoiceRequest extends Request
|
|||||||
*/
|
*/
|
||||||
public function rules()
|
public function rules()
|
||||||
{
|
{
|
||||||
if ($this->action == ACTION_ARCHIVE) {
|
$invoiceId = $this->entity()->id;
|
||||||
return [];
|
|
||||||
}
|
|
||||||
|
|
||||||
$publicId = $this->route('invoices');
|
|
||||||
$invoiceId = Invoice::getPrivateId($publicId);
|
|
||||||
|
|
||||||
$rules = [
|
$rules = [
|
||||||
|
'client.contacts' => 'valid_contacts',
|
||||||
'invoice_items' => 'valid_invoice_items',
|
'invoice_items' => 'valid_invoice_items',
|
||||||
'invoice_number' => 'unique:invoices,invoice_number,'.$invoiceId.',id,account_id,'.Auth::user()->account_id,
|
'invoice_number' => 'required|unique:invoices,invoice_number,' . $invoiceId . ',id,account_id,' . $this->user()->account_id,
|
||||||
'discount' => 'positive',
|
'discount' => 'positive',
|
||||||
];
|
];
|
||||||
|
|
||||||
|
/* There's a problem parsing the dates
|
||||||
|
if (Request::get('is_recurring') && Request::get('start_date') && Request::get('end_date')) {
|
||||||
|
$rules['end_date'] = 'after' . Request::get('start_date');
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
return $rules;
|
return $rules;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,9 +1,6 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
use App\Http\Requests\Request;
|
class UpdatePaymentRequest extends PaymentRequest
|
||||||
use Illuminate\Validation\Factory;
|
|
||||||
|
|
||||||
class UpdatePaymentRequest extends Request
|
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Determine if the user is authorized to make this request.
|
* Determine if the user is authorized to make this request.
|
||||||
@ -12,7 +9,7 @@ class UpdatePaymentRequest extends Request
|
|||||||
*/
|
*/
|
||||||
public function authorize()
|
public function authorize()
|
||||||
{
|
{
|
||||||
return true;
|
return $this->user()->can('edit', $this->entity());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
26
app/Http/Requests/UpdateProductRequest.php
Normal file
26
app/Http/Requests/UpdateProductRequest.php
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
|
class UpdateProductRequest extends ProductRequest
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Determine if the user is authorized to make this request.
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function authorize()
|
||||||
|
{
|
||||||
|
return $this->user()->can('edit', $this->entity());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the validation rules that apply to the request.
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function rules()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'product_key' => 'required',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
26
app/Http/Requests/UpdateTaskRequest.php
Normal file
26
app/Http/Requests/UpdateTaskRequest.php
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
|
class UpdateTaskRequest extends TaskRequest
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Determine if the user is authorized to make this request.
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function authorize()
|
||||||
|
{
|
||||||
|
return $this->user()->can('edit', $this->entity());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the validation rules that apply to the request.
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function rules()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'time_log' => 'time_log',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
@ -1,9 +1,9 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
use App\Http\Requests\Request;
|
use App\Http\Requests\Request;
|
||||||
use Illuminate\Validation\Factory;
|
use Illuminate\Validation\Factory;
|
||||||
|
|
||||||
class UpdateTaxRateRequest extends Request
|
class UpdateTaxRateRequest extends TaxRateRequest
|
||||||
{
|
{
|
||||||
// Expenses
|
// Expenses
|
||||||
/**
|
/**
|
||||||
@ -13,7 +13,7 @@ class UpdateTaxRateRequest extends Request
|
|||||||
*/
|
*/
|
||||||
public function authorize()
|
public function authorize()
|
||||||
{
|
{
|
||||||
return true;
|
return $this->user()->can('edit', $this->entity());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
use Auth;
|
use Auth;
|
||||||
use App\Http\Requests\Request;
|
use App\Http\Requests\Request;
|
||||||
@ -14,7 +14,7 @@ class UpdateUserRequest extends Request
|
|||||||
*/
|
*/
|
||||||
public function authorize()
|
public function authorize()
|
||||||
{
|
{
|
||||||
return true;
|
return $this->user()->can('edit', $this->entity());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,9 +1,6 @@
|
|||||||
<?php namespace app\Http\Requests;
|
<?php namespace App\Http\Requests;
|
||||||
// vendor
|
|
||||||
use App\Http\Requests\Request;
|
|
||||||
use Illuminate\Validation\Factory;
|
|
||||||
|
|
||||||
class UpdateVendorRequest extends Request
|
class UpdateVendorRequest extends VendorRequest
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Determine if the user is authorized to make this request.
|
* Determine if the user is authorized to make this request.
|
||||||
@ -12,7 +9,7 @@ class UpdateVendorRequest extends Request
|
|||||||
*/
|
*/
|
||||||
public function authorize()
|
public function authorize()
|
||||||
{
|
{
|
||||||
return true;
|
return $this->user()->can('edit', $this->entity());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
19
app/Http/Requests/VendorRequest.php
Normal file
19
app/Http/Requests/VendorRequest.php
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
<?php namespace App\Http\Requests;
|
||||||
|
|
||||||
|
class VendorRequest extends EntityRequest {
|
||||||
|
|
||||||
|
protected $entityType = ENTITY_VENDOR;
|
||||||
|
|
||||||
|
public function entity()
|
||||||
|
{
|
||||||
|
$vendor = parent::entity();
|
||||||
|
|
||||||
|
// eager load the contacts
|
||||||
|
if ($vendor && ! $vendor->relationLoaded('vendor_contacts')) {
|
||||||
|
$vendor->load('vendor_contacts');
|
||||||
|
}
|
||||||
|
|
||||||
|
return $vendor;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -56,8 +56,8 @@ Route::group(['middleware' => 'auth:client'], function() {
|
|||||||
Route::get('client/documents', 'PublicClientController@documentIndex');
|
Route::get('client/documents', 'PublicClientController@documentIndex');
|
||||||
Route::get('client/payments', 'PublicClientController@paymentIndex');
|
Route::get('client/payments', 'PublicClientController@paymentIndex');
|
||||||
Route::get('client/dashboard', 'PublicClientController@dashboard');
|
Route::get('client/dashboard', 'PublicClientController@dashboard');
|
||||||
Route::get('client/document/js/{public_id}/{filename}', 'PublicClientController@getDocumentVFSJS');
|
Route::get('client/documents/js/{documents}/{filename}', 'PublicClientController@getDocumentVFSJS');
|
||||||
Route::get('client/document/{invitation_key}/{public_id}/{filename?}', 'PublicClientController@getDocument');
|
Route::get('client/documents/{invitation_key}/{documents}/{filename?}', 'PublicClientController@getDocument');
|
||||||
Route::get('client/documents/{invitation_key}/{filename?}', 'PublicClientController@getInvoiceDocumentsZip');
|
Route::get('client/documents/{invitation_key}/{filename?}', 'PublicClientController@getInvoiceDocumentsZip');
|
||||||
|
|
||||||
Route::get('api/client.quotes', array('as'=>'api.client.quotes', 'uses'=>'PublicClientController@quoteDatatable'));
|
Route::get('api/client.quotes', array('as'=>'api.client.quotes', 'uses'=>'PublicClientController@quoteDatatable'));
|
||||||
@ -121,9 +121,11 @@ Route::group(['middleware' => 'auth:user'], function() {
|
|||||||
Route::get('view_archive/{entity_type}/{visible}', 'AccountController@setTrashVisible');
|
Route::get('view_archive/{entity_type}/{visible}', 'AccountController@setTrashVisible');
|
||||||
Route::get('hide_message', 'HomeController@hideMessage');
|
Route::get('hide_message', 'HomeController@hideMessage');
|
||||||
Route::get('force_inline_pdf', 'UserController@forcePDFJS');
|
Route::get('force_inline_pdf', 'UserController@forcePDFJS');
|
||||||
|
Route::get('account/getSearchData', array('as' => 'getSearchData', 'uses' => 'AccountController@getSearchData'));
|
||||||
|
|
||||||
Route::get('settings/user_details', 'AccountController@showUserDetails');
|
Route::get('settings/user_details', 'AccountController@showUserDetails');
|
||||||
Route::post('settings/user_details', 'AccountController@saveUserDetails');
|
Route::post('settings/user_details', 'AccountController@saveUserDetails');
|
||||||
|
Route::post('users/change_password', 'UserController@changePassword');
|
||||||
|
|
||||||
Route::resource('clients', 'ClientController');
|
Route::resource('clients', 'ClientController');
|
||||||
Route::get('api/clients', array('as'=>'api.clients', 'uses'=>'ClientController@getDatatable'));
|
Route::get('api/clients', array('as'=>'api.clients', 'uses'=>'ClientController@getDatatable'));
|
||||||
@ -145,20 +147,20 @@ Route::group(['middleware' => 'auth:user'], function() {
|
|||||||
Route::get('invoices/create/{client_id?}', 'InvoiceController@create');
|
Route::get('invoices/create/{client_id?}', 'InvoiceController@create');
|
||||||
Route::get('recurring_invoices/create/{client_id?}', 'InvoiceController@createRecurring');
|
Route::get('recurring_invoices/create/{client_id?}', 'InvoiceController@createRecurring');
|
||||||
Route::get('recurring_invoices', 'RecurringInvoiceController@index');
|
Route::get('recurring_invoices', 'RecurringInvoiceController@index');
|
||||||
Route::get('invoices/{public_id}/clone', 'InvoiceController@cloneInvoice');
|
Route::get('invoices/{invoices}/clone', 'InvoiceController@cloneInvoice');
|
||||||
Route::post('invoices/bulk', 'InvoiceController@bulk');
|
Route::post('invoices/bulk', 'InvoiceController@bulk');
|
||||||
Route::post('recurring_invoices/bulk', 'InvoiceController@bulk');
|
Route::post('recurring_invoices/bulk', 'InvoiceController@bulk');
|
||||||
|
|
||||||
Route::get('document/{public_id}/{filename?}', 'DocumentController@get');
|
Route::get('documents/{documents}/{filename?}', 'DocumentController@get');
|
||||||
Route::get('document/js/{public_id}/{filename}', 'DocumentController@getVFSJS');
|
Route::get('documents/js/{documents}/{filename}', 'DocumentController@getVFSJS');
|
||||||
Route::get('document/preview/{public_id}/{filename?}', 'DocumentController@getPreview');
|
Route::get('documents/preview/{documents}/{filename?}', 'DocumentController@getPreview');
|
||||||
Route::post('document', 'DocumentController@postUpload');
|
Route::post('document', 'DocumentController@postUpload');
|
||||||
|
|
||||||
Route::get('quotes/create/{client_id?}', 'QuoteController@create');
|
Route::get('quotes/create/{client_id?}', 'QuoteController@create');
|
||||||
Route::get('quotes/{public_id}/clone', 'InvoiceController@cloneInvoice');
|
Route::get('quotes/{invoices}/clone', 'InvoiceController@cloneInvoice');
|
||||||
Route::get('quotes/{public_id}/edit', 'InvoiceController@edit');
|
Route::get('quotes/{invoices}/edit', 'InvoiceController@edit');
|
||||||
Route::put('quotes/{public_id}', 'InvoiceController@update');
|
Route::put('quotes/{invoices}', 'InvoiceController@update');
|
||||||
Route::get('quotes/{public_id}', 'InvoiceController@edit');
|
Route::get('quotes/{invoices}', 'InvoiceController@edit');
|
||||||
Route::post('quotes', 'InvoiceController@store');
|
Route::post('quotes', 'InvoiceController@store');
|
||||||
Route::get('quotes', 'QuoteController@index');
|
Route::get('quotes', 'QuoteController@index');
|
||||||
Route::get('api/quotes/{client_id?}', array('as'=>'api.quotes', 'uses'=>'QuoteController@getDatatable'));
|
Route::get('api/quotes/{client_id?}', array('as'=>'api.quotes', 'uses'=>'QuoteController@getDatatable'));
|
||||||
@ -202,7 +204,6 @@ Route::group([
|
|||||||
Route::get('start_trial/{plan}', 'AccountController@startTrial')
|
Route::get('start_trial/{plan}', 'AccountController@startTrial')
|
||||||
->where(['plan'=>'pro']);
|
->where(['plan'=>'pro']);
|
||||||
Route::get('restore_user/{user_id}', 'UserController@restoreUser');
|
Route::get('restore_user/{user_id}', 'UserController@restoreUser');
|
||||||
Route::post('users/change_password', 'UserController@changePassword');
|
|
||||||
Route::get('/switch_account/{user_id}', 'UserController@switchAccount');
|
Route::get('/switch_account/{user_id}', 'UserController@switchAccount');
|
||||||
Route::get('/unlink_account/{user_account_id}/{user_id}', 'UserController@unlinkAccount');
|
Route::get('/unlink_account/{user_account_id}/{user_id}', 'UserController@unlinkAccount');
|
||||||
Route::get('/manage_companies', 'UserController@manageCompanies');
|
Route::get('/manage_companies', 'UserController@manageCompanies');
|
||||||
@ -219,6 +220,7 @@ Route::group([
|
|||||||
Route::resource('tax_rates', 'TaxRateController');
|
Route::resource('tax_rates', 'TaxRateController');
|
||||||
Route::post('tax_rates/bulk', 'TaxRateController@bulk');
|
Route::post('tax_rates/bulk', 'TaxRateController@bulk');
|
||||||
|
|
||||||
|
Route::get('settings/email_preview', 'AccountController@previewEmail');
|
||||||
Route::get('company/{section}/{subSection?}', 'AccountController@redirectLegacy');
|
Route::get('company/{section}/{subSection?}', 'AccountController@redirectLegacy');
|
||||||
Route::get('settings/data_visualizations', 'ReportController@d3');
|
Route::get('settings/data_visualizations', 'ReportController@d3');
|
||||||
Route::get('settings/charts_and_reports', 'ReportController@showReports');
|
Route::get('settings/charts_and_reports', 'ReportController@showReports');
|
||||||
@ -230,11 +232,6 @@ Route::group([
|
|||||||
Route::get('settings/{section?}', 'AccountController@showSection');
|
Route::get('settings/{section?}', 'AccountController@showSection');
|
||||||
Route::post('settings/{section?}', 'AccountController@doSection');
|
Route::post('settings/{section?}', 'AccountController@doSection');
|
||||||
|
|
||||||
//Route::get('api/payment_terms', array('as'=>'api.payment_terms', 'uses'=>'PaymentTermController@getDatatable'));
|
|
||||||
//Route::resource('payment_terms', 'PaymentTermController');
|
|
||||||
//Route::post('payment_terms/bulk', 'PaymentTermController@bulk');
|
|
||||||
|
|
||||||
Route::get('account/getSearchData', array('as' => 'getSearchData', 'uses' => 'AccountController@getSearchData'));
|
|
||||||
Route::post('user/setTheme', 'UserController@setTheme');
|
Route::post('user/setTheme', 'UserController@setTheme');
|
||||||
Route::post('remove_logo', 'AccountController@removeLogo');
|
Route::post('remove_logo', 'AccountController@removeLogo');
|
||||||
Route::post('account/go_pro', 'AccountController@enableProPlan');
|
Route::post('account/go_pro', 'AccountController@enableProPlan');
|
||||||
@ -257,15 +254,15 @@ Route::group([
|
|||||||
// Route groups for API
|
// Route groups for API
|
||||||
Route::group(['middleware' => 'api', 'prefix' => 'api/v1'], function()
|
Route::group(['middleware' => 'api', 'prefix' => 'api/v1'], function()
|
||||||
{
|
{
|
||||||
Route::get('ping', 'ClientApiController@ping');
|
Route::get('ping', 'AccountApiController@ping');
|
||||||
Route::post('login', 'AccountApiController@login');
|
Route::post('login', 'AccountApiController@login');
|
||||||
Route::post('register', 'AccountApiController@register');
|
Route::post('register', 'AccountApiController@register');
|
||||||
Route::get('static', 'AccountApiController@getStaticData');
|
Route::get('static', 'AccountApiController@getStaticData');
|
||||||
Route::get('accounts', 'AccountApiController@show');
|
Route::get('accounts', 'AccountApiController@show');
|
||||||
Route::put('accounts', 'AccountApiController@update');
|
Route::put('accounts', 'AccountApiController@update');
|
||||||
Route::resource('clients', 'ClientApiController');
|
Route::resource('clients', 'ClientApiController');
|
||||||
Route::get('quotes', 'QuoteApiController@index');
|
//Route::get('quotes', 'QuoteApiController@index');
|
||||||
Route::resource('quotes', 'QuoteApiController');
|
//Route::resource('quotes', 'QuoteApiController');
|
||||||
Route::get('invoices', 'InvoiceApiController@index');
|
Route::get('invoices', 'InvoiceApiController@index');
|
||||||
Route::resource('invoices', 'InvoiceApiController');
|
Route::resource('invoices', 'InvoiceApiController');
|
||||||
Route::get('payments', 'PaymentApiController@index');
|
Route::get('payments', 'PaymentApiController@index');
|
||||||
@ -573,24 +570,26 @@ if (!defined('CONTACT_EMAIL')) {
|
|||||||
define('NINJA_ACCOUNT_KEY', 'zg4ylmzDkdkPOT8yoKQw9LTWaoZJx79h');
|
define('NINJA_ACCOUNT_KEY', 'zg4ylmzDkdkPOT8yoKQw9LTWaoZJx79h');
|
||||||
define('NINJA_GATEWAY_ID', GATEWAY_STRIPE);
|
define('NINJA_GATEWAY_ID', GATEWAY_STRIPE);
|
||||||
define('NINJA_GATEWAY_CONFIG', 'NINJA_GATEWAY_CONFIG');
|
define('NINJA_GATEWAY_CONFIG', 'NINJA_GATEWAY_CONFIG');
|
||||||
define('NINJA_WEB_URL', 'https://www.invoiceninja.com');
|
define('NINJA_WEB_URL', env('NINJA_WEB_URL', 'https://www.invoiceninja.com'));
|
||||||
define('NINJA_APP_URL', 'https://app.invoiceninja.com');
|
define('NINJA_APP_URL', env('NINJA_APP_URL', 'https://app.invoiceninja.com'));
|
||||||
define('NINJA_VERSION', '2.5.1.3');
|
define('NINJA_DATE', '2000-01-01');
|
||||||
|
define('NINJA_VERSION', '2.5.1.3' . env('NINJA_VERSION_SUFFIX'));
|
||||||
|
|
||||||
define('SOCIAL_LINK_FACEBOOK', 'https://www.facebook.com/invoiceninja');
|
define('SOCIAL_LINK_FACEBOOK', env('SOCIAL_LINK_FACEBOOK', 'https://www.facebook.com/invoiceninja'));
|
||||||
define('SOCIAL_LINK_TWITTER', 'https://twitter.com/invoiceninja');
|
define('SOCIAL_LINK_TWITTER', env('SOCIAL_LINK_TWITTER', 'https://twitter.com/invoiceninja'));
|
||||||
define('SOCIAL_LINK_GITHUB', 'https://github.com/invoiceninja/invoiceninja/');
|
define('SOCIAL_LINK_GITHUB', env('SOCIAL_LINK_GITHUB', 'https://github.com/invoiceninja/invoiceninja/'));
|
||||||
|
|
||||||
define('NINJA_FROM_EMAIL', 'maildelivery@invoiceninja.com');
|
define('NINJA_FROM_EMAIL', env('NINJA_FROM_EMAIL', 'maildelivery@invoiceninja.com'));
|
||||||
define('RELEASES_URL', 'https://trello.com/b/63BbiVVe/invoice-ninja');
|
define('RELEASES_URL', env('RELEASES_URL', 'https://trello.com/b/63BbiVVe/invoice-ninja'));
|
||||||
define('ZAPIER_URL', 'https://zapier.com/zapbook/invoice-ninja');
|
define('ZAPIER_URL', env('ZAPIER_URL', 'https://zapier.com/zapbook/invoice-ninja'));
|
||||||
define('OUTDATE_BROWSER_URL', 'http://browsehappy.com/');
|
define('OUTDATE_BROWSER_URL', env('OUTDATE_BROWSER_URL', 'http://browsehappy.com/'));
|
||||||
define('PDFMAKE_DOCS', 'http://pdfmake.org/playground.html');
|
define('PDFMAKE_DOCS', env('PDFMAKE_DOCS', 'http://pdfmake.org/playground.html'));
|
||||||
define('PHANTOMJS_CLOUD', 'http://api.phantomjscloud.com/api/browser/v2/');
|
define('PHANTOMJS_CLOUD', env('PHANTOMJS_CLOUD', 'http://api.phantomjscloud.com/api/browser/v2/'));
|
||||||
define('PHP_DATE_FORMATS', 'http://php.net/manual/en/function.date.php');
|
define('PHP_DATE_FORMATS', env('PHP_DATE_FORMATS', 'http://php.net/manual/en/function.date.php'));
|
||||||
define('REFERRAL_PROGRAM_URL', 'https://www.invoiceninja.com/referral-program/');
|
define('REFERRAL_PROGRAM_URL', env('REFERRAL_PROGRAM_URL', 'https://www.invoiceninja.com/referral-program/'));
|
||||||
define('EMAIL_MARKUP_URL', 'https://developers.google.com/gmail/markup');
|
define('EMAIL_MARKUP_URL', env('EMAIL_MARKUP_URL', 'https://developers.google.com/gmail/markup'));
|
||||||
define('OFX_HOME_URL', 'http://www.ofxhome.com/index.php/home/directory/all');
|
define('OFX_HOME_URL', env('OFX_HOME_URL', 'http://www.ofxhome.com/index.php/home/directory/all'));
|
||||||
|
define('GOOGLE_ANALYITCS_URL', env('GOOGLE_ANALYITCS_URL', 'https://www.google-analytics.com/collect'));
|
||||||
|
|
||||||
define('BLANK_IMAGE', '');
|
define('BLANK_IMAGE', '');
|
||||||
|
|
||||||
@ -604,13 +603,12 @@ if (!defined('CONTACT_EMAIL')) {
|
|||||||
define('INVOICE_DESIGNS_AFFILIATE_KEY', 'T3RS74');
|
define('INVOICE_DESIGNS_AFFILIATE_KEY', 'T3RS74');
|
||||||
define('SELF_HOST_AFFILIATE_KEY', '8S69AD');
|
define('SELF_HOST_AFFILIATE_KEY', '8S69AD');
|
||||||
|
|
||||||
define('PRO_PLAN_PRICE', 50);
|
define('PLAN_PRICE_PRO_MONTHLY', env('PLAN_PRICE_PRO_MONTHLY', 5));
|
||||||
define('PLAN_PRICE_PRO_MONTHLY', 5);
|
define('PLAN_PRICE_PRO_YEARLY', env('PLAN_PRICE_PRO_YEARLY', 50));
|
||||||
define('PLAN_PRICE_PRO_YEARLY', 50);
|
define('PLAN_PRICE_ENTERPRISE_MONTHLY', env('PLAN_PRICE_ENTERPRISE_MONTHLY', 10));
|
||||||
define('PLAN_PRICE_ENTERPRISE_MONTHLY', 10);
|
define('PLAN_PRICE_ENTERPRISE_YEARLY', env('PLAN_PRICE_ENTERPRISE_YEARLY', 100));
|
||||||
define('PLAN_PRICE_ENTERPRISE_YEARLY', 100);
|
define('WHITE_LABEL_PRICE', env('WHITE_LABEL_PRICE', 20));
|
||||||
define('WHITE_LABEL_PRICE', 20);
|
define('INVOICE_DESIGNS_PRICE', env('INVOICE_DESIGNS_PRICE', 10));
|
||||||
define('INVOICE_DESIGNS_PRICE', 10);
|
|
||||||
|
|
||||||
define('USER_TYPE_SELF_HOST', 'SELF_HOST');
|
define('USER_TYPE_SELF_HOST', 'SELF_HOST');
|
||||||
define('USER_TYPE_CLOUD_HOST', 'CLOUD_HOST');
|
define('USER_TYPE_CLOUD_HOST', 'CLOUD_HOST');
|
||||||
@ -619,9 +617,11 @@ if (!defined('CONTACT_EMAIL')) {
|
|||||||
define('TEST_USERNAME', 'user@example.com');
|
define('TEST_USERNAME', 'user@example.com');
|
||||||
define('TEST_PASSWORD', 'password');
|
define('TEST_PASSWORD', 'password');
|
||||||
define('API_SECRET', 'API_SECRET');
|
define('API_SECRET', 'API_SECRET');
|
||||||
|
define('DEFAULT_API_PAGE_SIZE', 15);
|
||||||
|
define('MAX_API_PAGE_SIZE', 100);
|
||||||
|
|
||||||
define('IOS_PRODUCTION_PUSH','ninjaIOS');
|
define('IOS_PRODUCTION_PUSH', env('IOS_PRODUCTION_PUSH', 'ninjaIOS'));
|
||||||
define('IOS_DEV_PUSH','devNinjaIOS');
|
define('IOS_DEV_PUSH', env('IOS_DEV_PUSH', 'devNinjaIOS'));
|
||||||
|
|
||||||
define('TOKEN_BILLING_DISABLED', 1);
|
define('TOKEN_BILLING_DISABLED', 1);
|
||||||
define('TOKEN_BILLING_OPT_IN', 2);
|
define('TOKEN_BILLING_OPT_IN', 2);
|
||||||
@ -788,30 +788,6 @@ if (!defined('CONTACT_EMAIL')) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
// Log all SQL queries to laravel.log
|
|
||||||
if (Utils::isNinjaDev()) {
|
|
||||||
Event::listen('illuminate.query', function($query, $bindings, $time, $name) {
|
|
||||||
$data = compact('bindings', 'time', 'name');
|
|
||||||
|
|
||||||
// Format binding data for sql insertion
|
|
||||||
foreach ($bindings as $i => $binding) {
|
|
||||||
if ($binding instanceof \DateTime) {
|
|
||||||
$bindings[$i] = $binding->format('\'Y-m-d H:i:s\'');
|
|
||||||
} elseif (is_string($binding)) {
|
|
||||||
$bindings[$i] = "'$binding'";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Insert bindings into query
|
|
||||||
$query = str_replace(array('%', '?'), array('%%', '%s'), $query);
|
|
||||||
$query = vsprintf($query, $bindings);
|
|
||||||
|
|
||||||
Log::info($query, $data);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
if (Utils::isNinjaDev())
|
if (Utils::isNinjaDev())
|
||||||
{
|
{
|
||||||
|
@ -2,6 +2,8 @@
|
|||||||
|
|
||||||
// https://github.com/denvertimothy/OFX
|
// https://github.com/denvertimothy/OFX
|
||||||
|
|
||||||
|
use Utils;
|
||||||
|
use Log;
|
||||||
use SimpleXMLElement;
|
use SimpleXMLElement;
|
||||||
|
|
||||||
class OFX
|
class OFX
|
||||||
@ -21,13 +23,19 @@ class OFX
|
|||||||
$c = curl_init();
|
$c = curl_init();
|
||||||
curl_setopt($c, CURLOPT_URL, $this->bank->url);
|
curl_setopt($c, CURLOPT_URL, $this->bank->url);
|
||||||
curl_setopt($c, CURLOPT_POST, 1);
|
curl_setopt($c, CURLOPT_POST, 1);
|
||||||
curl_setopt($c, CURLOPT_HTTPHEADER, array('Content-Type: application/x-ofx'));
|
// User-Agent: http://www.ofxhome.com/ofxforum/viewtopic.php?pid=108091#p108091
|
||||||
|
curl_setopt($c, CURLOPT_HTTPHEADER, array('Content-Type: application/x-ofx', 'User-Agent: httpclient'));
|
||||||
curl_setopt($c, CURLOPT_POSTFIELDS, $this->request);
|
curl_setopt($c, CURLOPT_POSTFIELDS, $this->request);
|
||||||
curl_setopt($c, CURLOPT_RETURNTRANSFER, 1);
|
curl_setopt($c, CURLOPT_RETURNTRANSFER, 1);
|
||||||
|
|
||||||
$this->response = curl_exec($c);
|
$this->response = curl_exec($c);
|
||||||
//print_r($this->response);
|
|
||||||
//\Log::info(print_r($this->response, true));
|
if (Utils::isNinjaDev()) {
|
||||||
|
Log::info(print_r($this->response, true));
|
||||||
|
}
|
||||||
|
|
||||||
curl_close($c);
|
curl_close($c);
|
||||||
|
|
||||||
$tmp = explode('<OFX>', $this->response);
|
$tmp = explode('<OFX>', $this->response);
|
||||||
$this->responseHeader = $tmp[0];
|
$this->responseHeader = $tmp[0];
|
||||||
$this->responseBody = '<OFX>'.$tmp[1];
|
$this->responseBody = '<OFX>'.$tmp[1];
|
||||||
@ -35,14 +43,15 @@ class OFX
|
|||||||
public function xml()
|
public function xml()
|
||||||
{
|
{
|
||||||
$xml = $this->responseBody;
|
$xml = $this->responseBody;
|
||||||
self::closeTags($xml);
|
$xml = self::closeTags($xml);
|
||||||
$x = new SimpleXMLElement($xml);
|
$x = new SimpleXMLElement($xml);
|
||||||
|
|
||||||
return $x;
|
return $x;
|
||||||
}
|
}
|
||||||
public static function closeTags(&$x)
|
public static function closeTags($x)
|
||||||
{
|
{
|
||||||
$x = preg_replace('/(<([^<\/]+)>)(?!.*?<\/\2>)([^<]+)/', '\1\3</\2>', $x);
|
$x = preg_replace('/\s+/', '', $x);
|
||||||
|
return preg_replace('/(<([^<\/]+)>)(?!.*?<\/\2>)([^<]+)/', '\1\3</\2>', $x);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -224,3 +233,4 @@ class Account
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -51,6 +51,11 @@ class Utils
|
|||||||
return php_sapi_name() == 'cli';
|
return php_sapi_name() == 'cli';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static function isTravis()
|
||||||
|
{
|
||||||
|
return env('TRAVIS') == 'true';
|
||||||
|
}
|
||||||
|
|
||||||
public static function isNinja()
|
public static function isNinja()
|
||||||
{
|
{
|
||||||
return self::isNinjaProd() || self::isNinjaDev();
|
return self::isNinjaProd() || self::isNinjaDev();
|
||||||
@ -135,7 +140,7 @@ class Utils
|
|||||||
|
|
||||||
public static function hasAllPermissions($permission)
|
public static function hasAllPermissions($permission)
|
||||||
{
|
{
|
||||||
return Auth::check() && Auth::user()->hasPermissions($permission);
|
return Auth::check() && Auth::user()->hasPermission($permission);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function isTrial()
|
public static function isTrial()
|
||||||
@ -336,6 +341,7 @@ class Utils
|
|||||||
$currency = self::getFromCache($currencyId, 'currencies');
|
$currency = self::getFromCache($currencyId, 'currencies');
|
||||||
$thousand = $currency->thousand_separator;
|
$thousand = $currency->thousand_separator;
|
||||||
$decimal = $currency->decimal_separator;
|
$decimal = $currency->decimal_separator;
|
||||||
|
$precision = $currency->precision;
|
||||||
$code = $currency->code;
|
$code = $currency->code;
|
||||||
$swapSymbol = false;
|
$swapSymbol = false;
|
||||||
|
|
||||||
@ -350,7 +356,7 @@ class Utils
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$value = number_format($value, $currency->precision, $decimal, $thousand);
|
$value = number_format($value, $precision, $decimal, $thousand);
|
||||||
$symbol = $currency->symbol;
|
$symbol = $currency->symbol;
|
||||||
|
|
||||||
if ($showCode || !$symbol) {
|
if ($showCode || !$symbol) {
|
||||||
@ -669,9 +675,14 @@ class Utils
|
|||||||
return $year + $offset;
|
return $year + $offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static function getEntityClass($entityType)
|
||||||
|
{
|
||||||
|
return 'App\\Models\\' . static::getEntityName($entityType);
|
||||||
|
}
|
||||||
|
|
||||||
public static function getEntityName($entityType)
|
public static function getEntityName($entityType)
|
||||||
{
|
{
|
||||||
return ucwords(str_replace('_', ' ', $entityType));
|
return ucwords(Utils::toCamelCase($entityType));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function getClientDisplayName($model)
|
public static function getClientDisplayName($model)
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Listeners;
|
<?php namespace App\Listeners;
|
||||||
|
|
||||||
use App\Models\Invoice;
|
use App\Models\Invoice;
|
||||||
use App\Events\ClientWasCreated;
|
use App\Events\ClientWasCreated;
|
||||||
|
54
app/Listeners/AnalyticsListener.php
Normal file
54
app/Listeners/AnalyticsListener.php
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
<?php namespace App\Listeners;
|
||||||
|
|
||||||
|
use Log;
|
||||||
|
use Utils;
|
||||||
|
use App\Events\PaymentWasCreated;
|
||||||
|
|
||||||
|
class AnalyticsListener
|
||||||
|
{
|
||||||
|
public function trackRevenue(PaymentWasCreated $event)
|
||||||
|
{
|
||||||
|
if ( ! Utils::isNinja() || ! env('ANALYTICS_KEY')) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$payment = $event->payment;
|
||||||
|
$invoice = $payment->invoice;
|
||||||
|
$account = $payment->account;
|
||||||
|
|
||||||
|
if ($account->account_key != NINJA_ACCOUNT_KEY) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$analyticsId = env('ANALYTICS_KEY');
|
||||||
|
$client = $payment->client;
|
||||||
|
$amount = $payment->amount;
|
||||||
|
|
||||||
|
$base = "v=1&tid={$analyticsId}&cid{$client->public_id}&cu=USD&ti={$invoice->invoice_number}";
|
||||||
|
|
||||||
|
$url = $base . "&t=transaction&ta=ninja&tr={$amount}";
|
||||||
|
$this->sendAnalytics($url);
|
||||||
|
//Log::info($url);
|
||||||
|
|
||||||
|
$url = $base . "&t=item&in=plan&ip={$amount}&iq=1";
|
||||||
|
$this->sendAnalytics($url);
|
||||||
|
//Log::info($url);
|
||||||
|
}
|
||||||
|
|
||||||
|
private function sendAnalytics($data)
|
||||||
|
{
|
||||||
|
$data = json_encode($data);
|
||||||
|
$curl = curl_init();
|
||||||
|
|
||||||
|
$opts = [
|
||||||
|
CURLOPT_URL => GOOGLE_ANALYITCS_URL,
|
||||||
|
CURLOPT_RETURNTRANSFER => true,
|
||||||
|
CURLOPT_POST => 'POST',
|
||||||
|
CURLOPT_POSTFIELDS => $data,
|
||||||
|
];
|
||||||
|
|
||||||
|
curl_setopt_array($curl, $opts);
|
||||||
|
$response = curl_exec($curl);
|
||||||
|
curl_close($curl);
|
||||||
|
}
|
||||||
|
}
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Listeners;
|
<?php namespace App\Listeners;
|
||||||
|
|
||||||
use App\Events\PaymentFailed;
|
use App\Events\PaymentFailed;
|
||||||
use Carbon;
|
use Carbon;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Listeners;
|
<?php namespace App\Listeners;
|
||||||
|
|
||||||
use Carbon;
|
use Carbon;
|
||||||
use App\Models\Expense;
|
use App\Models\Expense;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Listeners;
|
<?php namespace App\Listeners;
|
||||||
|
|
||||||
use Utils;
|
use Utils;
|
||||||
use Auth;
|
use Auth;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Listeners;
|
<?php namespace App\Listeners;
|
||||||
|
|
||||||
use Utils;
|
use Utils;
|
||||||
use Auth;
|
use Auth;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Listeners;
|
<?php namespace App\Listeners;
|
||||||
|
|
||||||
use App\Ninja\Mailers\UserMailer;
|
use App\Ninja\Mailers\UserMailer;
|
||||||
use App\Ninja\Mailers\ContactMailer;
|
use App\Ninja\Mailers\ContactMailer;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Listeners;
|
<?php namespace App\Listeners;
|
||||||
|
|
||||||
use Carbon;
|
use Carbon;
|
||||||
use App\Events\QuoteWasEmailed;
|
use App\Events\QuoteWasEmailed;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Listeners;
|
<?php namespace App\Listeners;
|
||||||
|
|
||||||
use Auth;
|
use Auth;
|
||||||
use Utils;
|
use Utils;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Listeners;
|
<?php namespace App\Listeners;
|
||||||
|
|
||||||
use App\Models\Task;
|
use App\Models\Task;
|
||||||
use App\Events\InvoiceWasDeleted;
|
use App\Events\InvoiceWasDeleted;
|
||||||
|
@ -212,7 +212,9 @@ class Account extends Eloquent
|
|||||||
|
|
||||||
public function isGatewayConfigured($gatewayId = 0)
|
public function isGatewayConfigured($gatewayId = 0)
|
||||||
{
|
{
|
||||||
|
if ( ! $this->relationLoaded('account_gateways')) {
|
||||||
$this->load('account_gateways');
|
$this->load('account_gateways');
|
||||||
|
}
|
||||||
|
|
||||||
if ($gatewayId) {
|
if ($gatewayId) {
|
||||||
return $this->getGatewayConfig($gatewayId) != false;
|
return $this->getGatewayConfig($gatewayId) != false;
|
||||||
@ -241,7 +243,7 @@ class Account extends Eloquent
|
|||||||
return $this->name;
|
return $this->name;
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->load('users');
|
//$this->load('users');
|
||||||
$user = $this->users()->first();
|
$user = $this->users()->first();
|
||||||
|
|
||||||
return $user->getDisplayName();
|
return $user->getDisplayName();
|
||||||
@ -481,10 +483,17 @@ class Account extends Eloquent
|
|||||||
return Document::getDirectFileUrl($this->logo, $this->getLogoDisk());
|
return Document::getDirectFileUrl($this->logo, $this->getLogoDisk());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getToken($name)
|
public function getPrimaryUser()
|
||||||
|
{
|
||||||
|
return $this->users()
|
||||||
|
->orderBy('id')
|
||||||
|
->first();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getToken($userId, $name)
|
||||||
{
|
{
|
||||||
foreach ($this->account_tokens as $token) {
|
foreach ($this->account_tokens as $token) {
|
||||||
if ($token->name === $name) {
|
if ($token->user_id == $userId && $token->name === $name) {
|
||||||
return $token->token;
|
return $token->token;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -809,6 +818,10 @@ class Account extends Eloquent
|
|||||||
|
|
||||||
public function hasFeature($feature)
|
public function hasFeature($feature)
|
||||||
{
|
{
|
||||||
|
if (Utils::isNinjaDev()) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
$planDetails = $this->getPlanDetails();
|
$planDetails = $this->getPlanDetails();
|
||||||
$selfHost = !Utils::isNinjaProd();
|
$selfHost = !Utils::isNinjaProd();
|
||||||
|
|
||||||
@ -1176,13 +1189,18 @@ class Account extends Eloquent
|
|||||||
return str_replace('/>', ' />', $template);
|
return str_replace('/>', ' />', $template);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getTemplateView($view = '')
|
||||||
|
{
|
||||||
|
return $this->getEmailDesignId() == EMAIL_DESIGN_PLAIN ? $view : 'design' . $this->getEmailDesignId();
|
||||||
|
}
|
||||||
|
|
||||||
public function getEmailFooter()
|
public function getEmailFooter()
|
||||||
{
|
{
|
||||||
if ($this->email_footer) {
|
if ($this->email_footer) {
|
||||||
// Add line breaks if HTML isn't already being used
|
// Add line breaks if HTML isn't already being used
|
||||||
return strip_tags($this->email_footer) == $this->email_footer ? nl2br($this->email_footer) : $this->email_footer;
|
return strip_tags($this->email_footer) == $this->email_footer ? nl2br($this->email_footer) : $this->email_footer;
|
||||||
} else {
|
} else {
|
||||||
return "<p>" . trans('texts.email_signature') . "\n<br>\$account</p>";
|
return "<p><div>" . trans('texts.email_signature') . "\n<br>\$account</div></p>";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -16,4 +16,9 @@ class AccountToken extends EntityModel
|
|||||||
{
|
{
|
||||||
return $this->belongsTo('App\Models\Account');
|
return $this->belongsTo('App\Models\Account');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function user()
|
||||||
|
{
|
||||||
|
return $this->belongsTo('App\Models\User');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -199,6 +199,13 @@ class Client extends EntityModel
|
|||||||
return $this->name;
|
return $this->name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getPrimaryContact()
|
||||||
|
{
|
||||||
|
return $this->contacts()
|
||||||
|
->whereIsPrimary(true)
|
||||||
|
->first();
|
||||||
|
}
|
||||||
|
|
||||||
public function getDisplayName()
|
public function getDisplayName()
|
||||||
{
|
{
|
||||||
if ($this->name) {
|
if ($this->name) {
|
||||||
@ -254,14 +261,18 @@ class Client extends EntityModel
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public function getGatewayToken(&$accountGateway = null)
|
public function getGatewayToken(&$accountGateway)
|
||||||
{
|
{
|
||||||
$this->account->load('account_gateways');
|
$account = $this->account;
|
||||||
|
|
||||||
if (!count($this->account->account_gateways)) {
|
if ( ! $account->relationLoaded('account_gateways')) {
|
||||||
|
$account->load('account_gateways');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!count($account->account_gateways)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$accountGateway = $this->account->getTokenGateway();
|
$accountGateway = $account->getTokenGateway();
|
||||||
|
|
||||||
if (!$accountGateway) {
|
if (!$accountGateway) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -173,11 +173,11 @@ class Document extends EntityModel
|
|||||||
}
|
}
|
||||||
|
|
||||||
public function getUrl(){
|
public function getUrl(){
|
||||||
return url('document/'.$this->public_id.'/'.$this->name);
|
return url('documents/'.$this->public_id.'/'.$this->name);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getClientUrl($invitation){
|
public function getClientUrl($invitation){
|
||||||
return url('client/document/'.$invitation->invitation_key.'/'.$this->public_id.'/'.$this->name);
|
return url('client/documents/'.$invitation->invitation_key.'/'.$this->public_id.'/'.$this->name);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function isPDFEmbeddable(){
|
public function isPDFEmbeddable(){
|
||||||
@ -186,16 +186,16 @@ class Document extends EntityModel
|
|||||||
|
|
||||||
public function getVFSJSUrl(){
|
public function getVFSJSUrl(){
|
||||||
if(!$this->isPDFEmbeddable())return null;
|
if(!$this->isPDFEmbeddable())return null;
|
||||||
return url('document/js/'.$this->public_id.'/'.$this->name.'.js');
|
return url('documents/js/'.$this->public_id.'/'.$this->name.'.js');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getClientVFSJSUrl(){
|
public function getClientVFSJSUrl(){
|
||||||
if(!$this->isPDFEmbeddable())return null;
|
if(!$this->isPDFEmbeddable())return null;
|
||||||
return url('client/document/js/'.$this->public_id.'/'.$this->name.'.js');
|
return url('client/documents/js/'.$this->public_id.'/'.$this->name.'.js');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getPreviewUrl(){
|
public function getPreviewUrl(){
|
||||||
return $this->preview?url('document/preview/'.$this->public_id.'/'.$this->name.'.'.pathinfo($this->preview, PATHINFO_EXTENSION)):null;
|
return $this->preview?url('documents/preview/'.$this->public_id.'/'.$this->name.'.'.pathinfo($this->preview, PATHINFO_EXTENSION)):null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function toArray()
|
public function toArray()
|
||||||
|
@ -101,6 +101,16 @@ class EntityModel extends Eloquent
|
|||||||
return $this->getName();
|
return $this->getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static function getClassName($entityType)
|
||||||
|
{
|
||||||
|
return 'App\\Models\\' . ucwords(Utils::toCamelCase($entityType));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function getTransformerName($entityType)
|
||||||
|
{
|
||||||
|
return 'App\\Ninja\\Transformers\\' . ucwords(Utils::toCamelCase($entityType)) . 'Transformer';
|
||||||
|
}
|
||||||
|
|
||||||
public function setNullValues()
|
public function setNullValues()
|
||||||
{
|
{
|
||||||
foreach ($this->fillable as $field) {
|
foreach ($this->fillable as $field) {
|
||||||
|
@ -228,6 +228,12 @@ class Invoice extends EntityModel implements BalanceAffecting
|
|||||||
return $this->hasMany('App\Models\Expense','invoice_id','id')->withTrashed();
|
return $this->hasMany('App\Models\Expense','invoice_id','id')->withTrashed();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function scopeInvoices($query)
|
||||||
|
{
|
||||||
|
return $query->where('is_quote', '=', false)
|
||||||
|
->where('is_recurring', '=', false);
|
||||||
|
}
|
||||||
|
|
||||||
public function markInvitationsSent($notify = false)
|
public function markInvitationsSent($notify = false)
|
||||||
{
|
{
|
||||||
foreach ($this->invitations as $invitation) {
|
foreach ($this->invitations as $invitation) {
|
||||||
@ -436,6 +442,7 @@ class Invoice extends EntityModel implements BalanceAffecting
|
|||||||
'contacts',
|
'contacts',
|
||||||
'country',
|
'country',
|
||||||
'currency_id',
|
'currency_id',
|
||||||
|
'country_id',
|
||||||
'custom_value1',
|
'custom_value1',
|
||||||
'custom_value2',
|
'custom_value2',
|
||||||
]);
|
]);
|
||||||
@ -792,7 +799,6 @@ class Invoice extends EntityModel implements BalanceAffecting
|
|||||||
$invitation = $this->invitations[0];
|
$invitation = $this->invitations[0];
|
||||||
$link = $invitation->getLink('view', true);
|
$link = $invitation->getLink('view', true);
|
||||||
$key = env('PHANTOMJS_CLOUD_KEY');
|
$key = env('PHANTOMJS_CLOUD_KEY');
|
||||||
$curl = curl_init();
|
|
||||||
|
|
||||||
if (Utils::isNinjaDev()) {
|
if (Utils::isNinjaDev()) {
|
||||||
$link = env('TEST_LINK');
|
$link = env('TEST_LINK');
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?php namespace app\Models;
|
<?php namespace App\Models;
|
||||||
|
|
||||||
use Eloquent;
|
use Eloquent;
|
||||||
use Auth;
|
use Auth;
|
||||||
|
@ -19,6 +19,11 @@ class InvoiceItem extends EntityModel
|
|||||||
return $this->belongsTo('App\Models\Invoice');
|
return $this->belongsTo('App\Models\Invoice');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function user()
|
||||||
|
{
|
||||||
|
return $this->belongsTo('App\Models\User')->withTrashed();
|
||||||
|
}
|
||||||
|
|
||||||
public function product()
|
public function product()
|
||||||
{
|
{
|
||||||
return $this->belongsTo('App\Models\Product');
|
return $this->belongsTo('App\Models\Product');
|
||||||
|
@ -8,6 +8,14 @@ class Product extends EntityModel
|
|||||||
use SoftDeletes;
|
use SoftDeletes;
|
||||||
protected $dates = ['deleted_at'];
|
protected $dates = ['deleted_at'];
|
||||||
|
|
||||||
|
protected $fillable = [
|
||||||
|
'product_key',
|
||||||
|
'notes',
|
||||||
|
'cost',
|
||||||
|
'qty',
|
||||||
|
'default_tax_rate_id',
|
||||||
|
];
|
||||||
|
|
||||||
public function getEntityType()
|
public function getEntityType()
|
||||||
{
|
{
|
||||||
return ENTITY_PRODUCT;
|
return ENTITY_PRODUCT;
|
||||||
@ -18,6 +26,11 @@ class Product extends EntityModel
|
|||||||
return Product::scope()->where('product_key', '=', $key)->first();
|
return Product::scope()->where('product_key', '=', $key)->first();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function user()
|
||||||
|
{
|
||||||
|
return $this->belongsTo('App\Models\User')->withTrashed();
|
||||||
|
}
|
||||||
|
|
||||||
public function default_tax_rate()
|
public function default_tax_rate()
|
||||||
{
|
{
|
||||||
return $this->belongsTo('App\Models\TaxRate');
|
return $this->belongsTo('App\Models\TaxRate');
|
||||||
|
@ -17,4 +17,9 @@ class TaxRate extends EntityModel
|
|||||||
{
|
{
|
||||||
return ENTITY_TAX_RATE;
|
return ENTITY_TAX_RATE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function user()
|
||||||
|
{
|
||||||
|
return $this->belongsTo('App\Models\User')->withTrashed();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user