Spamworldpro Mini Shell
Spamworldpro


Server : Apache
System : Linux indy02.toastserver.com 3.10.0-962.3.2.lve1.5.85.el7.x86_64 #1 SMP Thu Apr 18 15:18:36 UTC 2024 x86_64
User : palandch ( 1163)
PHP Version : 7.1.33
Disable Function : NONE
Directory :  /home/palandch/www/core/components/formit/model/formit/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : //home/palandch/www/core/components/formit/model/formit/fidictionary.class.php
<?php
/**
 * FormIt
 *
 * Copyright 2009-2012 by Shaun McCormick <shaun@modx.com>
 *
 * FormIt is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License as published by the Free
 * Software Foundation; either version 2 of the License, or (at your option) any
 * later version.
 *
 * FormIt is distributed in the hope that it will be useful, but WITHOUT ANY
 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
 * A PARTICULAR PURPOSE. See the GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License along with
 * FormIt; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
 * Suite 330, Boston, MA 02111-1307 USA
 *
 * @package formit
 */
/**
 * Abstracts storage of values of posted fields and fields set by hooks.
 *
 * @package formit
 */
class fiDictionary {
    /**
     * A reference to the modX instance
     * @var modX $modx
     */
    public $modx;
    /**
     * A reference to the FormIt instance
     * @var FormIt $formit
     */
    public $formit;
    /**
     * A configuration array
     * @var array $config
     */
    public $config = array();
    /**
     * An array of key->name pairs storing the fields passed
     * @var array $fields
     */
    public $fields = array();

    /**
     * @param FormIt $formit
     * @param array $config
     */
    function __construct(FormIt &$formit,array $config = array()) {
        $this->modx =& $formit->modx;
        $this->formit =& $formit;
        $this->config = array_merge($this->config,$config);
    }

    /**
     * Get the fields from POST
     *
     * @param array $fields A default set of fields to load
     * @return void
     */
    public function gather(array $fields = array()) {
        if (empty($fields)) $fields = array();
        $this->fields = array_merge($fields,$_POST);
        if (!empty($_FILES)) { $this->fields = array_merge($this->fields,$_FILES); }
    }

    /**
     * Set a value
     * @param string $field
     * @param mixed $value
     * @return void
     */
    public function set($field,$value) {
        $this->fields[$field] = $value;
    }

    /**
     * Get a field value
     * @param string $field
     * @return mixed
     */
    public function get($field) {
        return $this->fields[$field];
    }

    /**
     * Return all field values in an array of key->name pairs
     * @return array
     */
    public function toArray() {
        return $this->fields;
    }

    /**
     * Set a variable number of fields by passing in a key->name pair array
     * @param array $array
     * @return void
     */
    public function fromArray(array $array) {
        foreach ($array as $k => $v) {
            $this->fields[$k] = $v;
        }
    }

    /**
     * Remove a field from the stack
     * @param string $key
     * @return void
     */
    public function remove($key) {
        unset($this->fields[$key]);
    }

    /**
     * Stash the fields into the cache
     * 
     * @return void
     */
    public function store() {
         /* default to store data for 5 minutes */
        $storeTime = $this->modx->getOption('storeTime',$this->config,300);
        /* create the hash to store */
        $cacheKey = $this->formit->getStoreKey();
        $data = $this->toArray();
        $this->modx->cacheManager->set($cacheKey,$data,$storeTime);
        unset($data);
    }

    /**
     * Retrieve the fields from the cache
     * 
     * @return mixed
     */
    public function retrieve() {
        $cacheKey = $this->formit->getStoreKey();
        return $this->modx->cacheManager->get($cacheKey);
    }

    /**
     * Erase the stored fields
     * 
     * @return boolean
     */
    public function erase() {
        $cacheKey = $this->formit->getStoreKey();
        return $this->modx->cacheManager->delete($cacheKey);
    }

    /**
     * @return void
     */
    public function reset() {
        $this->fields = array();
    }
}

Spamworldpro Mini