คุณสามารถแสดงรายชื่อลูกค้าที่คุณเข้าถึงได้ด้วย
ListAccessibleCustomers
ใน CustomerService
อย่างไรก็ตาม มีความจำเป็น
เพื่อทำความเข้าใจว่าลูกค้ารายใดแสดงผลในคำขอประเภทนี้
รายชื่อลูกค้าที่เข้าถึงได้เป็นหนึ่งในไม่กี่คำขอใน Google Ads API ที่
คุณไม่จำเป็นต้องระบุรหัสลูกค้าในคำขอ และจะไม่สนใจ
login-customer-id
ที่ระบุ
รายชื่อลูกค้าที่ได้จะอิงตามข้อมูลเข้าสู่ระบบ OAuth จะแสดงรายชื่อบัญชีทั้งหมดที่คุณสามารถดำเนินการได้ โดยตรง โดยใช้ข้อมูลเข้าสู่ระบบปัจจุบันของคุณ ซึ่งอาจไม่ได้รวม บัญชีทั้งหมดภายในลำดับชั้นบัญชี แต่จะรวมเฉพาะบัญชี ซึ่งมีการเพิ่มผู้ใช้ที่ได้รับการตรวจสอบสิทธิ์แล้วพร้อมสิทธิ์ระดับผู้ดูแลระบบหรือสิทธิ์อื่นๆ ใน ของคุณได้
สมมติว่าคุณเป็นผู้ใช้ A
ซึ่งเป็นผู้ดูแลระบบของ M1
และ C3
ใน 2 ลำดับชั้น
ตามภาพด้านบน หากคุณเรียกใช้ Google Ads API เช่น
GoogleAdsService
คุณมีสิทธิ์เข้าถึง
ข้อมูลสำหรับบัญชี M1
, C1
, C2
และ C3
อย่างไรก็ตาม ขอให้
CustomerService.ListAccessibleCustomers
จะ
แสดงผลเฉพาะ M1
และ C3
เนื่องจากเป็นบัญชีเดียวที่ผู้ใช้ A
มี
การเข้าถึงโดยตรง
ต่อไปนี้คือตัวอย่างโค้ดที่แสดงการใช้งาน CustomerService.ListAccessibleCustomers
วิธีการ:
Java
private void runExample(GoogleAdsClient client) { // Optional: Change credentials to use a different refresh token, to retrieve customers // available for a specific user. // // UserCredentials credentials = // UserCredentials.newBuilder() // .setClientId("INSERT_OAUTH_CLIENT_ID") // .setClientSecret("INSERT_OAUTH_CLIENT_SECRET") // .setRefreshToken("INSERT_REFRESH_TOKEN") // .build(); // // client = client.toBuilder().setCredentials(credentials).build(); try (CustomerServiceClient customerService = client.getLatestVersion().createCustomerServiceClient()) { ListAccessibleCustomersResponse response = customerService.listAccessibleCustomers( ListAccessibleCustomersRequest.newBuilder().build()); System.out.printf("Total results: %d%n", response.getResourceNamesCount()); for (String customerResourceName : response.getResourceNamesList()) { System.out.printf("Customer resource name: %s%n", customerResourceName); } } }
C#
public void Run(GoogleAdsClient client) { // Get the CustomerService. CustomerServiceClient customerService = client.GetService(Services.V17.CustomerService); try { // Retrieve the list of customer resources. string[] customerResourceNames = customerService.ListAccessibleCustomers(); // Display the result. foreach (string customerResourceName in customerResourceNames) { Console.WriteLine( $"Found customer with resource name = '{customerResourceName}'."); } } catch (GoogleAdsException e) { Console.WriteLine("Failure:"); Console.WriteLine($"Message: {e.Message}"); Console.WriteLine($"Failure: {e.Failure}"); Console.WriteLine($"Request ID: {e.RequestId}"); throw; } }
PHP
public static function runExample(GoogleAdsClient $googleAdsClient) { $customerServiceClient = $googleAdsClient->getCustomerServiceClient(); // Issues a request for listing all accessible customers. $accessibleCustomers = $customerServiceClient->listAccessibleCustomers(new ListAccessibleCustomersRequest()); print 'Total results: ' . count($accessibleCustomers->getResourceNames()) . PHP_EOL; // Iterates over all accessible customers' resource names and prints them. foreach ($accessibleCustomers->getResourceNames() as $resourceName) { /** @var string $resourceName */ printf("Customer resource name: '%s'%s", $resourceName, PHP_EOL); } }
Python
def main(client): customer_service = client.get_service("CustomerService") accessible_customers = customer_service.list_accessible_customers() result_total = len(accessible_customers.resource_names) print(f"Total results: {result_total}") resource_names = accessible_customers.resource_names for resource_name in resource_names: print(f'Customer resource name: "{resource_name}"')
Ruby
def list_accessible_customers() # GoogleAdsClient will read a config file from # ENV['HOME']/google_ads_config.rb when called without parameters client = Google::Ads::GoogleAds::GoogleAdsClient.new accessible_customers = client.service.customer.list_accessible_customers().resource_names accessible_customers.each do |resource_name| puts "Customer resource name: #{resource_name}" end end
Perl
sub list_accessible_customers { my ($api_client) = @_; my $list_accessible_customers_response = $api_client->CustomerService()->list_accessible_customers(); printf "Total results: %d.\n", scalar @{$list_accessible_customers_response->{resourceNames}}; foreach my $resource_name (@{$list_accessible_customers_response->{resourceNames}}) { printf "Customer resource name: '%s'.\n", $resource_name; } return 1; }
แสดงรายการบัญชีที่ยกเลิก
Google Ads API ไม่ได้มีวิธีโดยตรงในการแสดงบัญชีที่ยกเลิกภายใต้ บัญชีดูแลจัดการ แต่คุณสามารถใช้วิธีแก้ไขปัญหาต่อไปนี้เพื่อเรียกข้อมูล รายการนี้
ดึงข้อมูลรายการลิงก์
ACTIVE
โดยใช้แหล่งข้อมูลcustomer_client_link
และสร้างรายชื่อลูกค้าโดยใช้customer_client_link.client_customer
ด้วยSELECT customer_client_link.client_customer, customer_client_link.status FROM customer_client_link WHERE customer_client_link.status = ACTIVE
เรียกข้อมูลรายชื่อ
ENABLED
บัญชีโดยใช้ทรัพยากรcustomer_client
SELECT customer_client.id, customer_client.descriptive_name FROM customer_client
ความแตกต่างระหว่าง 2 รายการนี้จะแสดงรายการบัญชีที่ถูกยกเลิก