Ngiler SH3LL 360
Home
Information
Create File
Create Folder
:
/
home
/
tbf
/
cursbackend
/
app
/
Models
/
Information Server
MySQL :
OFF
Perl :
OFF
CURL :
ON
WGET :
OFF
PKEXEC :
OFF
Directive
Local Value
IP Address
89.40.16.97
System
Linux server.atelieruldeit.ro 3.10.0-1160.el7.x86_64 #1 SMP Mon Oct 19 16:18:59 UTC 2020 x86_64
User
tbf
PHP Version
7.3.33
Software
Apache
Doc root
Writable
close
Edit File :
Instance.php
| Size :
3.84
KB
Copy
<?php namespace App\Models; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\SoftDeletes; use DB; use Webpatser\Uuid\Uuid; class Instance extends Model { use SoftDeletes; const STATUS_NEW = 'new'; const STATUS_ACTIVE = 'active'; const STATUS_GRACE_PERIOD = 'grace_period'; const STATUS_UNPAID = 'unpaid'; protected $fillable = ['name', 'phone', 'address', 'city', 'country_id', 'has_company', 'company_name', 'cui', 'reg_no', 'cnp', 'package_id', 'status', 'agree_with_terms', 'stripe_customer_id', 'vat_percentage', 'grace_period_date', 'referral_uuid', 'referred_by_instance_id', 'free_period', 'first_payment','voucher_id','discount_link_id', 'kartra_id', 'katra_response', 'bank_name']; public static function boot(){ parent::boot(); self::creating(function(Instance $instance){ $instance->referral_uuid = (string) Uuid::generate(4); }); self::created(function(Instance $instance){ // Add default tags to instance $tagArrays = [ ['name' => 'Management', 'color_id' => '1', 'instance_id' => $instance->id], ['name' => 'Marketing', 'color_id' => '2', 'instance_id' => $instance->id], ['name' => 'Vanzari', 'color_id' => '3', 'instance_id' => $instance->id], ['name' => 'Productie', 'color_id' => '4', 'instance_id' => $instance->id], ['name' => 'Financiar', 'color_id' => '5', 'instance_id' => $instance->id], ]; DB::table('tags')->insert($tagArrays); // create table for promises DB::statement('CREATE TABLE promises_'.$instance->id.' LIKE promises'); // create table for key result logs DB::statement('CREATE TABLE key_result_logs_'.$instance->id.' LIKE key_result_logs'); // create table for key result - promies many to many DB::statement('CREATE TABLE key_result_promise_'.$instance->id.' ( key_result_id BIGINT(20) NOT NULL, promise_id BIGINT(20) NOT NULL )'); }); } public function country(){ return $this->belongsTo(Country::class); } public function instance(){ return $this->belongsTo(Instance::class); } public function discount_link() { return $this->belongsTo(DiscountLink::class); } public function package(){ return $this->belongsTo(Package::class); } public function users(){ return $this->hasMany(User::class); } public function invoices(){ return $this->hasMany(Invoice::class); } public function roles(){ return $this->hasMany(Role::class); } public function tags(){ return $this->hasMany(Tag::class); } public function objectives(){ return $this->hasMany(Objective::class); } public function key_results(){ return $this->hasMany(KeyResult::class); } public function master_goals(){ return $this->hasMany(MasterGoal::class); } public function promises(){ return $this->hasMany(Promise::class); } public function key_result_logs(){ return $this->hasMany(KeyResultLog::class); } public function tasks(){ return $this->hasMany(Task::class); } public function instance_notifications(){ return $this->hasMany(InstanceNotification::class); } public function notification_logs(){ return $this->hasMany(NotificationLog::class); } public function voucher(){ return $this->belongsTo(Voucher::class); } public static function getStatusList(){ return [ self::STATUS_NEW, self::STATUS_ACTIVE, self::STATUS_GRACE_PERIOD, self::STATUS_UNPAID, ]; } }
Back