2017/11/29 - Amazon GuardDuty - 37 new api methods
Changes Enable Amazon GuardDuty to continuously monitor and process AWS data sources to identify threats to your AWS accounts and workloads. You can add customization by uploading additional threat intelligence lists and IP safe lists. You can list security findings, suspend, and disable the service.
Describes Amazon GuardDuty findings specified by finding IDs.
See also: AWS API Documentation
Request Syntax
client.get_findings( DetectorId='string', FindingIds=[ 'string', ], SortCriteria={ 'AttributeName': 'string', 'OrderBy': 'ASC'|'DESC' } )
string
[REQUIRED] The ID of the detector that specifies the GuardDuty service whose findings you want to retrieve.
list
IDs of the findings that you want to retrieve.
(string) -- The unique identifier for the Finding
dict
Represents the criteria used for sorting findings.
AttributeName (string) -- Represents the finding attribute (for example, accountId) by which to sort findings.
OrderBy (string) -- Order by which the sorted findings are to be displayed.
dict
Response Syntax
{ 'Findings': [ { 'AccountId': 'string', 'Arn': 'string', 'Confidence': 123.0, 'CreatedAt': 'string', 'Description': 'string', 'Id': 'string', 'Partition': 'string', 'Region': 'string', 'Resource': { 'InstanceDetails': { 'AvailabilityZone': 'string', 'IamInstanceProfile': { 'Arn': 'string', 'Id': 'string' }, 'ImageId': 'string', 'InstanceId': 'string', 'InstanceState': 'string', 'InstanceType': 'string', 'LaunchTime': 'string', 'NetworkInterfaces': [ { 'Ipv6Addresses': [ 'string', ], 'PrivateDnsName': 'string', 'PrivateIpAddress': 'string', 'PrivateIpAddresses': [ { 'PrivateDnsName': 'string', 'PrivateIpAddress': 'string' }, ], 'PublicDnsName': 'string', 'PublicIp': 'string', 'SecurityGroups': [ { 'GroupId': 'string', 'GroupName': 'string' }, ], 'SubnetId': 'string', 'VpcId': 'string' }, ], 'Platform': 'string', 'ProductCodes': [ { 'Code': 'string', 'ProductType': 'string' }, ], 'Tags': [ { 'Key': 'string', 'Value': 'string' }, ] }, 'ResourceType': 'string' }, 'SchemaVersion': 'string', 'Service': { 'Action': { 'ActionType': 'string', 'AwsApiCallAction': { 'Api': 'string', 'CallerType': 'string', 'DomainDetails': {}, 'RemoteIpDetails': { 'City': { 'CityName': 'string' }, 'Country': { 'CountryCode': 'string', 'CountryName': 'string' }, 'GeoLocation': { 'Lat': 123.0, 'Lon': 123.0 }, 'IpAddressV4': 'string', 'Organization': { 'Asn': 'string', 'AsnOrg': 'string', 'Isp': 'string', 'Org': 'string' } }, 'ServiceName': 'string' }, 'DnsRequestAction': { 'Domain': 'string' }, 'NetworkConnectionAction': { 'Blocked': True|False, 'ConnectionDirection': 'string', 'LocalPortDetails': { 'Port': 123, 'PortName': 'string' }, 'Protocol': 'string', 'RemoteIpDetails': { 'City': { 'CityName': 'string' }, 'Country': { 'CountryCode': 'string', 'CountryName': 'string' }, 'GeoLocation': { 'Lat': 123.0, 'Lon': 123.0 }, 'IpAddressV4': 'string', 'Organization': { 'Asn': 'string', 'AsnOrg': 'string', 'Isp': 'string', 'Org': 'string' } }, 'RemotePortDetails': { 'Port': 123, 'PortName': 'string' } } }, 'Archived': True|False, 'Count': 123, 'DetectorId': 'string', 'EventFirstSeen': 'string', 'EventLastSeen': 'string', 'ResourceRole': 'string', 'ServiceName': 'string', 'UserFeedback': 'string' }, 'Severity': 123.0, 'Title': 'string', 'Type': 'string', 'UpdatedAt': 'string' }, ] }
Response Structure
(dict) -- 200 response
Findings (list) -- A list of findings.
(dict) -- Representation of a abnormal or suspicious activity.
AccountId (string) -- AWS account ID where the activity occurred that prompted GuardDuty to generate a finding.
Arn (string) -- The ARN of a finding described by the action.
Confidence (float) -- The confidence level of a finding.
CreatedAt (string) -- The time stamp at which a finding was generated.
Description (string) -- The description of a finding.
Id (string) -- The identifier that corresponds to a finding described by the action.
Partition (string) -- The AWS resource partition.
Region (string) -- The AWS region where the activity occurred that prompted GuardDuty to generate a finding.
Resource (dict) -- The AWS resource associated with the activity that prompted GuardDuty to generate a finding.
InstanceDetails (dict) -- The information about the EC2 instance associated with the activity that prompted GuardDuty to generate a finding.
AvailabilityZone (string) -- The availability zone of the EC2 instance.
IamInstanceProfile (dict) -- The profile information of the EC2 instance.
Arn (string) -- AWS EC2 instance profile ARN.
Id (string) -- AWS EC2 instance profile ID.
ImageId (string) -- The image ID of the EC2 instance.
InstanceId (string) -- The ID of the EC2 instance.
InstanceState (string) -- The state of the EC2 instance.
InstanceType (string) -- The type of the EC2 instance.
LaunchTime (string) -- The launch time of the EC2 instance.
NetworkInterfaces (list) -- The network interface information of the EC2 instance.
(dict) -- The network interface information of the EC2 instance.
Ipv6Addresses (list) -- A list of EC2 instance IPv6 address information.
(string) -- IpV6 address of the EC2 instance.
PrivateDnsName (string) -- Private DNS name of the EC2 instance.
PrivateIpAddress (string) -- Private IP address of the EC2 instance.
PrivateIpAddresses (list) -- Other private IP address information of the EC2 instance.
(dict) -- Other private IP address information of the EC2 instance.
PrivateDnsName (string) -- Private DNS name of the EC2 instance.
PrivateIpAddress (string) -- Private IP address of the EC2 instance.
PublicDnsName (string) -- Public DNS name of the EC2 instance.
PublicIp (string) -- Public IP address of the EC2 instance.
SecurityGroups (list) -- Security groups associated with the EC2 instance.
(dict) -- Security groups associated with the EC2 instance.
GroupId (string) -- EC2 instance's security group ID.
GroupName (string) -- EC2 instance's security group name.
SubnetId (string) -- The subnet ID of the EC2 instance.
VpcId (string) -- The VPC ID of the EC2 instance.
Platform (string) -- The platform of the EC2 instance.
ProductCodes (list) -- The product code of the EC2 instance.
(dict) -- The product code of the EC2 instance.
Code (string) -- Product code information.
ProductType (string) -- Product code type.
Tags (list) -- The tags of the EC2 instance.
(dict) -- A tag of the EC2 instance.
Key (string) -- EC2 instance tag key.
Value (string) -- EC2 instance tag value.
ResourceType (string) -- The type of the AWS resource.
SchemaVersion (string) -- Findings' schema version.
Service (dict) -- Additional information assigned to the generated finding by GuardDuty.
Action (dict) -- Information about the activity described in a finding.
ActionType (string) -- GuardDuty Finding activity type.
AwsApiCallAction (dict) -- Information about the AWS_API_CALL action described in this finding.
Api (string) -- AWS API name.
CallerType (string) -- AWS API caller type.
DomainDetails (dict) -- Domain information for the AWS API call.
RemoteIpDetails (dict) -- Remote IP information of the connection.
City (dict) -- City information of the remote IP address.
CityName (string) -- City name of the remote IP address.
Country (dict) -- Country code of the remote IP address.
CountryCode (string) -- Country code of the remote IP address.
CountryName (string) -- Country name of the remote IP address.
GeoLocation (dict) -- Location information of the remote IP address.
Lat (float) -- Latitude information of remote IP address.
Lon (float) -- Longitude information of remote IP address.
IpAddressV4 (string) -- IPV4 remote address of the connection.
Organization (dict) -- ISP Organization information of the remote IP address.
Asn (string) -- Autonomous system number of the internet provider of the remote IP address.
AsnOrg (string) -- Organization that registered this ASN.
Isp (string) -- ISP information for the internet provider.
Org (string) -- Name of the internet provider.
ServiceName (string) -- AWS service name whose API was invoked.
DnsRequestAction (dict) -- Information about the DNS_REQUEST action described in this finding.
Domain (string) -- Domain information for the DNS request.
NetworkConnectionAction (dict) -- Information about the NETWORK_CONNECTION action described in this finding.
Blocked (boolean) -- Network connection blocked information.
ConnectionDirection (string) -- Network connection direction.
LocalPortDetails (dict) -- Local port information of the connection.
Port (integer) -- Port number of the local connection.
PortName (string) -- Port name of the local connection.
Protocol (string) -- Network connection protocol.
RemoteIpDetails (dict) -- Remote IP information of the connection.
City (dict) -- City information of the remote IP address.
CityName (string) -- City name of the remote IP address.
Country (dict) -- Country code of the remote IP address.
CountryCode (string) -- Country code of the remote IP address.
CountryName (string) -- Country name of the remote IP address.
GeoLocation (dict) -- Location information of the remote IP address.
Lat (float) -- Latitude information of remote IP address.
Lon (float) -- Longitude information of remote IP address.
IpAddressV4 (string) -- IPV4 remote address of the connection.
Organization (dict) -- ISP Organization information of the remote IP address.
Asn (string) -- Autonomous system number of the internet provider of the remote IP address.
AsnOrg (string) -- Organization that registered this ASN.
Isp (string) -- ISP information for the internet provider.
Org (string) -- Name of the internet provider.
RemotePortDetails (dict) -- Remote port information of the connection.
Port (integer) -- Port number of the remote connection.
PortName (string) -- Port name of the remote connection.
Archived (boolean) -- Indicates whether this finding is archived.
Count (integer) -- Total count of the occurrences of this finding type.
DetectorId (string) -- Detector ID for the GuardDuty service.
EventFirstSeen (string) -- First seen timestamp of the activity that prompted GuardDuty to generate this finding.
EventLastSeen (string) -- Last seen timestamp of the activity that prompted GuardDuty to generate this finding.
ResourceRole (string) -- Resource role information for this finding.
ServiceName (string) -- The name of the AWS service (GuardDuty) that generated a finding.
UserFeedback (string) -- Feedback left about the finding.
Severity (float) -- The severity of a finding.
Title (string) -- The title of a finding.
Type (string) -- The type of a finding described by the action.
UpdatedAt (string) -- The time stamp at which a finding was last updated.
Retrieves the IPSet specified by the IPSet ID.
See also: AWS API Documentation
Request Syntax
client.get_ip_set( DetectorId='string', IpSetId='string' )
string
[REQUIRED] The detectorID that specifies the GuardDuty service whose IPSet you want to retrieve.
string
[REQUIRED] The unique ID that specifies the IPSet that you want to describe.
dict
Response Syntax
{ 'Format': 'TXT'|'STIX'|'OTX_CSV'|'ALIEN_VAULT'|'PROOF_POINT'|'FIRE_EYE', 'Location': 'string', 'Name': 'string', 'Status': 'INACTIVE'|'ACTIVATING'|'ACTIVE'|'DEACTIVATING'|'ERROR'|'DELETE_PENDING'|'DELETED' }
Response Structure
(dict) -- 200 response
Format (string) -- The format of the file that contains the IPSet.
Location (string) -- The URI of the file that contains the IPSet. For example (https://s3.us-west-2.amazonaws.com/my-bucket/my-object-key)
Name (string) -- The user friendly name to identify the IPSet. This name is displayed in all findings that are triggered by activity that involves IP addresses included in this IPSet.
Status (string) -- The status of ipSet file uploaded.
Retrieves an Amazon GuardDuty detector specified by the detectorId.
See also: AWS API Documentation
Request Syntax
client.get_detector( DetectorId='string' )
string
[REQUIRED] The unique ID of the detector that you want to retrieve.
dict
Response Syntax
{ 'CreatedAt': 'string', 'ServiceRole': 'string', 'Status': 'ENABLED'|'DISABLED', 'UpdatedAt': 'string' }
Response Structure
(dict) -- 200 response
CreatedAt (string) -- The first time a resource was created. The format will be ISO-8601.
ServiceRole (string) -- Customer serviceRole name or ARN for accessing customer resources
Status (string) -- The status of detector.
UpdatedAt (string) -- The first time a resource was created. The format will be ISO-8601.
Disassociates the current GuardDuty member account from its master account.
See also: AWS API Documentation
Request Syntax
client.disassociate_from_master_account( DetectorId='string' )
string
[REQUIRED] The unique ID of the detector of the GuardDuty member account.
dict
Response Syntax
{}
Response Structure
(dict) -- 200 response
Lists Amazon GuardDuty findings for the specified detector ID.
See also: AWS API Documentation
Request Syntax
client.list_findings( DetectorId='string', FindingCriteria={ 'Criterion': { 'string': { 'Eq': [ 'string', ], 'Gt': 123, 'Gte': 123, 'Lt': 123, 'Lte': 123, 'Neq': [ 'string', ] } } }, MaxResults=123, NextToken='string', SortCriteria={ 'AttributeName': 'string', 'OrderBy': 'ASC'|'DESC' } )
string
[REQUIRED] The ID of the detector that specifies the GuardDuty service whose findings you want to list.
dict
Represents the criteria used for querying findings.
Criterion (dict) -- Represents a map of finding properties that match specified conditions and values when querying findings.
(string) --
(dict) -- Finding attribute (for example, accountId) for which conditions and values must be specified when querying findings.
Eq (list) -- Represents the equal condition to be applied to a single field when querying for findings.
(string) --
Gt (integer) -- Represents the greater than condition to be applied to a single field when querying for findings.
Gte (integer) -- Represents the greater than equal condition to be applied to a single field when querying for findings.
Lt (integer) -- Represents the less than condition to be applied to a single field when querying for findings.
Lte (integer) -- Represents the less than equal condition to be applied to a single field when querying for findings.
Neq (list) -- Represents the not equal condition to be applied to a single field when querying for findings.
(string) --
integer
You can use this parameter to indicate the maximum number of items you want in the response. The default value is 50. The maximum value is 50.
string
You can use this parameter when paginating results. Set the value of this parameter to null on your first call to the ListFindings action. For subsequent calls to the action fill nextToken in the request with the value of nextToken from the previous response to continue listing data.
dict
Represents the criteria used for sorting findings.
AttributeName (string) -- Represents the finding attribute (for example, accountId) by which to sort findings.
OrderBy (string) -- Order by which the sorted findings are to be displayed.
dict
Response Syntax
{ 'FindingIds': [ 'string', ], 'NextToken': 'string' }
Response Structure
(dict) -- 200 response
FindingIds (list) -- The list of the Findings.
(string) -- The unique identifier for the Finding
NextToken (string) -- You can use this parameter when paginating results. Set the value of this parameter to null on your first call to the list action. For subsequent calls to the action fill nextToken in the request with the value of NextToken from the previous response to continue listing data.
Lists the ThreatIntelSets of the GuardDuty service specified by the detector ID.
See also: AWS API Documentation
Request Syntax
client.list_threat_intel_sets( DetectorId='string', MaxResults=123, NextToken='string' )
string
[REQUIRED] The detectorID that specifies the GuardDuty service whose ThreatIntelSets you want to list.
integer
You can use this parameter to indicate the maximum number of items that you want in the response. The default value is 7. The maximum value is 7.
string
Pagination token to start retrieving threat intel sets from.
dict
Response Syntax
{ 'NextToken': 'string', 'ThreatIntelSetIds': [ 'string', ] }
Response Structure
(dict) -- 200 response
NextToken (string) -- You can use this parameter when paginating results. Set the value of this parameter to null on your first call to the list action. For subsequent calls to the action fill nextToken in the request with the value of NextToken from the previous response to continue listing data.
ThreatIntelSetIds (list) -- The list of the threat intel set IDs
(string) -- The unique identifier for an threat intel set
Retrieves the ThreatIntelSet that is specified by the ThreatIntelSet ID.
See also: AWS API Documentation
Request Syntax
client.get_threat_intel_set( DetectorId='string', ThreatIntelSetId='string' )
string
[REQUIRED] The detectorID that specifies the GuardDuty service whose ThreatIntelSet you want to describe.
string
[REQUIRED] The unique ID that specifies the ThreatIntelSet that you want to describe.
dict
Response Syntax
{ 'Format': 'TXT'|'STIX'|'OTX_CSV'|'ALIEN_VAULT'|'PROOF_POINT'|'FIRE_EYE', 'Location': 'string', 'Name': 'string', 'Status': 'INACTIVE'|'ACTIVATING'|'ACTIVE'|'DEACTIVATING'|'ERROR'|'DELETE_PENDING'|'DELETED' }
Response Structure
(dict) -- 200 response
Format (string) -- The format of the threatIntelSet.
Location (string) -- The URI of the file that contains the ThreatIntelSet. For example (https://s3.us-west-2.amazonaws.com/my-bucket/my-object-key).
Name (string) -- A user-friendly ThreatIntelSet name that is displayed in all finding generated by activity that involves IP addresses included in this ThreatIntelSet.
Status (string) -- The status of threatIntelSet file uploaded.
Lists all GuardDuty membership invitations that were sent to the current AWS account.
See also: AWS API Documentation
Request Syntax
client.list_invitations( MaxResults=123, NextToken='string' )
integer
You can use this parameter to indicate the maximum number of invitations you want in the response. The default value is 50. The maximum value is 50.
string
You can use this parameter when paginating results. Set the value of this parameter to null on your first call to the ListInvitations action. Subsequent calls to the action fill nextToken in the request with the value of NextToken from the previous response to continue listing data.
dict
Response Syntax
{ 'Invitations': [ { 'AccountId': 'string', 'InvitationId': 'string', 'InvitedAt': 'string', 'RelationshipStatus': 'string' }, ], 'NextToken': 'string' }
Response Structure
(dict) -- 200 response
Invitations (list) -- A list of invitation descriptions.
(dict) -- Invitation from an AWS account to become the current account's master.
AccountId (string) -- Inviter account ID
InvitationId (string) -- This value is used to validate the inviter account to the member account.
InvitedAt (string) -- Timestamp at which the invitation was sent
RelationshipStatus (string) -- The status of the relationship between the inviter and invitee accounts.
NextToken (string) -- You can use this parameter when paginating results. Set the value of this parameter to null on your first call to the list action. For subsequent calls to the action fill nextToken in the request with the value of NextToken from the previous response to continue listing data.
Deletes the IPSet specified by the IPSet ID.
See also: AWS API Documentation
Request Syntax
client.delete_ip_set( DetectorId='string', IpSetId='string' )
string
[REQUIRED] The detectorID that specifies the GuardDuty service whose IPSet you want to delete.
string
[REQUIRED] The unique ID that specifies the IPSet that you want to delete.
dict
Response Syntax
{}
Response Structure
(dict) -- 200 response
Provides the details for the GuardDuty master account to the current GuardDuty member account.
See also: AWS API Documentation
Request Syntax
client.get_master_account( DetectorId='string' )
string
[REQUIRED] The unique ID of the detector of the GuardDuty member account.
dict
Response Syntax
{ 'Master': { 'AccountId': 'string', 'InvitationId': 'string', 'InvitedAt': 'string', 'RelationshipStatus': 'string' } }
Response Structure
(dict) -- 200 response
Master (dict) -- Contains details about the master account.
AccountId (string) -- Master account ID
InvitationId (string) -- This value is used to validate the master account to the member account.
InvitedAt (string) -- Timestamp at which the invitation was sent
RelationshipStatus (string) -- The status of the relationship between the master and member accounts.
Marks specified Amazon GuardDuty findings as useful or not useful.
See also: AWS API Documentation
Request Syntax
client.update_findings_feedback( Comments='string', DetectorId='string', Feedback='USEFUL'|'NOT_USEFUL', FindingIds=[ 'string', ] )
string
Additional feedback about the GuardDuty findings.
string
[REQUIRED] The ID of the detector that specifies the GuardDuty service whose findings you want to mark as useful or not useful.
string
Valid values: USEFUL | NOT_USEFUL
list
IDs of the findings that you want to mark as useful or not useful.
(string) -- The unique identifier for the Finding
dict
Response Syntax
{}
Response Structure
(dict) -- 200 response
Declines invitations sent to the current member account by AWS account specified by their account IDs.
See also: AWS API Documentation
Request Syntax
client.decline_invitations( AccountIds=[ 'string', ] )
list
A list of account IDs of the AWS accounts that sent invitations to the current member account that you want to decline invitations from.
(string) --
dict
Response Syntax
{ 'UnprocessedAccounts': [ { 'AccountId': 'string', 'Result': 'string' }, ] }
Response Structure
(dict) -- 200 response
UnprocessedAccounts (list) -- A list of objects containing the unprocessed account and a result string explaining why it was unprocessed.
(dict) -- An object containing the unprocessed account and a result string explaining why it was unprocessed.
AccountId (string) -- AWS Account ID.
Result (string) -- A reason why the account hasn't been processed.
Create a new ThreatIntelSet. ThreatIntelSets consist of known malicious IP addresses. GuardDuty generates findings based on ThreatIntelSets.
See also: AWS API Documentation
Request Syntax
client.create_threat_intel_set( Activate=True|False, DetectorId='string', Format='TXT'|'STIX'|'OTX_CSV'|'ALIEN_VAULT'|'PROOF_POINT'|'FIRE_EYE', Location='string', Name='string' )
boolean
A boolean value that indicates whether GuardDuty is to start using the uploaded ThreatIntelSet.
string
[REQUIRED] The unique ID of the detector that you want to update.
string
The format of the file that contains the ThreatIntelSet.
string
The URI of the file that contains the ThreatIntelSet. For example (https://s3.us-west-2.amazonaws.com/my-bucket/my-object-key).
string
A user-friendly ThreatIntelSet name that is displayed in all finding generated by activity that involves IP addresses included in this ThreatIntelSet.
dict
Response Syntax
{ 'ThreatIntelSetId': 'string' }
Response Structure
(dict) -- 200 response
ThreatIntelSetId (string) -- The unique identifier for an threat intel set
Updates an Amazon GuardDuty detector specified by the detectorId.
See also: AWS API Documentation
Request Syntax
client.update_detector( DetectorId='string', Enable=True|False )
string
[REQUIRED] The unique ID of the detector that you want to update.
boolean
Updated boolean value for the detector that specifies whether the detector is enabled.
dict
Response Syntax
{}
Response Structure
(dict) -- 200 response
Updates the ThreatIntelSet specified by ThreatIntelSet ID.
See also: AWS API Documentation
Request Syntax
client.update_threat_intel_set( Activate=True|False, DetectorId='string', Location='string', Name='string', ThreatIntelSetId='string' )
boolean
The updated boolean value that specifies whether the ThreateIntelSet is active or not.
string
[REQUIRED] The detectorID that specifies the GuardDuty service whose ThreatIntelSet you want to update.
string
The updated URI of the file that contains the ThreateIntelSet. For example (https://s3.us-west-2.amazonaws.com/my-bucket/my-object-key)
string
The unique ID that specifies the ThreatIntelSet that you want to update.
string
[REQUIRED] The unique ID that specifies the ThreatIntelSet that you want to update.
dict
Response Syntax
{}
Response Structure
(dict) -- 200 response
Invites other AWS accounts (created as members of the current AWS account by CreateMembers) to enable GuardDuty and allow the current AWS account to view and manage these accounts' GuardDuty findings on their behalf as the master account.
See also: AWS API Documentation
Request Syntax
client.invite_members( AccountIds=[ 'string', ], DetectorId='string', Message='string' )
list
A list of account IDs of the accounts that you want to invite to GuardDuty as members.
(string) --
string
[REQUIRED] The unique ID of the detector of the GuardDuty account with which you want to invite members.
string
The invitation message that you want to send to the accounts that you're inviting to GuardDuty as members.
dict
Response Syntax
{ 'UnprocessedAccounts': [ { 'AccountId': 'string', 'Result': 'string' }, ] }
Response Structure
(dict) -- 200 response
UnprocessedAccounts (list) -- A list of objects containing the unprocessed account and a result string explaining why it was unprocessed.
(dict) -- An object containing the unprocessed account and a result string explaining why it was unprocessed.
AccountId (string) -- AWS Account ID.
Result (string) -- A reason why the account hasn't been processed.
Re-enables GuardDuty to monitor findings of the member accounts specified by the account IDs. A master GuardDuty account can run this command after disabling GuardDuty from monitoring these members' findings by running StopMonitoringMembers.
See also: AWS API Documentation
Request Syntax
client.start_monitoring_members( AccountIds=[ 'string', ], DetectorId='string' )
list
A list of account IDs of the GuardDuty member accounts whose findings you want the master account to monitor.
(string) --
string
[REQUIRED] The unique ID of the detector of the GuardDuty account whom you want to re-enable to monitor members' findings.
dict
Response Syntax
{ 'UnprocessedAccounts': [ { 'AccountId': 'string', 'Result': 'string' }, ] }
Response Structure
(dict) -- 200 response
UnprocessedAccounts (list) -- A list of objects containing the unprocessed account and a result string explaining why it was unprocessed.
(dict) -- An object containing the unprocessed account and a result string explaining why it was unprocessed.
AccountId (string) -- AWS Account ID.
Result (string) -- A reason why the account hasn't been processed.
Creates a new IPSet - a list of trusted IP addresses that have been whitelisted for secure communication with AWS infrastructure and applications.
See also: AWS API Documentation
Request Syntax
client.create_ip_set( Activate=True|False, DetectorId='string', Format='TXT'|'STIX'|'OTX_CSV'|'ALIEN_VAULT'|'PROOF_POINT'|'FIRE_EYE', Location='string', Name='string' )
boolean
A boolean value that indicates whether GuardDuty is to start using the uploaded IPSet.
string
[REQUIRED] The unique ID of the detector that you want to update.
string
The format of the file that contains the IPSet.
string
The URI of the file that contains the IPSet. For example (https://s3.us-west-2.amazonaws.com/my-bucket/my-object-key)
string
The user friendly name to identify the IPSet. This name is displayed in all findings that are triggered by activity that involves IP addresses included in this IPSet.
dict
Response Syntax
{ 'IpSetId': 'string' }
Response Structure
(dict) -- 200 response
IpSetId (string) -- The unique identifier for an IP Set
Disassociates GuardDuty member accounts (to the current GuardDuty master account) specified by the account IDs.
See also: AWS API Documentation
Request Syntax
client.disassociate_members( AccountIds=[ 'string', ], DetectorId='string' )
list
A list of account IDs of the GuardDuty member accounts that you want to disassociate from master.
(string) --
string
[REQUIRED] The unique ID of the detector of the GuardDuty account whose members you want to disassociate from master.
dict
Response Syntax
{ 'UnprocessedAccounts': [ { 'AccountId': 'string', 'Result': 'string' }, ] }
Response Structure
(dict) -- 200 response
UnprocessedAccounts (list) -- A list of objects containing the unprocessed account and a result string explaining why it was unprocessed.
(dict) -- An object containing the unprocessed account and a result string explaining why it was unprocessed.
AccountId (string) -- AWS Account ID.
Result (string) -- A reason why the account hasn't been processed.
Lists Amazon GuardDuty findings' statistics for the specified detector ID.
See also: AWS API Documentation
Request Syntax
client.get_findings_statistics( DetectorId='string', FindingCriteria={ 'Criterion': { 'string': { 'Eq': [ 'string', ], 'Gt': 123, 'Gte': 123, 'Lt': 123, 'Lte': 123, 'Neq': [ 'string', ] } } }, FindingStatisticTypes=[ 'COUNT_BY_SEVERITY', ] )
string
[REQUIRED] The ID of the detector that specifies the GuardDuty service whose findings' statistics you want to retrieve.
dict
Represents the criteria used for querying findings.
Criterion (dict) -- Represents a map of finding properties that match specified conditions and values when querying findings.
(string) --
(dict) -- Finding attribute (for example, accountId) for which conditions and values must be specified when querying findings.
Eq (list) -- Represents the equal condition to be applied to a single field when querying for findings.
(string) --
Gt (integer) -- Represents the greater than condition to be applied to a single field when querying for findings.
Gte (integer) -- Represents the greater than equal condition to be applied to a single field when querying for findings.
Lt (integer) -- Represents the less than condition to be applied to a single field when querying for findings.
Lte (integer) -- Represents the less than equal condition to be applied to a single field when querying for findings.
Neq (list) -- Represents the not equal condition to be applied to a single field when querying for findings.
(string) --
list
Types of finding statistics to retrieve.
(string) -- The types of finding statistics.
dict
Response Syntax
{ 'FindingStatistics': { 'CountBySeverity': { 'string': 123 } } }
Response Structure
(dict) -- 200 response
FindingStatistics (dict) -- Finding statistics object.
CountBySeverity (dict) -- Represents a map of severity to count statistic for a set of findings
(string) --
(integer) -- The count of findings for the given severity.
Deletes a Amazon GuardDuty detector specified by the detector ID.
See also: AWS API Documentation
Request Syntax
client.delete_detector( DetectorId='string' )
string
[REQUIRED] The unique ID that specifies the detector that you want to delete.
dict
Response Syntax
{}
Response Structure
(dict) -- 200 response
Archives Amazon GuardDuty findings specified by the list of finding IDs.
See also: AWS API Documentation
Request Syntax
client.archive_findings( DetectorId='string', FindingIds=[ 'string', ] )
string
[REQUIRED] The ID of the detector that specifies the GuardDuty service whose findings you want to archive.
list
IDs of the findings that you want to archive.
(string) -- The unique identifier for the Finding
dict
Response Syntax
{}
Response Structure
(dict) -- 200 response
Disables GuardDuty from monitoring findings of the member accounts specified by the account IDs. After running this command, a master GuardDuty account can run StartMonitoringMembers to re-enable GuardDuty to monitor these members' findings.
See also: AWS API Documentation
Request Syntax
client.stop_monitoring_members( AccountIds=[ 'string', ], DetectorId='string' )
list
A list of account IDs of the GuardDuty member accounts whose findings you want the master account to stop monitoring.
(string) --
string
[REQUIRED] The unique ID of the detector of the GuardDuty account that you want to stop from monitor members' findings.
dict
Response Syntax
{ 'UnprocessedAccounts': [ { 'AccountId': 'string', 'Result': 'string' }, ] }
Response Structure
(dict) -- 200 response
UnprocessedAccounts (list) -- A list of objects containing the unprocessed account and a result string explaining why it was unprocessed.
(dict) -- An object containing the unprocessed account and a result string explaining why it was unprocessed.
AccountId (string) -- AWS Account ID.
Result (string) -- A reason why the account hasn't been processed.
Unarchives Amazon GuardDuty findings specified by the list of finding IDs.
See also: AWS API Documentation
Request Syntax
client.unarchive_findings( DetectorId='string', FindingIds=[ 'string', ] )
string
[REQUIRED] The ID of the detector that specifies the GuardDuty service whose findings you want to unarchive.
list
IDs of the findings that you want to unarchive.
(string) -- The unique identifier for the Finding
dict
Response Syntax
{}
Response Structure
(dict) -- 200 response
Accepts the invitation to be monitored by a master GuardDuty account.
See also: AWS API Documentation
Request Syntax
client.accept_invitation( DetectorId='string', InvitationId='string', MasterId='string' )
string
[REQUIRED] The unique ID of the detector of the GuardDuty member account.
string
This value is used to validate the master account to the member account.
string
The account ID of the master GuardDuty account whose invitation you're accepting.
dict
Response Syntax
{}
Response Structure
(dict) -- 200 response
Deletes GuardDuty member accounts (to the current GuardDuty master account) specified by the account IDs.
See also: AWS API Documentation
Request Syntax
client.delete_members( AccountIds=[ 'string', ], DetectorId='string' )
list
A list of account IDs of the GuardDuty member accounts that you want to delete.
(string) --
string
[REQUIRED] The unique ID of the detector of the GuardDuty account whose members you want to delete.
dict
Response Syntax
{ 'UnprocessedAccounts': [ { 'AccountId': 'string', 'Result': 'string' }, ] }
Response Structure
(dict) -- 200 response
UnprocessedAccounts (list) -- A list of objects containing the unprocessed account and a result string explaining why it was unprocessed.
(dict) -- An object containing the unprocessed account and a result string explaining why it was unprocessed.
AccountId (string) -- AWS Account ID.
Result (string) -- A reason why the account hasn't been processed.
Updates the IPSet specified by the IPSet ID.
See also: AWS API Documentation
Request Syntax
client.update_ip_set( Activate=True|False, DetectorId='string', IpSetId='string', Location='string', Name='string' )
boolean
The updated boolean value that specifies whether the IPSet is active or not.
string
[REQUIRED] The detectorID that specifies the GuardDuty service whose IPSet you want to update.
string
[REQUIRED] The unique ID that specifies the IPSet that you want to update.
string
The updated URI of the file that contains the IPSet. For example (https://s3.us-west-2.amazonaws.com/my-bucket/my-object-key).
string
The unique ID that specifies the IPSet that you want to update.
dict
Response Syntax
{}
Response Structure
(dict) -- 200 response
Retrieves GuardDuty member accounts (to the current GuardDuty master account) specified by the account IDs.
See also: AWS API Documentation
Request Syntax
client.get_members( AccountIds=[ 'string', ], DetectorId='string' )
list
A list of account IDs of the GuardDuty member accounts that you want to describe.
(string) --
string
[REQUIRED] The unique ID of the detector of the GuardDuty account whose members you want to retrieve.
dict
Response Syntax
{ 'Members': [ { 'AccountId': 'string', 'DetectorId': 'string', 'Email': 'string', 'InvitedAt': 'string', 'MasterId': 'string', 'RelationshipStatus': 'string', 'UpdatedAt': 'string' }, ], 'UnprocessedAccounts': [ { 'AccountId': 'string', 'Result': 'string' }, ] }
Response Structure
(dict) -- 200 response
Members (list) -- A list of member descriptions.
(dict) -- Contains details about the member account.
AccountId (string) -- AWS account ID.
DetectorId (string) -- The unique identifier for a detector.
Email (string) -- Member account's email address.
InvitedAt (string) -- Timestamp at which the invitation was sent
MasterId (string) -- The master account ID.
RelationshipStatus (string) -- The status of the relationship between the member and the master.
UpdatedAt (string) -- The first time a resource was created. The format will be ISO-8601.
UnprocessedAccounts (list) -- A list of objects containing the unprocessed account and a result string explaining why it was unprocessed.
(dict) -- An object containing the unprocessed account and a result string explaining why it was unprocessed.
AccountId (string) -- AWS Account ID.
Result (string) -- A reason why the account hasn't been processed.
Deletes invitations sent to the current member account by AWS accounts specified by their account IDs.
See also: AWS API Documentation
Request Syntax
client.delete_invitations( AccountIds=[ 'string', ] )
list
A list of account IDs of the AWS accounts that sent invitations to the current member account that you want to delete invitations from.
(string) --
dict
Response Syntax
{ 'UnprocessedAccounts': [ { 'AccountId': 'string', 'Result': 'string' }, ] }
Response Structure
(dict) -- 200 response
UnprocessedAccounts (list) -- A list of objects containing the unprocessed account and a result string explaining why it was unprocessed.
(dict) -- An object containing the unprocessed account and a result string explaining why it was unprocessed.
AccountId (string) -- AWS Account ID.
Result (string) -- A reason why the account hasn't been processed.
Creates a single Amazon GuardDuty detector. A detector is an object that represents the GuardDuty service. A detector must be created in order for GuardDuty to become operational.
See also: AWS API Documentation
Request Syntax
client.create_detector( Enable=True|False )
boolean
A boolean value that specifies whether the detector is to be enabled.
dict
Response Syntax
{ 'DetectorId': 'string' }
Response Structure
(dict) -- 200 response
DetectorId (string) -- The unique ID of the created detector.
Creates member accounts of the current AWS account by specifying a list of AWS account IDs. The current AWS account can then invite these members to manage GuardDuty in their accounts.
See also: AWS API Documentation
Request Syntax
client.create_members( AccountDetails=[ { 'AccountId': 'string', 'Email': 'string' }, ], DetectorId='string' )
list
A list of account ID and email address pairs of the accounts that you want to associate with the master GuardDuty account.
(dict) -- An object containing the member's accountId and email address.
AccountId (string) -- Member account ID.
Email (string) -- Member account's email address.
string
[REQUIRED] The unique ID of the detector of the GuardDuty account with which you want to associate member accounts.
dict
Response Syntax
{ 'UnprocessedAccounts': [ { 'AccountId': 'string', 'Result': 'string' }, ] }
Response Structure
(dict) -- 200 response
UnprocessedAccounts (list) -- A list of objects containing the unprocessed account and a result string explaining why it was unprocessed.
(dict) -- An object containing the unprocessed account and a result string explaining why it was unprocessed.
AccountId (string) -- AWS Account ID.
Result (string) -- A reason why the account hasn't been processed.
Lists the IPSets of the GuardDuty service specified by the detector ID.
See also: AWS API Documentation
Request Syntax
client.list_ip_sets( DetectorId='string', MaxResults=123, NextToken='string' )
string
[REQUIRED] The unique ID of the detector that you want to retrieve.
integer
You can use this parameter to indicate the maximum number of items that you want in the response. The default value is 7. The maximum value is 7.
string
You can use this parameter when paginating results. Set the value of this parameter to null on your first call to the ListIPSet action. For subsequent calls to the action fill nextToken in the request with the value of NextToken from the previous response to continue listing data.
dict
Response Syntax
{ 'IpSetIds': [ 'string', ], 'NextToken': 'string' }
Response Structure
(dict) -- 200 response
IpSetIds (list) -- A list of the IP set IDs
(string) -- The unique identifier for an IP Set
NextToken (string) -- You can use this parameter when paginating results. Set the value of this parameter to null on your first call to the list action. For subsequent calls to the action fill nextToken in the request with the value of NextToken from the previous response to continue listing data.
Generates example findings of types specified by the list of finding types. If 'NULL' is specified for findingTypes, the API generates example findings of all supported finding types.
See also: AWS API Documentation
Request Syntax
client.create_sample_findings( DetectorId='string', FindingTypes=[ 'string', ] )
string
[REQUIRED] The ID of the detector to create sample findings for.
list
Types of sample findings that you want to generate.
(string) -- The finding type for the finding
dict
Response Syntax
{}
Response Structure
(dict) -- 200 response
Deletes ThreatIntelSet specified by the ThreatIntelSet ID.
See also: AWS API Documentation
Request Syntax
client.delete_threat_intel_set( DetectorId='string', ThreatIntelSetId='string' )
string
[REQUIRED] The detectorID that specifies the GuardDuty service whose ThreatIntelSet you want to delete.
string
[REQUIRED] The unique ID that specifies the ThreatIntelSet that you want to delete.
dict
Response Syntax
{}
Response Structure
(dict) -- 200 response
Returns the count of all GuardDuty membership invitations that were sent to the current member account except the currently accepted invitation.
See also: AWS API Documentation
Request Syntax
client.get_invitations_count()
dict
Response Syntax
{ 'InvitationsCount': 123 }
Response Structure
(dict) -- 200 response
InvitationsCount (integer) -- The number of received invitations.
Lists detectorIds of all the existing Amazon GuardDuty detector resources.
See also: AWS API Documentation
Request Syntax
client.list_detectors( MaxResults=123, NextToken='string' )
integer
You can use this parameter to indicate the maximum number of detectors that you want in the response.
string
You can use this parameter when paginating results. Set the value of this parameter to null on your first call to the ListDetectors action. For subsequent calls to the action fill nextToken in the request with the value of nextToken from the previous response to continue listing data.
dict
Response Syntax
{ 'DetectorIds': [ 'string', ], 'NextToken': 'string' }
Response Structure
(dict) -- 200 response
DetectorIds (list) -- A list of detector Ids.
(string) -- The unique identifier for a detector.
NextToken (string) -- You can use this parameter when paginating results. Set the value of this parameter to null on your first call to the list action. For subsequent calls to the action fill nextToken in the request with the value of NextToken from the previous response to continue listing data.
Lists details about all member accounts for the current GuardDuty master account.
See also: AWS API Documentation
Request Syntax
client.list_members( DetectorId='string', MaxResults=123, NextToken='string', OnlyAssociated='string' )
string
[REQUIRED] The unique ID of the detector of the GuardDuty account whose members you want to list.
integer
You can use this parameter to indicate the maximum number of items you want in the response. The default value is 1. The maximum value is 50.
string
You can use this parameter when paginating results. Set the value of this parameter to null on your first call to the ListMembers action. Subsequent calls to the action fill nextToken in the request with the value of NextToken from the previous response to continue listing data.
string
Specifies what member accounts the response is to include based on their relationship status with the master account. The default value is TRUE. If onlyAssociated is set to TRUE, the response will include member accounts whose relationship status with the master is set to Enabled, Disabled. If onlyAssociated is set to FALSE, the response will include all existing member accounts.
dict
Response Syntax
{ 'Members': [ { 'AccountId': 'string', 'DetectorId': 'string', 'Email': 'string', 'InvitedAt': 'string', 'MasterId': 'string', 'RelationshipStatus': 'string', 'UpdatedAt': 'string' }, ], 'NextToken': 'string' }
Response Structure
(dict) -- 200 response
Members (list) -- A list of member descriptions.
(dict) -- Contains details about the member account.
AccountId (string) -- AWS account ID.
DetectorId (string) -- The unique identifier for a detector.
Email (string) -- Member account's email address.
InvitedAt (string) -- Timestamp at which the invitation was sent
MasterId (string) -- The master account ID.
RelationshipStatus (string) -- The status of the relationship between the member and the master.
UpdatedAt (string) -- The first time a resource was created. The format will be ISO-8601.
NextToken (string) -- You can use this parameter when paginating results. Set the value of this parameter to null on your first call to the list action. For subsequent calls to the action fill nextToken in the request with the value of NextToken from the previous response to continue listing data.