Skip to content
PHP Aplication Distribution Licensing
Branch: master
Clone or download
Latest commit b71722b Jan 1, 2017

README.md

PHP Aplication Distribution Licensing

What is PADL

A class to generate and validate licenses for a domain, restricting an expire date.

Demo and API

History

PADL is a originaly written in 2005 by Oliver Lillie under older PHP4, parked on PHPCLASSES site. You can find the original code as part as this distribution or directelly in PHP-Generate-PHP-application-license-keys.

You can see a quote about:

There are several solutions to help developers protecting the PHP software
of applications that they want to sell.

Usually the developers provide license keys with their software
that include information about the licensed code, enabled features,
authorized configuration of the environment on which it is being installed.

This helps the developers to limit the scope of usage of their
software according to the type of software license that their clients purchase.

This way the developers can use the same software distribution
for different configurations and prices and even trial versions.

This class provides a means to generate license keys that include encrypted
information about the clients PHP environment and even a way to send the keys
to the developers site so they can capture the client features and generate
upgraded keys that can enable more features for clients that pay the upgrade price.

Manuel Lemos (PHPCLASSES manteiner)

When I need to licence a PHP project, found this class and as it was so well written, it was very easy to update it to PH 5.2 and 5.3.

You can find more about the original author in:

TODO

A validator server is not yet implemented - code was not converted to PHP 5.2 and 5.3 - but in fact it could be done very easily with a webservice.

Instaling

composer require rafaelgou/padl

Usage

On examples directory there are a many examples of basic usage. Run the examples under a web server.

To test under a localhost, use the parameter allowLocal=True.

To generate and validate the license the code MUST BE and MUST RUN under the domain to be validated.

You can store the license in a file, database, or even remotely.

Generate

<?php
/*
Instance of License
parameters:
- useMcrypt
- useTime
- useServer
- allowLocal
*/
$padl = new Padl\License(true, true, true, true);

//For better security injecting a copy of $_SERVER global var
$server_array = $_SERVER;
$padl->setServerVars($server_array);

$date_expire = '12/31/2011';
list($month, $day, $year) = explode($date_expire);
// Calculating the time offset (expire_in)
$now       = mktime(date('H'), date('i'), date('s'), date('m'), date('d') , date('Y'));
$dateLimit = mktime(23, 59, 59, $month, $day, $year);
$expireIn  = $dateLimit - $now;

// Generating a key with your server details
$license = $padl->generate('localhost', 0, $expire_in);

// Save the license anywhere, database, filesystem, even remotely

Validate

<?php
/*
Instance of License
parameters used in this sample:
- useMcrypt  = false
- useTime    = true
- useServer  = false
- allowLocal = true
*/
$padl = new PadlLicense(true, true, true, true);

// For better security injecting a copy of $_SERVER global var
$server_array = $_SERVER;
$padl->setServerVars($server_array);

// get the license from a form, or load from database, filesystem
$license = (... load the license ...);

// the set key is the key validated
$results = $padl->validate($license);
You can’t perform that action at this time.