Merge branch 'auto-update' into 'master'

Auto update

See merge request mohit.panjvani/crater-web!23
This commit is contained in:
Mohit Panjwani
2019-11-14 15:39:05 +00:00
33 changed files with 369 additions and 69 deletions

View File

@ -0,0 +1,31 @@
<?php
namespace Laraspace\Events;
use Illuminate\Broadcasting\Channel;
use Illuminate\Broadcasting\InteractsWithSockets;
use Illuminate\Broadcasting\PresenceChannel;
use Illuminate\Broadcasting\PrivateChannel;
use Illuminate\Contracts\Broadcasting\ShouldBroadcast;
use Illuminate\Foundation\Events\Dispatchable;
use Illuminate\Queue\SerializesModels;
class UpdateFinished
{
use Dispatchable;
public $new;
public $old;
/**
* Create a new event instance.
*
* @return void
*/
public function __construct($old, $new)
{
$this->old = $old;
$this->new = $new;
}
}

View File

@ -54,7 +54,7 @@ class AccessTokensController extends Controller
{ {
$request->validate([ $request->validate([
'username' => 'required|email', 'username' => 'required|email',
'password' => 'required|string', 'password' => 'required|string|min:8',
]); ]);
if ($this->hasTooManyLoginAttempts($request)) { if ($this->hasTooManyLoginAttempts($request)) {

View File

@ -37,6 +37,7 @@ class EnvironmentController extends Controller
if(array_key_exists("success", $results)) { if(array_key_exists("success", $results)) {
Artisan::call('config:clear'); Artisan::call('config:clear');
Artisan::call('key:generate --force');
Artisan::call('migrate --seed'); Artisan::call('migrate --seed');
Artisan::call('migrate', ['--path' => 'vendor/laravel/passport/database/migrations']); Artisan::call('migrate', ['--path' => 'vendor/laravel/passport/database/migrations']);

View File

@ -260,6 +260,7 @@ class InvoicesController extends Controller
'error' => 'invalid_due_amount' 'error' => 'invalid_due_amount'
]); ]);
} elseif ($invoice->due_amount != 0 && $invoice->paid_status == Invoice::STATUS_PAID) { } elseif ($invoice->due_amount != 0 && $invoice->paid_status == Invoice::STATUS_PAID) {
$invoice->status = $invoice->getPreviousStatus();
$invoice->paid_status = Invoice::STATUS_PARTIALLY_PAID; $invoice->paid_status = Invoice::STATUS_PARTIALLY_PAID;
} }

View File

@ -170,6 +170,7 @@ class PaymentController extends Controller
$invoice->status = Invoice::STATUS_COMPLETED; $invoice->status = Invoice::STATUS_COMPLETED;
$invoice->paid_status = Invoice::STATUS_PAID; $invoice->paid_status = Invoice::STATUS_PAID;
} else { } else {
$invoice->status = $invoice->getPreviousStatus();
$invoice->paid_status = Invoice::STATUS_PARTIALLY_PAID; $invoice->paid_status = Invoice::STATUS_PARTIALLY_PAID;
} }
@ -211,16 +212,7 @@ class PaymentController extends Controller
$invoice->paid_status = Invoice::STATUS_PARTIALLY_PAID; $invoice->paid_status = Invoice::STATUS_PARTIALLY_PAID;
} }
if ($invoice->due_date < Carbon::now()) { $invoice->status = $invoice->getPreviousStatus();
$invoice->status = Invoice::STATUS_OVERDUE;
} elseif ($invoice->viewed) {
$invoice->status = Invoice::STATUS_VIEWED;
} elseif ($invoice->sent) {
$invoice->status = Invoice::STATUS_SENT;
} else {
$invoice->status = Invoice::STATUS_DRAFT;
}
$invoice->save(); $invoice->save();
} }
@ -246,16 +238,7 @@ class PaymentController extends Controller
$invoice->paid_status = Invoice::STATUS_PARTIALLY_PAID; $invoice->paid_status = Invoice::STATUS_PARTIALLY_PAID;
} }
if ($invoice->due_date < Carbon::now()) { $invoice->status = $invoice->getPreviousStatus();
$invoice->status = Invoice::STATUS_OVERDUE;
} elseif ($invoice->sent) {
$invoice->status = Invoice::STATUS_SENT;
} elseif ($invoice->viewed) {
$invoice->status = Invoice::STATUS_VIEWED;
} else {
$invoice->status = Invoice::STATUS_DRAFT;
}
$invoice->save(); $invoice->save();
} }

