Add Sitelinks
Stay organized with collections
Save and categorize content based on your preferences.
Java
// Copyright 2021 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// https://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package
com.google.ads.googleads.examples.assets
;
import
com.beust.jcommander.Parameter
;
import
com.google.ads.googleads.examples.utils.ArgumentNames
;
import
com.google.ads.googleads.examples.utils.CodeSampleParams
;
import
com.google.ads.googleads.lib.GoogleAdsClient
;
import
com.google.ads.googleads.v21.common.SitelinkAsset
;
import
com.google.ads.googleads.v21.enums.AssetFieldTypeEnum.AssetFieldType
;
import
com.google.ads.googleads.v21.errors.GoogleAdsError
;
import
com.google.ads.googleads.v21.errors.GoogleAdsException
;
import
com.google.ads.googleads.v21.resources.Asset
;
import
com.google.ads.googleads.v21.resources.CampaignAsset
;
import
com.google.ads.googleads.v21.services.AssetOperation
;
import
com.google.ads.googleads.v21.services.AssetServiceClient
;
import
com.google.ads.googleads.v21.services.CampaignAssetOperation
;
import
com.google.ads.googleads.v21.services.CampaignAssetServiceClient
;
import
com.google.ads.googleads.v21.services.MutateAssetResult
;
import
com.google.ads.googleads.v21.services.MutateAssetsResponse
;
import
com.google.ads.googleads.v21.services.MutateCampaignAssetResult
;
import
com.google.ads.googleads.v21.services.MutateCampaignAssetsResponse
;
import
com.google.ads.googleads.v21.utils.ResourceNames
;
import
java.io.FileNotFoundException
;
import
java.io.IOException
;
import
java.util.ArrayList
;
import
java.util.List
;
import
java.util.stream.Collectors
;
/** Adds sitelinks to a campaign using Assets. To create a campaign, run AddCampaigns.java. */
public
class
AddSitelinks
{
private
static
class
AddSitelinksParams
extends
CodeSampleParams
{
@Parameter
(
names
=
ArgumentNames
.
CUSTOMER_ID
,
required
=
true
)
private
Long
customerId
;
@Parameter
(
names
=
ArgumentNames
.
CAMPAIGN_ID
,
required
=
true
)
private
Long
campaignId
;
}
public
static
void
main
(
String
[]
args
)
{
AddSitelinksParams
params
=
new
AddSitelinksParams
();
if
(
!
params
.
parseArguments
(
args
))
{
// Either pass the required parameters for this example on the command line, or insert them
// into the code here. See the parameter class definition above for descriptions.
params
.
customerId
=
Long
.
parseLong
(
"INSERT_CUSTOMER_ID_HERE"
);
params
.
campaignId
=
Long
.
parseLong
(
"INSERT_CAMPAIGN_ID_HERE"
);
}
GoogleAdsClient
googleAdsClient
=
null
;
try
{
googleAdsClient
=
GoogleAdsClient
.
newBuilder
().
fromPropertiesFile
().
build
();
}
catch
(
FileNotFoundException
fnfe
)
{
System
.
err
.
printf
(
"Failed to load GoogleAdsClient configuration from file. Exception: %s%n"
,
fnfe
);
System
.
exit
(
1
);
}
catch
(
IOException
ioe
)
{
System
.
err
.
printf
(
"Failed to create GoogleAdsClient. Exception: %s%n"
,
ioe
);
System
.
exit
(
1
);
}
try
{
new
AddSitelinks
().
runExample
(
googleAdsClient
,
params
.
customerId
,
params
.
campaignId
);
}
catch
(
GoogleAdsException
gae
)
{
// GoogleAdsException is the base class for most exceptions thrown by an API request.
// Instances of this exception have a message and a GoogleAdsFailure that contains a
// collection of GoogleAdsErrors that indicate the underlying causes of the
// GoogleAdsException.
System
.
err
.
printf
(
"Request ID %s failed due to GoogleAdsException. Underlying errors:%n"
,
gae
.
getRequestId
());
int
i
=
0
;
for
(
GoogleAdsError
googleAdsError
:
gae
.
getGoogleAdsFailure
().
getErrorsList
())
{
System
.
err
.
printf
(
" Error %d: %s%n"
,
i
++
,
googleAdsError
);
}
System
.
exit
(
1
);
}
}
/**
* Runs the example.
*
* @param googleAdsClient the Google Ads API client.
* @param customerId the client customer ID.
* @param campaignId the campaign ID on which to add the sitelinks.
* @throws GoogleAdsException if an API request failed with one or more service errors.
*/
private
void
runExample
(
GoogleAdsClient
googleAdsClient
,
long
customerId
,
long
campaignId
)
{
// Creates a sitelink asset.
List<String>
resourceNames
=
createSitelinkAssets
(
googleAdsClient
,
customerId
);
// Associates the sitelinks at the campaign level.
linkSitelinksToCampaign
(
googleAdsClient
,
resourceNames
,
customerId
,
campaignId
);
}
/** Creates a {@link SitelinkAsset} which can then be added to campaigns. */
private
List<String>
createSitelinkAssets
(
GoogleAdsClient
googleAdsClient
,
long
customerId
)
{
// Creates some sitelink assets.
SitelinkAsset
storeLocatorSitelinkAsset
=
SitelinkAsset
.
newBuilder
()
.
setDescription1
(
"Get in touch"
)
.
setDescription2
(
"Find your local store"
)
.
setLinkText
(
"Store locator"
)
.
build
();
SitelinkAsset
storeSitelinkAsset
=
SitelinkAsset
.
newBuilder
()
.
setDescription1
(
"Buy some stuff"
)
.
setDescription2
(
"It's really good"
)
.
setLinkText
(
"Store"
)
.
build
();
SitelinkAsset
storeAdditionalSitelinkAsset
=
SitelinkAsset
.
newBuilder
()
.
setDescription1
(
"Even more stuff"
)
.
setDescription2
(
"There's never enough"
)
.
setLinkText
(
"Store for more"
)
.
build
();
// Wraps the sitelinks in an Asset and sets the URLs.
List<Asset>
assets
=
new
ArrayList
();
assets
.
add
(
Asset
.
newBuilder
()
.
setSitelinkAsset
(
storeLocatorSitelinkAsset
)
.
addFinalUrls
(
"http://example.com/contact/store-finder"
)
// Optionally sets a different URL for mobile.
.
addFinalMobileUrls
(
"http://example.com/mobile/contact/store-finder"
)
.
build
());
assets
.
add
(
Asset
.
newBuilder
()
.
setSitelinkAsset
(
storeSitelinkAsset
)
.
addFinalUrls
(
"http://example.com/store"
)
// Optionally sets a different URL for mobile.
.
addFinalMobileUrls
(
"http://example.com/mobile/store"
)
.
build
());
assets
.
add
(
Asset
.
newBuilder
()
.
setSitelinkAsset
(
storeAdditionalSitelinkAsset
)
.
addFinalUrls
(
"http://example.com/store/more"
)
// Optionally sets a different URL for mobile.
.
addFinalMobileUrls
(
"http://example.com/mobile/store/more"
)
.
build
());
// Creates an operation to add each asset.
List<AssetOperation>
operations
=
assets
.
stream
()
.
map
(
a
-
>
AssetOperation
.
newBuilder
().
setCreate
(
a
).
build
())
.
collect
(
Collectors
.
toList
());
// Creates the service client.
try
(
AssetServiceClient
client
=
googleAdsClient
.
getLatestVersion
().
createAssetServiceClient
())
{
// Sends the mutate request.
MutateAssetsResponse
response
=
client
.
mutateAssets
(
String
.
valueOf
(
customerId
),
operations
);
// Prints some information about the result.
List<String>
resourceNames
=
response
.
getResultsList
().
stream
()
.
map
(
MutateAssetResult
::
getResourceName
)
.
collect
(
Collectors
.
toList
());
for
(
String
resName
:
resourceNames
)
{
System
.
out
.
printf
(
"Created sitelink asset with resource name '%s'.%n"
,
resName
);
}
return
resourceNames
;
}
}
/** Links the assets to a campaign. */
private
void
linkSitelinksToCampaign
(
GoogleAdsClient
googleAdsClient
,
List<String>
sitelinkAssetResourceName
,
long
customerId
,
long
campaignId
)
{
// Creates CampaignAssets representing the association between sitelinks and campaign.
List<CampaignAssetOperation>
campaignAssetOperations
=
sitelinkAssetResourceName
.
stream
()
// Creates the CampaignAsset link.
.
map
(
resName
-
>
CampaignAsset
.
newBuilder
()
.
setAsset
(
resName
)
.
setCampaign
(
ResourceNames
.
campaign
(
customerId
,
campaignId
))
.
setFieldType
(
AssetFieldType
.
SITELINK
)
.
build
())
// Creates a CampaignAssetOperation to create the CampaignAsset.
.
map
(
a
-
>
CampaignAssetOperation
.
newBuilder
().
setCreate
(
a
).
build
())
.
collect
(
Collectors
.
toList
());
// Creates the service client.
try
(
CampaignAssetServiceClient
client
=
googleAdsClient
.
getLatestVersion
().
createCampaignAssetServiceClient
())
{
// Sends the mutate request.
MutateCampaignAssetsResponse
response
=
client
.
mutateCampaignAssets
(
String
.
valueOf
(
customerId
),
campaignAssetOperations
);
// Prints some information about the result.
for
(
MutateCampaignAssetResult
result
:
response
.
getResultsList
())
{
System
.
out
.
printf
(
"Linked sitelink to campaign with resource name '%s'.%n"
,
result
.
getResourceName
());
}
}
}
}
C#
// Copyright 2021 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
using
CommandLine
;
using
Google.Ads.Gax.Examples
;
using
Google.Ads.GoogleAds.Lib
;
using
Google.Ads.GoogleAds.V21.Common
;
using
Google.Ads.GoogleAds.V21.Errors
;
using
Google.Ads.GoogleAds.V21.Resources
;
using
Google.Ads.GoogleAds.V21.Services
;
using
System
;
using
System.Collections.Generic
;
using
System.Linq
;
using
static
Google
.
Ads
.
GoogleAds
.
V21
.
Enums
.
AssetFieldTypeEnum
.
Types
;
namespace
Google.Ads.GoogleAds.Examples.V21
{
/// <summary>
/// This code example adds sitelinks to a campaign using assets. Run AddCampaigns.cs to
/// create a campaign.
/// </summary>
public
class
AddSitelinks
:
ExampleBase
{
/// <summary>
/// Command line options for running the <see cref="AddSitelinks"/> example.
/// </summary>
public
class
Options
:
OptionsBase
{
/// <summary>
/// The customer ID for which the call is made.
/// </summary>
[Option("customerId", Required = true, HelpText =
"The customer ID for which the call is made.")]
public
long
CustomerId
{
get
;
set
;
}
/// <summary>
/// ID of the campaign to which sitelinks are added.
/// </summary>
[Option("campaignId", Required = true, HelpText =
"ID of the campaign to which sitelinks are added.")]
public
long
CampaignId
{
get
;
set
;
}
}
/// <summary>
/// Main method, to run this code example as a standalone application.
/// </summary>
/// <param name="args">The command line arguments.</param>
public
static
void
Main
(
string
[]
args
)
{
Options
options
=
ExampleUtilities
.
ParseCommandLine<Options>
(
args
);
AddSitelinks
codeExample
=
new
AddSitelinks
();
Console
.
WriteLine
(
codeExample
.
Description
);
codeExample
.
Run
(
new
GoogleAdsClient
(),
options
.
CustomerId
,
options
.
CampaignId
);
}
/// <summary>
/// Returns a description about the code example.
/// </summary>
public
override
string
Description
=
>
"This code example adds sitelinks to a campaign using assets. Run AddCampaigns.cs "
+
"to create a campaign."
;
/// <summary>
/// Runs the code example.
/// </summary>
/// <param name="client">The Google Ads client.</param>
/// <param name="customerId">The customer ID for which the call is made.</param>
/// <param name="campaignId">ID of the campaign to which sitelinks are added.</param>
public
void
Run
(
GoogleAdsClient
client
,
long
customerId
,
long
campaignId
)
{
try
{
// Creates a sitelink asset.
List<string>
siteLinkResourceNames
=
CreateSitelinkAssets
(
client
,
customerId
);
// Associates the sitelinks at the campaign level.
LinkSitelinksToCampaign
(
client
,
customerId
,
campaignId
,
siteLinkResourceNames
);
}
catch
(
GoogleAdsException
e
)
{
Console
.
WriteLine
(
"Failure:"
);
Console
.
WriteLine
(
$"Message: {e.Message}"
);
Console
.
WriteLine
(
$"Failure: {e.Failure}"
);
Console
.
WriteLine
(
$"Request ID: {e.RequestId}"
);
throw
;
}
}
/// <summary>
/// Creates a list of <see cref="SitelinkAsset"/> objects which can then be added
/// to campaigns.
/// </summary>
/// <param name="client">The Google Ads client.</param>
/// <param name="customerId">The customer ID for which the call is made.</param>
/// <returns>The list of sitelink resource names.</returns>
private
List<string>
CreateSitelinkAssets
(
GoogleAdsClient
client
,
long
customerId
)
{
AssetServiceClient
assetService
=
client
.
GetService
(
Services
.
V21
.
AssetService
);
// Creates some sitelink assets.
SitelinkAsset
storeLocatorAsset
=
new
SitelinkAsset
()
{
Description1
=
"Get in touch"
,
Description2
=
"Find your local store"
,
LinkText
=
"Store locator"
};
SitelinkAsset
storeAsset
=
new
SitelinkAsset
()
{
Description1
=
"Buy some stuff"
,
Description2
=
"It's really good"
,
LinkText
=
"Store"
};
SitelinkAsset
storeAdditionalAsset
=
new
SitelinkAsset
()
{
Description1
=
"Even more stuff"
,
Description2
=
"There's never enough"
,
LinkText
=
"Store for more"
};
// Wraps the sitelinks in an Asset and sets the URLs.
List<Asset>
assets
=
new
List<Asset>
()
{
new
Asset
()
{
SitelinkAsset
=
storeLocatorAsset
,
FinalUrls
=
{
"http://example.com/contact/store-finder"
},
// Optionally sets a different URL for mobile.
FinalMobileUrls
=
{
"http://example.com/mobile/contact/store-finder"
}
},
new
Asset
()
{
SitelinkAsset
=
storeAsset
,
FinalUrls
=
{
"http://example.com/store"
},
// Optionally sets a different URL for mobile.
FinalMobileUrls
=
{
"http://example.com/mobile/store"
}
},
new
Asset
()
{
SitelinkAsset
=
storeAdditionalAsset
,
FinalUrls
=
{
"http://example.com/store/more"
},
// Optionally sets a different URL for mobile.
FinalMobileUrls
=
{
"http://example.com/mobile/store/more"
}
}
};
// Creates an operation to add each asset.
List<AssetOperation>
operations
=
assets
.
Select
(
asset
=
>
new
AssetOperation
()
{
Create
=
asset
,
}).
ToList
();
// Sends the mutate request.
MutateAssetsResponse
response
=
assetService
.
MutateAssets
(
customerId
.
ToString
(),
operations
);
// Prints some information about the result.
List<string>
resourceNames
=
response
.
Results
.
Select
(
result
=
>
result
.
ResourceName
).
ToList
();
foreach
(
string
resourceName
in
resourceNames
)
{
Console
.
WriteLine
(
$"Created sitelink asset with resource name '{resourceNames}'."
);
}
return
resourceNames
;
}
/** Links the assets to a campaign. */
/// <summary>
/// Links the sitelinks to campaign.
/// </summary>
/// <param name="client">The Google Ads client.</param>
/// <param name="customerId">The customer ID for which the call is made.</param>
/// <param name="campaignId">ID of the campaign to which sitelinks are added.
/// </param>
/// <param name="sitelinkAssetResourceNames">The sitelink asset resource names.</param>
private
void
LinkSitelinksToCampaign
(
GoogleAdsClient
client
,
long
customerId
,
long
campaignId
,
List<string>
sitelinkAssetResourceNames
)
{
CampaignAssetServiceClient
campaignAssetService
=
client
.
GetService
(
Services
.
V21
.
CampaignAssetService
);
string
campaignResourceName
=
ResourceNames
.
Campaign
(
customerId
,
campaignId
);
// Creates operations.
List<CampaignAssetOperation>
campaignAssetOperations
=
sitelinkAssetResourceNames
.
Select
(
resourceName
=
>
new
CampaignAssetOperation
()
{
// Creates CampaignAsset representing the association between sitelinks
// and campaign.
Create
=
new
CampaignAsset
()
{
Asset
=
resourceName
,
Campaign
=
campaignResourceName
,
FieldType
=
AssetFieldType
.
Sitelink
}
}).
ToList
();
// Sends the mutate request.
MutateCampaignAssetsResponse
response
=
campaignAssetService
.
MutateCampaignAssets
(
customerId
.
ToString
(),
campaignAssetOperations
);
// Prints some information about the result.
foreach
(
MutateCampaignAssetResult
result
in
response
.
Results
)
{
Console
.
WriteLine
(
$"Linked sitelink to campaign with resource "
+
$"name '{result.ResourceName}'."
);
}
}
}
}
PHP
This example is not yet available in PHP; you can take a look at the other languages.
Python
#!/usr/bin/env python
# Copyright 2020 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Adds sitelinks to a campaign using Assets.
Run basic_operations/add_campaigns.py to create a campaign.
"""
import
argparse
from
typing
import
List
import
sys
from
google.ads.googleads.client
import
GoogleAdsClient
from
google.ads.googleads.errors
import
GoogleAdsException
from
google.ads.googleads.v21.services.types.asset_service
import
AssetOperation
from
google.ads.googleads.v21.resources.types.asset
import
Asset
from
google.ads.googleads.v21.services.types.campaign_asset_service
import
(
CampaignAssetOperation
,
)
from
google.ads.googleads.v21.resources.types.campaign_asset
import
(
CampaignAsset
,
)
def
main
(
client
:
GoogleAdsClient
,
customer_id
:
str
,
campaign_id
:
str
)
-
> None
:
"""Adds sitelinks to a campaign using assets.
Args:
client: The Google Ads client.
customer_id: The customer ID for which to add the keyword.
campaign_id: The campaign to which sitelinks will be added.
"""
# Creates sitelink assets.
resource_names
:
List
[
str
]
=
create_sitelink_assets
(
client
,
customer_id
)
# Associates the sitelinks at the campaign level.
link_sitelinks_to_campaign
(
client
,
customer_id
,
campaign_id
,
resource_names
)
def
create_sitelink_assets
(
client
:
GoogleAdsClient
,
customer_id
:
str
)
-
> List
[
str
]:
"""Creates sitelink assets, which can be added to campaigns.
Args:
client: The Google Ads client.
customer_id: The customer ID for which to add the keyword.
Returns:
a list of sitelink asset resource names.
"""
store_locator_operation
:
AssetOperation
=
client
.
get_type
(
"AssetOperation"
)
store_locator_asset
:
Asset
=
store_locator_operation
.
create
store_locator_asset
.
final_urls
.
append
(
"http://example.com/contact/store-finder"
)
store_locator_asset
.
final_mobile_urls
.
append
(
"http://example.com/mobile/contact/store-finder"
)
store_locator_asset
.
sitelink_asset
.
description1
=
"Get in touch"
store_locator_asset
.
sitelink_asset
.
description2
=
"Find your local store"
store_locator_asset
.
sitelink_asset
.
link_text
=
"Store locator"
store_asset_operation
:
AssetOperation
=
client
.
get_type
(
"AssetOperation"
)
store_asset
:
Asset
=
store_asset_operation
.
create
store_asset
.
final_urls
.
append
(
"http://example.com/store"
)
store_asset
.
final_mobile_urls
.
append
(
"http://example.com/mobile/store"
)
store_asset
.
sitelink_asset
.
description1
=
"Buy some stuff"
store_asset
.
sitelink_asset
.
description2
=
"It's really good"
store_asset
.
sitelink_asset
.
link_text
=
"Store"
store_addnl_asset_operation
:
AssetOperation
=
client
.
get_type
(
"AssetOperation"
)
store_addnl_asset
:
Asset
=
store_addnl_asset_operation
.
create
store_addnl_asset
.
final_urls
.
append
(
"http://example.com/store/more"
)
store_addnl_asset
.
final_mobile_urls
.
append
(
"http://example.com/mobile/store/more"
)
store_addnl_asset
.
sitelink_asset
.
description1
=
"Buy some stuff"
store_addnl_asset
.
sitelink_asset
.
description2
=
"It's really good"
store_addnl_asset
.
sitelink_asset
.
link_text
=
"Store"
asset_service
=
client
.
get_service
(
"AssetService"
)
response
=
asset_service
.
mutate_assets
(
customer_id
=
customer_id
,
operations
=
[
store_locator_operation
,
store_asset_operation
,
store_addnl_asset_operation
,
],
)
resource_names
:
List
[
str
]
=
[
result
.
resource_name
for
result
in
response
.
results
]
for
resource_name
in
resource_names
:
print
(
f
"Created sitelink asset with resource name '
{
resource_name
}
'."
)
return
resource_names
def
link_sitelinks_to_campaign
(
client
:
GoogleAdsClient
,
customer_id
:
str
,
campaign_id
:
str
,
resource_names
:
List
[
str
],
)
-
> None
:
"""Creates sitelink assets, which can be added to campaigns.
Args:
client: The Google Ads client.
customer_id: The customer ID for which to add the keyword.
campaign_id: The campaign to which sitelinks will be added.
resource_names: a list of sitelink asset resource names.
"""
campaign_service
=
client
.
get_service
(
"CampaignService"
)
operations
:
List
[
CampaignAssetOperation
]
=
[]
for
resource_name
in
resource_names
:
operation
:
CampaignAssetOperation
=
client
.
get_type
(
"CampaignAssetOperation"
)
campaign_asset
:
CampaignAsset
=
operation
.
create
campaign_asset
.
asset
=
resource_name
campaign_asset
.
campaign
=
campaign_service
.
campaign_path
(
customer_id
,
campaign_id
)
campaign_asset
.
field_type
=
client
.
enums
.
AssetFieldTypeEnum
.
SITELINK
operations
.
append
(
operation
)
campaign_asset_service
=
client
.
get_service
(
"CampaignAssetService"
)
response
=
campaign_asset_service
.
mutate_campaign_assets
(
customer_id
=
customer_id
,
operations
=
operations
)
for
result
in
response
.
results
:
print
(
"Linked sitelink to campaign with resource name '
{result.resource_name}
'."
)
if
__name__
==
"__main__"
:
parser
:
argparse
.
ArgumentParser
=
argparse
.
ArgumentParser
(
description
=
"Adds sitelinks to a campaign using feed services."
)
# The following argument(s) should be provided to run the example.
parser
.
add_argument
(
"-c"
,
"--customer_id"
,
type
=
str
,
required
=
True
,
help
=
"The Google Ads customer ID."
,
)
parser
.
add_argument
(
"-i"
,
"--campaign_id"
,
type
=
str
,
required
=
True
,
default
=
None
,
help
=
"ID of the campaign to which sitelinks will be added."
,
)
args
:
argparse
.
Namespace
=
parser
.
parse_args
()
# GoogleAdsClient will read the google-ads.yaml configuration file in the
# home directory if none is specified.
googleads_client
:
GoogleAdsClient
=
GoogleAdsClient
.
load_from_storage
(
version
=
"v21"
)
try
:
main
(
googleads_client
,
args
.
customer_id
,
args
.
campaign_id
)
except
GoogleAdsException
as
ex
:
print
(
f
"Request with ID '
{
ex
.
request_id
}
' failed with status "
f
"'
{
ex
.
error
.
code
()
.
name
}
' and includes the following errors:"
)
for
error
in
ex
.
failure
.
errors
:
print
(
f
"
\t
Error with message '
{
error
.
message
}
'."
)
if
error
.
location
:
for
field_path_element
in
error
.
location
.
field_path_elements
:
print
(
f
"
\t\t
On field:
{
field_path_element
.
field_name
}
"
)
sys
.
exit
(
1
)
Ruby
#!/usr/bin/env ruby
# Encoding: utf-8
#
# Copyright 2020 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# Adds sitelinks to a campaign. To create a campaign, run add_campaigns.rb.
require
'optparse'
require
'google/ads/google_ads'
require
'date'
def
add_sitelinks
(
customer_id
,
campaign_id
)
# GoogleAdsClient will read a config file from
# ENV['HOME']/google_ads_config.rb when called without parameters
client
=
Google
::
Ads
::
GoogleAds
::
GoogleAdsClient
.
new
resource_names
=
create_sitelink_assets
(
client
,
customer_id
)
link_sitelinks_to_campaign
(
client
,
resource_names
,
customer_id
,
campaign_id
)
end
def
create_sitelink_assets
(
client
,
customer_id
)
assets
=
[
client
.
resource
.
asset
do
|
asset
|
asset
.
sitelink_asset
=
client
.
resource
.
sitelink_asset
do
|
sitelink
|
sitelink
.
description1
=
"Get in touch"
sitelink
.
description2
=
"Find your local store"
sitelink
.
link_text
=
"Store locator"
end
asset
.
final_urls
<<
"http://example.com/contact/store-finder"
asset
.
final_mobile_urls
<<
"http://example.com/mobile/contact/store-finder"
end
,
client
.
resource
.
asset
do
|
asset
|
asset
.
sitelink_asset
=
client
.
resource
.
sitelink_asset
do
|
sitelink
|
sitelink
.
description1
=
"But some stuff"
sitelink
.
description2
=
"It's really good"
sitelink
.
link_text
=
"Store"
end
asset
.
final_urls
<<
"http://example.com/store"
asset
.
final_mobile_urls
<<
"http://example.com/mobile/store"
end
,
client
.
resource
.
asset
do
|
asset
|
asset
.
sitelink_asset
=
client
.
resource
.
sitelink_asset
do
|
sitelink
|
sitelink
.
description1
=
"Even more stuff"
sitelink
.
description2
=
"There's never enough"
sitelink
.
link_text
=
"Store for more"
end
asset
.
final_urls
<<
"http://example.com/store/more"
asset
.
final_mobile_urls
<<
"http://example.com/mobile/store/more"
end
,
]
operations
=
assets
.
map
do
|
asset
|
client
.
operation
.
create_resource
.
asset
(
asset
)
end
response
=
client
.
service
.
asset
.
mutate_assets
(
customer_id
:
customer_id
,
operations
:
operations
,
)
response
.
results
.
map
do
|
result
|
puts
"Created sitelink asset with resource name
#{
result
.
resource_name
}
"
result
.
resource_name
end
end
def
link_sitelinks_to_campaign
(
client
,
resource_names
,
customer_id
,
campaign_id
)
operations
=
resource_names
.
map
do
|
resource_name
|
client
.
operation
.
create_resource
.
campaign_asset
do
|
ca
|
ca
.
asset
=
resource_name
ca
.
campaign
=
client
.
path
.
campaign
(
customer_id
,
campaign_id
)
ca
.
field_type
=
:SITELINK
end
end
response
=
client
.
service
.
campaign_asset
.
mutate_campaign_assets
(
customer_id
:
customer_id
,
operations
:
operations
,
)
response
.
results
.
each
do
|
result
|
puts
"Created campaign asset with resource name
#{
result
.
resource_name
}
."
end
end
if
__FILE__
==
$0
options
=
{}
# The following parameter(s) should be provided to run the example. You can
# either specify these by changing the INSERT_XXX_ID_HERE values below, or on
# the command line.
#
# Parameters passed on the command line will override any parameters set in
# code.
#
# Running the example with -h will print the command line usage.
options
[
:customer_id
]
=
'INSERT_CUSTOMER_ID_HERE'
options
[
:campaign_id
]
=
'INSERT_CAMPAIGN_ID_HERE'
OptionParser
.
new
do
|
opts
|
opts
.
banner
=
sprintf
(
'Usage: %s [options]'
,
File
.
basename
(
__FILE__
))
opts
.
separator
''
opts
.
separator
'Options:'
opts
.
on
(
'-C'
,
'--customer-id CUSTOMER-ID'
,
String
,
'Customer ID'
)
do
|
v
|
options
[
:customer_id
]
=
v
end
opts
.
on
(
'-c'
,
'--campaign-id CAMPAIGN-ID'
,
String
,
'Campaign ID'
)
do
|
v
|
options
[
:campaign_id
]
=
v
end
opts
.
separator
''
opts
.
separator
'Help:'
opts
.
on_tail
(
'-h'
,
'--help'
,
'Show this message'
)
do
puts
opts
exit
end
end
.
parse!
begin
add_sitelinks
(
options
.
fetch
(
:customer_id
)
.
tr
(
"-"
,
""
),
options
.
fetch
(
:campaign_id
))
rescue
Google
::
Ads
::
GoogleAds
::
Errors
::
GoogleAdsError
=
>
e
e
.
failure
.
errors
.
each
do
|
error
|
STDERR
.
printf
(
"Error with message: %s
\n
"
,
error
.
message
)
if
error
.
location
error
.
location
.
field_path_elements
.
each
do
|
field_path_element
|
STDERR
.
printf
(
"
\t
On field: %s
\n
"
,
field_path_element
.
field_name
)
end
end
error
.
error_code
.
to_h
.
each
do
|
k
,
v
|
next
if
v
==
:UNSPECIFIED
STDERR
.
printf
(
"
\t
Type: %s
\n\t
Code: %s
\n
"
,
k
,
v
)
end
end
raise
end
end
Perl
#!/usr/bin/perl -w
#
# Copyright 2021, Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# Adds sitelinks to a campaign using Assets. To create a campaign, run add_campaigns.pl.
use
strict
;
use
warnings
;
use
utf8
;
use
FindBin
qw($Bin)
;
use
lib
"$Bin/../../lib"
;
use
Google::Ads::GoogleAds::Client
;
use
Google::Ads::GoogleAds::Utils::GoogleAdsHelper
;
use
Google::Ads::GoogleAds::V21::Resources::Asset
;
use
Google::Ads::GoogleAds::V21::Resources::CampaignAsset
;
use
Google::Ads::GoogleAds::V21::Common::SitelinkAsset
;
use
Google::Ads::GoogleAds::V21::Enums::AssetFieldTypeEnum
qw(SITELINK)
;
use
Google::Ads::GoogleAds::V21::Services::AssetService::AssetOperation
;
use
Google::Ads::GoogleAds::V21::Services::CampaignAssetService::CampaignAssetOperation
;
use
Google::Ads::GoogleAds::V21::Utils::ResourceNames
;
use
Getopt::Long
qw(:config auto_help)
;
use
Pod::Usage
;
use
Cwd
qw(abs_path)
;
# The following parameter(s) should be provided to run the example. You can
# either specify these by changing the INSERT_XXX_ID_HERE values below, or on
# the command line.
#
# Parameters passed on the command line will override any parameters set in
# code.
#
# Running the example with -h will print the command line usage.
my
$customer_id
=
"INSERT_CUSTOMER_ID_HERE"
;
my
$campaign_id
=
"INSERT_CAMPAIGN_ID_HERE"
;
sub
add_sitelinks_using_assets
{
my
(
$api_client
,
$customer_id
,
$campaign_id
)
=
@_
;
# Create sitelink assets.
my
$sitelink_asset_resource_names
=
create_sitelink_assets
(
$api_client
,
$customer_id
);
# Associate the sitelinks at the campaign level.
link_sitelinks_to_campaign
(
$api_client
,
$sitelink_asset_resource_names
,
$customer_id
,
$campaign_id
);
return
1
;
}
# Creates sitelink assets which can then be added to campaigns.
sub
create_sitelink_assets
{
my
(
$api_client
,
$customer_id
)
=
@_
;
# Create some sitelink assets.
my
$store_locator_asset
=
Google::Ads::GoogleAds::V21::Common::
SitelinkAsset
-
> new
({
description1
=
>
"Get in touch"
,
description2
=
>
"Find your local store"
,
linkText
=
>
"Store locator"
});
my
$store_asset
=
Google::Ads::GoogleAds::V21::Common::
SitelinkAsset
-
> new
({
description1
=
>
"Buy some stuff"
,
description2
=
>
"It's really good"
,
linkText
=
>
"Store"
});
my
$store_additional_asset
=
Google::Ads::GoogleAds::V21::Common::
SitelinkAsset
-
> new
({
description1
=
>
"Even more stuff"
,
description2
=
>
"There's never enough"
,
linkText
=
>
"Store for more"
});
# Wrap the sitelinks in an Asset and set the URLs.
my
$assets
=
[]
;
push
@$assets
,
Google::Ads::GoogleAds::V21::Resources::
Asset
-
> new
({
sitelinkAsset
=
>
$store_locator_asset
,
finalUrls
=
>
[
"http://example.com/contact/store-finder"
],
# Optionally set a different URL for mobile.
finalMobileUrls
=
>
[
"http://example.com/mobile/contact/store-finder"
]});
push
@$assets
,
Google::Ads::GoogleAds::V21::Resources::
Asset
-
> new
({
sitelinkAsset
=
>
$store_asset
,
finalUrls
=
>
[
"http://example.com/store"
],
# Optionally set a different URL for mobile.
finalMobileUrls
=
>
[
"http://example.com/mobile/store"
]});
push
@$assets
,
Google::Ads::GoogleAds::V21::Resources::
Asset
-
> new
({
sitelinkAsset
=
>
$store_additional_asset
,
finalUrls
=
>
[
"http://example.com/store/more"
],
# Optionally set a different URL for mobile.
finalMobileUrls
=
>
[
"http://example.com/mobile/store/more"
]});
# Create the operations to add each asset.
my
$operations
=
[]
;
foreach
my
$asset
(
@$assets
)
{
push
@$operations
,
Google::Ads::GoogleAds::V21::Services::AssetService::
AssetOperation
-
> new
((
{
create
=
>
$asset
}));
}
# Send the mutate request.
my
$response
=
$api_client
-
> AssetService
()
-
> mutate
({
customerId
=
>
$customer_id
,
operations
=
>
$operations
});
# Print some information about the result.
my
$resource_names
=
[]
;
foreach
my
$result
(
@
{
$response
-
> {
results
}})
{
push
@$resource_names
,
$result
-
> {
resourceName
};
printf
"Created sitelink asset with resource name '%s'.\n"
,
$result
-
> {
resourceName
};
}
return
$resource_names
;
}
# Links the assets to a campaign.
sub
link_sitelinks_to_campaign
{
my
(
$api_client
,
$sitelink_asset_resource_names
,
$customer_id
,
$campaign_id
)
=
@_
;
# Create CampaignAssets representing the association between sitelinks and campaign.
my
$operations
=
[]
;
foreach
my
$sitelink_asset_resource_name
(
@$sitelink_asset_resource_names
)
{
push
@$operations
,
# Create a CampaignAssetOperation to create the CampaignAsset.
Google::Ads::GoogleAds::V21::Services::CampaignAssetService::
CampaignAssetOperation
-
> new
({
# Create the CampaignAsset link.
create
=
>
Google::Ads::GoogleAds::V21::Resources::
CampaignAsset
-
> new
({
asset
=
>
$sitelink_asset_resource_name
,
campaign
=
>
Google::Ads::GoogleAds::V21::Utils::ResourceNames::
campaign
(
$customer_id
,
$campaign_id
),
fieldType
=
>
SITELINK
})});
}
# Send the mutate request.
my
$response
=
$api_client
-
> CampaignAssetService
()
-
> mutate
({
customerId
=
>
$customer_id
,
operations
=
>
$operations
});
# Print some information about the result.
foreach
my
$result
(
@
{
$response
-
> {
results
}})
{
printf
"Linked sitelink to campaign with resource name '%s'.\n"
,
$result
-
> {
resourceName
};
}
}
# Don't run the example if the file is being included.
if
(
abs_path
(
$0
)
ne
abs_path
(
__FILE__
))
{
return
1
;
}
# Get Google Ads Client, credentials will be read from ~/googleads.properties.
my
$api_client
=
Google::Ads::GoogleAds::
Client
-
> new
();
# By default examples are set to die on any server returned fault.
$api_client
-
> set_die_on_faults
(
1
);
# Parameters passed on the command line will override any parameters set in code.
GetOptions
(
"customer_id=s"
=
>
\
$customer_id
,
"campaign_id=i"
=
>
\
$campaign_id
);
# Print the help message if the parameters are not initialized in the code nor
# in the command line.
pod2usage
(
2
)
if
not
check_params
(
$customer_id
,
$campaign_id
);
# Call the example.
add_sitelinks_using_assets
(
$api_client
,
$customer_id
=~
s/-//g
r
,
$campaign_id
);
=pod
=head1 NAME
add_sitelinks_using_assets.pl
=head1 DESCRIPTION
Adds sitelinks to a campaign using Assets. To create a campaign, run add_campaigns.pl.
=head1 SYNOPSIS
add_sitelinks.pl [options]
-help Show the help message.
-customer_id The Google Ads customer ID.
-campaign_id The campaign ID.
=cut
Except as otherwise noted, the content of this page is licensed under the Creative Commons Attribution 4.0 License
, and code samples are licensed under the Apache 2.0 License
. For details, see the Google Developers Site Policies
. Java is a registered trademark of Oracle and/or its affiliates.
Last updated 2025-09-03 UTC.
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Missing the information I need","missingTheInformationINeed","thumb-down"],["Too complicated / too many steps","tooComplicatedTooManySteps","thumb-down"],["Out of date","outOfDate","thumb-down"],["Samples / code issue","samplesCodeIssue","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-09-03 UTC."],[[["\u003cp\u003eThe code provides functionality to add sitelinks to an existing Google Ads campaign using the Google Ads API.\u003c/p\u003e\n"],["\u003cp\u003eThis is achieved by first creating sitelink assets with relevant data (descriptions, link text, URLs) and then linking them to the target campaign.\u003c/p\u003e\n"],["\u003cp\u003eThe code is available in multiple languages (Python, Ruby, Perl, Java, C#) and includes error handling for API interactions.\u003c/p\u003e\n"],["\u003cp\u003eUsers need to provide their Google Ads customer ID and campaign ID to utilize the functionality.\u003c/p\u003e\n"],["\u003cp\u003eThe core process involves defining sitelink data, creating sitelink assets via the API, and linking these assets to the desired campaign using the API.\u003c/p\u003e\n"]]],[],null,[]]