GraphQL API
Panther GraphQL API를 사용하여 Panther 엔티티와 상호작용하기
개요
Panther는 공개 GraphQL-over-HTTP API를 제공하므로 일반적인 HTTP 요청을 사용해 GraphQL 쿼리를 작성하고 API를 호출할 수 있습니다. GraphQL에 대한 자세한 내용은 GraphQL의 문서.
현재 GraphQL API를 통해 다음 엔터티와 상호작용할 수 있습니다:
추가 작업은 REST API.
GraphQL 쿼리 이해하기
클릭하여 GraphQL 쿼리 예시 확장
아래 예제 쿼리의 이름은 ListAlerts입니다. 이 쿼리는 각 알러트의 모든 id, title, severity 와 status 제공된 시간 범위를 기반으로 반환합니다.
사용자를 사용할 것이며,
input형식의 변수AlertsInput는 createdAtAfter와 같은 특정 조건을 기반으로 알러트를 필터링하는 데 사용됩니다,createdAtAfter와createdAtBefore입니다. 이러한 조건들은 쿼리에 대한 시간 범위를 제공합니다.사용자를 사용할 것이며,
알러트필드는edges와pageInfo를 포함한 객체를 반환합니다. 각 엣지는node필드를 가지며 실제 알러트 데이터(예:id,title,severity와status.사용자를 사용할 것이며,
pageInfo필드는hasNextPage와endCursor, 사용자가hasNextPage가 되면 모든 알러트 페이지를 순회할 수 있게 해주는) 페이지네이션에 대한 정보를 포함합니다.true.
query ListAlerts($input: AlertsInput!) {
alerts(input: $input) {
edges {
node {
id
title
severity
status
}
}
pageInfo {
hasNextPage
endCursor
}
}
}Panther GraphQL 스키마 알아보기
GraphQL 스키마를 찾는 방법은 세 가지가 있습니다:
옵션 1(가장 빠름): 공개적으로 제공되는 GraphQL 스키마 파일 다운로드
옵션 2(가장 사용자 친화적): 사용 Panther의 API 플레이그라운드
옵션 3(도구 및 서비스에 가장 적합): 수행 인트로스펙션 쿼리 를 GraphQL 엔드포인트에 대해
옵션 1: 공개적으로 제공되는 GraphQL 스키마 파일 다운로드
최신 버전의 GraphQL 스키마 파일을 다운로드할 수 있습니다 에 대해 더 읽을 수 있습니다.
옵션 2: GraphQL 플레이그라운드 사용
Panther의 API 플레이그라운드는 API에서 지원하는 항목을 탐색하고 발견하는 데 사용자 친화적인 방법입니다. 사용 방법에 대해서는 API 플레이그라운드 문서 를 참조하십시오. 발견 메커니즘으로서 이를 사용하는 방법에 대한 정보입니다.
옵션 3: 인트로스펙션 쿼리 실행
인트로스펙션 쿼리는 대부분의 서드파티 라이브러리가 파싱할 수 있는 형식으로 GraphQL API의 모든 엔티티를 반환합니다. 이 발견 옵션은 다른 라이브러리나 서비스가 Panther API가 지원하는 작업과 타입을 인식하게 하려는 경우에 유용합니다. 이러한 라이브러리들은 일반적으로 자체적인 인트로스펙션 쿼리를 발행하므로 API URL만 가리키면 됩니다.
보안상의 이유로 인트로스펙션 쿼리는 권한이 필요한 작업입니다. 이는 인트로스펙션이 작동하려면 X-API-Key 헤더를 HTTP 호출에 추가하고 값으로 API 토큰 을(를) 제공해야 함을 의미합니다.
인트로스펙션 쿼리의 실제 형태는 사용자 정의가 가능합니다. 제한된 엔티티 집합만 요청하거나 스키마에 대한 모든 가능한 정보를 요청할 수 있습니다. 예를 들어 다음과 같은 쿼리는 스키마의 모든 정보를 반환합니다:
Panther GraphQL API 사용 방법
1단계: Panther GraphQL API URL 확인
GraphQL API URL을 찾으려면:
Panther 콘솔의 오른쪽 상단에서 톱니바퀴 아이콘을 클릭한 다음, API 토큰.
페이지 상단에서 API URL.
GraphQL API URL 구조는 Panther 배포 모델에 따라 다릅니다:
SaaS 배포:
https://api.{YOUR_PANTHER_DOMAIN}.runpanther.net/public/graphqlCloud Connected 와 셀프호스트 배포:
https://{YOUR_PANTHER_DOMAIN}/v1/public/graphql

2단계: API 토큰 생성
3단계: Panther GraphQL API 호출
테스트용으로 API 플레이그라운드외에도 GraphQL-over-HTTP API를 호출하는 방법은 두 가지가 있습니다:
옵션 1 (권장): GraphQL 클라이언트를 설치하여 전송 관련 복잡성을 추상화하여 사용
옵션 2: 수동으로 HTTP 호출 구성
옵션 1: GraphQL 클라이언트 설치 및 사용 (권장)
모든 GraphQL 연산은 본질적으로 단순한 HTTP 호출이지만, GraphQL 클라이언트를 사용하면 더 사용자 친화적이라는 장점이 있습니다.
다음을 사용하는 것을 권장합니다:
graphql-requestNodeJS 프로젝트용gqlPython 프로젝트용go-graphql-clientGo 프로젝트용
아래는 시스템에서 첫 페이지의 알러트를 가져오기 위해 GraphQL 쿼리를 구성하는 몇 가지 예입니다:
옵션 2: 수동으로 HTTP 호출 구성하기
요청 예시:
위의 쿼리는 모든 Panther 알러트의 첫 페이지를 반환합니다. GraphQL을 처음 사용하신다면 다음 사항을 참고하세요:
엔드포인트는 하나뿐입니다.
HTTP 작업은 항상
POST입니다.API 작업은
HTTP 원시 이벤트(HTTP Raw events)의 본문에 정의되어 있습니다.의 본문은
HTTP 원시 이벤트(HTTP Raw events)작업 항상 다음 키들을 포함합니다:query- 실행되어야 할 GraphQL 작업을 정의하는 GraphQL 문자열variables- 쿼리에 전달될 선택적 변수 집합operationName- 이 작업에 대한 선택적 "별명"
데이터를 반환하는 작업인 경우 항상 반환할 필드 집합을 선택해야 합니다.
참고: 한 GraphQL 작업에서 다른 작업으로 변경되는 유일한 것은 HTTP의 본문뿐입니다 HTTP 원시 이벤트(HTTP Raw events).
마지막 업데이트
도움이 되었나요?