View File

@ -26,8 +26,7 @@ class ReportController extends Controller
$query->whereBetween( $query->whereBetween(
'invoice_date', 'invoice_date',
[$start->format('Y-m-d'), $end->format('Y-m-d')] [$start->format('Y-m-d'), $end->format('Y-m-d')]
) );
->where('paid_status', Invoice::STATUS_PAID);
}]) }])
->customer() ->customer()
->whereCompany($company->id) ->whereCompany($company->id)

View File

@ -0,0 +1,28 @@
<?php
namespace Laraspace\Http\Controllers;
use Illuminate\Http\Request;
use Laraspace\Space\Updater;
use Laraspace\Space\SiteApi;
class UpdateController extends Controller
{
public function update(Request $request)
{
set_time_limit(600); // 10 minutes
$json = Updater::update($request->installed, $request->version);
return response()->json($json);
}
public function checkLatestVersion(Request $request)
{
set_time_limit(600); // 10 minutes
$json = Updater::checkForUpdate();
return response()->json($json);
}
}

View File

@ -26,12 +26,16 @@ class CustomerRequest extends FormRequest
case 'POST': case 'POST':
return [ return [
'name' => 'required', 'name' => 'required',
'addresses.*.address_street_1' => 'max:255',
'addresses.*.address_street_2' => 'max:255',
'email' => 'email|nullable|unique:users,email', 'email' => 'email|nullable|unique:users,email',
]; ];
break; break;
case 'PUT': case 'PUT':
return [ return [
'name' => 'required', 'name' => 'required',
'addresses.*.address_street_1' => 'max:255',
'addresses.*.address_street_2' => 'max:255',
]; ];
break; break;
default: default:

View File

@ -27,13 +27,22 @@ class EstimatesRequest extends FormRequest
'expiry_date' => 'required', 'expiry_date' => 'required',
'estimate_number' => 'required|unique:estimates,estimate_number', 'estimate_number' => 'required|unique:estimates,estimate_number',
'user_id' => 'required', 'user_id' => 'required',
'discount' => 'required', 'discount' => 'required|digits_between:1,20',
'discount_val' => 'required|digits_between:1,20',
'sub_total' => 'required|digits_between:1,20',
'total' => 'required|digits_between:1,20',
'tax' => 'required|digits_between:1,20',
'estimate_template_id' => 'required', 'estimate_template_id' => 'required',
'items' => 'required|array', 'items' => 'required|array',
'items.*.description' => 'max:255',
'items.*' => 'required|max:255', 'items.*' => 'required|max:255',
'items.*.name' => 'required', 'items.*.name' => 'required',
'items.*.quantity' => 'required|numeric', 'items.*.quantity' => 'required|digits_between:1,20',
'items.*.price' => 'required|numeric', 'items.*.price' => 'required|digits_between:1,20',
'items.*.discount' => 'digits_between:1,20',
'items.*.discount_val' => 'digits_between:1,20',
'items.*.tax' => 'digits_between:1,20',
'items.*.total' => 'digits_between:1,20',
]; ];
if ($this->getMethod() == 'PUT') { if ($this->getMethod() == 'PUT') {

View File

@ -25,7 +25,7 @@ class ExpenseRequest extends FormRequest
return [ return [
'expense_date' => 'required', 'expense_date' => 'required',
'expense_category_id' => 'required', 'expense_category_id' => 'required',
'amount' => 'required' 'amount' => 'required|digits_between:1,20'
]; ];
} }
} }

