class Priority
Represents the priority header, used to indicate the relative importance of an HTTP request.
The priority header allows clients to express their preference for how resources should be prioritized by the server. It supports directives like u= to specify the urgency level of a request, and i to indicate whether a response can be delivered incrementally. The urgency levels range from 0 (highest priority) to 7 (lowest priority), while the i directive is a boolean flag.
Definitions
def initialize(value = nil)
Initialize the priority header with the given value.
Signature
-
parameter
valueString | Nil the value of the priority header, if any. The value should be a comma-separated string of directives.
Implementation
def initialize(value = nil)
super(value&.downcase)
end
def <<(value)
Add a value to the priority header.
Signature
-
parameter
valueString the directive to add to the header.
Implementation
def << value
super(value.downcase)
end
DEFAULT_URGENCY = 3
The default urgency level if not specified.
def urgency(default = DEFAULT_URGENCY)
The urgency level, if specified using u=. 0 is the highest priority, and 7 is the lowest.
Note that when duplicate Dictionary keys are encountered, all but the last instance are ignored.
Signature
-
returns
Integer | Nil the urgency level if specified, or
nilif not present.
Implementation
def urgency(default = DEFAULT_URGENCY)
if value = self.reverse_find{|value| value.start_with?("u=")}
_, level = value.split("=", 2)
return Integer(level)
end
return default
end
def incremental?
Checks if the response should be delivered incrementally.
The i directive, when present, indicates that the response can be delivered incrementally as data becomes available.
Signature
-
returns
Boolean whether the request should be delivered incrementally.
Implementation
def incremental?
self.include?("i")
end