: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in
* Queries https://cdn.ampproject.org/rtv/metadata for the latest AMP runtime version. Uses a stale-while-revalidate
* caching strategy to avoid refreshing the version.
* More details: https://cdn.ampproject.org/rtv/metadata returns the following metadata:
* "ampRuntimeVersion": "CURRENT_PROD",
* "ampCssUrl": "https://cdn.ampproject.org/rtv/CURRENT_PROD/v0.css",
* "canaryPercentage": "0.1",
* <li> CURRENT_OPTIN: is when you go to https://cdn.ampproject.org/experiments.html and toggle "dev-channel". It's
* the earliest possible time to get new code.</li>
* <li> CURRENT_1%: 1% is the same code as opt-in that we're now comfortable releasing to 1% of the population.</li>
* <li> CURRENT_CONTROL is the same thing as production, but with a different URL. This is to compare experiments
* against, since prod's immutable caching would affect metrics.</li>
* @package ampproject/amp-toolbox
final class RuntimeVersion
* Option to retrieve the latest canary version data instead of the production version data.
const OPTION_CANARY = 'canary';
* Endpoint to query for retrieving the runtime version data.
const RUNTIME_METADATA_ENDPOINT = 'https://cdn.ampproject.org/rtv/metadata';
* Transport to use for remote requests.
* Instantiate a RuntimeVersion object.
* @param RemoteGetRequest $remoteRequest Transport to use for remote requests.
public function __construct(RemoteGetRequest $remoteRequest)
$this->remoteRequest = $remoteRequest;
* Returns the version of the current AMP runtime release.
* Pass [ canary => true ] to get the latest canary version.
* @param array $options Optional. Associative array of options.
* @return string Version string of the AMP runtime.
public function currentVersion($options = [])
$response = $this->remoteRequest->get(self::RUNTIME_METADATA_ENDPOINT);
$statusCode = $response->getStatusCode();
if ($statusCode < 200 || $statusCode >= 300) {
$metadata = json_decode($response->getBody());
$version = (! empty($options['canary']))
? $metadata->diversions[0]
: $metadata->ampRuntimeVersion;
return $this->padVersionString($version);
* Pad the version string to the required length.
* @param string $version Version string to pad.
* @return string Padded version string.
private function padVersionString($version)
return str_pad($version, 15, '0');
* Append the runtime version to the host URL.
* @param string $host Host domain to use.
* @param string $version Version to use.
* @return string Runtime version URL.
public static function appendRuntimeVersion($host, $version)
return "{$host}/rtv/{$version}";