phpgroupware-cvs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Phpgroupware-cvs] phpgwapi/inc/adodb/session/adodb-encrypt-mcrypt.php,


From: nomail
Subject: [Phpgroupware-cvs] phpgwapi/inc/adodb/session/adodb-encrypt-mcrypt.php, 1.2
Date: Thu, 30 Dec 2004 07:47:33 +0100

Update of /phpgwapi/inc/adodb/session
Added Files:
        Branch: 
          adodb-encrypt-mcrypt.php

date: 2004/12/30 06:47:33;  author: skwashd;  state: Exp;  lines: +109 -0

Log Message:
new HEAD
=====================================================================
<?php


/*
V4.01 23 Oct 2003  (c) 2000-2004 John Lim (address@hidden). All rights reserved.
         Contributed by Ross Smith (address@hidden). 
  Released under both BSD license and Lesser GPL library license.
  Whenever there is any discrepancy between the two licenses,
  the BSD license will take precedence.
          Set tabs to 4 for best viewing.

*/

if (!function_exists('mcrypt_encrypt')) {
        trigger_error('Mcrypt functions are not available', E_USER_ERROR);
        return 0;
}

/**
 */
class ADODB_Encrypt_MCrypt {
        /**
         */
        var $_cipher;

        /**
         */
        var $_mode;

        /**
         */
        var $_source;

        /**
         */
        function getCipher() {
                return $this->_cipher;
        }

        /**
         */
        function setCipher($cipher) {
                $this->_cipher = $cipher;
        }

        /**
         */
        function getMode() {
                return $this->_mode;
        }

        /**
         */
        function setMode($mode) {
                $this->_mode = $mode;
        }

        /**
         */
        function getSource() {
                return $this->_source;
        }

        /**
         */
        function setSource($source) {
                $this->_source = $source;
        }

        /**
         */
        function ADODB_Encrypt_MCrypt($cipher = null, $mode = null, $source = 
null) {
                if (!$cipher) {
                        $cipher = MCRYPT_RIJNDAEL_256;
                }
                if (!$mode) {
                        $mode = MCRYPT_MODE_ECB;
                }
                if (!$source) {
                        $source = MCRYPT_RAND;
                }

                $this->_cipher = $cipher;
                $this->_mode = $mode;
                $this->_source = $source;
        }

        /**
         */
        function write($data, $key) {
                $iv_size = mcrypt_get_iv_size($this->_cipher, $this->_mode);
                $iv = mcrypt_create_iv($iv_size, $this->_source);
                return mcrypt_encrypt($this->_cipher, $key, $data, 
$this->_mode, $iv);
        }

        /**
         */
        function read($data, $key) {
                $iv_size = mcrypt_get_iv_size($this->_cipher, $this->_mode);
                $iv = mcrypt_create_iv($iv_size, $this->_source);
                $rv = mcrypt_decrypt($this->_cipher, $key, $data, $this->_mode, 
$iv);
                return rtrim($rv, "\0");
        }

}

return 1;

?>




reply via email to

[Prev in Thread] Current Thread [Next in Thread]