GateKeeper allows you to hide part of your product and make it active under given circumstances.
You can install the GateKeeper simply by adding the files into your project or using the composer.
Add the following line to your composer.json
file:
"ipapikas/gatekeeper": "~1.0"
Gatekeeper works with gates and with keepers.
Gates are special software doors that should allow the execution flow when they are open and deny (or do something else) when they are closed. They have a name and a set of keepers.
Keepers are a number of conditions on every gate that decide whether the gate will open or close. On this approach, in order for the gate to open, all the keepers must “allow access”.
GateKeeper library consists of two parts, the initialization and the gate check.
The initialization should usually happen when the application starts, so it can be part of the application bootstrap:
Initialization
// [GateKeeperBootstrap].php
use Gatekeeper\Gate;
use Gatekeeper\GateKeeper;
use Gatekeeper\GateRegistry;
use Gatekeeper\Keeper\DateTimeKeeper;
use Gatekeeper\Keeper\IpAddressKeeper;
// Get / Mock (Symfony) Request object
$request = new \Symfony\Component\HttpFoundation\Request();
// Initialize a gate registry
$registry = new GateRegistry();
// Create a gate that will be activated only for January 2017
$keeper = new DateTimeKeeper(new \DateTime('2017-01-01'), new \DateTime('2017-02-01'));
$gate = new Gate('January-Feature', $keeper);
$registry->register($gate);
// Create a gate that will allow access only from a specific sub-network
$keeper = new IpAddressKeeper($request, ['10.1.1.0/24'], ['20.0.1.0/24']);
$gate = new Gate('Ip-Specific-Feature', $keeper);
$registry->register($gate);
// Setup GateKeeper and set to a container (or create a singleton)
$gateKeeper = new GateKeeper($registry);
$container->set(GateKeeper::class, $gateKeeper);
Gate Check
// example.php
// At any point in our code, we can simply get the GateKeeper and check any gate
// Using a container (like PHP-DI) or a singleton that we have already created
$gateKeeper = $container->get(GateKeeper::class);
// Check gate
if ($gateKeeper->checkGate('January-Feature')) {
// Gate is open
echo 'gate is open';
} else {
// Gate is closed
echo 'gate is closed';
}
You can easily create your own custom keeper that will have its own logic. The logic can include simple conditions like the weather or build more complex logic based on your user profiles or even custom beta tester programs and so on.
Here is an example of how to build a proper keeper:
// MyKeeper.php
namespace MyProject\Gatekeeper\Keeper;
use Gatekeeper\Keeper\AbstractKeeper;
class MyKeeper extends AbstractKeeper
{
/**
* Implementation of keeper allow() function logic.
*/
public function allow()
{
// Implement your allow logic anyway you believe that suits your product
// Remember, it has to return true for the gate to open (along with the rest of the keepers)
}
}
// [GateKeeperBootstrap].php
use Gatekeeper\Gate;
use Gatekeeper\GateKeeper;
use Gatekeeper\GateRegistry;
use MyProject\Gatekeeper\Keeper\MyKeeper;
// Initialize a gate registry
$registry = new GateRegistry();
// Create a gate with MyKeeper
$keeper = new MyKeeper();
$gate = new Gate('My-Feature', $keeper);
$registry->register($gate);
// Create GateKeeper
$gateKeeper = new GateKeeper($registry);