JSON 매핑

Search Ads 360 Reporting API의 REST 인터페이스를 사용하면 Search Ads 360 Reporting API의 .proto descriptor 파일에 정의된 것과 동일한 리소스 및 유형의 JSON 표현을 사용하게 됩니다. JSON 인코딩 스키마는 프로토콜 버퍼 Language GuideJSON 매핑 섹션에 설명된 표준 인코딩 스키마를 따릅니다.

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

식별자는 프로토콜 버퍼의 snake_case에서 JSON의 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 배열로 래핑됨) 대신 camelCase 식별자 adGroupCriterion를 사용합니다.

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