Wenn Sie das Merchant Center und seine Funktionen nutzen möchten, müssen Sie die Merchant Center-Nutzungsbedingungen (Nutzungsbedingungen) für Ihren Unternehmensstandort akzeptieren. In diesen Vereinbarungen sind die rechtlichen Bestimmungen für die Nutzung der Merchant Center-Dienste festgelegt.
In dieser Anleitung erfahren Sie, wie Sie diese Vereinbarungen mit der Merchant API verwalten können, sowohl für Ihr eigenes Konto als auch für Konten, die Sie als Drittanbieter verwalten.
Sie haben folgende Möglichkeiten:
- Den aktuellen Status der Nutzungsbedingungen für ein Konto prüfen
- Händler anleiten, die erforderlichen Nutzungsbedingungen zu akzeptieren
- Nutzungsbedingungen als Dienstanbieter für Kundenkonten verwalten
Vorbereitung
Für die Nutzung der Merchant API benötigen Sie ein Merchant Center-Konto. Nachdem Sie es über die Merchant Center Benutzeroberfläche erstellt haben, können Sie Änderungen am Konto vornehmen (z. B. Ihre Unternehmensinformationen aktualisieren oder Nutzer verwalten). Dazu können Sie entweder die Benutzeroberfläche oder die API verwenden.
Wenn Sie mehrere Konten verwalten müssen, können Sie mit der Merchant API Kundenkonten erstellen. Weitere Informationen zu Konten erstellen.
Status der Nutzungsbedingungen für ein Konto prüfen
Bevor ein Händler das Merchant Center vollständig nutzen kann oder wenn Sie den aktuellen Status der Vereinbarung überprüfen müssen, können Sie den Status der Nutzungsbedingungen abrufen.
Verwenden Sie die
termsOfServiceAgreementStates.retrieveForApplication
Methode, um den Status der Nutzungsbedingungen für die Merchant Center
Anwendung abzurufen. Diese Methode gibt die aktuellen Nutzungsbedingungen zurück, sofern vorhanden. Wenn die Nutzungsbedingungen seit Ihrer letzten Annahme aktualisiert wurden, wird die neueste Version zurückgegeben, die Sie akzeptieren müssen.
Ein Beispiel für eine Anfrage:
GET https://merchantapi.googleapis.com/accounts/v1/accounts/{ACCOUNT_ID}/termsOfServiceAgreementStates:retrieveForApplication
Ein erfolgreicher Aufruf gibt eine
TermsOfServiceAgreementState
Ressource zurück. Diese Ressource enthält folgende Informationen:
name: Die ID für diesen Status der Vereinbarung.regionCode: Das Land, auf das sich dieser Status der Vereinbarung bezieht, in der Regel das Land des Unternehmens des Kontos.termsOfServiceKind: Dies istMERCHANT_CENTER.accepted: Details zur Version der Nutzungsbedingungen, die das Konto bereits akzeptiert hat, einschließlich destermsOfServiceRessourcennamens (z. B.termsOfService/132) und der Person, die sieacceptedByhat. Wenn eine neuere Version der Nutzungsbedingungenrequiredist, kann auch ein Datum fürvalidUntilenthalten sein.required: Details zu einer Version der Nutzungsbedingungen, die das Konto akzeptieren muss. Dazu gehören der RessourcennametermsOfServiceund eintosFileUri, der auf das für Menschen lesbare Dokument mit den Nutzungsbedingungen verweist.
Beispielantwort :
{
"name": "accounts/{ACCOUNT_ID}/termsOfServiceAgreementStates/MERCHANT_CENTER-{REGION_CODE}",
"regionCode": "{REGION_CODE}",
"termsOfServiceKind": "MERCHANT_CENTER",
"accepted": {
"termsOfService": "termsOfService/132",
"acceptedBy": "accounts/{ACCOUNT_ID}"
},
"required": {
"termsOfService": "termsOfService/132",
"tosFileUri": "https://www.google.com/intl/{REGION_CODE}/policies/merchants/terms/"
}
}
Wenn neue Nutzungsbedingungen required sind, sollten Sie den Händler anleiten, sie zu akzeptieren.
Hier ist ein Beispiel, mit dem Sie den Status der Nutzungsbedingungen für ein bestimmtes Konto und Land abrufen können:
Java
import com.google.api.gax.core.FixedCredentialsProvider;
import com.google.auth.oauth2.GoogleCredentials;
import com.google.shopping.merchant.accounts.v1.GetTermsOfServiceAgreementStateRequest;
import com.google.shopping.merchant.accounts.v1.TermsOfServiceAgreementState;
import com.google.shopping.merchant.accounts.v1.TermsOfServiceAgreementStateName;
import com.google.shopping.merchant.accounts.v1.TermsOfServiceAgreementStateServiceClient;
import com.google.shopping.merchant.accounts.v1.TermsOfServiceAgreementStateServiceSettings;
import shopping.merchant.samples.utils.Authenticator;
import shopping.merchant.samples.utils.Config;
/**
* This class demonstrates how to get a TermsOfServiceAgreementState for a specific
* TermsOfServiceKind and country.
*/
public class GetTermsOfServiceAgreementStateSample {
public static void getTermsOfServiceAgreementState(Config config) throws Exception {
// Obtains OAuth token based on the user's configuration.
GoogleCredentials credential = new Authenticator().authenticate();
// Creates service settings using the credentials retrieved above.
TermsOfServiceAgreementStateServiceSettings termsOfServiceAgreementStateServiceSettings =
TermsOfServiceAgreementStateServiceSettings.newBuilder()
.setCredentialsProvider(FixedCredentialsProvider.create(credential))
.build();
// Creates TermsOfServiceAgreementState name to identify TermsOfServiceAgreementState.
String name =
TermsOfServiceAgreementStateName.newBuilder()
.setAccount(config.getAccountId().toString())
// The Identifier is: "{TermsOfServiceKind}-{country}"
.setIdentifier("MERCHANT_CENTER-US")
.build()
.toString();
System.out.println(name);
// Calls the API and catches and prints any network failures/errors.
try (TermsOfServiceAgreementStateServiceClient termsOfServiceAgreementStateServiceClient =
TermsOfServiceAgreementStateServiceClient.create(
termsOfServiceAgreementStateServiceSettings)) {
// The name has the format:
// accounts/{account}/termsOfServiceAgreementStates/{TermsOfServiceKind}-{country}
GetTermsOfServiceAgreementStateRequest request =
GetTermsOfServiceAgreementStateRequest.newBuilder().setName(name).build();
System.out.println("Sending Get TermsOfServiceAgreementState request:");
TermsOfServiceAgreementState response =
termsOfServiceAgreementStateServiceClient.getTermsOfServiceAgreementState(request);
System.out.println("Retrieved TermsOfServiceAgreementState below");
// If the terms of service needs to be accepted, the "required" field will include the
// specific version of the terms of service which needs to be accepted, alongside a link to
// the terms of service itself.
System.out.println(response);
} catch (Exception e) {
System.out.println(e);
}
}
public static void main(String[] args) throws Exception {
Config config = Config.load();
getTermsOfServiceAgreementState(config);
}
}
PHP
use Google\ApiCore\ApiException;
use Google\Shopping\Merchant\Accounts\V1\Client\TermsOfServiceAgreementStateServiceClient;
use Google\Shopping\Merchant\Accounts\V1\GetTermsOfServiceAgreementStateRequest;
/**
* Demonstrates how to get a TermsOfServiceAgreementState.
*/
class GetTermsOfServiceAgreementState
{
/**
* Gets a TermsOfServiceAgreementState.
*
* @param array $config The configuration data.
* @return void
*/
public static function getTermsOfServiceAgreementState($config): void
{
// Get OAuth credentials.
$credentials = Authentication::useServiceAccountOrTokenFile();
// Create client options.
$options = ['credentials' => $credentials];
// Create a TermsOfServiceAgreementStateServiceClient.
$termsOfServiceAgreementStateServiceClient = new TermsOfServiceAgreementStateServiceClient($options);
// Service agreeement identifier
$identifier = "MERCHANT_CENTER-US";
// Create TermsOfServiceAgreementState name.
$name = "accounts/" . $config['accountId'] . "/termsOfServiceAgreementStates/" . $identifier;
print $name . PHP_EOL;
try {
// Prepare the request.
$request = new GetTermsOfServiceAgreementStateRequest([
'name' => $name,
]);
print "Sending Get TermsOfServiceAgreementState request:" . PHP_EOL;
$response = $termsOfServiceAgreementStateServiceClient->getTermsOfServiceAgreementState($request);
print "Retrieved TermsOfServiceAgreementState below\n";
print $response->serializeToJsonString() . PHP_EOL;
} catch (ApiException $e) {
print $e->getMessage();
}
}
/**
* Helper to execute the sample.
*
* @return void
*/
public function callSample(): void
{
$config = Config::generateConfig();
self::getTermsOfServiceAgreementState($config);
}
}
// Run the script
$sample = new GetTermsOfServiceAgreementState();
$sample->callSample();
Python
from examples.authentication import configuration
from examples.authentication import generate_user_credentials
from google.shopping.merchant_accounts_v1 import GetTermsOfServiceAgreementStateRequest
from google.shopping.merchant_accounts_v1 import TermsOfServiceAgreementStateServiceClient
# Replace with your actual value.
_ACCOUNT_ID = configuration.Configuration().read_merchant_info()
_IDENTIFIER = "MERCHANT_CENTER-US" # Replace with your identifier
def get_terms_of_service_agreement_state():
"""Gets a TermsOfServiceAgreementState for a specific TermsOfServiceKind and country."""
credentials = generate_user_credentials.main()
client = TermsOfServiceAgreementStateServiceClient(credentials=credentials)
name = (
"accounts/"
+ _ACCOUNT_ID
+ "/termsOfServiceAgreementStates/"
+ _IDENTIFIER
)
print(name)
request = GetTermsOfServiceAgreementStateRequest(name=name)
try:
print("Sending Get TermsOfServiceAgreementState request:")
response = client.get_terms_of_service_agreement_state(request=request)
print("Retrieved TermsOfServiceAgreementState below")
print(response)
except RuntimeError as e:
print(e)
if __name__ == "__main__":
get_terms_of_service_agreement_state()
Nutzungsbedingungen akzeptieren
Händler müssen die neuesten Nutzungsbedingungen akzeptieren, um weiterhin auf die Merchant Center-Funktionen zugreifen zu können.
Nutzungsbedingungen für Ihr eigenes Konto akzeptieren
Wenn Sie Ihr eigenes Merchant Center-Konto verwalten, gehen Sie so vor:
- Rufen Sie
termsOfServiceAgreementStates.retrieveForApplicationauf, um zu prüfen, ob Nutzungsbedingungenrequiredsind. - Wenn Nutzungsbedingungen erforderlich sind, notieren Sie den
termsOfServiceNamen aus demrequiredFeld (z. B.termsOfService/132). Rufen Sie
termsOfService.acceptauf, um die Nutzungsbedingungen zu akzeptieren. Sie benötigen den Namen der Nutzungsbedingungen, IhreACCOUNT_IDund denregionCode, der von `retrieveForApplication` zurückgegeben wurde.Ein Beispiel für eine Anfrage:
POST https://merchantapi.googleapis.com/accounts/v1/{name={termsOfService/VERSION}}:accept { "account": "accounts/{ACCOUNT_ID}", "regionCode": "{REGION_CODE}" }Ein erfolgreicher Aufruf gibt einen leeren Antworttext zurück und aktualisiert den Status der Nutzungsbedingungen für das Konto.
Händler anleiten, Nutzungsbedingungen zu akzeptieren (für Drittanbieter)
Wenn Sie als Drittanbieter Merchant Center-Konten für andere Unternehmen verwalten, dürfen Sie die Nutzungsbedingungen nicht in deren Namen akzeptieren. Stattdessen sollten Sie so vorgehen:
Neueste Nutzungsbedingungen abrufen: Rufen Sie
termsOfService.retrieveLatestfür denregionCodedes Händlers und die ArtMERCHANT_CENTERauf, um die Details der neuesten Version der Nutzungsbedingungen zu erhalten, die er möglicherweise akzeptieren muss.Beispielanfrage:
GET https://merchantapi.googleapis.com/accounts/v1/termsOfService:retrieveLatest?regionCode={REGION_CODE}&kind=MERCHANT_CENTERBeispielantwort:
{ "name": "{termsOfService/VERSION}", "regionCode": "{REGION_CODE}", "kind": "MERCHANT_CENTER", "fileUri": "https://www.google.com/intl/{REGION_CODE}/policies/merchants/terms/" }Nutzungsbedingungen anzeigen: Verwenden Sie den
fileUriaus der Antwort, um den vollständigen Text der Nutzungsbedingungen auf der Benutzeroberfläche Ihrer Anwendung für den Händler anzuzeigen.Einwilligung des Händlers einholen: Der Händler muss den Bedingungen auf Ihrer Benutzeroberfläche ausdrücklich zustimmen.
Annahme mit der API aufzeichnen: Nachdem der Händler die Nutzungsbedingungen akzeptiert hat, rufen Sie
termsOfService.acceptmit demnameder Nutzungsbedingungen aus Schritt 1, derACCOUNT_IDdes Händlers und seinemregionCodeauf.Beispielanfrage:
POST https://merchantapi.googleapis.com/accounts/v1/{name={termsOfService/VERSION}}:accept { "account": "accounts/{MERCHANT_ACCOUNT_ID}", "regionCode": "{REGION_CODE}" }
Hier ist ein Beispiel, mit dem Sie die Nutzungsbedingungen für ein bestimmtes Konto akzeptieren können, nachdem der Händler zugestimmt hat:
Java
import com.google.api.gax.core.FixedCredentialsProvider;
import com.google.auth.oauth2.GoogleCredentials;
import com.google.shopping.merchant.accounts.v1.AcceptTermsOfServiceRequest;
import com.google.shopping.merchant.accounts.v1.TermsOfServiceServiceClient;
import com.google.shopping.merchant.accounts.v1.TermsOfServiceServiceSettings;
import shopping.merchant.samples.utils.Authenticator;
import shopping.merchant.samples.utils.Config;
/** This class demonstrates how to accept the TermsOfService agreement in a given account. */
public class AcceptTermsOfServiceSample {
public static void acceptTermsOfService(String accountId, String tosVersion, String regionCode)
throws Exception {
// Obtains OAuth token based on the user's configuration.
GoogleCredentials credential = new Authenticator().authenticate();
// Creates service settings using the credentials retrieved above.
TermsOfServiceServiceSettings tosServiceSettings =
TermsOfServiceServiceSettings.newBuilder()
.setCredentialsProvider(FixedCredentialsProvider.create(credential))
.build();
// Calls the API and catches and prints any network failures/errors.
try (TermsOfServiceServiceClient tosServiceClient =
TermsOfServiceServiceClient.create(tosServiceSettings)) {
// The parent has the format: accounts/{account}
AcceptTermsOfServiceRequest request =
AcceptTermsOfServiceRequest.newBuilder()
.setName(String.format("termsOfService/%s", tosVersion))
.setAccount(String.format("accounts/%s", accountId))
.setRegionCode(regionCode)
.build();
System.out.println("Sending request to accept terms of service...");
tosServiceClient.acceptTermsOfService(request);
System.out.println("Successfully accepted terms of service.");
} catch (Exception e) {
System.out.println(e);
}
}
public static void main(String[] args) throws Exception {
Config config = Config.load();
// See GetTermsOfServiceAgreementStateSample to understand how to check which version of the
// terms of service needs to be accepted, if any.
// Likewise, if you know that the terms of service needs to be accepted, you can also simply
// call RetrieveLatestTermsOfService to get the latest version of the terms of service.
// Region code is either a country when the ToS applies specifically to that country or 001 when
// it applies globally.
acceptTermsOfService(config.getAccountId().toString(), "VERSION_HERE", "REGION_CODE_HERE");
}
}
PHP
use Google\ApiCore\ApiException;
use Google\Shopping\Merchant\Accounts\V1\AcceptTermsOfServiceRequest;
use Google\Shopping\Merchant\Accounts\V1\Client\TermsOfServiceServiceClient;
/**
* Demonstrates how to accept the TermsOfService agreement in a given account.
*/
class AcceptTermsOfService
{
/**
* Accepts the Terms of Service agreement.
*
* @param string $accountId The account ID.
* @param string $tosVersion The Terms of Service version.
* @param string $regionCode The region code.
* @return void
*/
public static function acceptTermsOfService($accountId, $tosVersion, $regionCode): void
{
// Get OAuth credentials.
$credentials = Authentication::useServiceAccountOrTokenFile();
// Create client options.
$options = ['credentials' => $credentials];
// Create a TermsOfServiceServiceClient.
$tosServiceClient = new TermsOfServiceServiceClient($options);
try {
// Prepare the request.
$request = new AcceptTermsOfServiceRequest([
'name' => sprintf("termsOfService/%s", $tosVersion),
'account' => sprintf("accounts/%s", $accountId),
'region_code' => $regionCode,
]);
print "Sending request to accept terms of service...\n";
$tosServiceClient->acceptTermsOfService($request);
print "Successfully accepted terms of service.\n";
} catch (ApiException $e) {
print $e->getMessage();
}
}
/**
* Helper to execute the sample.
*
* @return void
*/
public function callSample(): void
{
$config = Config::generateConfig();
// Replace with actual values.
$tosVersion = "132";
$regionCode = "US";
self::acceptTermsOfService($config['accountId'], $tosVersion, $regionCode);
}
}
// Run the script
$sample = new AcceptTermsOfService();
$sample->callSample();
Python
from examples.authentication import configuration
from examples.authentication import generate_user_credentials
from google.shopping.merchant_accounts_v1 import AcceptTermsOfServiceRequest
from google.shopping.merchant_accounts_v1 import TermsOfServiceServiceClient
# Replace with your actual values.
_ACCOUNT_ID = configuration.Configuration().read_merchant_info()
_TOS_VERSION = ( # Replace with the Terms of Service version to accept
"VERSION_HERE"
)
_REGION_CODE = "US" # Replace with the region code
def accept_terms_of_service():
"""Accepts the Terms of Service agreement for a given account."""
credentials = generate_user_credentials.main()
client = TermsOfServiceServiceClient(credentials=credentials)
# Construct the request
request = AcceptTermsOfServiceRequest(
name=f"termsOfService/{_TOS_VERSION}",
account=f"accounts/{_ACCOUNT_ID}",
region_code=_REGION_CODE,
)
try:
print("Sending request to accept terms of service...")
client.accept_terms_of_service(request=request)
print("Successfully accepted terms of service.")
except RuntimeError as e:
print(e)
if __name__ == "__main__":
accept_terms_of_service()
Besondere Überlegungen für Drittanbieter
Als Drittanbieter können Sie die Nutzungsbedingungen für Kundenkonten verwalten.
Nutzungsbedingungen für Kundenkonten verwalten
Wenn Sie ein erweitertes Konto betreiben und Kundenkonten für verschiedene Unternehmen erstellen, gilt Folgendes:
- Annahme durch das erweiterte Konto: Wenn ein erweitertes Konto den Dienst zur Konto aggregation für Kundenkonten bereitstellt, gelten die vom erweiterten Konto akzeptierten Nutzungsbedingungen auch für alle Kundenkonten, die diesen Dienst nutzen.
- Anzeige und Einwilligung: Auch wenn die Annahme durch das erweiterte Konto Kundenkonten abdeckt, ist es empfehlenswert (und möglicherweise rechtlich erforderlich), dem tatsächlichen Inhaber jedes solchen Kundenkontos die relevanten Nutzungsbedingungen für das Google Merchant Center anzuzeigen. Sie müssen die ausdrückliche Einwilligung einholen, dass er diese Bedingungen verstanden hat und ihnen zustimmt, auch wenn der API-Aufruf zur Annahme auf Ebene des erweiterten Kontos erfolgt.
- Status des Kundenkontos prüfen: Verwenden Sie
termsOfServiceAgreementStates.retrieveForApplicationfür ein bestimmtes Kundenkonto, um den Status der Nutzungsbedingungen zu prüfen und festzustellen, ob es durch die Vereinbarung des erweiterten Kontos abgedeckt ist oder ob eine direkte Aktion erforderlich ist.
Nutzungsbedingungen für andere Konten verwalten
Wie unter Händler anleiten, Nutzungsbedingungen zu akzeptieren beschrieben, muss das Unternehmen (der Kontoinhaber) die Nutzungsbedingungen persönlich akzeptieren, wenn Sie es bei der Erstellung oder Verwaltung seines eigenen Kontos unterstützen . Sie erleichtern dies, indem Sie die Nutzungsbedingungen abrufen und anzeigen und dann in seinem Namen die Methode termsOfService.accept aufrufen, nachdem er über Ihre Benutzeroberfläche seine ausdrückliche Einwilligung gegeben hat.