View File

@ -27,13 +27,22 @@ class InvoicesRequest extends FormRequest
'due_date' => 'required', 'due_date' => 'required',
'invoice_number' => 'required|unique:invoices,invoice_number', 'invoice_number' => 'required|unique:invoices,invoice_number',
'user_id' => 'required', 'user_id' => 'required',
'discount' => 'required', 'discount' => 'required|digits_between:1,20',
'discount_val' => 'required|digits_between:1,20',
'sub_total' => 'required|digits_between:1,20',
'total' => 'required|digits_between:1,20',
'tax' => 'required|digits_between:1,20',
'invoice_template_id' => 'required', 'invoice_template_id' => 'required',
'items' => 'required|array', 'items' => 'required|array',
'items.*' => 'required|max:255', 'items.*' => 'required|max:255',
'items.*.description' => 'max:255',
'items.*.name' => 'required', 'items.*.name' => 'required',
'items.*.quantity' => 'required|numeric', 'items.*.quantity' => 'required|digits_between:1,20',
'items.*.price' => 'required|numeric', 'items.*.price' => 'required|digits_between:1,20',
'items.*.discount' => 'digits_between:1,20',
'items.*.discount_val' => 'digits_between:1,20',
'items.*.tax' => 'digits_between:1,20',
'items.*.total' => 'digits_between:1,20',
]; ];
if ($this->getMethod() == 'PUT') { if ($this->getMethod() == 'PUT') {

View File

@ -24,7 +24,7 @@ class ItemsRequest extends FormRequest
{ {
return [ return [
'name' => 'required', 'name' => 'required',
'price' => 'required', 'price' => 'required|digits_between:1,20',
]; ];
} }
} }

View File

