blob: e129a99faa5afd58bce10e79cfb363ce56368890 [file] [log] [blame]
// <copyright file="DevToolsVersionInfo.cs" company="Selenium Committers">
// Licensed to the Software Freedom Conservancy (SFC) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The SFC licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.
// </copyright>
using System;
using System.Text.Json.Serialization;
using System.Text.RegularExpressions;
namespace OpenQA.Selenium.DevTools;
/// <summary>
/// Provides information about the version of DevTools components being automated.
/// </summary>
public class DevToolsVersionInfo
{
/// <summary>
/// Gets or sets the browser name, usually expressed as "Browser/Version" (e.g., "Chrome/86.0.0.1234".
/// </summary>
[JsonPropertyName("Browser")]
[JsonInclude]
public string? Browser { get; internal set; }
/// <summary>
/// Gets the browser version without the preceding browser name.
/// </summary>
[JsonIgnore]
public string BrowserVersion
{
get
{
if (Browser is null)
{
throw new InvalidOperationException("Browser value is null");
}
return Regex.Match(Browser, ".*/(.*)").Groups[1].Value;
}
}
/// <summary>
/// Gets the browser major version number without the preceding browser name.
/// </summary>
[JsonIgnore]
public string BrowserMajorVersion
{
get
{
if (Browser is null)
{
throw new InvalidOperationException("Browser value is null");
}
return Regex.Match(Browser, ".*/(\\d+)\\..*").Groups[1].Value;
}
}
/// <summary>
/// Gets the version of the Developer Tools Protocol.
/// </summary>
[JsonPropertyName("Protocol-Version")]
[JsonInclude]
public string? ProtocolVersion { get; internal set; }
/// <summary>
/// Gets the user agent string.
/// </summary>
[JsonPropertyName("User-Agent")]
[JsonInclude]
public string? UserAgent { get; internal set; }
/// <summary>
/// Gets the version string for the V8 script engine in use by this version of the browser.
/// </summary>
[JsonPropertyName("V8-Version")]
[JsonInclude]
public string? V8Version { get; internal set; }
/// <summary>
/// Gets the URL for the WebSocket connection used for communicating via the DevTools Protocol.
/// </summary>
[JsonPropertyName("webSocketDebuggerUrl")]
[JsonInclude]
public string? WebSocketDebuggerUrl { get; internal set; }
/// <summary>
/// Gets the version number of the V8 script engine, stripping values other than the version number.
/// </summary>
[JsonIgnore]
public string V8VersionNumber
{
get
{
//Get the v8 version
Match? v8VersionMatch = V8Version is null ? null : Regex.Match(V8Version, @"^(\d+)\.(\d+)\.(\d+)(\.\d+.*)?");
if (v8VersionMatch is null || v8VersionMatch.Success == false || v8VersionMatch.Groups.Count < 4)
{
throw new InvalidOperationException($"Unable to determine v8 version number from v8 version string ({V8Version})");
}
return $"{v8VersionMatch.Groups[1].Value}.{v8VersionMatch.Groups[2].Value}.{v8VersionMatch.Groups[3].Value}";
}
}
/// <summary>
/// Gets the version string for the version of WebKit used to build this version of the browser.
/// </summary>
[JsonPropertyName("WebKit-Version")]
[JsonInclude]
public string? WebKitVersion { get; internal set; }
/// <summary>
/// Gets the hash of the version of WebKit, stripping values other than the hash.
/// </summary>
[JsonIgnore]
public string WebKitVersionHash
{
get
{
//Get the webkit version hash.
var webkitVersionMatch = WebKitVersion is null ? null : Regex.Match(WebKitVersion, @"\s\(@(\b[0-9a-f]{5,40}\b)");
if (webkitVersionMatch is null || webkitVersionMatch.Success == false || webkitVersionMatch.Groups.Count != 2)
{
throw new InvalidOperationException($"Unable to determine webkit version hash from webkit version string ({WebKitVersion})");
}
return webkitVersionMatch.Groups[1].Value;
}
}
}