JSON 매핑

Search Ads 360 Reporting API의 REST 인터페이스를 사용할 때 Search Ads 360 Reporting API의 .proto 설명자 파일에 정의된 것과 동일한 리소스 및 유형의 JSON 표현으로 작업하게 됩니다. JSON 인코딩 스키마는 프로토콜 버퍼 언어 가이드JSON 매핑 섹션에 설명된 표준 인코딩 스키마를 따릅니다.

일반적으로 서비스에서 주고받는 모든 최상위 메시지는 단일 JSON 객체입니다. search 응답은 쿼리 결과 집합과 함께 results 배열이 포함된 JSON 객체입니다.

식별자는 JSON의 snake_case (프로토콜 버퍼 내)에서 lowerCamelCase로 변환됩니다. 이 규칙에서 주의할 점은 search 또는 searchStream를 사용하여 Search Ads 360 쿼리 언어 쿼리를 전송하는 경우입니다. 사용 중인 인터페이스에 관계없이 쿼리 언어 자체는 스네이크 표기법을 사용합니다. 하지만 REST의 쿼리 결과는 일반 JSON 객체로 반환되며 lowerCamelCase에 식별자가 있습니다.

예를 들어 계정의 활성 키워드 목록을 가져오는 쿼리는 쿼리 자체 내에서 스네이크 표기법 (adGroupCriterion가 아닌 ad_group_criterion)을 사용합니다.

POST /v0/customers/CUSTOMER_ID/searchAds360:searchStream HTTP/1.1
Host: searchads360.googleapis.com
Content-Type: application/json
Authorization: Bearer ACCESS_TOKEN

{
  "query": "SELECT ad_group_criterion.keyword.text
            FROM ad_group_criterion
            WHERE ad_group_criterion.type = 'KEYWORD'
            AND ad_group_criterion.status = 'ENABLED'"
}

그러나 응답은 객체의 JSON 표현이며 (이 요청에서 searchStream를 사용하므로 JSON 배열로 래핑됨) 대신 CamlCase 식별자 adGroupCriterion를 사용합니다.

[
  {
    "results": [
      {
        "adGroupCriterion": {
          "resourceName": "customers/1842689525/adGroupCriteria/55771861891~10003060",
          "keyword": {
            "text": "pay per click"
          }
        }
      },
      ...
    ]
  }
]