액세스 가능한 고객을 나열하는 것은 Search Ads 360 Reporting API에서 요청에 고객 ID를 지정할 필요가 없는 몇 가지 요청 중 하나이며 제공된 login-customer-id를 무시합니다.
결과로 반환되는 고객 목록은 OAuth 사용자 인증 정보를 기반으로 합니다. 이 요청은 현재 사용자 인증 정보를 사용하여 직접 작업할 수 있는 모든 계정의 목록을 반환합니다.
여기에는 계정 계층 구조 내의 모든 계정이 포함되는 것은 아닙니다. 인증된 사용자가 계정에 관리자 또는 기타 권한으로 추가된 계정만 포함됩니다.
위 그림의 두 계층에서 M1 및 C3의 관리자인 사용자 A라고 가정해 보겠습니다. Search Ads 360 Reporting API(예: SearchAds360Service)를 호출하면 M1, C1, C2, C3 계정의 정보에 액세스할 수 있습니다. 하지만 CustomerService.ListAccessibleCustomers를 호출하면 M1 및 C3만 반환됩니다. A 사용자가 직접 액세스할 수 있는 계정이 이 두 계정뿐이기 때문입니다.
[[["이해하기 쉬움","easyToUnderstand","thumb-up"],["문제가 해결됨","solvedMyProblem","thumb-up"],["기타","otherUp","thumb-up"]],[["필요한 정보가 없음","missingTheInformationINeed","thumb-down"],["너무 복잡함/단계 수가 너무 많음","tooComplicatedTooManySteps","thumb-down"],["오래됨","outOfDate","thumb-down"],["번역 문제","translationIssue","thumb-down"],["샘플/코드 문제","samplesCodeIssue","thumb-down"],["기타","otherDown","thumb-down"]],["최종 업데이트: 2025-08-29(UTC)"],[[["\u003cp\u003eUse the \u003ccode\u003eListAccessibleCustomers\u003c/code\u003e method in \u003ccode\u003eCustomerService\u003c/code\u003e to retrieve a list of customers you can directly access.\u003c/p\u003e\n"],["\u003cp\u003eThis request uses your OAuth credentials and returns only accounts where you have admin or other direct access rights, not all accounts within the hierarchy.\u003c/p\u003e\n"],["\u003cp\u003eUnlike other Search Ads 360 Reporting API requests, this method doesn't require or consider a customer ID.\u003c/p\u003e\n"],["\u003cp\u003eYou can use the returned customer resource names to access data for those specific accounts using other API services.\u003c/p\u003e\n"]]],["The `ListAccessibleCustomers` method in `CustomerService` allows you to retrieve a list of directly accessible customer accounts. This request doesn't need a customer ID or `login-customer-id`. The returned list is determined by your OAuth credentials, showing only accounts where your user has direct administrative or other rights. Accessing information for an account in the hierarchy requires the user to have admin rights for it, while a direct call to `ListAccessibleCustomers` reveals only accounts directly managed. The document presents examples in Java and Python.\n"],null,["# List Accessible Accounts\n\nYou can list customers accessible to you with the\n[`ListAccessibleCustomers`](/search-ads/reporting/api/reference/rpc/google.ads.searchads360.v0.services#customerservice)\nmethod in [`CustomerService`](/search-ads/reporting/api/reference/rpc/google.ads.searchads360.v0.services#customerservice).\nHowever, it is necessary\nto understand which customers are returned in this type of request.\n\nListing accessible customers is one of the few requests in the Search Ads 360 Reporting API\nthat does not require you to specify a customer ID in the request,\nand will ignore any supplied\n[`login-customer-id`](/search-ads/reporting/concepts/call-structure#login_customer_id_header).\n\nThe resulting list of customers is based on your OAuth credentials. The\nrequest returns a list of all accounts that you are able to act upon\n**directly** given your current credentials.\nThis will not necessarily include all accounts within the account\nhierarchy; rather, it will only include accounts\nwhere your authenticated user has been added with admin or other rights\nin the account.\n\nImagine you are user `A` who is an admin for `M1` and `C3` in the two\nhierarchies\npictured above. If you were to make a call to the Search Ads 360 Reporting API, for example to\n[`SearchAds360Service`](/search-ads/reporting/api/reference/rpc/google.ads.searchads360.v0.services#searchads360service),\nyou could access information for accounts `M1`, `C1`, `C2`,\nand `C3`. However, a call to\n[`CustomerService.ListAccessibleCustomers`](/search-ads/reporting/api/reference/rpc/google.ads.searchads360.v0.services#customerservice) would\nreturn only `M1` and `C3` since those are the only accounts where user `A` has\n**direct** access.\n\nHere is a code example illustrating the use of the\n[`CustomerService.ListAccessibleCustomers`](/search-ads/reporting/api/reference/rpc/google.ads.searchads360.v0.services#customerservice)\nmethod: \n\n### Java\n\n\n```java\n// Copyright 2022 Google LLC\n//\n// Licensed under the Apache License, Version 2.0 (the \"License\");\n// you may not use this file except in compliance with the License.\n// You may obtain a copy of the License at\n//\n// https://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing, software\n// distributed under the License is distributed on an \"AS IS\" BASIS,\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n// See the License for the specific language governing permissions and\n// limitations under the License.\n\npackage sample;\n\nimport com.google.ads.searchads360.v0.lib.SearchAds360Client;\nimport com.google.ads.searchads360.v0.services.CustomerServiceClient;\nimport com.google.ads.searchads360.v0.services.ListAccessibleCustomersRequest;\nimport com.google.ads.searchads360.v0.services.ListAccessibleCustomersResponse;\n\n/** List all customers that can be accessed by the authenticated Google account. */\npublic class ListAccessibleCustomers {\n\n public static void main(String[] args) {\n try {\n // Creates a SearchAds360Client with local properties file\n final SearchAds360Client searchAds360Client =\n SearchAds360Client.newBuilder().fromPropertiesFile().build();\n // Creates the Customer Service Client.\n CustomerServiceClient client = searchAds360Client.createCustomerServiceClient();\n new ListAccessibleCustomers().runExample(client);\n } catch (Exception exception) {\n System.err.printf(\"Failed with exception: %s%n\", exception);\n exception.printStackTrace();\n System.exit(1);\n }\n }\n\n private void runExample(CustomerServiceClient customerServiceClient) {\n ListAccessibleCustomersResponse response =\n customerServiceClient.listAccessibleCustomers(\n ListAccessibleCustomersRequest.getDefaultInstance());\n\n System.out.printf(\"Total results: %d%n\", response.getResourceNamesCount());\n\n for (String customerResourceName : response.getResourceNamesList()) {\n System.out.printf(\"Customer resource name: %s%n\", customerResourceName);\n }\n }\n}\n```\n\n\u003cbr /\u003e\n\n[Download ListAccessibleCustomers.java](https://developers.google.com/search-ads/reporting/sample-code/ListAccessibleCustomers.java)\n\n### Python\n\n\n```python\n#!/usr/bin/env python\n# Copyright 2022 Google LLC\n#\n# Licensed under the Apache License, Version 2.0 (the \"License\");\n# you may not use this file except in compliance with the License.\n# You may obtain a copy of the License at\n#\n# https://www.apache.org/licenses/LICENSE-2.0\n#\n# Unless required by applicable law or agreed to in writing, software\n# distributed under the License is distributed on an \"AS IS\" BASIS,\n# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n# See the License for the specific language governing permissions and\n# limitations under the License.\n\"\"\"Lists all accessible customers.\"\"\"\n\nimport traceback\nfrom util_searchads360 import SearchAds360Client\n\n\ndef main(client) -\u003e None:\n customer_service = client.get_customer_service()\n\n # Issues a list accessible customer request.\n accessible_customers = customer_service.list_accessible_customers()\n result_total = len(accessible_customers.resource_names)\n print(f\"Total results: {result_total}\")\n\n resource_names = accessible_customers.resource_names\n for resource_name in resource_names:\n print(f'Accessible customer resource name: \"{resource_name}\"')\n\n\nif __name__ == \"__main__\":\n # SearchAds360Client will read the search-ads-360.yaml configuration file in\n # the home directory if none is specified.\n search_ads_360_client = SearchAds360Client.load_from_file()\n\n try:\n main(search_ads_360_client)\n except Exception: # pylint: disable=broad-except\n traceback.print_exc()\n```\n\n\u003cbr /\u003e\n\n[Download list_accessible_customers.py](https://developers.google.com/search-ads/reporting/sample-code/list_accessible_customers.py)"]]