@ -26,7 +26,7 @@ class PaymentRequest extends FormRequest
'payment_date' => 'required', 'payment_date' => 'required',
'payment_number' => 'required|unique:payments,payment_number', 'payment_number' => 'required|unique:payments,payment_number',
'user_id' => 'required', 'user_id' => 'required',
'amount' => 'required', 'amount' => 'required|digits_between:1,20',
]; ];
if ($this->getMethod() == 'PUT') { if ($this->getMethod() == 'PUT') {

View File

@ -31,6 +31,8 @@ class ProfileRequest extends FormRequest
return [ return [
'name' => 'required', 'name' => 'required',
'password' => 'required', 'password' => 'required',
'address_street_1' => 'max:255',
'address_street_2' => 'max:255',
'email' => [ 'email' => [
'required', 'required',
'email', 'email',
@ -41,6 +43,8 @@ class ProfileRequest extends FormRequest
case 'PUT': case 'PUT':
return [ return [
'name' => 'required', 'name' => 'required',
'address_street_1' => 'max:255',
'address_street_2' => 'max:255',
'email' => 'required|email' 'email' => 'required|email'
]; ];
break; break;

View File

@ -113,6 +113,19 @@ class Invoice extends Model
return $this->belongsTo(InvoiceTemplate::class); return $this->belongsTo(InvoiceTemplate::class);
} }
public function getPreviousStatus()
{
if ($this->due_date < Carbon::now()) {
return self::STATUS_OVERDUE;
} elseif ($this->viewed) {
return self::STATUS_VIEWED;
} elseif ($this->sent) {
return self::STATUS_SENT;
} else {
return self::STATUS_DRAFT;
}
}
private function strposX($haystack, $needle, $number) private function strposX($haystack, $needle, $number)
{ {
if ($number == '1') { if ($number == '1') {

View File

@ -60,7 +60,7 @@ class InvoiceItem extends Model
$query->whereBetween( $query->whereBetween(
'invoice_date', 'invoice_date',
[$start->format('Y-m-d'), $end->format('Y-m-d')] [$start->format('Y-m-d'), $end->format('Y-m-d')]
)->where('paid_status', Invoice::STATUS_PAID); );
}); });
} }

View File

@ -0,0 +1,24 @@
<?php
namespace Laraspace\Listeners\Updates;
class Listener
{
const VERSION = '';
/**
* Check if should listen.
*
* @param $event
* @return boolean
*/
protected function check($event)
{
// Do not apply to the same or newer versions
// if (version_compare($event->old, static::VERSION, '>=')) {
// return false;
// }
return true;
}
}

View File

@ -0,0 +1,32 @@
<?php
namespace Laraspace\Listeners\Updates\V10;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Queue\InteractsWithQueue;
use Laraspace\Listeners\Updates\Listener;
use Laraspace\Events\UpdateFinished;
use Illuminate\Support\Facades\Artisan;
use Laraspace\Setting;
class Version101 extends Listener
{
const VERSION = '1.0.1';
/**
* Handle the event.
*
* @param object $event
* @return void
*/
public function handle(UpdateFinished $event)
{
// if (!$this->check($event)) {
// return;
// }
Artisan::call('db:seed', ['--class' => 'DemoSeeder', '--force' => true]);
Setting::getSetting('version', self::VERSION);
}
}

View File

@ -4,6 +4,8 @@ namespace Laraspace\Providers;
use Illuminate\Foundation\Support\Providers\EventServiceProvider as ServiceProvider; use Illuminate\Foundation\Support\Providers\EventServiceProvider as ServiceProvider;
use Illuminate\Auth\Events\Registered; use Illuminate\Auth\Events\Registered;
use Illuminate\Auth\Listeners\SendEmailVerificationNotification; use Illuminate\Auth\Listeners\SendEmailVerificationNotification;
use Laraspace\Events\UpdateFinished;
use Laraspace\Listeners\Updates\V10\Version101;
class EventServiceProvider extends ServiceProvider class EventServiceProvider extends ServiceProvider
{ {
@ -13,8 +15,8 @@ class EventServiceProvider extends ServiceProvider
* @var array * @var array
*/ */
protected $listen = [ protected $listen = [
'Laraspace\Events\SomeEvent' => [ UpdateFinished::class=> [
'Laraspace\Listeners\EventListener', Version101::class,
], ],
Registered::class => [ Registered::class => [
SendEmailVerificationNotification::class, SendEmailVerificationNotification::class,

36
app/Space/SiteApi.php Normal file
View File

@ -0,0 +1,36 @@
<?php
namespace Laraspace\Space;
use GuzzleHttp\Client;
use GuzzleHttp\Exception\RequestException;
use Laraspace\Setting;
trait SiteApi
{
protected static function getRemote($url, $data = array())
{
$base = 'http://crater-main.test/';
$client = new Client(['verify' => false, 'base_uri' => $base]);
$headers['headers'] = array(
'Accept' => 'application/json',
'Referer' => url('/'),
'crater' => Setting::getSetting('version')
);
$data['http_errors'] = false;
$data = array_merge($data, $headers);
try {
$result = $client->get($url, $data);
} catch (RequestException $e) {
$result = $e;
}
return $result;
}
}

110
app/Space/Updater.php Normal file
View File

@ -0,0 +1,110 @@
<?php
namespace Laraspace\Space;
use File;
use ZipArchive;
use Artisan;
use GuzzleHttp\Exception\RequestException;
use Laraspace\Space\SiteApi;
use Laraspace\Events\UpdateFinished;
use Laraspace\Setting;
class Updater
{
use SiteApi;
public static function update($installed, $version)
{
$data = null;
$path = null;
$url = '/download/'.$version;
$response = static::getRemote($url, ['timeout' => 100, 'track_redirects' => true]);
// Exception
if ($response instanceof RequestException) {
return [
'success' => false,
'errors' => 'Download Exception',
'data' => [
'path' => $path
]
];
}
if ($response && ($response->getStatusCode() == 200)) {
$data = $response->getBody()->getContents();
}
// Create temp directory
$path = 'temp-' . md5(mt_rand());
$path2 = 'temp2-' . md5(mt_rand());
$temp_path = storage_path('app/temp') . '/' . $path;
$temp_path2 = storage_path('app/temp') . '/' . $path2;
if (!File::isDirectory($temp_path)) {
File::makeDirectory($temp_path);
File::makeDirectory($temp_path2);
}
$file = $temp_path . '/upload.zip';
// Add content to the Zip file
$uploaded = is_int(file_put_contents($file, $data)) ? true : false;
if (!$uploaded) {
return false;
}
// Unzip the file
$zip = new ZipArchive();
if ($zip->open($file)) {
$zip->extractTo($temp_path2);
}
$zip->close();
// Delete zip file
File::delete($file);
if (!File::copyDirectory($temp_path2.'/crater', base_path())) {
return false;
}
// Delete temp directory
File::deleteDirectory($temp_path);
File::deleteDirectory($temp_path2);
try {
event(new UpdateFinished($installed, $version));
return [
'success' => true,
'errors' => false,
'data' => []
];
} catch (\Exception $e) {
return [
'success' => false,
'errors' => 'Update error',
'data' => []
];
}
}
public static function checkForUpdate()
{
$data = null;
$url = '/check/latest/download/'.Setting::getSetting('version');
$response = static::getRemote($url, ['timeout' => 100, 'track_redirects' => true]);
if ($response && ($response->getStatusCode() == 200)) {
$data = $response->getBody()->getContents();
}
return json_decode($data);
}
}

View File

@ -216,7 +216,7 @@ class User extends Authenticatable implements HasMedia
$query->whereBetween( $query->whereBetween(
'invoice_date', 'invoice_date',
[$start->format('Y-m-d'), $end->format('Y-m-d')] [$start->format('Y-m-d'), $end->format('Y-m-d')]
)->where('paid_status', Invoice::STATUS_PAID); );
}); });
} }

View File

@ -18,7 +18,7 @@ class CreateItemsTable extends Migration
$table->string('name'); $table->string('name');
$table->string('description')->nullable(); $table->string('description')->nullable();
$table->string('unit')->nullable(); $table->string('unit')->nullable();
$table->integer('price'); $table->unsignedBigInteger('price');
$table->integer('company_id')->unsigned()->nullable(); $table->integer('company_id')->unsigned()->nullable();
$table->foreign('company_id')->references('id')->on('companies')->onDelete('cascade'); $table->foreign('company_id')->references('id')->on('companies')->onDelete('cascade');
$table->timestamps(); $table->timestamps();

View File

@ -24,13 +24,13 @@ class CreateInvoicesTable extends Migration
$table->string('tax_per_item'); $table->string('tax_per_item');
$table->string('discount_per_item'); $table->string('discount_per_item');
$table->text('notes')->nullable(); $table->text('notes')->nullable();
$table->decimal('discount', 15, 0)->nullable();
$table->string('discount_type')->nullable(); $table->string('discount_type')->nullable();
$table->integer('discount_val')->nullable(); $table->unsignedBigInteger('discount')->nullable();
$table->integer('sub_total'); $table->unsignedBigInteger('discount_val')->nullable();
$table->integer('total'); $table->unsignedBigInteger('sub_total');
$table->integer('tax'); $table->unsignedBigInteger('total');
$table->integer('due_amount'); $table->unsignedBigInteger('tax');
$table->unsignedBigInteger('due_amount');
$table->boolean('sent')->default(false); $table->boolean('sent')->default(false);
$table->boolean('viewed')->default(false); $table->boolean('viewed')->default(false);
$table->string('unique_hash')->nullable(); $table->string('unique_hash')->nullable();

View File

@ -17,13 +17,13 @@ class CreateInvoiceItemsTable extends Migration
$table->increments('id'); $table->increments('id');
$table->string('name'); $table->string('name');
$table->string('description')->nullable(); $table->string('description')->nullable();
$table->integer('quantity');
$table->integer('price');
$table->string('discount_type'); $table->string('discount_type');
$table->integer('discount_val'); $table->unsignedBigInteger('quantity');
$table->decimal('discount', 15, 0); $table->unsignedBigInteger('price');
$table->integer('tax'); $table->unsignedBigInteger('discount_val');
$table->integer('total'); $table->unsignedBigInteger('discount');
$table->unsignedBigInteger('tax');
$table->unsignedBigInteger('total');
$table->integer('invoice_id')->unsigned(); $table->integer('invoice_id')->unsigned();
$table->foreign('invoice_id')->references('id')->on('invoices')->onDelete('cascade'); $table->foreign('invoice_id')->references('id')->on('invoices')->onDelete('cascade');
$table->integer('item_id')->unsigned()->nullable(); $table->integer('item_id')->unsigned()->nullable();

View File

@ -23,12 +23,12 @@ class CreateEstimatesTable extends Migration
$table->string('tax_per_item'); $table->string('tax_per_item');
$table->string('discount_per_item'); $table->string('discount_per_item');
$table->string('notes')->nullable(); $table->string('notes')->nullable();
$table->decimal('discount', 15, 0)->nullable();
$table->string('discount_type')->nullable(); $table->string('discount_type')->nullable();
$table->integer('discount_val')->nullable(); $table->unsignedBigInteger('discount')->nullable();
$table->integer('sub_total'); $table->unsignedBigInteger('discount_val')->nullable();
$table->integer('total'); $table->unsignedBigInteger('sub_total');
$table->integer('tax'); $table->unsignedBigInteger('total');
$table->unsignedBigInteger('tax');
$table->string('unique_hash')->nullable(); $table->string('unique_hash')->nullable();
$table->integer('user_id')->unsigned()->nullable(); $table->integer('user_id')->unsigned()->nullable();
$table->foreign('user_id')->references('id')->on('users')->onDelete('cascade'); $table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');

View File

@ -17,13 +17,13 @@ class CreateEstimateItemsTable extends Migration
$table->increments('id'); $table->increments('id');
$table->string('name'); $table->string('name');
$table->string('description')->nullable(); $table->string('description')->nullable();
$table->integer('quantity');
$table->string('discount_type'); $table->string('discount_type');
$table->decimal('discount', 15, 0); $table->unsignedBigInteger('quantity');
$table->integer('discount_val'); $table->unsignedBigInteger('discount');
$table->integer('price'); $table->unsignedBigInteger('discount_val');
$table->integer('tax'); $table->unsignedBigInteger('price');
$table->integer('total'); $table->unsignedBigInteger('tax');
$table->unsignedBigInteger('total');
$table->integer('item_id')->unsigned()->nullable(); $table->integer('item_id')->unsigned()->nullable();
$table->foreign('item_id')->references('id')->on('items')->onDelete('cascade'); $table->foreign('item_id')->references('id')->on('items')->onDelete('cascade');
$table->integer('estimate_id')->unsigned(); $table->integer('estimate_id')->unsigned();

View File

@ -17,7 +17,7 @@ class CreateExpensesTable extends Migration
$table->increments('id'); $table->increments('id');
$table->date('expense_date'); $table->date('expense_date');
$table->string('attachment_receipt')->nullable(); $table->string('attachment_receipt')->nullable();
$table->integer('amount'); $table->unsignedBigInteger('amount');
$table->string('notes')->nullable(); $table->string('notes')->nullable();
$table->integer('expense_category_id')->unsigned(); $table->integer('expense_category_id')->unsigned();
$table->foreign('expense_category_id')->references('id')->on('expense_categories')->onDelete('cascade'); $table->foreign('expense_category_id')->references('id')->on('expense_categories')->onDelete('cascade');

View File

@ -19,7 +19,7 @@ class CreatePaymentsTable extends Migration
$table->string('payment_mode')->nullable(); $table->string('payment_mode')->nullable();
$table->date('payment_date'); $table->date('payment_date');
$table->text('notes')->nullable(); $table->text('notes')->nullable();
$table->decimal('amount', 15, 0); $table->unsignedBigInteger('amount');
$table->integer('user_id')->unsigned(); $table->integer('user_id')->unsigned();
$table->foreign('user_id')->references('id')->on('users')->onDelete('cascade'); $table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');
$table->integer('invoice_id')->unsigned()->nullable(); $table->integer('invoice_id')->unsigned()->nullable();

View File

@ -30,7 +30,7 @@ class CreateTaxesTable extends Migration
$table->integer('company_id')->unsigned()->nullable(); $table->integer('company_id')->unsigned()->nullable();
$table->foreign('company_id')->references('id')->on('companies'); $table->foreign('company_id')->references('id')->on('companies');
$table->string('name'); $table->string('name');
$table->decimal('amount', 15, 0); $table->unsignedBigInteger('amount');
$table->decimal('percent', 5, 2); $table->decimal('percent', 5, 2);
$table->tinyInteger('compound_tax')->default(0); $table->tinyInteger('compound_tax')->default(0);
$table->timestamps(); $table->timestamps();

View File

@ -13,19 +13,19 @@ class EstimateTemplateSeeder extends Seeder
public function run() public function run()
{ {
EstimateTemplate::create([ EstimateTemplate::create([
'name' => 'Estimate Template1', 'name' => 'Template 1',
'view' => 'estimate1', 'view' => 'estimate1',
'path' => '/assets/img/PDF/Template1.png' 'path' => '/assets/img/PDF/Template1.png'
]); ]);
EstimateTemplate::create([ EstimateTemplate::create([
'name' => 'Estimate Template2', 'name' => 'Template 2',
'view' => 'estimate2', 'view' => 'estimate2',
'path' => '/assets/img/PDF/Template2.png' 'path' => '/assets/img/PDF/Template2.png'
]); ]);
EstimateTemplate::create([ EstimateTemplate::create([
'name' => 'Estimate Template3', 'name' => 'Template 3',
'view' => 'estimate3', 'view' => 'estimate3',
'path' => '/assets/img/PDF/Template3.png' 'path' => '/assets/img/PDF/Template3.png'
]); ]);

View File

@ -13,19 +13,19 @@ class InvoiceTemplateSeeder extends Seeder
public function run() public function run()
{ {
InvoiceTemplate::create([ InvoiceTemplate::create([
'name' => 'Invoice Template1', 'name' => 'Template 1',
'view' => 'invoice1', 'view' => 'invoice1',
'path' => '/assets/img/PDF/Template1.png' 'path' => '/assets/img/PDF/Template1.png'
]); ]);
InvoiceTemplate::create([ InvoiceTemplate::create([
'name' => 'Invoice Template2', 'name' => ' Template 2',
'view' => 'invoice2', 'view' => 'invoice2',
'path' => '/assets/img/PDF/Template2.png' 'path' => '/assets/img/PDF/Template2.png'
]); ]);
InvoiceTemplate::create([ InvoiceTemplate::create([
'name' => 'Invoice Template3', 'name' => 'Template 3',
'view' => 'invoice3', 'view' => 'invoice3',
'path' => '/assets/img/PDF/Template3.png' 'path' => '/assets/img/PDF/Template3.png'
]); ]);

View File

@ -106,6 +106,8 @@ Route::group(['middleware' => 'redirect-if-installed'], function () {
'uses' => 'OnboardingController@companySettings' 'uses' => 'OnboardingController@companySettings'
]); ]);
}); });
// App version // App version
// ---------------------------------- // ----------------------------------
@ -120,6 +122,18 @@ Route::group(['middleware' => 'api'], function () {
'middleware' => 'admin' 'middleware' => 'admin'
], function () { ], function () {
// Auto update routes
//----------------------------------
Route::post('/update', [
'as' => 'auto.update',
'uses' => 'UpdateController@update'
]);
Route::get('/check/update', [
'as' => 'check.update',
'uses' => 'UpdateController@checkLatestVersion'
]);
Route::get('/bootstrap', [ Route::get('/bootstrap', [
'as' => 'bootstrap', 'as' => 'bootstrap',
'uses' => 'UsersController@getBootstrap' 'uses' => 'UsersController@getBootstrap'