2024-02-08 13:02:07 +05:30
|
|
|
// 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.
|
|
|
|
|
|
2024-04-03 10:05:52 +05:30
|
|
|
/**
|
|
|
|
|
* Represents a URL pattern to intercept.
|
|
|
|
|
* Described in network.UrlPatternPattern https://w3c.github.io/webdriver-bidi/#type-network-UrlPattern
|
|
|
|
|
*/
|
2024-02-08 13:02:07 +05:30
|
|
|
class UrlPattern {
|
|
|
|
|
#map = new Map()
|
|
|
|
|
|
2024-04-03 10:05:52 +05:30
|
|
|
/**
|
|
|
|
|
* Sets the protocol for the URL pattern.
|
|
|
|
|
*
|
|
|
|
|
* @param {string} protocol - The protocol to set.
|
|
|
|
|
* @returns {UrlPattern} - Returns the updated instance of the URL pattern for chaining.
|
|
|
|
|
*/
|
2024-02-08 13:02:07 +05:30
|
|
|
protocol(protocol) {
|
|
|
|
|
this.#map.set('protocol', protocol)
|
|
|
|
|
return this
|
|
|
|
|
}
|
|
|
|
|
|
2024-04-03 10:05:52 +05:30
|
|
|
/**
|
|
|
|
|
* Sets the hostname for the URL pattern.
|
|
|
|
|
*
|
|
|
|
|
* @param {string} hostname - The hostname to set.
|
|
|
|
|
* @returns {UrlPattern} - Returns the updated instance of the URL pattern for chaining.
|
|
|
|
|
*/
|
2024-02-08 13:02:07 +05:30
|
|
|
hostname(hostname) {
|
|
|
|
|
this.#map.set('hostname', hostname)
|
|
|
|
|
return this
|
|
|
|
|
}
|
|
|
|
|
|
2024-04-03 10:05:52 +05:30
|
|
|
/**
|
|
|
|
|
* Sets the port for the URL pattern.
|
|
|
|
|
*
|
|
|
|
|
* @param {number} port - The port number to set.
|
|
|
|
|
* @returns {UrlPattern} - Returns the updated instance of the URL pattern for chaining.
|
|
|
|
|
* @throws {Error} - Throws an error if the port is not a number.
|
|
|
|
|
*/
|
2024-02-08 13:02:07 +05:30
|
|
|
port(port) {
|
|
|
|
|
if (typeof port === 'number') {
|
|
|
|
|
this.#map.set('port', port.toString())
|
|
|
|
|
} else {
|
|
|
|
|
throw new Error(`Port must be a number. Received:'${port}'`)
|
|
|
|
|
}
|
|
|
|
|
return this
|
|
|
|
|
}
|
|
|
|
|
|
2024-04-03 10:05:52 +05:30
|
|
|
/**
|
|
|
|
|
* Sets the pathname for the URL pattern.
|
|
|
|
|
*
|
|
|
|
|
* @param {string} pathname - The pathname to set.
|
|
|
|
|
* @returns {UrlPattern} - Returns the updated instance of the URL pattern for chaining.
|
|
|
|
|
*/
|
2024-02-08 13:02:07 +05:30
|
|
|
pathname(pathname) {
|
|
|
|
|
this.#map.set('pathname', pathname)
|
|
|
|
|
return this
|
|
|
|
|
}
|
|
|
|
|
|
2024-04-03 10:05:52 +05:30
|
|
|
/**
|
|
|
|
|
* Sets the search parameter in the URL pattern.
|
|
|
|
|
*
|
|
|
|
|
* @param {string} search - The search parameter to be set.
|
|
|
|
|
* @returns {UrlPattern} - Returns the updated instance of the URL pattern for chaining.
|
|
|
|
|
*/
|
2024-02-08 13:02:07 +05:30
|
|
|
search(search) {
|
|
|
|
|
this.#map.set('search', search)
|
|
|
|
|
return this
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
asMap() {
|
|
|
|
|
this.#map.set('type', 'pattern')
|
|
|
|
|
return this.#map
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-08 12:13:00 +00:00
|
|
|
module.exports = { UrlPattern }
|