48 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Python
		
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Python
		
	
	
	
from __future__ import annotations
 | 
						|
 | 
						|
 | 
						|
class UserAgent:
 | 
						|
    """Represents a parsed user agent header value.
 | 
						|
 | 
						|
    The default implementation does no parsing, only the :attr:`string`
 | 
						|
    attribute is set. A subclass may parse the string to set the
 | 
						|
    common attributes or expose other information. Set
 | 
						|
    :attr:`werkzeug.wrappers.Request.user_agent_class` to use a
 | 
						|
    subclass.
 | 
						|
 | 
						|
    :param string: The header value to parse.
 | 
						|
 | 
						|
    .. versionadded:: 2.0
 | 
						|
        This replaces the previous ``useragents`` module, but does not
 | 
						|
        provide a built-in parser.
 | 
						|
    """
 | 
						|
 | 
						|
    platform: str | None = None
 | 
						|
    """The OS name, if it could be parsed from the string."""
 | 
						|
 | 
						|
    browser: str | None = None
 | 
						|
    """The browser name, if it could be parsed from the string."""
 | 
						|
 | 
						|
    version: str | None = None
 | 
						|
    """The browser version, if it could be parsed from the string."""
 | 
						|
 | 
						|
    language: str | None = None
 | 
						|
    """The browser language, if it could be parsed from the string."""
 | 
						|
 | 
						|
    def __init__(self, string: str) -> None:
 | 
						|
        self.string: str = string
 | 
						|
        """The original header value."""
 | 
						|
 | 
						|
    def __repr__(self) -> str:
 | 
						|
        return f"<{type(self).__name__} {self.browser}/{self.version}>"
 | 
						|
 | 
						|
    def __str__(self) -> str:
 | 
						|
        return self.string
 | 
						|
 | 
						|
    def __bool__(self) -> bool:
 | 
						|
        return bool(self.browser)
 | 
						|
 | 
						|
    def to_header(self) -> str:
 | 
						|
        """Convert to a header value."""
 | 
						|
        return self.string
 |