Overview

Packages

  • application
    • commands
    • components
      • actions
      • filters
      • leftWidget
      • permissions
      • sortableWidget
      • util
      • webupdater
      • x2flow
        • actions
        • triggers
      • X2GridView
      • X2Settings
    • controllers
    • models
      • embedded
    • modules
      • accounts
        • controllers
        • models
      • actions
        • controllers
        • models
      • calendar
        • controllers
        • models
      • charts
        • models
      • contacts
        • controllers
        • models
      • docs
        • components
        • controllers
        • models
      • groups
        • controllers
        • models
      • marketing
        • components
        • controllers
        • models
      • media
        • controllers
        • models
      • mobile
        • components
      • opportunities
        • controllers
        • models
      • products
        • controllers
        • models
      • quotes
        • controllers
        • models
      • services
        • controllers
        • models
      • template
        • models
      • users
        • controllers
        • models
      • workflow
        • controllers
        • models
      • x2Leads
        • controllers
        • models
  • None
  • system
    • base
    • caching
    • console
    • db
      • ar
      • schema
    • validators
    • web
      • actions
      • auth
      • helpers
      • widgets
        • captcha
        • pagers
  • zii
    • widgets
      • grid

Classes

  • GridViewDbSettingsBehavior
  • GridViewSessionSettingsBehavior
  • X2Settings
  • Overview
  • Package
  • Class
  • Tree
  1: <?php
  2: /*****************************************************************************************
  3:  * X2Engine Open Source Edition is a customer relationship management program developed by
  4:  * X2Engine, Inc. Copyright (C) 2011-2016 X2Engine Inc.
  5:  * 
  6:  * This program is free software; you can redistribute it and/or modify it under
  7:  * the terms of the GNU Affero General Public License version 3 as published by the
  8:  * Free Software Foundation with the addition of the following permission added
  9:  * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
 10:  * IN WHICH THE COPYRIGHT IS OWNED BY X2ENGINE, X2ENGINE DISCLAIMS THE WARRANTY
 11:  * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
 12:  * 
 13:  * This program is distributed in the hope that it will be useful, but WITHOUT
 14:  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 15:  * FOR A PARTICULAR PURPOSE.  See the GNU Affero General Public License for more
 16:  * details.
 17:  * 
 18:  * You should have received a copy of the GNU Affero General Public License along with
 19:  * this program; if not, see http://www.gnu.org/licenses or write to the Free
 20:  * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
 21:  * 02110-1301 USA.
 22:  * 
 23:  * You can contact X2Engine, Inc. P.O. Box 66752, Scotts Valley,
 24:  * California 95067, USA. or at email address contact@x2engine.com.
 25:  * 
 26:  * The interactive user interfaces in modified source and object code versions
 27:  * of this program must display Appropriate Legal Notices, as required under
 28:  * Section 5 of the GNU Affero General Public License version 3.
 29:  * 
 30:  * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
 31:  * these Appropriate Legal Notices must retain the display of the "Powered by
 32:  * X2Engine" logo. If the display of the logo is not reasonably feasible for
 33:  * technical reasons, the Appropriate Legal Notices must display the words
 34:  * "Powered by X2Engine".
 35:  *****************************************************************************************/
 36: 
 37: /**
 38:  * Manages storage and retrieval of settings.
 39:  *
 40:  * @package application.components.X2Settings
 41:  */
 42: abstract class X2Settings extends CBehavior {
 43: 
 44:     /**
 45:      * @var string|null $uid Allows state prefix to be explicitly set
 46:      */
 47:     public $uid = null; 
 48:     
 49:     /**
 50:      * @var string $modelClass class of model for which settings are being saved/retrieved
 51:      */
 52:     public $modelClass; 
 53: 
 54:     /**
 55:      * session/db JSON key
 56:      * @var string|null
 57:      */
 58:     private $_statePrefix; 
 59:     
 60:     // commented out since they might become useful
 61:     /**
 62:      * @param string $uid 
 63:      * @param array (<setting name> => <setting val>) $settings The settings to save
 64:      * @return bool true for success, false otherwise
 65:      */
 66:     //public function saveSettings ($uid, array $settings);
 67: 
 68:     /**
 69:      * @param string $uid 
 70:      */
 71:     //public function getSettings ($uid);
 72: 
 73:     /**
 74:      * @param string key the setting name
 75:      * @param string key the setting value
 76:      * @return bool true for success, false otherwise
 77:      */
 78:     abstract public function saveSetting ($key, $val);
 79: 
 80:     /**
 81:      * @param string key the setting name
 82:      * @return mixed The value of the gv setting
 83:      */
 84:     abstract public function getSetting ($key);
 85: 
 86:     /**
 87:      * state prefix defaults to uid or uid constructed from path and model id. It might be
 88:      * better to call this getUID since the state prefix isn't actually a prefix, it is the key in
 89:      * its entirety.
 90:      * @return string 
 91:      */
 92:     public function getStatePrefix () {
 93:         if (!isset ($this->_statePrefix)) {
 94:             if (isset ($this->uid)) {
 95:                 $this->_statePrefix = $this->uid;
 96:             } else {
 97:                 $this->_statePrefix = ((!Yii::app()->params->noSession ?
 98:                     Yii::app()->controller->uniqueid . '/' . Yii::app()->controller->action->id . 
 99:                         (isset($_GET['id']) ? '/' . $_GET['id'] : '') : '').
100:                     $this->modelClass);
101:             }
102:         }
103:         return $this->_statePrefix;
104:     }
105: 
106: }
107: ?>
108: 
X2CRM Documentation API documentation generated by ApiGen 2.8.0