파생 디택션

Panther에서 하나의 기본 디택션으로부터 하나 이상의 파생 디택션 생성하기

개요

Panther에서는 단일 Base 디택션에서 하나 이상의 Derived 디택션을 생성할 수 있습니다. Derived 디택션은 변경할 수 없는 Base 디택션의 핵심 로직과, 덮어쓸 수 있는 메타데이터 및 알러트 필드 값을 상속합니다.

디택션 파생은 다음으로 생성된 룰에 사용할 수 있습니다 간단한 디택션 또는 Python 탐지.

Derived 디택션의 사용 사례

파생은 다음과 같은 경우 특히 유용할 수 있습니다:

  • 서로 다른 메타데이터를 가진 동일한 룰의 여러 복사본을 유지하는 경우

  • CLI 워크플로우에서 다음을 사용하고 사용자 지정합니다 Panther에서 관리하는 룰, 그리고 Panther가 업데이트를 출시할 때 병합 충돌을 해결해야 하는 일을 피하고 싶은 경우

  • 사고 대응 중에 다음 결정을 내리는 데 도움이 되는 텔레메트리를 수집하기 위해 하나의 디택션의 여러 변형을 배포할 수 있는 기능을 원합니다

  • 팀의 한 구성원(예: 위협 연구 책임자)은 다른 구성원(예: SOC 분석가)이 수정할 수 있는 Base 디택션 집합을 만들고 싶어 합니다

Base 디택션 및 Derived 디택션

Base 디택션은 사용자 지정 또는 Panther 관리형 룰이며, 여기서 Derived 디택션이 생성되었습니다.

