Updated on 2022-01-25 GMT+08:00

Querying Security Group Rules

Function

This API is used to query security group rules using search criteria and to display the security group rules in a list.

URI

GET /v1/{project_id}/security-group-rules

Example:
GET https://{Endpoint}/v1/{project_id}/security-group-rules?security_group_id=a7734e61-b545-452da3cd-0189cbd9747a&limit=10&marker=4779ab1c-7c1a-44b1-a02e-93dfc361b32d
Table 1 describes the parameters.
Table 1 Parameter description

Name

Mandatory

Type

Description

project_id

Yes

String

Specifies the project ID. For details about how to obtain a project ID, see Obtaining a Project ID.

marker

No

String

Specifies the start resource ID of pagination query. If the parameter is left blank, only resources on the first page are queried.

limit

No

Integer

Specifies the number of records returned on each page.

The value ranges from 0 to intmax.

security_group_id

No

String

Specifies the security group ID.

Request Message

  • Request parameter

    None

  • Example request
    GET https://{Endpoint}/v1/{project_id}/security-group-rules

Response Message

  • Response parameter

    Name

    Type

    Description

    security_group_rules

    Array of security_group_rule objects

    Specifies the security group rule objects. For details, see Table 2.

    Table 2 security_group_rule objects

    Name

    Type

    Description

    id

    String

    Specifies the security group rule ID, which uniquely identifies the security group rule.

    description

    String

    • Provides supplementary information about the security group rule.
    • The value is a string of no more than 255 characters that can contain letters and digits.

    security_group_id

    String

    Specifies the security group rule ID, which uniquely identifies the security group rule.

    direction

    String

    • Specifies the direction of access control.
    • Possible values are as follows:
      • egress
      • ingress

    ethertype

    String

    • Specifies the IP protocol version.
    • The value can be IPv4 or IPv6.

    protocol

    String

    • Specifies the protocol type.
    • The value can be icmp, tcp, or udp.
    • If the parameter is left blank, all protocols are supported.

    port_range_min

    Integer

    • Specifies the start port number.
    • The value ranges from 1 to 65535.
    • The value cannot be greater than the port_range_max value. An empty value indicates all ports. If the protocol is icmp, the value range is shown in ICMP-Port Range Relationship Table.

    port_range_max

    Integer

    • Specifies the end port number.
    • The value ranges from 1 to 65535.
    • If the protocol is not icmp, the value cannot be smaller than the port_range_min value. An empty value indicates all ports. If the protocol is icmp, the value range is shown in ICMP-Port Range Relationship Table.

    remote_ip_prefix

    String

    • Specifies the remote IP address. If the access control direction is set to egress, the parameter specifies the source IP address. If the access control direction is set to ingress, the parameter specifies the destination IP address.
    • The value can be in the CIDR format or IP addresses.
    • The parameter is exclusive with parameter remote_group_id.

    remote_group_id

    String

    • Specifies the ID of the peer security group.
    • The value is exclusive with parameter remote_ip_prefix.

    tenant_id

    String

    • Specifies the ID of the project to which the security group rule belongs.
  • Example response
    {
        "security_group_rules": [
            {
                "direction": "egress", 
                "ethertype": "IPv6", 
                "id": "3c0e45ff-adaf-4124-b083-bf390e5482ff", 
                "description": "",
                "port_range_max": null, 
                "port_range_min": null, 
                "protocol": null, 
                "remote_group_id": null, 
                "remote_ip_prefix": null, 
                "security_group_id": "85cc3048-abc3-43cc-89b3-377341426ac5", 
                "tenant_id": "e4f50856753b4dc6afee5fa6b9b6c550"
            }, 
            {
                "direction": "egress", 
                "ethertype": "IPv4", 
                "id": "93aa42e5-80db-4581-9391-3a608bd0e448",
                "description": "", 
                "port_range_max": null, 
                "port_range_min": null, 
                "protocol": null, 
                "remote_group_id": null, 
                "remote_ip_prefix": null, 
                "security_group_id": "85cc3048-abc3-43cc-89b3-377341426ac5", 
                "tenant_id": "e4f50856753b4dc6afee5fa6b9b6c550"
            }, 
            {
                "direction": "ingress", 
                "ethertype": "IPv6", 
                "id": "c0b09f00-1d49-4e64-a0a7-8a186d928138", 
                "description": "",
                "port_range_max": null, 
                "port_range_min": null, 
                "protocol": null, 
                "remote_group_id": "85cc3048-abc3-43cc-89b3-377341426ac5", 
                "remote_ip_prefix": null, 
                "security_group_id": "85cc3048-abc3-43cc-89b3-377341426ac5", 
                "tenant_id": "e4f50856753b4dc6afee5fa6b9b6c550"
            }, 
            {
                "direction": "ingress", 
                "ethertype": "IPv4", 
                "id": "f7d45c89-008e-4bab-88ad-d6811724c51c", 
                "description": "",
                "port_range_max": null, 
                "port_range_min": null, 
                "protocol": null, 
                "remote_group_id": "85cc3048-abc3-43cc-89b3-377341426ac5", 
                "remote_ip_prefix": null, 
                "security_group_id": "85cc3048-abc3-43cc-89b3-377341426ac5", 
                "tenant_id": "e4f50856753b4dc6afee5fa6b9b6c550"
            }
        ]
    }

Status Code

See Status Codes.

Error Code

See Error Codes.