drupol/anonymize

Converts an object/class into an anonymous class.

Maintainers

👁 drupol

Package info

github.com/drupol/anonymize

Forum

pkg:composer/drupol/anonymize

Fund package maintenance!

drupol

Statistics

Installs: 14

Dependents: 0

Suggesters: 0

Stars: 1

Open Issues: 0

1.1.4 2019-07-23 18:50 UTC

Requires

Suggests

None

Provides

None

Conflicts

None

Replaces

None

MIT c27bbf0c4efb9a86deee7382b28f4cd30b8a28b6

anonymize classesanonymous classes

This package is auto-updated.

Last update: 2026-06-15 12:16:18 UTC


README

👁 Latest Stable Version
👁 GitHub stars
👁 Total Downloads
👁 Build Status
👁 Scrutinizer code quality
👁 Code Coverage
👁 Mutation testing badge
👁 License
👁 Say Thanks!
👁 Donate!

Anonymize

Description

Convert a regular class into an anonymous class.

Features

  • Converts public properties and methods into dynamic classes and properties.

Requirements

  • PHP >= 7.1.3

Installation

composer require drupol/anonymize

Usage

Using the object:

<?php

include 'vendor/autoload.php';

class Hello
{
 public $property = 'YES!';

 public function say()
 {
 echo 'Hello ' . $this->world();
 }

 private function world()
 {
 return 'world!';
 }
}

$class = new Hello();
$class->say(); // Hello world!

$anonymizedClass = \drupol\Anonymize\Anonymize::convertToAnonymous($class);

$anonymizedClass::addDynamicMethod('say', function () use ($anonymizedClass) {
 echo 'Goodbye ' . $anonymizedClass->world();
});

$anonymizedClass::addDynamicMethod('world', function () {
 return 'universe!';
});

$anonymizedClass->say(); // Goodbye universe!

API

<?php

/**
 * Convert an object into an anonymous object.
 *
 * @param \stdClass $object
 * The object to convert. 
 *
 * @return Anonymize
 */
AnonymizeTrait::convertToAnonymous($object);

The rest of the library API relies and inherit from DynamicObjects.

Code quality, tests and benchmarks

Every time changes are introduced into the library, Travis CI run the tests and the benchmarks.

The library has tests written with PHPSpec. Feel free to check them out in the spec directory. Run composer phpspec to trigger the tests.

Before each commit some inspections are executed with GrumPHP, run ./vendor/bin/grumphp run to check manually.

PHPInfection is used to ensure that your code is properly tested, run composer infection to test your code.

Contributing

Feel free to contribute to this library by sending Github pull requests. I'm quite reactive :-)

Sponsors