Login   Register  
Icontem

File: tests/default.php

Recommend this page to a friend!
Stumble It! Stumble It! Bookmark in del.icio.us Bookmark in del.icio.us
  Classes of Jason Gerfen  >  jQuery.pidCrypt  >  tests/default.php  >  Download  
File: tests/default.php
Role: Auxiliary data
Content type: text/plain
Description: Auxiliary data
Class: jQuery.pidCrypt
Encrypt form values using RSA and AES
Author: By
Last change:
Date: 2012-05-21 06:18
Size: 5,321 bytes
 

Contents

Class file image Download
<?php

/* session init */
session_start();

/* fix sync problems or delete session file */
//unset($_SESSION); exit();

/* does our configuration file exist? */
if (!file_exists('config.php')) {
 exit('config.php file does not exist');
}
include 'config.php';

/* load the libraries class */
if (!file_exists('../libs/classes/class.libraries.php')) {
 exit('../libs/classes/class.libraries.php does not exist');
}
include '../libs/classes/class.libraries.php';

/* handle for libraries object */
$libs = new libraries;

/* load the ajax class */
if (!file_exists('../libs/classes/class.ajax.php')) {
 exit('../libs/classes/class.ajax.php does not exist');
}
include '../libs/classes/class.ajax.php';

/* load the openssl class */
if (!file_exists('../libs/classes/class.openssl.php')) {
 exit('../libs/classes/class.openssl.php does not exist');
}
include '../libs/classes/class.openssl.php';

/* verify settings */
if (!verify($settings)) {
 exit($libs->JSONencode(array('error'=>'Please configure the config.php file')));
}

/* handle for class object */
$openssl = openssl::instance($settings);

if (!is_object($openssl)) {
 exit($libs->JSONencode(array('error'=>'An error occured when initializing the OpenSSL class')));
}

if (!empty($_POST)) {

 /* ensure our ajax request passes required checks */
 $ajax = new ajax;
 if (!$ajax){
  exit($libs->JSONencode(array('error'=>'AJAX request did not pass sanity checks')));
 }

 /* make sure we have our necessary data, creates new keypair if not */
 if ((empty($_SESSION[$libs->_getRealIPv4()]['default']['private-key']))||
     (empty($_SESSION[$libs->_getRealIPv4()]['default']['public-key']))){
  create($settings, $openssl, $libs, 'default');
 }

 /*
  * public key?
  * If you used a database to store existing keys
  * add the support after this conditional
  */
 if ((!empty($_POST['key']))&&($_POST['key']==='true')){
  exit($libs->JSONencode(array('key'=>$_SESSION[$libs->_getRealIPv4()]['default']['public-key'])));
 }

 /* if more then two keyring entries exist with our users session pick the last entry */
 $c = count($_SESSION[$libs->_getRealIPv4()]);
 $email = ($c >= 2) ? array_pop(array_keys($_SESSION[$libs->_getRealIPv4()])) : 'default';

 /*
  * If you wish to do anything further such as add a response that the data was recieved by the server etc
  * add it here (this is EXAMPLE ONLY because it decrypts the sent data)
  */
 $x = $libs->JSONencode(helper($_POST, $openssl, $libs, $_SESSION[$libs->_getRealIPv4()][$email]['private-key']));

 /*
  * We create and append a new keyring entry for the client to store based on the email
  * that was provided. This is example code only and a database driven example should be
  * developed within your project. Please see the implementation guide for more information.
  */
 exit($libs->JSONencode(array('success'=>$x,'keyring'=>keyring($settings, $openssl, $libs, $x))));
}

/*
 * Create private/public/certificate for referring machine (stored in sessions)
 */
function create($settings, $openssl, $libs, $email)
{
 /* seed the generator */
 $openssl->genRand();

 /* Generate the private key */
 $_SESSION[$libs->_getRealIPv4()][$email]['private-key'] = $openssl->genPriv($libs->_getRealIPv4());

 /* Get the public key */
 $_SESSION[$libs->_getRealIPv4()][$email]['public-key'] = $openssl->genPub();
}

/*
 * Create a new keyring for the response to allow for multiple local public keys
 */
function keyring($s, $ssl, $libs, $d)
{
 $r = '';
 if (!empty($d)){

  /* decode object */
  $obj = json_decode($d);

  /* call create() if keyring entry doesnt exist & $obj->{'email'} is valid */
  if ((!array_key_exists($obj->{'email'}, $_SESSION[$libs->_getRealIPv4()]))&&(!empty($obj->{'email'}))) {
   create($s, $ssl, $libs, $obj->{'email'});
  }

  /* create new array with public key and associated email */
  $r = (!empty($obj->{'email'})) ? array('email'=>$obj->{'email'}, 'key'=>$_SESSION[$libs->_getRealIPv4()][$obj->{'email'}]['public-key']) : $r;
 }
 return $r;
}

/*
 * Verify our $settings array
 */
function verify($array)
{
 return ((!empty($array['dn']['countryName']))&&
         (!empty($array['dn']['stateOrProvinceName']))&&
         (!empty($array['dn']['localityName']))&&
         (!empty($array['dn']['organizationName']))&&
         (!empty($array['dn']['organizationalUnitName']))&&
         (!empty($array['dn']['commonName']))&&
         (!empty($array['dn']['emailAddress']))) ? true : false;
}

/*
 * Because of limitations with the RSA encryption
 * using public keys we may need to process an
 * array of encrypted data from the client
 */
function helper($array, $openssl, $libs, $pkey)
{
 if (is_array($array)) {
  foreach($array as $key => $value) {
   if (is_array($value)) {
    foreach($value as $k => $v) {
     $b[$k] = $openssl->privDenc($v, $pkey, $libs->_getRealIPv4());
    }
    $a[$key] = combine($b);
   } else {
    $a[$key] = $openssl->privDenc($value, $pkey, $libs->_getRealIPv4());
   }
  }
 } else {
  $a = $openssl->privDenc($array, $pkey, $libs->_getRealIPv4());
 }
 return $a;
}

/*
 * Put the original string back
 * together
 */
function combine($array) {
 $a = '';
 if (is_array($array)){
  foreach($array as $k => $v) {
   if (is_array($v)) {
    combine($array);
   } else {
    $a .= $v;
   }
  }
 } else {
  $a = $array;
 }
 return $a;
}

?>