PHP 5.4+ class for interacting with a bloomd server (https://github.com/armon/bloomd). MIT Licensed.
php-bloomd can be installed via Composer. Add "mdlayher/php-bloomd": "dev-master"
to the require
section
of your composer.json
and run composer install
.
php-bloomd can be tested using PHPUnit. Simply run phpunit test
from the project root with a local bloomd
server running on port 8673.
All commands accepted by bloomd are implemented in php-bloomd. Here is a basic example script.
<?php
// php-bloomd - Example basic usage script
require_once __DIR__ . "/vendor/autoload.php";
// Establish a connection to a local bloomd with client
$bloomd = new PhpBloomd\BloomdClient("localhost", 8673);
// Create a filter
if (!$bloomd->createFilter("php"))
{
printf("example: failed to create filter\n");
exit;
}
// Create a filter object to use more concise, object-oriented interface
$filter = $bloomd->filter("php");
// Set a couple of values in filter, using both BloomdClient and direct BloomFilter
// Either method may be used for all functions which accept a filter name as first parameter
$bloomd->set("php", "foo");
$filter->set("bar");
// Check the filter for membership
if ($bloomd->check("php", "foo"))
{
printf("example: got it!\n");
}
// Bulk set values
$results = $filter->bulk(array("foo", "bar", "baz"));
foreach ($results as $k => $v)
{
printf("%s -> %s\n", $k, $v ? "true" : "false");
}
// Multi check values
$results = $filter->multi(array("foo", "bar", "baz"));
foreach ($results as $k => $v)
{
printf("%s -> %s\n", $k, $v ? "true" : "false");
}
// Check for any value in array
if ($filter->any(array("foo", "qux")))
{
printf("any: yes!\n");
}
// Check for all values in array
if ($filter->all(array("foo", "bar", "baz")))
{
printf("all: yes!\n");
}
// Drop filter
$filter->dropFilter();