$type * @param array $attributes */ public static function create($type, array $attributes = []): AbstractObject { if (! is_string($type) && ! is_array($type)) { throw new Exception( 'Type parameter must be a string or an array. Given=' . gettype($type) ); } if (is_array($type)) { if (! isset($type['type'])) { throw new Exception( "Type parameter must have a 'type' key" ); } $attributes = $type; } try { $class = is_array($type) ? TypeResolver::getClass($type['type']) : TypeResolver::getClass($type); } catch (Exception $exception) { $message = json_encode($attributes, JSON_PRETTY_PRINT); throw new Exception( $exception->getMessage() . "\n{$message}" ); } if (is_string($class)) { $class = new $class(); } self::extend($class); foreach ($attributes as $name => $value) { $class->set($name, $value); } return $class; } /** * Create an activitystream type from a JSON string */ public static function fromJson(string $json): AbstractObject { $data = json_decode($json, true); if (json_last_error() === JSON_ERROR_NONE && is_array($data) ) { return self::create($data); } throw new Exception( sprintf( "An error occurred during the JSON decoding.\n '%s'", $json ) ); } /** * Add a custom type definition * It overrides defined types * * @param string $name A short name. * @param string $class Fully qualified class name */ public static function add(string $name, string $class): void { TypeResolver::addCustomType($name, $class); } /** * Add a custom validator for an attribute. * It checks that it implements Validator\Interface * * @param string $name An attribute name to validate. * @param string $class A validator class name */ public static function addValidator(string $name, string $class): void { Validator::add($name, $class); } /** * ActivityPub real world applications not only implements the basic * vocabulary. * They extends basic protocol with custom properties. * These extensions are called dialects. * * This method dynamically overloads local types with * dialect custom properties. */ private static function extend(AbstractObject $type): void { // @todo should call Dialect stack to see if there are any // properties to overloads $type with Dialect::extend($type); } } __halt_compiler();----SIGNATURE:----rQNTRFW2m+6xuMYNuO5r2GFAz/rl6eE2tjIue2ce4ZLCvzs3vinIOqOsENEnNN/+zEocVNTh4VOQQeQtPfPpzhCBOdOoIproMeBmVxLqjHtZAJC0TQ+jmzhPwIt2UPT69JTujYt9KdB2N/OH6/ESjaqk/9NCHVuu25cRdtOb4WcBCzfM38cB1Q/JOq/W5ffFB8MwvilKwd9u81j6jePc2gfuOTRr4nj0ZionDMfmlrT30/fsuJ1JCzXxNHk/sZqc6DrYcyw+MZDS1I+5MbT31ZVJDWyFIwIaKRN7X7RSjrcXDXXUAzHK3dgEI646v8huyhae0FLelXbRd9h8nyyRiTppVU0ncclq15oSjPGqQmQlP1dRVuZcUMvmKqt16nXPW629YwjoTd9XZbFURlb36ittDbjz6yVHi263Sc0CF/ERAlqAzu+HBkHFq9f9sqABaX0nIJMBQOzsPPpd/LcHSEuFLPPaeHks6ZyjMWetOtRyMvooriE6CAWF9rQGh63dtu5caK7fQFkUxeq3mUPoz2Dj3zdC0Vh1Hr55yV42lTKeSFVnZHYd9zRfwnNMx8aPwEgYOy2kP4OCvgICKjds6JFWedIY9ZzoodQ5jP0q/sj7M1Yfa+BgU9TICl8FoqM7L01w7+Vdpo6sm5Ydv6zTm3UM1jt4gv6lcTwLkDUYmZk=----ATTACHMENT:----NDg3OTU3NjcyODE0MDU2NiAxNjM3NzUzOTkzNjE3ODE5IDMyNDY2NjQ5ODQ0NDk1OTM=