คู่มือนี้จะแสดงภาพรวมระดับสูงของวิธีใช้ฟีเจอร์การขายตรงแบบเป็นโปรแกรมผ่าน API โดยจะอธิบายวิธีสร้างข้อเสนอและวิธีเจรจาต่อรอง
Primer
ข้อเสนอแบบเป็นโปรแกรมคล้ายกับคำสั่งซื้อใน Google Ad Manager ข้อเสนอแบบเป็นโปรแกรมมีข้อมูลกว้างๆ เกี่ยวกับธุรกรรมที่เสนอระหว่างคุณกับผู้ซื้อ ข้อเสนอพร้อมกับรายการโฆษณาเปรียบเสมือนข้อเสนอพื้นที่โฆษณาแก่ผู้ซื้อ
ดูข้อมูลเพิ่มเติมได้ที่ศูนย์ช่วยเหลือ
การสร้างข้อเสนอผ่าน API
หากต้องการสร้างออบเจ็กต์ Proposal
คุณต้องระบุเพียงชื่อและผู้ซื้อแบบเป็นโปรแกรมเท่านั้น คุณจะรับรหัสผู้ซื้อแบบเป็นโปรแกรมได้จาก UI หรือตาราง PQL ของ Programmatic_Buyer
Java
Proposal proposal = new Proposal(); // Setting required Marketplace information. ProposalMarketplaceInfo proposalMarketplaceInfo = new ProposalMarketplaceInfo(); proposalMarketplaceInfo.setBuyerAccountId(programmaticBuyerId); // Set common required fields for a proposal. proposal.setName("Proposal #" + new Random().nextInt(Integer.MAX_VALUE)); proposal.setPrimaryTraffickerId(primaryTraffickerId); proposal.setMarketplaceInfo(proposalMarketplaceInfo);
Python
proposal = { # Setting required Marketplace information. 'isProgrammatic': 'true', 'marketplaceInfo': { 'buyerAccountId': programmatic_buyer_id, }, # Set common required fields for proposals. 'name': 'Proposal #%s' % uuid.uuid4(), # ... }
PHP
$proposal = new Proposal(); $proposal->setName('Proposal #' . uniqid()); // Set the required Marketplace information. $proposalMarketplaceInfo = new ProposalMarketplaceInfo(); $proposalMarketplaceInfo->setBuyerAccountId($buyerId); $proposal->setMarketplaceInfo($proposalMarketplaceInfo);
C#
// Create a proposal with the minimum required fields. Proposal proposal = new Proposal() { name = "Programmatic proposal #" + new Random().Next(int.MaxValue), // Set required Marketplace information marketplaceInfo = new ProposalMarketplaceInfo() { buyerAccountId = programmaticBuyerId } };
Ruby
# Create proposal configuration object. proposal = { :marketplace_info => { :buyer_account_id => buyer_id }, :name => 'Proposal %s' % SecureRandom.uuid(), # ... }
ก่อนที่จะส่งให้ผู้ซื้อเพื่อเจรจาต่อรอง คุณจะต้องตั้งค่าฟิลด์เพิ่มเติม ข้อเสนอต้องมีผู้ติดต่อของผู้ลงโฆษณา พนักงานขาย ผู้ดูแลการแสดงโฆษณา และผู้ขาย
Java
SalespersonSplit primarySalesperson = new SalespersonSplit(); primarySalesperson.setUserId(primarySalespersonId); proposal.setPrimarySalesperson(primarySalesperson);
Python
'primarySalesperson': { 'userId': primary_salesperson_id, }, 'primaryTraffickerId': primary_trafficker_id, 'probabilityOfClose': '100000',
PHP
// Create salesperson splits for the primary salesperson. $primarySalesperson = new SalespersonSplit(); $primarySalesperson->setUserId($primarySalespersonId); $proposal->setPrimarySalesperson($primarySalesperson); // Set the primary trafficker on the proposal for when it becomes an // order. $proposal->setPrimaryTraffickerId($primaryTraffickerId); $advertiser = new ProposalCompanyAssociation(); $advertiser->setType( ProposalCompanyAssociationType::ADVERTISER ); $advertiser->setCompanyId($advertiserId); $proposal->setAdvertiser($advertiser);
C#
// Set fields that are required before sending the proposal to the buyer. proposal.primaryTraffickerId = primaryTraffickerId; proposal.sellerContactIds = new long[] { primarySalespersonId }; proposal.primarySalesperson = new SalespersonSplit() { userId = primarySalespersonId, }; proposal.advertiser = new ProposalCompanyAssociation() { type = ProposalCompanyAssociationType.ADVERTISER, companyId = advertiserId };
Ruby
:primary_salesperson => { :user_id => primary_salesperson_id }, :primary_trafficker_id => primary_trafficker_id
เนื่องจากข้อเสนอโดยทั่วไปประกอบด้วยออบเจ็กต์ ProposalLineItem ขั้นตอนต่อไปคือการเพิ่มรายการโฆษณาข้อเสนอใต้ข้อเสนอที่สร้างขึ้นใหม่
สถานะของข้อเสนอแบบเป็นโปรแกรม
รูปต่อไปนี้แสดงข้อเสนอแบบเป็นโปรแกรมในจุดต่างๆ ระหว่างกระบวนการต่อรองจากมุมมอง API แต่ละรัฐจะแสดงด้วย ชุดค่าผสมของช่องต่อไปนี้ในรูปแบบต่างๆ
- ProposalMarketplaceInfo.hasLocalVersionEdits
- ProposalMarketplaceInfo.negotiationStatus
- Proposal.status
ดูข้อมูลเพิ่มเติมได้ที่ศูนย์ช่วยเหลือของ Ad Manager
คำแนะนำแบบทีละขั้นในการเจรจาต่อรอง
ในสไลด์นี้ เราจะนำคุณเข้าสู่การใช้ API เพื่อเจรจาขอข้อเสนอแบบเป็นโปรแกรมกับผู้ซื้อให้เสร็จสมบูรณ์ เราจะอ้างอิงรัฐในแผนภาพด้านบน
การเตรียมพร้อมสําหรับการตรวจสอบหรือการยอมรับจากผู้ซื้อ
ก่อนอื่น คุณต้องร่างข้อเสนอแบบเป็นโปรแกรมที่มีรายการโฆษณาข้อเสนอที่ต้องการส่งไปยังผู้ซื้อ นี่คือ state C
ในภาพด้านบน
ขอให้ผู้ซื้อตรวจสอบหรือยอมรับ
เมื่อพร้อมให้ผู้ซื้อตรวจสอบข้อเสนอแบบเป็นโปรแกรมแล้ว คุณจะ RequestBuyerReview
หรือ RequestBuyerAcceptance
ได้โดยใช้เมธอด ProposalService.performProposalAction
ซึ่งจะนำไปสู่ขั้นตอนการเจรจาต่อรอง
การเจรจาต่อรอง
ในระยะนี้ อาจมีหลายสิ่งเกิดขึ้น
- ผู้ซื้ออาจยอมรับข้อเสนอแบบเป็นโปรแกรมของคุณโดยไม่มีการเปลี่ยนแปลง
- ผู้ซื้ออาจเสนอให้เปลี่ยนแปลง ในกรณีนี้ ระบบจะส่งข้อเสนอกลับไปยัง
สถานะฉบับร่าง (
state B
ในรูปที่ 1) จากนั้นคุณต้องเปิดข้อเสนอเพื่อแก้ไข ทำการเปลี่ยนแปลงที่เสนอ แล้วส่งกลับไปให้ผู้ซื้อตรวจสอบ - คุณอาจตัดสินใจทำการเปลี่ยนแปลงได้ก่อนที่ผู้ซื้อจะตอบกลับ ซึ่งทำได้โดยเปิดข้อเสนอสำหรับแก้ไขจาก
state D
ในรูปที่ 1
การเจรจานี้จะดำเนินต่อไปจนกว่าคุณจะบรรลุข้อตกลงกับผู้ซื้อ คุณจะดึงความคิดเห็นระหว่างคุณและผู้ซื้อได้โดยใช้ getMarketplaceCommentsByStatement
คุณส่งความคิดเห็นไปยังผู้ซื้อได้ขณะอยู่ที่ state A
ในการดำเนินการ คุณจะต้องอัปเดตช่อง marketplaceComment ในข้อเสนอโดยใช้ updateProposals
ความคิดเห็นจะถูกส่งเมื่อคุณขอการยอมรับจากผู้ซื้อ
สรุปผลแล้ว
เมื่อทั้งคุณและผู้ซื้อยอมรับข้อเสนอแบบเป็นโปรแกรมแล้ว สถานะจะเข้าสู่สถานะสรุปผล (state F
ในรูปที่ 1)
จากนั้น Ad Manager จะสร้างรายการโฆษณาจากข้อเสนอแบบเป็นโปรแกรมนี้โดยอัตโนมัติ
ในกรณีส่วนใหญ่ คุณจะรับข้อเสนอแบบเป็นโปรแกรมแล้ว อย่างไรก็ตามมีการดำเนินการ 2 อย่างที่คุณทำได้จากสถานะนี้ ได้แก่
- คุณสามารถเปิดข้อเสนอแบบเป็นโปรแกรมอีกครั้งเพื่อเจรจาต่อรองใหม่ได้โดยแก้ไขช่องที่เกี่ยวข้องกับการแสดงโฆษณาในข้อเสนอ ซึ่งทำได้โดยเปิดข้อเสนอเพื่อแก้ไข (
state E to A
ในรูปที่ 1) ทำการเปลี่ยนแปลง แล้วขอการยอมรับจากผู้ซื้อ - คุณทำการแก้ไขที่ไม่เกี่ยวข้องกับการแสดงโฆษณาได้ เช่น อัปเดตชื่อข้อเสนอ และแสดงการเปลี่ยนแปลงเหล่านี้ในคำสั่งซื้อ Ad Manager และรายการโฆษณาที่สร้างจากดีลนี้ ซึ่งทําได้โดยแก้ไขจาก
state E
ในรูปที่ 1 แล้วดําเนินการUpdateOrderWithSellerData