factories
הוא ממשק ברמה גבוהה ליצירת פעולות ומשאבים באמצעות ספריית הלקוח.
השיטות של המפעלים נוצרות באופן אוטומטי לכל המשאבים, הטיפוסים, הפעולות וסוגי השירותים ש-Google Ads API מספק.
פעולות
הספרייה מספקת שיטות נוחות ל-client.operation.create_resource.<resource_type>
, ל-client.operation.update_resource.<resource_type>
ול-client.operation.remove_resource.<resource_type>
כדי ליצור בקלות פעולות לעבודה עם Google Ads API.
דוגמה ליצירת משאב:
campaign_budget_operation = client.operation.create_resource.campaign_budget do |cb|
cb.name = client.wrapper.string(
"Interplanetary Budget #{(Time.new.to_f * 1000).to_i}",
)
cb.delivery_method = :STANDARD
cb.amount_micros = client.wrapper.int64(500000)
end
return_budget = client.service.campaign_budget.mutate_campaign_budgets(
customer_id,
[campaign_budget_operation]
)
שימו לב שהאובייקט שניתן לבלוק cb
הוא מופע חדש של CampaignBudget
שאפשר לשנות אותו, ופעולת היצירה המתאימה ל-CampaignBudgetService
מוחזרת.
באופן דומה, אנו מספקים שיטות נוחות לעדכון:
# if you only have a resource name
update_operation = client.operation.update_resource.campaign(campaign_resource_name) do |camp|
camp.status = :PAUSED
end
campaign_service.mutate_campaigns(customer_id, [update_operation])
# if you have a full resource proto
update_operation = client.operation.update_resource.campaign(campaign) do
campaign.name = client.wrapper.string(
"A different interplanetary Cruise #{(Time.new.to_f * 1000).to_i}",
)
end
campaign_service.mutate_campaigns(customer_id, [update_operation])
הקריאות האלה מחזירות פעולת עדכון תקינה, עם מסכת שדות מאוכלסת מראש שמטרתה לעדכן את המשאב ב-Google Ads API.
לפניכם דוגמה להסרת משאב באמצעות נתיב של משאב:
remove_operation = client.operation.remove_resource.campaign(campaign_resource_name)
campaign_service.mutate_campaigns(customer_id, [remove_operation])
אם אתם מעדיפים לעבוד על הפעולה בעצמכם, אתם יכולים לקבל פעולה גולמית ואז לאכלס את השדות באופן ידני.
operation = client.operation.campaign
משאבים
הספרייה מספקת את client.resource.<resource_type>
כדרך נוחה לאתחל אובייקטים של משאבים:
campaign.network_settings = client.resource.network_settings do |ns|
ns.target_google_search = client.wrapper.bool(true)
ns.target_search_network = client.wrapper.bool(true)
ns.target_content_network = client.wrapper.bool(false)
ns.target_partner_search_network = client.wrapper.bool(false)
end
מכונה חדשה של סוג המשאב המבוקש מוצגת לבלוק שהועבר לצורך הגדרת שדות.
שירותים
הספרייה client.service.<service_name>
היא דרך נוחה לקבל אובייקטים של שירות:
campaign_service = client.service.campaign
טיפוסים בני מנייה (enums)
מומלץ להשתמש בתחביר הסמלים להגדרה סטטית של שדות 'טיפוסים בני מנייה (enum)' (למשל, campaign.status = :PAUSED
). עם זאת, אם רוצים לספור את כל הערכים החוקיים של טיפוסים בני מנייה (enum), אנחנו מספקים גם שיטות כך:
client.enum.ad_type.each { |x| p x }
:SHOPPING_PRODUCT_AD
:GMAIL_AD
:UNKNOWN
:UNSPECIFIED
:CALL_ONLY_AD
:VIDEO_AD
:IMAGE_AD
:EXPANDED_DYNAMIC_SEARCH_AD
:RESPONSIVE_DISPLAY_AD
:TEXT_AD
:LEGACY_RESPONSIVE_DISPLAY_AD
:LEGACY_APP_INSTALL_AD
:APP_AD
:SHOPPING_SMART_AD
:EXPANDED_TEXT_AD
:HOTEL_AD
:RESPONSIVE_SEARCH_AD
הגדרה מפורשת של גרסאות Google Ads API
ניתן גם להגדיר גרסה באופן מפורש:
client.resource.v16.[entity]
client.operation.v16.[operation]
client.service.v16.[service]
client.enum.v16.[enum]