HEX
Server: Apache
System: Linux WWW 6.1.0-40-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.153-1 (2025-09-20) x86_64
User: web11 (1011)
PHP: 8.2.29
Disabled: NONE
Upload Files
File: /var/www/apklausos/application/models/Tutorial.php
<?php

/**
 * This is the model class for table "{{tutorials}}".
 *
 * The following are the available columns in table '{{tutorials}}':
 * @property integer $tid
 * @property string $name
 * @property string $title
 * @property string $icon
 * @property string $description
 * @property integer $active
 * @property string $permission
 * @property string $permission_grade
 * @property string $settings
 *
 * The following are the available model relations:
 * @property TutorialEntry[] $tutorialEntries
 */
class Tutorial extends LSActiveRecord
{
    /**
     * @return string the associated database table name
     */
    public function tableName()
    {
        return '{{tutorials}}';
    }

    /**
     * @return array validation rules for model attributes.
     */
    public function rules()
    {
        // NOTE: you should only define rules for those attributes that
        // will receive user inputs.
        return array(
            array('name, description, active, permission, permission_grade', 'required'),
            array('active', 'numerical', 'integerOnly' => true),
            array('name, permission, permission_grade', 'length', 'max' => 128),
            array('title', 'length', 'max' => 192),
            array('icon', 'length', 'max' => 64),
            // The following rule is used by search().
            // @todo Please remove those attributes that should not be searched.
            array('tid, name, description, active, permission, permission_grade', 'safe', 'on' => 'search'),
        );
    }

    /**
     * @return array relational rules.
     */
    public function relations()
    {
        // NOTE: you may need to adjust the relation name and the related
        // class name for the relations automatically generated below.
        return array(
            'tutorialEntryRelation' => array(self::HAS_MANY, 'TutorialEntryRelation', 'tid', 'together' => true),
        );
    }

    /**
     * @return array customized attribute labels (name=>label)
     */
    public function attributeLabels()
    {
        return array(
            'tid' => 'Tutorial ID',
            'name' => 'Name',
            'title' => 'Title',
            'icon' => 'Icon',
            'description' => 'Description',
            'active' => 'Active',
            'permission' => 'Permission',
            'permission_grade' => 'Permission Grade',
        );
    }

    public function getColumns()
    {
        $cols = array(
            array(
            'name' => 'tid',
            'value' => '\'<input type="checkbox" name="id[]" class="action_selectthisentry" value="\'.$data->tid.\'" />\'',
            'type' => 'raw',
            'filter' => false
            ),
            array(
            'name' => 'name',
            ),
            array(
            'name' => 'title',
            ),
            array(
            'name' => 'description',
            ),
            array(
            'name' => 'active',
            ),
            array(
            'name' => 'settings',
            'value' => '"<pre>".print_r(json_decode($data->settings,true),true)."</pre>"',
            'type' => 'raw',
            )
        );
        return $cols;
    }

    /**
     * Retrieves a list of models based on the current search/filter conditions.
     *
     * Typical usecase:
     * - Initialize the model fields with values from filter form.
     * - Execute this method to get CActiveDataProvider instance which will filter
     * models according to data in model fields.
     * - Pass data provider to CGridView, CListView or any similar widget.
     *
     * @return CActiveDataProvider the data provider that can return the models
     * based on the search/filter conditions.
     */
    public function search()
    {
        // @todo Please modify the following code to remove attributes that should not be searched.

        $criteria = new CDbCriteria();

        $criteria->compare('tid', $this->tid);
        $criteria->compare('name', $this->name, true);
        $criteria->compare('title', $this->title, true);
        $criteria->compare('icon', $this->icon, true);
        $criteria->compare('description', $this->description, true);
        $criteria->compare('active', $this->active);
        $criteria->compare('permission', $this->permission, true);
        $criteria->compare('permission_grade', $this->permission_grade, true);

        return new CActiveDataProvider($this, array(
            'criteria' => $criteria,
        ));
    }


    /**
     * @param string $tutorialName
     * @return Tutorial
     */
    public function findByName($tutorialName)
    {
        $defaultTutorials = LsDefaultDataSets::getTutorialData();
        if (array_key_exists($tutorialName, $defaultTutorials)) {
            $oTutorial = new Tutorial();

            array_walk($defaultTutorials[$tutorialName], function ($attribute, $key) use (&$oTutorial) {
                $oTutorial->setAttribute($key, $attribute);
            });

            return $oTutorial;
        }
        return $this->find('name=:name', [':name' => $tutorialName]);
    }

    public function getDefaultTutorials()
    {
        $aDefaultTutorials = LsDefaultDataSets::getTutorialData();
        $result = [];
        foreach ($aDefaultTutorials as $aDefaultTutorial) {
            $oTutorial = new Tutorial();
            $oTutorial->setAttributes($aDefaultTutorial);
            $result[] = $oTutorial;
        }
        return $result;
    }

    public function getActiveTutorials()
    {
        $aTutorials = self::model()->findAll('active=1');
        if (!empty($aTutorials)) {
            return array_merge($aTutorials, $this->getDefaultTutorials());
        }

        return $this->getDefaultTutorials();
    }

    public function setFinished($iUserId)
    {
        $oMapTutUser = MapTutorialUsers::model()->find('uid=:uid AND tid=:tid', [':uid' => $iUserId, 'tid' => $this->tid]);
        if ($oMapTutUser == null) {
            $oMapTutUser = new MapTutorialUsers();
            $oMapTutUser->setAttributes([
                'uid' => $iUserId,
                'tid' => $this->tid
            ]);
            @$oMapTutUser->save();
        }
    }

    public function getTutorialDataArray($tutorialName)
    {
        $aSteps = [];

        if ($this->tid === null) {
            $defaultEntries = LsDefaultDataSets::getTutorialEntryData();
            $this->tid = $tutorialName;
            foreach ($defaultEntries[$tutorialName] as $aTutorialMapEntry) {
                $oTutorialEntry = new TutorialEntry();
                $oTutorialEntry->setAttributes($aTutorialMapEntry, false);
                $aSteps[] = $oTutorialEntry->getStepFromEntry();
            }
        } else {
            $aTutorialEntryRelations = TutorialEntryRelation::model()->findAll('tid=:tid', [':tid' => $this->tid]);
            foreach ($aTutorialEntryRelations as $oTutorialMapEntry) {
                $oTutorialEntry = $oTutorialMapEntry->tutorialEntry;
                $aSteps[] = $oTutorialEntry->getStepFromEntry();
            }
        }

        $aTutorialData = json_decode($this->settings, true);
        $aTutorialData['steps'] = $aSteps;
        $aTutorialData['tid'] = $this->tid;

        return $aTutorialData;
    }

    /**
     * Returns the static model of the specified AR class.
     * Please note that you should have this exact method in all your CActiveRecord descendants!
     * @param string $className active record class name.
     * @return Tutorial the static model class
     */
    public static function model($className = __CLASS__)
    {
        /** @var Tutorial $model */
        $model = parent::model($className);
        return $model;
    }
}