2017 © Pedro Peláez
 

library feature-toggle-bundle

Feature toggle is responsible for switching service injection depending on configuration. Allowing to modify system behavior without changing code.

image

cleancode/feature-toggle-bundle

Feature toggle is responsible for switching service injection depending on configuration. Allowing to modify system behavior without changing code.

  • Sunday, February 26, 2017
  • by dgafka
  • Repository
  • 1 Watchers
  • 0 Stars
  • 6 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 2 Versions
  • 0 % Grown

The README.md

Feature-Toggle-Bundle

Description

Feature toggle is responsible for switching service injection depending on configuration.
Allowing to modify system behavior without changing code., (*1)

Example

Example use JMSDiExtraBundle, but you can easily configure it with services.yml, (*2)

Let's say we want to store images. On developer machines we want to store them on file system, but anywhere else we want to store them on amazon., (*3)

interface PictureStorage
{
    /**
     * @param PictureWithContent $picture
     * @return void
     */
    public function store(string $pictureName, string $content);
}


/**
* @DI\Service("amazon_picture_storage")
* @DI\Tag(name="toggle", attributes={"for"="picture_storage", "on"="amazon_storage", "when"="enabled"})
*/
class AmazonPictureStorage
{
    public function store(string $pictureName, string $content)
    {
        // send it amazon
    }
}

/**
* @DI\Service("file_system_picture_storage")
* @DI\Tag(name="toggle", attributes={"for"="picture_storage", "on"="amazon_storage", "when"="disabled"})
*/
class FileSystemPictureStorage
{
    public function store(string $pictureName, string $content)
    {
        // save it locally
    }
}

Now when we have our services defined. We have to set default service, that will always be chosen, if all when specification fails. We are doing it by service aliases. The default for us is amazon_picture_storage, (*4)

services.yml
    picture_storage:
       alias: amazon_picture_storage

We should also have the parameter, that we are using for deciding which implementation to pick.
In our example it's amazon_storage., (*5)

parameters.yml
    amazon_storage: "disabled"

We can make use of our storage now., (*6)

class AppController
{
    private $pictureStorage;

    /**
     * @DI\InjectParams({
     *      "pictureStorage" = @DI\Inject("picture_storage")
     * })
    */
    public function __construct(PictureStorage $pictureStorage)
    {
        $this->pictureStorage = $pictureStorage;       
    }

    public function createPersonWithImage(string $pictureName, string $content)
    {
        $this->pictureStorage->store($pictureName, $content);
    }
}
Annotation Explained

@DI\Tag(name="toggle", attributes={"for"="picture_storage", "on"="amazon_storage", "when"="disabled"}), (*7)

  • name="toggle" - Marks service to be used by FeatureToggleBundle
  • "for"="picture_storage" - Which service alias will replaced
  • "on"="amazon_storage" - Parameter name, that will be used for deciding, which one to inject
  • "when"="disabled" - On what parameter value service containing this tag should be picked

So service that contains above tag will be used when amazon_storage parameters will be equal to "disabled", (*8)

The Versions

26/02 2017

dev-master

9999999-dev

Feature toggle is responsible for switching service injection depending on configuration. Allowing to modify system behavior without changing code.

  Sources   Download

MIT

The Requires

 

by Dariusz Gafka

26/02 2017

1.0.0

1.0.0.0

Feature toggle is responsible for switching service injection depending on configuration. Allowing to modify system behavior without changing code.

  Sources   Download

MIT

The Requires

 

by Dariusz Gafka