<?php
/**
* Project: Distrubution License Class
* File: example.oninstall.php
* File type: DEMO
* Notes: This file is a demonstration file that illustrates various
* ways to generate and check a license key
*
* Copyright (C) 2005 Oliver Lillie
*
* 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.
*
* 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
*
* @link http://www.buggedcom.co.uk/
* @link http://www.phpclasses.org/browse/package/2298.html
* @author Oliver Lillie, buggedcom <publicmail at buggedcom dot co dot uk>
* @version 0.1
* @history---------------------------------------------
* see CHANGELOG
*/
$file = 'license.oninstall.dat';
if(isset($_GET['WIPE']))
{
$h = fopen($file, 'a');
ftruncate($h, 0);
fclose($h);
header('Location: '.$_SERVER['PHP_SELF']);
exit;
}
# copy the server vars (important for security, see note below)
$server_array = $_SERVER;
echo '<link rel="stylesheet" type="text/css" href="../shared/styles.css">';
echo '<body>'."\r\n";
echo '<span class="header">'."\r\n";
echo '<b>########################################################################</b><br />'."\r\n";
echo '<b>Generation Demonstration</b><br />'."\r\n";
echo 'This file demonstrates the generation of a key on install of the application. It registers the <br />'."\r\n";
echo 'install with the license server. It then generates a temporary license key that is valid for two days.<br />'."\r\n";
echo 'NOTE: This connects to a demo license server that resides on my server. It is set to allow<br />'."\r\n";
echo 'any amount of install requests from the same ip and mac address, this can however be limited<br />'."\r\n";
echo 'using, ip addresses, domains, mac addresses.<br />'."\r\n";
echo '<span style="font-size: 10;">'."\r\n";
echo '<b>Oliver Lillie, buggedcom [publicmail at buggedcom dot co dot uk]<br />'."\r\n";
echo '<a href="http://www.buggedcom.co.uk/" target="_blank" style="color: #F00">http://www.buggedcom.co.uk/</a></b><br />'."\r\n";
echo '</span>'."\r\n";
echo '<b>########################################################################</b><br /><br />'."\r\n";
echo '</span>'."\r\n";
# import the classes
include_once('../shared/class.license.lib.php');
include_once('class.license.app.php');
include_once('class.license.gen.php');
# initialise the class
# note for this demonstration script we will turn off mcrypt usage
# as some systems do not have it installed in their setup.
# the initial argument usually defaults to true (use mcrypt)
$architect = new license_architect($file, false, true, true, true);
# set the server vars
# note this doesn't have to be set, however if not all of your app files are encoded
# then there would be a possibility that the end user could modify the server vars
# to fit the key thus making it possible to use your app on any domain
# you should copy your server vars in the first line of your active script so you can
# use the unmodified copy of the vars
$architect->set_server_vars($server_array);
# add some data vars
# remember that the reserver variable names in the data is _PHP_OS and _PHP_VERSION
$data = array();
$data['MAX_UPLOADS'] = 10;
$data['WATERMARK_IMAGES'] = true;
$data['COPYRIGHT_TEXT'] = 'This project is copyrighted to FooBar Limited 2005.';
# work out secs in two weeks
# NOTE: an important thing to remember for this example. Although we are
# asking for a 2 week license, the approval value set on server is 2 days
# Even though the license returned is temporary if it returned the actual key
# it would be capped by the approval time value to two days.
$span = 60*60*24*7*2;
# $span = 'NEVER';
# generate the install request
$results = $architect->register_install('localhost', 0, $span, $data, 'www.buggedcom.co.uk', 'http://www.buggedcom.co.uk/distributionlicense/files/server/demo.register.license.php');
echo '<span style="font-size: 10;">'."\r\n";
echo '</span>'."\r\n";
echo '<b>########################################################################</b><br />'."\r\n";
echo '<b>On Install</b><br />'."\r\n";
echo 'The server details are evaluated in this script and if they meet the requirements the data<br />'."\r\n";
echo 'is sent to my server and makes checks against the demo license server. If the request is<br />'."\r\n";
echo 'approved. This file generates a temporary key to <a href="license.oninstall.dat" target="_blank" class="bodylink">license.oninstall.dat</a> license file<br />'."\r\n";
echo '<b>########################################################################</b><br /><br />'."\r\n";
echo '<span style="color: #F00"><b>Result of the License Request is : '.$results['RESULT'].'</b></span><br />';
switch($results['RESULT'])
{
# this example will never return ok because my server is set to ADMIN
# and returns temp keys valid for two days
case 'OK' :
# if everything went ok for this example then PENDING is the result
# it means that a temp key has been returned
case 'PENDING' :
$key = $architect->validate($results['KEY']);
echo '<span style="font-size: 10;color: #F00;">'."\r\n";
echo 'Key is valid untill : '.$key['DATE']['HUMAN']['END'];
echo '</span><br /><br />'."\r\n";
if($architect->writeKey($results['KEY']))
{
echo '<span style="color: #F00"><b>License Key Written to <a href="license.oninstall.dat" target="_blank" style="color: #F00;">license.oninstall.dat</a></b></span><br /><br />';
}
else
{
}
echo '<b>Requested License Key</b><br />'."\r\n";
echo '<pre>'.$results['KEY'].'</pre><br />'."\r\n";
echo '<b>Requested License Key Contents</b><br />'."\r\n";
echo '<pre>';
print_r($key);
echo '</pre><br />'."\r\n";
break;
# means something went wrong transfering the data and no data was recieved by the server
case 'EMPTY_DATA' :
echo '<br /><span style="color: #F00"><b>WARNING : No request data was received by the license server.</b></span><br /><br />';
break;
# the socket failed to be opened and no data could be sent
case 'SOCKET_FAILED' :
echo '<br /><span style="color: #F00"><b>WARNING : It was not possible to open a socket to connect to the license server.</b></span><br /><br />';
break;
# the domain supplied by the registering client didn't match the collected ip addresses
# thus the request failed
case 'DOMAIN_IP_FAIL' :
echo '<br /><span style="color: #F00"><b>WARNING : The domain supplied by this script did not match the corresponding IP Address.<br />';
echo 'Please edit the address on line #83 to the address you are running this script on.</b></span><br /><br />';
break;
# the number of required $_SERVER vars were not met and thus failed the request
case 'SERVER_FAIL' :
echo '<br /><span style="color: #F00"><b>WARNING : The number of $_SERVER vars supplied by your server did not meet the required number.</b></span><br /><br />';
break;
# either the key has already been written or a temp key has been written
case 'KEY_EXISTS' :
echo '<br /><span style="color: #F00"><b>WARNING : The key has already been written.</b></span><br />';
echo '<span style="color: #F00;font-size: 10;">'."\r\n";
echo 'To wipe the generated key click <a href="?WIPE=1" style="color: #F00">here</a><br />'."\r\n";
echo '</span><br /><br />'."\r\n";
break;
case 'SERVER_DB_FAILED' :
echo '<br /><span style="color: #F00"><b>WARNING : The server failed to store the license request, as a result the request failed.<br />';
echo 'The mysql error was as follows :</b><br /><br />';
echo wordwrap($results['ERROR'], 130, '<br />').'</b></span>';
}
# make the application secure by running this function
# it also prevents any future reincarnations of the class calling any of the
# key generation and validation functions, it also deletes any class variables
# that may be set.
$architect->make_secure();
# delete the $architect object
unset($architect);
echo '</body>'."\r\n";
?>
|