QoS backend drivers are using validators "type:range" and "type:values" to validate if given value is supported. Such possible values should be represented in different way when rule_type details are requested. This commit changes format of values which can be returned as result of such request. Change-Id: I460f7b2b265115120102e575d4040c0c5f5264f8 Partial-Bug: 1686035
4.1 KiB
QoS detailed reporting of available QoS rules
https://bugs.launchpad.net/neutron/+bug/1686035
Problem Description
With [1] different QoS rules can be supported by different backend drivers. Whether the driver can handle the given rule type, and the parameters passed with the rule, are validated only when the user wants to apply the rule to a port/network. With [2] merged, Neutron returns a list of all rule types supported by at least one of the enabled backends. This is not enough as users are unable to discover what values are supported by the back ends for each rule type
Proposed Change
We propose to add new API. This call would be used to get details of every available rule type.
REST API
New REST API call is:
GET /v2.0/qos/rule-types/{rule_type}
Request example:
GET /v2.0/qos/rule-types/bandwidth_limit
The response is a dict with details for the supported rule type for each of the enabled backends.
As parameter values can be returned:
- list of supported values if driver uses "type:values" validator from neutron-lib to validate this parameter
- dict with 'start' and 'end' value if driver uses "type:range" validator from neutron-lib to validate this parameter. Both 'start' and 'end' values are inclusive in the range.
QoS rule types uses only "type:values" and "type:range" validators currently and only those validators are supported by this spec.
This call should be available only for users with admin rights to not expose details about cloud infra to regular users.
Response example:
{
"rule_type": {
"type": "bandwidth_limit",
"drivers": [
{
"name": "ovs",
"supported_parameters": [
{
"parameter_name": "max_kbps",
"parameter_type": "range",
"parameter_values": {
"start": 0,
"end": 1000
}
},
{
"parameter_name": "max_burst_kbps",
"parameter_type": "range",
"parameter_values": {
"start": 0,
"end": 1000
}
},
{
"parameter_name": "direction",
"parameter_type": "choices",
"parameter_values": ["ingress", "egress"]
}
]
},
{
"name": "linuxbridge",
"supported_parameters": [
{
"parameter_name": "max_kbps",
"parameter_type": "range",
"parameter_values": {
"start": 0,
"end": 1000
}
},
{
"parameter_name": "max_burst_kbps",
"parameter_type": "range",
"parameter_values": {
"start": 0,
"end": 1000
}
},
{
"parameter_name": "direction",
"parameter_type": "choices",
"parameter_values": ["egress"]
}
]
}
]
}
}
References
[1] http://specs.openstack.org/openstack/neutron-specs/pike/qos-improved-validation-mechanism-rules.html [2] https://review.openstack.org/#/c/461257