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/SurveyURLParameter.php
<?php

/*
* LimeSurvey
* Copyright (C) 2007-2011 The LimeSurvey Project Team / Carsten Schmitz
* All rights reserved.
* License: GNU/GPL License v2 or later, see LICENSE.php
* LimeSurvey is free software. This version may have been modified pursuant
* to the GNU General Public License, and as distributed it includes or
* is derivative of works licensed under the GNU General Public License or
* other free or open source software licenses.
* See COPYRIGHT.php for copyright notices and details.
*
*/

/**
 * Class SurveyURLParameter
 *
 * @property integer $id
 * @property integer $sid Survey ID
 * @property string $parameter
 * @property integer $targetqid
 * @property integer $targetsqid
 */
class SurveyURLParameter extends LSActiveRecord
{
    public $searched_value = null;

    /**
     * @return array validation rules for model attributes.
     */
    public function rules()
    {
        return  [
            ['sid', 'required'],
            ['sid', 'numerical', 'integerOnly' => true],
            ['parameter', 'required'],
            ['targetqid', 'numerical', 'integerOnly' => true],
            ['targetsqid', 'numerical', 'integerOnly' => true, 'allowEmpty' => true],
        ];
    }

    /**
     * @inheritdoc
     * @return SurveyURLParameter
     */
    public static function model($className = __CLASS__)
    {
        /** @var self $model */
        $model = parent::model($className);
        return $model;
    }

    /** @inheritdoc */
    public function primaryKey()
    {
        return 'id';
    }

    /** @inheritdoc */
    public function tableName()
    {
        return '{{survey_url_parameters}}';
    }
    /** @inheritdoc */
    public function relations()
    {
        return array(
            'survey' => array(self::BELONGS_TO, 'Survey', 'sid', 'together' => true),
            'question' => array(self::BELONGS_TO, 'Question', array('targetqid' => 'qid')),
            'subquestion' => array(self::BELONGS_TO, 'Question', array('targetsqid' => 'qid'))
        );
    }
    /**
     * @param integer $iSurveyID
     * @return mixed
     */
    public function getParametersForSurvey($iSurveyID)
    {
        return Yii::app()->db->createCommand("select '' as act, up.*,q.title, sq.title as sqtitle from {{survey_url_parameters}} up
            left join {{questions}} q on q.qid=up.targetqid
            left join {{questions}} sq on q.qid=up.targetsqid
            where up.sid=:surveyid")
            ->bindParam(":surveyid", $iSurveyID, PDO::PARAM_INT)
            ->query();
    }

    /**
     * @param array $aConditions
     * @return mixed
     */
    public function deleteRecords($aConditions)
    {
        foreach ($aConditions as $sFieldname => $sFieldvalue) {
            Yii::app()->db->createCommand()->where($sFieldname, $sFieldvalue);
        }
        return Yii::app()->db->delete('survey_url_parameters'); // Deletes from token
    }

    /**
     * @param array $aData
     * @return mixed
     */
    public function insertRecord($aData)
    {
        return Yii::app()->db->createCommand()->insert('{{survey_url_parameters}}', $aData);
    }

    /**
     * @return CActiveDataProvider
     */
    public function search()
    {
        $pageSize = Yii::app()->user->getState('pageSize', Yii::app()->params['defaultPageSize']);

        $survey = Survey::model()->findByPk($this->sid);
        $language = $survey->language;

        $criteria = new CDbCriteria();
        $criteria->with = ['question', 'question.questionl10ns', 'subquestion', 'subquestion.questionl10ns' => ['alias' => 'subquestionl10ns']];
        $criteria->together = true;
        $criteria->compare('t.parameter', $this->searched_value, true);
        $criteria->compare('question.title', $this->searched_value, true, 'OR');
        $criteria->compare('questionl10ns.question', $this->searched_value, true, 'OR');
        $criteria->compare('question.title', $this->searched_value, true, 'OR');
        $criteria->compare('subquestionl10ns.question', $this->searched_value, true, 'OR');
        $criteria->addCondition('t.sid=:surveyid');
        $criteria->addCondition('questionl10ns.language=:language OR questionl10ns.language IS NULL');
        $criteria->addCondition('subquestionl10ns.language=:language2 OR subquestionl10ns.language IS NULL');
        $criteria->params[':surveyid'] = $this->sid;
        $criteria->params[':language'] = $language;
        $criteria->params[':language2'] = $language;    // For some reason MS SQL fails if we use the same parameter twice

        $sort = new CSort();
        $sort->defaultOrder = array('parameter' => false, 'target_question' => false);
        $sort->attributes = array(
            'parameter' => array(
                'asc' => 'parameter',
                'desc' => 'parameter desc',
            ),
            'target_question' => array(
                'asc' => 'question.title, questionl10ns.question, subquestionl10ns.question',
                'desc' => 'subquestionl10ns.question desc, questionl10ns.question desc, question.title desc',
            ),
        );

        $dataProvider = new CActiveDataProvider(get_class($this), array(
            'criteria' => $criteria,

            'sort' => $sort,

            'pagination' => array(
                'pageSize' => $pageSize,
            ),
        ));

        return $dataProvider;
    }

    /**
     * @return string
     */
    public function getButtons()
    {
        $permissionPanelEdit = Permission::model()->hasSurveyPermission(
            $this->sid,
            'surveysettings',
            'update'
        );
        $permissionParameterDelete = Permission::model()->hasSurveyPermission(
            $this->sid,
            'surveysettings',
            'update'
        );
        $dropdownItems = [];
        $dropdownItems[] = [
            'title'            => gT('Edit parameter'),
            'iconClass'        => 'ri-pencil-fill',
            'linkClass'        => 'surveysettings_edit_intparameter',
            'enabledCondition' => $permissionPanelEdit,
            'linkAttributes'   => [
                'data-id'        => $this->id,
                'data-parameter' => $this->parameter,
                'data-qid'       => $this->targetqid,
            ],
        ];
        $dropdownItems[] = [
            'title'            => gT('Delete parameter'),
            'iconClass'        => 'ri-delete-bin-fill text-danger',
            'linkClass'        => 'surveysettings_delete_intparameter selector--ConfirmModal',
            'url'             => Yii::app()->createUrl("surveyAdministration/deleteUrlParam"),
            'linkAttributes'   => [
                'data-button-no'   => gT('Cancel'),
                'data-button-yes'  => gT('Delete'),
                'data-button-type' => 'btn-danger',
                'data-post'        => json_encode(['surveyId' => $this->sid, 'urlParamId' => $this->id]),
                'data-text'        => gT("Are you sure you want to delete this URL parameter?"),
            ],
            'enabledCondition' => $permissionParameterDelete
        ];

        return App()->getController()->widget(
            'ext.admin.grid.GridActionsWidget.GridActionsWidget',
            ['dropdownItems' => $dropdownItems],
            true
        );
    }

    public function getQuestionTitle()
    {
        $baseLanguage = Survey::model()->findByPk($this->sid)->language;
        $title = '';
        if ($this->targetqid != '') {
            $title = $this->question->title . ": " . ellipsize(flattenText($this->question->questionl10ns[$baseLanguage]->question, false, true), 43, .70);
        }
        if ($this->targetsqid != '') {
            $title .= (' - ' . ellipsize(flattenText($this->subquestion->questionl10ns[$baseLanguage]->question, false, true), 30, .75));
        }
        return $title;
    }
}