HEX
Server: Apache/2.4.58 (Ubuntu)
System: Linux Bradford-Sitios 6.14.0-1017-azure #17~24.04.1-Ubuntu SMP Mon Dec 1 20:10:50 UTC 2025 x86_64
User: www-data (33)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/api-talleres.bradford/app/Models/Period.php
<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;

class Period extends Model
{
    use HasFactory;

    protected $table = 'periods';

    protected $fillable = [
        'period_year',
        'period',
        'start_date',
        'end_date',
        'status',
        'finished',
        'deleted',
        'deleted_at',
        'user_created',
        'user_updated',
        'user_deleted',
    ];


    protected $hidden = [
        'deleted',
        'deleted_at',
        'user_deleted'
    ];

    public function enrollmentPeriods()
    {
        return $this->hasMany(EnrollmentPeriod::class, 'period_id')
            ->where('deleted', 0);
    }

    /**
     * Talleres disponibles en este perĂ­odo con sus cupos.
     */
    public function clubs()
    {
        return $this->belongsToMany(Club::class, 'club_period')
            ->withPivot(['max_capacity', 'current_enrollment', 'status', 'user_created', 'user_updated'])
            ->withTimestamps();
    }

    public function createdBy()
    {
        return $this->belongsTo(User::class, 'user_created');
    }

    public function updatedBy()
    {
        return $this->belongsTo(User::class, 'user_updated');
    }

    public function deletedBy()
    {
        return $this->belongsTo(User::class, 'user_deleted');
    }
}