Derived 디택션은 Base 디택션에서 생성되며 다음을 수행합니다:

  • Base 디택션의 핵심 디택션 로직을 상속합니다

    • 핵심 디택션 로직은 Base 디택션의 룰() 함수(Python 디택션의 경우) 또는 디택션 필드(Simple 디택션의 경우)에서 정의됩니다.

    • Derived 디택션은 자체 디택션 로직을 지정할 수 없습니다. 예를 들어 CLI 워크플로우에서 Derived 디택션에 디택션 키가 포함되어 있으면 해당 내용은 무시됩니다.

  • Base 디택션의 메타데이터/알러트 필드 값을 상속하지만 일부 필드는 덮어쓸 수 있습니다

    • 다음을 참조하세요 디택션 파생의 제한 사항 오늘날 덮어쓸 수 있는 필드의 전체 목록은 다음에서 확인하세요.

    • Derived 디택션에서 수행한 재정의는 Base 디택션에서 상속한 필드 값을 완전히 대체합니다. 예를 들어 Base 디택션과 Derived 디택션이 모두 인라인 필터 를 정의하는 경우( InlineFilters 키(CLI 워크플로우에서) 또는 이벤트만 포함하도록 필터링 필드(콘솔에서)를 사용하면 Derived 디택션의 인라인 필터만 적용됩니다.

    • 재정의는 한 방향으로만 수행할 수 있습니다. 즉, Derived 디택션에서 수행한 재정의는 Base 디택션 값에 영향을 주지 않습니다. 예를 들어 Base 디택션이 Enabled: False 이고 해당 Derived 디택션이 Enabled: True이면 Derived 디택션만 활성화됩니다.

Base 디택션이 업데이트될 때 발생하는 일

Base 디택션의 핵심 로직이 업데이트되면 변경 사항은 관련된 모든 Derived 디택션에 전파됩니다.

Base 디택션의 메타데이터가 업데이트될 때, 관련 Derived 디택션이 이미 업데이트된 필드의 값(들)을 덮어쓴 경우에는 변경 사항이 없습니다. 관련 Derived 디택션이 업데이트된 필드의 값(들)을 덮어쓰지 않은 경우에는 메타데이터 업데이트가 Derived 디택션으로 전파됩니다.

중복 알러트를 방지하려면 Base 디택션을 비활성화하세요

대부분의 경우 Base 디택션과 Derived 디택션은 동일한 들어오는 로그 집합에서 실행됩니다(하지만 인라인 필터 를 사용하여 서로 다른 이벤트를 대상으로 할 수는 있습니다). 이 시나리오에서는 디택션이 핵심 로직을 공유하므로 둘 다 활성화되어 있으면 중복 알러트를 생성합니다.

이를 방지하려면 Base 디택션을 비활성화하세요. 비활성화된 Base 디택션이 업데이트되면 해당 변경 사항은 계속해서 Derived 디택션으로 전파됩니다 위에서 설명한 대로.

CLI 워크플로우에서 Base 디택션을 자동으로 비활성화하기

CLI 워크플로우에서는 Base 디택션을 자동으로 비활성화하는 두 가지 방법이 있습니다:

  • 옵션 1(권장)다음 설정을 귀하의 .panther_settings.yml 파일에 추가하세요:

  • 옵션 2: 다음을 사용하세요. --auto-disable-basePanther Analysis Tool upload 명령.

    • 이 옵션을 따를 때는 --auto-disable-base 이후의 모든 upload 호출에 사용해야 합니다. 이를 생략하면 Base 디택션이 다시 활성화됩니다.

circle-exclamation

Derived 디택션을 만드는 방법

Panther Console에서 Derived 디택션 만들기

  1. Panther Console의 왼쪽 탐색 모음에서 Detections.

  2. 새 Derived 디택션의 Base 디택션이 될 디택션을 찾아 이름을 클릭합니다.

  3. 오른쪽 상단에서 다음을 클릭하세요. ....

  4. 다음을 클릭하세요. Derive: In the Panther Console, the three dots menu on a detection's page is open, and the Derive option is circled.

  5. 다음 항목에서 기본 정보 페이지에서 선택적으로 이름ID 필드를 Derived 디택션에 맞게 편집합니다.

    • 이름이 Base 디택션의 이름과 구별되도록 하세요.

  6. 다음을 클릭하세요. 계속.

  7. 아래로 스크롤하여 필터알러트 필드 설정 섹션으로 이동한 다음, 인라인 필터와 알러트 필드에 원하는 재정의를 설정합니다: The edit detection page in the Panther Console is shown. A Filter section is visible, along with a Set Alert Fields section. Within the latter are sub-sections for Required Fields and Optional Fields.

  8. 오른쪽 상단에서 다음을 클릭하세요. 배포.

    • 해당 디택션에는 DERIVED 레이블이 표시됩니다: The word "DERIVED" is shown in teal.

모든 파생 디택션을 보는 방법

Panther 인스턴스에서 모든 파생 디택션을 보려면:

  1. Panther Console의 왼쪽 탐색 모음에서 다음을 클릭하세요. Detections.

  2. 다음을 클릭하세요. 필터 아이콘.

  3. 다음에서 디택션 유형 드롭다운 필드에서 다음을 선택합니다 파생 룰.

  4. 다음을 클릭하세요. 필터 적용.

디택션 파생의 제한 사항

  • 다음에는 파생이 사용할 수 없습니다 예약된 룰 또는 정책.

  • 파생은 한 단계만 가능하며, 즉 파생 디택션은 에서 파생될 수 없습니다.

  • Console 워크플로에서는 파생 디택션이 생성될 때 테스트가 상속되지만, 그 이후 기본 디택션의 테스트가 업데이트될 때는 상속되지 않습니다.

  • Python 기본 디택션에서 메타데이터 필드의 값이 Python 함수를 사용해 설정된 경우, 그 값은 파생 디택션에 제공된 동등한 정적 재정의 값보다 우선합니다. 예를 들어, Python severity() 함수가 기본 디택션에 있으면, 그 값은 파생 디택션의 심각도 YAML 키(CLI 워크플로에서) 또는 심각도 필드(Console에서)에 제공된 재정의 값보다 우선합니다.

  • Console 워크플로에서 파생 디택션을 생성하고 기본 디택션이 Python 디택션인 경우, 알러트 필드를 동적으로 설정할 수 없습니다—이들은 정적으로만 설정할 수 있습니다.

    • 그것 기본 디택션이 Simple 디택션인 경우, Console 워크플로에서 알러트 필드를 동적으로 설정할 수 있습니다.

    • 그것 CLI 워크플로(사용)에서 알러트 필드를 동적으로 설정할 수 있습니다 알러트Title, DynamicSeverities, 알러트Context, 그리고 GroupBy—기본 디택션이 Python 디택션이든 YAML 디택션이든 상관없이.

  • 현재는 아래 필드만 덮어쓸 수 있습니다. 이들은 YAML 필드 이름이며 CLI 워크플로에 적용됩니다. Console에 대응하는 필드가 있는 경우, 해당 Console 필드도 덮어쓸 수 있습니다.

    • Enabled

    • 심각도

    • 설명

    • CreateAlert

    • DedupPeriodMinutes

    • InlineFilters

    • DisplayName

    • 기본 위험 점수만 사용

    • 출력 ID

    • 참고

    • Runbook

    • 요약 속성

    • 임계값

    • Tags

    • 보고서

    • DynamicSeverities

    • 알러트Title

    • 알러트Context

    • GroupBy

    • Tests

마지막 업데이트

도움이 되었나요?