- HTTP request
- Path parameters
- Request body
- Response body
- Authorization scopes
- IAM Permissions
- ExecutionError
- Try it!
Full name: projects.locations.instances.legacy.legacyTestRuleStreaming
legacy.legacyTestRuleStreaming tests the given rule text over a specified time range and streams detections/errors back without persisting them.
HTTP request
Path parameters
| Parameters | |
|---|---|
| instance | 
 Required. Chronicle instance this request is sent to. Format: projects/{project}/locations/{location}/instances/{instance} | 
Request body
The request body contains data with the following structure:
| JSON representation | 
|---|
| { "ruleText": string, "startTime": string, "endTime": string, "maxDetections": integer, "scope": string } | 
| Fields | |
|---|---|
| ruleText | 
 Required. The rule text to test as a UTF-8 string. | 
| startTime | 
 Optional. The start time of the time range of events to test the rule text over. If unspecified, will default to 12 hours before endTime. Uses RFC 3339, where generated output will always be Z-normalized and use 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
| endTime | 
 Optional. The end time of the time range of events to test the rule text over. If unspecified, will either default to 12 hours after startTime, or the current day bucket if startTime is also unspecified. Uses RFC 3339, where generated output will always be Z-normalized and use 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
| maxDetections | 
 Optional. The maximum number of detections to return. The service may return fewer than this value. If unspecified, at most 1,000 detections will be returned. The maximum value is 10,000; values above 10,000 will be coerced to 10,000. | 
| scope | 
 Optional. The data access scope to use to run the rule. This field is only required if data access control is enabled. If reference lists are used in the rule, validations will be performed against this scope to ensure that the reference lists are compatible with both the user's and the rule's scopes. The scope should be in the format: "projects/{project}/locations/{location}/instances/{instance}/dataAccessScopes/{scope}". | 
Response body
legacy.legacyTestRuleStreaming response message.
If successful, the response body contains data with the following structure:
| JSON representation | 
|---|
| { "ruleCompilationError": { object ( | 
| Fields | |
|---|---|
| ruleCompilationError | 
 The compilation error generated from the rule text. | 
| tooManyDetections | 
 Indicates if the request would have streamed more detections than maxResults allows. | 
| progressPercent | 
 The progress percent of the run, from 0.0-100.0. | 
| Union field  
 | |
| detection | 
 A detection generated from the test. The following fields will not be set because the detection is not persisted: - createdTime - detection[].rule_id - detection[].rule_version id will be set, but cannot be passed to other methods to retrieve the detection since it is not persisted. | 
| executionError | 
 An execution error generated from the test. | 
Authorization scopes
Requires the following OAuth scope:
- https://www.googleapis.com/auth/cloud-platform
For more information, see the Authentication Overview.
IAM Permissions
Requires the following IAM permission on the instance resource:
- chronicle.legacies.legacyTestRuleStreaming
For more information, see the IAM documentation.
ExecutionError
An execution error generated from the test.
| JSON representation | 
|---|
| { "error": { object ( | 
| Fields | |
|---|---|
| error | 
 The error status corresponding with the execution error. | 
| timeRange | 
 The event time range that the execution error corresponds with. |