실시간 탐지 시나리오 수정

지정한 실시간 탐지 시나리오를 수정합니다.

필요 권한

관리자 이상의 계정으로 이용할 수 있습니다.

HTTP 요청

PUT /api/sonar/stream-rules/:guid
cURL 예시
curl -H "Authorization: Bearer <API_KEY>" \
     -d priority="MEDIUM" \
     -d name="알려진 봇넷 대역 접속" \
     -d msg="알려진 봇넷 대역 접속: $dst_ip" \
     -d schema_code="session" \
     -d commands="[{'template_id': 3, 'query': 'matchnet invert=t field=dst_ip guid=697393b6-aecf-4e9d-a32c-8724cd8f067e verify=f', 'field_name': 'dst_ip', 'args':{'subnet':'697393b6-aecf-4e9d-a32c-8724cd8f067e'}}]"
     -X PUT \
     https://HOSTNAME/api/sonar/stream-rules/5a6b63f0-87d5-49c4-a5a1-94da4141b2f5
요청 매개변수
필수타입설명비고
priorityO문자열중요도LOW, MEDIUM, HIGH 중 하나
guidO문자열실시간 탐지 시나리오 GUID36자
nameO문자열실시간 탐지 시나리오 이름최소 1자, 최대 255자
descriptionX문자열실시간 탐지 시나리오 설명최대 2,000자
msgO문자열메시지 템플릿최소 1자, 최대 2,000자
enabledX불리언활성화 여부true 혹은 false
category_guidX문자열시나리오 분류 GUID36자
schema_codeO문자열정규화 스키마 식별자최소 1자, 최대 50자
source_typeX문자열탐지 대상LOGGER 또는 LOGGER_MODEL. 미지정 시 LOGGER
logger_guidsO배열수집기 GUID 목록
logger_model_guidsX배열수집기 모델 GUID 목록source_type이 LOGGER_MODEL인 경우 사용
commandsO배열실시간 탐지 명령어 목록1개 이상의 명령어 필요. 하단 설명 참조
address_group_guidX문자열주소 그룹 GUID36자
address_fieldX문자열주소 필드주소 그룹에 등록할 필드 이름. 최대 50자
ticket_issue_condX문자열티켓 발생 조건NEVER, ETIR_THRESHOLD, ALWAYS 중 하나
ticket_repo_guidX문자열티켓 분류 GUIDticket_issue_condNEVER가 아닌 경우 필수. 36자
ticket_assignee_guidX문자열티켓 할당자 GUID지정 시 담당자 자동 할당
ticket_suppress_intervalX32비트 정수중복 티켓 축약 기간초 단위. 0 또는 미설정 시 동일 티켓을 병합하지 않음
event_suppress_intervalX32비트 정수중복 이벤트 제거 기간초 단위. 0 또는 미설정 시 중복 이벤트를 제거하지 않음
suppress_keyX문자열중복 기준 필드$field 형식으로 매크로 사용 가능. 최대 2,000자
keep_aliveX불리언축약 타이머 유지 여부축약 타이머 유지 시 true, 초기화 시 false
audit_category_guidX문자열소명 분류 GUID미설정 시 자동 소명 요청이 비활성화됨. 36자
reviewer_guidX문자열1차 검토자 계정 GUID36자
auditor_guidX문자열소명 확인 계정 GUID미설정 시 부서장 전결. 36자
audit_daysX32비트 정수소명 제출 마감 시한최소 1일, 최대 365일
employee_key_fieldX문자열사번 필드 이름미설정 시 자동 소명 요청이 비활성화됨. 최대 50자
alarm_group_guidX문자열알람 그룹 GUID36자
field_orderX문자열근거 자료 필드 출력 순서최대 2,000자
user_noteX문자열소명 요청 메시지최대 2,000자
mitre_techniquesX문자열 목록MITRE ATT&CK 테크닉 ID쉼표로 구분된 테크닉 ID 목록. 설정 시 연관 택틱 자동 포함
mitre_tacticsX문자열 목록MITRE ATT&CK 택틱 ID쉼표로 구분된 택틱 ID 목록. 택틱만 단독 지정 시 사용
signature_appX문자열시그니처 앱 이름

commands의 각 배열 요소는 아래와 같이 정의합니다:

필수타입설명비고
template_idO32비트 정수실시간 탐지 명령어 템플릿 ID
queryO문자열부분 쿼리 문자열
field_nameX문자열대상 필드 이름
argsX인자 키/값
invertX불리언반전 여부

정상 응답

{}

오류 응답

필수 매개변수가 누락된 경우

HTTP 상태 코드 400 응답

{
  "error_code": "null-argument",
  "error_msg": "schema_code should be not null"
}
매개변수 값의 길이가 잘못된 경우

HTTP 상태 코드 400 응답

{
  "error_code": "invalid-argument",
  "error_msg": "'schema_code' must be shorter than or equal to 50 characters."
}
잘못된 중요도 값을 사용한 경우

HTTP 상태 코드 400 응답

{
  "error_code": "invalid-argument",
  "error_msg": "priority should be one of 'LOW', 'MEDIUM', 'HIGH'."
}
식별자가 GUID 형식이 아닌 경우

HTTP 상태 코드 400 응답

{
  "error_code": "invalid-param-type",
  "error_msg": "category_guid should be guid type."
}
실시간 탐지 명령어 목록이 유효한 JSON 형식이 아닌 경우

HTTP 상태 코드 400 응답

{
  "error_code": "invalid-argument",
  "error_msg": "'commands' parameter should follow valid JSON syntax"
}
시나리오가 존재하지 않는 경우

HTTP 상태 코드 500 응답

{
  "error_code": "illegal-state",
  "error_msg": "stream rule not found: 9071a6fe-6b91-4448-9761-7123381cb026"
}
정규화 스키마가 존재하지 않는 경우

HTTP 상태 코드 500 응답

{
  "error_code": "illegal-state",
  "error_msg": "schema not found: unknown"
}
시나리오 생성 권한이 없는 경우

HTTP 상태 코드 500 응답

{
  "error_code": "illegal-state",
  "error_msg": "no-permission"
}