File Manager

Current Path : /webspace/www.babilon.be/html/modules/CGExtensions/lib/
Upload File :
Current File : //webspace/www.babilon.be/html/modules/CGExtensions/lib/class.encrypted_store.php

<?php
#BEGIN_LICENSE
#-------------------------------------------------------------------------
# Module: CGExtensions (c) 2008-2014 by Robert Campbell
#         (calguy1000@cmsmadesimple.org)
#  An addon module for CMS Made Simple to provide useful functions
#  and commonly used gui capabilities to other modules.
#
#-------------------------------------------------------------------------
# CMSMS - CMS Made Simple is (c) 2005 by Ted Kulp (wishy@cmsmadesimple.org)
# Visit the CMSMS Homepage at: http://www.cmsmadesimple.org
#
#-------------------------------------------------------------------------
#
# This program 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.
#
# However, as a special exception to the GPL, this software is distributed
# as an addon module to CMS Made Simple.  You may not use this software
# in any Non GPL version of CMS Made simple, or in any version of CMS
# Made simple that does not indicate clearly and obviously in its admin
# section that the site was built with CMS Made simple.
#
# This program 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 this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
# Or read it online: http://www.gnu.org/licenses/licenses.html#GPL
#
#-------------------------------------------------------------------------
#END_LICENSE

/**
 * A utility class for caching encrypted information.
 *
 * @package CGExtensions
 * @category Utilities
 * @author  calguy1000 <calguy1000@cmsmadesimple.org>
 * @copyright Copyright 2010 by Robert Campbell
 */

/**
 * A utility class for caching encrypted information.
 * This class automatically calculates an encryption key with session specific entropy.
 * However the encryption key can be overridden.
 *
 * @package CGExtensions
 * @see cge_datastore
 * @see cge_encrypt
 */
class encrypted_store
{
    /**
     * @ignore
     */
    static private $_store;

    /**
     * @ignore
     */
    static private $_key;

    /**
     * @ignore
     */
    static private $_enckey;

    /**
     * @ignore
     */
    static private $_timeout = 600;

    /**
     * @ignore
     */
    private static function __make()
    {
        if( is_null(self::$_store) ) {
            self::$_store = new cge_datastore(self::$_timeout);
            self::$_key = md5(__FILE__);

            $config = cmsms()->GetConfig();
            $key = md5(__FILE__ . $config['root_url'] . $config['root_path'] . getenv('REMOTE_ADDR'));
            self::$_enckey = $key;
        }
    }


    /**
     * Get the data expiry time in seconds
     *
     * @return int
     */
    static public function get_timeout()
    {
        return self::$_timeout;
    }


    /**
     * Set the data expiry time in seconds.
     * Since this is encrypted data, it's lifetime is expected to be very short.
     * A maximum of 5 minutes (300 seconds)
     *
     * @param int $num  Expiry timeout in seconds.
     */
    static public function set_timeout($num)
    {
        $num = max($num,300);
        self::$_timeout = $num;
        if( is_object(self::$_store) ) self::$_store->set_expiry($num);
    }


    /**
     * Override the encryption key.
     * It is important to set this key with a long enough value and with enough entropy
     * to be random for different purposes.  i.e: if storing user specific data
     * for a short time it may be appropriate to use the session id as part of the encryption key.
     *
     * @param string $str
     */
    static public function set_key($str)
    {
        self::$_key = $str;
    }


    /**
     * Store encrypted data
     *
     * @param string $data  The data to store
     * @param string $key1 The first key in the encrypted set.  Up to three keys can be used
     * @param string $key2 The optional second key in the encrypted set
     * @param string $key3 The optional third key in the encrypted set
     */
    static public function put($data,$key1,$key2='',$key3='')
    {
        self::__make();
        if( is_null(self::$_enckey) ) die('abort - no encryption key set');
        $ser = serialize($data);
        $tmp = cge_encrypt::encrypt(self::$_enckey,$ser);
        self::$_store->store(base64_encode($tmp),self::$_key,$key1,$key2,$key3);
    }


    /**
     * A convenience method to store data with a special encryption key.
     *
     * @param string $data  The data to store
     * @param string $specialkey The override encryption key.
     * @param string $key1 The first key in the encrypted set.  Up to three keys can be used
     * @param string $key2 The optional second key in the encrypted set
     * @param string $key3 The optional third key in the encrypted set
     */
    static public function put_special($data,$specialkey,$key1,$key2='',$key3='')
    {
        self::__make();
        $tmp = cge_encrypt::encrypt($specialkey,serialize($data));
        self::$_store->store(base64_encode($tmp),self::$_key,$key1,$key2,$key3);
    }

    /**
     * unencrypt and return stored data
     *
     * @param string $key1 The first key in the encrypted set.  Up to three keys can be used
     * @param string $key2 The optional second key in the encrypted set
     * @param string $key3 The optional third key in the encrypted set
     * @return string.
     */
    static public function get($key1,$key2='',$key3='')
    {
        self::__make();
        $tmp = self::$_store->get(self::$_key,$key1,$key2,$key3);
        $tmp = base64_decode($tmp);
        $data = unserialize(cge_encrypt::decrypt(self::$_enckey,$tmp));
        return $data;
    }

    /**
     * unencrypt and return stored data using a special encryption key
     *
     * @param string $key1 The first key in the encrypted set.  Up to three keys can be used
     * @param string $specialkey The override encryption key.
     * @param string $key2 The optional second key in the encrypted set
     * @param string $key3 The optional third key in the encrypted set
     * @return string.
     */
    static public function get_special($specialkey,$key1,$key2='',$key3='')
    {
        self::__make();
        $tmp = self::$_store->get(self::$_key,$key1,$key2,$key3);
        $tmp = base64_decode($tmp);
        $data = unserialize(cge_encrypt::decrypt($specialkey,$tmp));
        return $data;
    }

    /**
     * Erase encrypted data from the datastore
     *
     * @param string $key1 The first key in the encrypted set.  Up to three keys can be used
     * @param string $key2 The optional second key in the encrypted set
     * @param string $key3 The optional third key in the encrypted set
     */
    static public function erase($key1,$key2='',$key3='')
    {
        self::__make();
        self::$_store->erase(self::$_key,$key1,$key2,$key3);
    }

    /**
     * Clean all expired data.
     */
    static public function cleanup()
    {
        self::__make();
        self::$_store->remove_expired();
    }
} // end of class

// EOF
?>

File Manager Version 1.0, Coded By Lucas
Email: hehe@yahoo.com