2017 © Pedro Peláez
 

lib database-activator

Activator for manage feature toggles via database

image

flagception/database-activator

Activator for manage feature toggles via database

  • Wednesday, July 11, 2018
  • by bestit
  • Repository
  • 4 Watchers
  • 0 Stars
  • 150 Installations
  • PHP
  • 2 Dependents
  • 3 Suggesters
  • 0 Forks
  • 0 Open issues
  • 2 Versions
  • 0 % Grown

The README.md

Database activator for flagception

Manage feature flags for Flagception with a sql database (mysql, postgres, sqlite, ...)!, (*1)

Download the library

Open a command console, enter your project directory and execute the following command to download the latest stable version of this library:, (*2)

$ composer require flagception/database-activator

Usage

Just create a new DatabaseActivator instance and commit it to your feature manager:, (*3)

// YourClass.php

class YourClass
{
    public function run()
    {
        $activator = new DatabaseActivator(['url' => 'mysql://user:secret@localhost/mydb']);

        $manager = new FeatureManager($activator);
        if ($manager->isActive('your_feature_name')) {
            // do something
        }
    }
}

Connection

This activator use dbal under the hood. We redirect the first argument directly to dbal - so you can use all known connection options (see documentation):, (*4)

User and password
// YourClass.php

class YourClass
{
    public function run()
    {
        $activator = new DatabaseActivator([
            'dbname' => 'mydb',
            'user' => 'user',
            'password' => 'secret',
            'host' => 'localhost',
            'driver' => 'pdo_mysql'
        ]);

        // ...
    }
}
Connection string
// YourClass.php

class YourClass
{
    public function run()
    {
        $activator = new DatabaseActivator([
            'url' => 'mysql://user:secret@localhost/mydb'
        ]);

        // ...
    }
}
PDO instance
// YourClass.php

class YourClass
{
    public function run()
    {
        $activator = new DatabaseActivator([
            'pdo' => $this->myPdoInstance
        ]);

        // ...
    }
}
DBAL instance
// YourClass.php

class YourClass
{
    public function run()
    {
        $activator = new DatabaseActivator($this->myDbalInstance);

        // ...
    }
}

Table

The activator will create the sql table if it does not already exist. The default table name is flagception_features which contains a feature and a state column. You can change the table and columns names by the second argument. It expects an array with values for db_table, db_column_feature and db_column_state. Setting one of the fields in optional., (*5)

Example:, (*6)

// YourClass.php

class YourClass
{
    public function run()
    {
        $activator = new DatabaseActivator(['url' => 'mysql://user:secret@localhost/mydb'], [
            'db_table' => 'my_feature_table',
            'db_column_feature' => 'foo_feature_name',
            'db_column_state' => 'foo_is_active'
        ]);

        // The activator create a table 'my_feature_table' with the column 'foo_feature_name' and 'foo_is_active'.

        $manager = new FeatureManager($activator);
        if ($manager->isActive('your_feature_name')) {
            // do something
        }
    }
}

The Versions

11/07 2018

dev-master

9999999-dev

Activator for manage feature toggles via database

  Sources   Download

MIT

The Requires

 

The Development Requires

database sql postgres doctrine dbal mysql sqlite flagception database-extension pssql

11/07 2018

1.0.0

1.0.0.0

Activator for manage feature toggles via database

  Sources   Download

MIT

The Requires

 

The Development Requires

database sql postgres doctrine dbal mysql sqlite flagception database-extension pssql