Requirement.php 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. <?php
  2. namespace App\Models;
  3. use App\Http\Requests\IndexHelper;
  4. use App\Models\Enums\DisplayIndexObjectType;
  5. use App\Models\Scopes\CompanyScope;
  6. use EloquentFilter\Filterable;
  7. use Illuminate\Database\Eloquent\Factories\HasFactory;
  8. use Illuminate\Database\Eloquent\Model;
  9. use Illuminate\Database\Eloquent\SoftDeletes;
  10. use Illuminate\Database\Eloquent\Builder;
  11. use App\Models\Enums\AssetACL;
  12. use Illuminate\Support\Facades\Auth;
  13. class Requirement extends Model
  14. {
  15. use HasFactory,SoftDeletes,Filterable;
  16. protected $fillable = [
  17. 'title',
  18. 'asset_id',
  19. 'status',
  20. 'requirement_group_id',
  21. 'priority',
  22. 'note',
  23. 'description',
  24. 'acceptance',
  25. 'mailto',
  26. 'company_id',
  27. 'comment',
  28. 'reviewed_by',
  29. 'note',
  30. 'plan_id'
  31. ];
  32. protected $casts = [
  33. 'mailto' => 'array',
  34. ];
  35. protected static function booted()
  36. {
  37. parent::booted(); // TODO: Change the autogenerated stub
  38. static::addGlobalScope(new CompanyScope);
  39. static::creating(function (Requirement $requirement){
  40. $type =DisplayIndexObjectType::REQUIREMENT;
  41. $displayIndex = IndexHelper::getObjectMaxIndex($type);
  42. $requirement->display_id =$displayIndex;
  43. });
  44. }
  45. public function scopeAllowed(Builder $query) : void
  46. {
  47. $requirementsIds = Requirement::query()->withoutGlobalScope(CompanyScope::class)->leftJoin("assets", "requirements.asset_id", "=", "assets.id")
  48. ->where(function ($query){
  49. $query->where('assets.acl', AssetACL::CUSTOM->value)
  50. ->where('assets.whitelist', 'like', '%,' .Auth::id() . ',%');
  51. })
  52. ->orwhere(function ($query){
  53. $query->where('assets.acl', AssetACL::PRIVATE->value)
  54. ->where('assets.created_by', Auth::id());
  55. })
  56. ->orwhere(function ($query){
  57. $query->whereNull('requirements.asset_id');
  58. })
  59. ->pluck("requirements.id")->unique();
  60. $query->whereIn("id", $requirementsIds->toArray())->where('company_id',Auth::user()->company_id);
  61. }
  62. public function createdBy(): \Illuminate\Database\Eloquent\Relations\BelongsTo
  63. {
  64. return $this->belongsTo(User::class, 'created_by');
  65. }
  66. public function reviewedBy(): \Illuminate\Database\Eloquent\Relations\BelongsTo
  67. {
  68. return $this->belongsTo(User::class, 'reviewed_by');
  69. }
  70. public function asset(): \Illuminate\Database\Eloquent\Relations\BelongsTo
  71. {
  72. return $this->belongsTo(Asset::class);
  73. }
  74. public function plan(): \Illuminate\Database\Eloquent\Relations\BelongsTo
  75. {
  76. return $this->belongsTo(Plan::class);
  77. }
  78. public function group(): \Illuminate\Database\Eloquent\Relations\BelongsTo
  79. {
  80. return $this->belongsTo(RequirementGroup::class, "requirement_group_id");
  81. }
  82. public function tasks(): \Illuminate\Database\Eloquent\Relations\HasMany
  83. {
  84. return $this->hasMany(Task::class);
  85. }
  86. public function projects():\Illuminate\Database\Eloquent\Relations\BelongsToMany
  87. {
  88. return $this->belongsToMany(Project::class, 'project_requirement');
  89. }
  90. }