import { Command as $Command } from "@smithy/smithy-client"; import type { MetadataBearer as __MetadataBearer } from "@smithy/types"; import type { EC2ClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../EC2Client"; import type { DescribeSecurityGroupRulesRequest, DescribeSecurityGroupRulesResult } from "../models/models_4"; /** * @public */ export type { __MetadataBearer }; export { $Command }; /** * @public * * The input for {@link DescribeSecurityGroupRulesCommand}. */ export interface DescribeSecurityGroupRulesCommandInput extends DescribeSecurityGroupRulesRequest { } /** * @public * * The output of {@link DescribeSecurityGroupRulesCommand}. */ export interface DescribeSecurityGroupRulesCommandOutput extends DescribeSecurityGroupRulesResult, __MetadataBearer { } declare const DescribeSecurityGroupRulesCommand_base: { new (input: DescribeSecurityGroupRulesCommandInput): import("@smithy/smithy-client").CommandImpl; new (...[input]: [] | [DescribeSecurityGroupRulesCommandInput]): import("@smithy/smithy-client").CommandImpl; getEndpointParameterInstructions(): import("@smithy/middleware-endpoint").EndpointParameterInstructions; }; /** *

Describes one or more of your security group rules.

* @example * Use a bare-bones client and the command you need to make an API call. * ```javascript * import { EC2Client, DescribeSecurityGroupRulesCommand } from "@aws-sdk/client-ec2"; // ES Modules import * // const { EC2Client, DescribeSecurityGroupRulesCommand } = require("@aws-sdk/client-ec2"); // CommonJS import * // import type { EC2ClientConfig } from "@aws-sdk/client-ec2"; * const config = {}; // type is EC2ClientConfig * const client = new EC2Client(config); * const input = { // DescribeSecurityGroupRulesRequest * Filters: [ // FilterList * { // Filter * Name: "STRING_VALUE", * Values: [ // ValueStringList * "STRING_VALUE", * ], * }, * ], * SecurityGroupRuleIds: [ // SecurityGroupRuleIdList * "STRING_VALUE", * ], * DryRun: true || false, * NextToken: "STRING_VALUE", * MaxResults: Number("int"), * }; * const command = new DescribeSecurityGroupRulesCommand(input); * const response = await client.send(command); * // { // DescribeSecurityGroupRulesResult * // SecurityGroupRules: [ // SecurityGroupRuleList * // { // SecurityGroupRule * // SecurityGroupRuleId: "STRING_VALUE", * // GroupId: "STRING_VALUE", * // GroupOwnerId: "STRING_VALUE", * // IsEgress: true || false, * // IpProtocol: "STRING_VALUE", * // FromPort: Number("int"), * // ToPort: Number("int"), * // CidrIpv4: "STRING_VALUE", * // CidrIpv6: "STRING_VALUE", * // PrefixListId: "STRING_VALUE", * // ReferencedGroupInfo: { // ReferencedSecurityGroup * // GroupId: "STRING_VALUE", * // PeeringStatus: "STRING_VALUE", * // UserId: "STRING_VALUE", * // VpcId: "STRING_VALUE", * // VpcPeeringConnectionId: "STRING_VALUE", * // }, * // Description: "STRING_VALUE", * // Tags: [ // TagList * // { // Tag * // Key: "STRING_VALUE", * // Value: "STRING_VALUE", * // }, * // ], * // SecurityGroupRuleArn: "STRING_VALUE", * // }, * // ], * // NextToken: "STRING_VALUE", * // }; * * ``` * * @param DescribeSecurityGroupRulesCommandInput - {@link DescribeSecurityGroupRulesCommandInput} * @returns {@link DescribeSecurityGroupRulesCommandOutput} * @see {@link DescribeSecurityGroupRulesCommandInput} for command's `input` shape. * @see {@link DescribeSecurityGroupRulesCommandOutput} for command's `response` shape. * @see {@link EC2ClientResolvedConfig | config} for EC2Client's `config` shape. * * @throws {@link EC2ServiceException} *

Base exception class for all service exceptions from EC2 service.

* * * @public */ export declare class DescribeSecurityGroupRulesCommand extends DescribeSecurityGroupRulesCommand_base { /** @internal type navigation helper, not in runtime. */ protected static __types: { api: { input: DescribeSecurityGroupRulesRequest; output: DescribeSecurityGroupRulesResult; }; sdk: { input: DescribeSecurityGroupRulesCommandInput; output: DescribeSecurityGroupRulesCommandOutput; }; }; }