3 namespace MediaWiki\Edit
;
5 use InvalidArgumentException
;
6 use MediaWiki\Parser\ParserOutput
;
9 * Represents the identity of a specific rendering of a specific revision
10 * at some point in time.
13 * @unstable since 1.39, should be stable by 1.39 release.
15 class ParsoidRenderID
{
16 private int $revisionID;
17 private string $uniqueID;
18 private string $stashKey;
21 * @param int $revisionID Revision that was rendered
22 * @param string $uniqueID An identifier for a point in time.
24 public function __construct( int $revisionID, string $uniqueID ) {
25 $this->revisionID
= $revisionID;
26 $this->uniqueID
= $uniqueID;
27 $this->stashKey
= $revisionID . '/' . $uniqueID;
31 * @param string $key String representation of render ID
32 * (synonymous with an etag with double quotes) as returned by ::getKey().
38 public static function newFromKey( string $key ): self
{
39 [ $revisionID, $uniqueID ] = explode( '/', $key, 2 );
41 if ( $revisionID === null ||
$uniqueID === null ) {
42 throw new InvalidArgumentException( 'Bad key: ' . $key );
45 return new self( (int)$revisionID, $uniqueID );
49 * Create a ParsoidRenderID from the revision and render id stored in
51 * @param ParserOutput $parserOutput
54 public static function newFromParserOutput( ParserOutput
$parserOutput ): self
{
55 $revisionID = $parserOutput->getCacheRevisionId();
56 $uniqueID = $parserOutput->getRenderId();
58 if ( $revisionID === null ||
$uniqueID === null ) {
59 throw new InvalidArgumentException( 'Missing render id' );
62 return new self( $revisionID, $uniqueID );
66 * This constructs a new render ID from the given ETag.
68 * Any suffix after a second forward slash will be ignored e.g.
69 * ->newFromEtag( '1/abc/stash' ) will return '1/abc' when ->getKey()
70 * is called on the ParsoidRenderID object instance.
72 * @param string $eTag ETag with double quotes,
73 * see https://www.rfc-editor.org/rfc/rfc7232#section-2.3
75 * @return ParsoidRenderID|null The render ID embedded in the ETag,
76 * or null if the ETag was malformed.
77 * @see newFromKey() if ETag already has outside quotes trimmed
80 public static function newFromETag( string $eTag ): ?self
{
81 if ( !preg_match( '@^(?:W/)?"(\d+)/([^/]+)(:?/.*)?"$@', $eTag, $m ) ) {
85 [ , $revisionID, $uniqueID ] = $m;
87 return new self( (int)$revisionID, $uniqueID );
91 * This returns the canonical string representation from
92 * the parsoid render ID which can be used to in newFromString().
96 public function getKey(): string {
97 return $this->stashKey
;
100 public function __toString() {
101 return $this->stashKey
;
105 * Get the revision ID from the parsoid render ID object.
109 public function getRevisionID(): int {
110 return $this->revisionID
;
114 * Get the unique identifier from the parsoid render ID object.
118 public function getUniqueID(): string {
119 return $this->uniqueID
;
124 /** @deprecated since 1.42 */
125 class_alias( ParsoidRenderID
::class, 'MediaWiki\\Parser\\Parsoid\\ParsoidRenderID' );