File: ManagedObjectFactory.php

package info (click to toggle)
mediawiki 1%3A1.43.3%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 417,464 kB
  • sloc: php: 1,062,949; javascript: 664,290; sql: 9,714; python: 5,458; xml: 3,489; sh: 1,131; makefile: 64
file content (61 lines) | stat: -rw-r--r-- 1,647 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
<?php
namespace MediaWiki\Tests\Json;

use Wikimedia\JsonCodec\JsonClassCodec;

/**
 * Managed object factory which also handles serialization/deserialization
 * of the objects it manages.
 *
 * @implements JsonClassCodec<ManagedObject>
 */
class ManagedObjectFactory implements JsonClassCodec {
	/** @var array<string,ManagedObject> Fake database */
	private $storage = [];

	/**
	 * Create and store an object with $name and $value in the database.
	 * @param string $name
	 * @param int $value
	 * @return ManagedObject
	 */
	public function create( string $name, int $value ) {
		if ( isset( $this->storage[$name] ) ) {
			throw new \Error( "duplicate name" );
		}
		$this->storage[$name] = $o = new ManagedObject( $name, $value );
		return $o;
	}

	/**
	 * Lookup $name in the database.
	 * @param string $name
	 * @return ManagedObject
	 */
	public function lookup( string $name ): ManagedObject {
		if ( !isset( $this->storage[$name] ) ) {
			throw new \Error( "not found" );
		}
		return $this->storage[$name];
	}

	/** @inheritDoc */
	public function toJsonArray( $obj ): array {
		'@phan-var ManagedObject $obj';
		// Not necessary to serialize all the properties, since they
		// will be reloaded from the "database" during deserialization
		return [ 'name' => $obj->name ];
	}

	/** @inheritDoc */
	public function newFromJsonArray( string $className, array $json ): ManagedObject {
		// @phan-suppress-next-line PhanTypeMismatchReturn template limitations
		return $this->lookup( $json['name'] );
	}

	/** @inheritDoc */
	public function jsonClassHintFor( string $className, string $key ): ?string {
		// no hints
		return null;
	}
}