แบบเป็นโปรแกรม

คู่มือนี้จะแสดงภาพรวมระดับสูงของวิธีใช้ฟีเจอร์การขายตรงแบบเป็นโปรแกรมผ่าน 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 แต่ละรัฐจะแสดงด้วย ชุดค่าผสมของช่องต่อไปนี้ในรูปแบบต่างๆ

ดูข้อมูลเพิ่มเติมได้ที่ศูนย์ช่วยเหลือของ Ad Manager

สถานะของข้อเสนอแบบเป็นโปรแกรมอาจอยู่ในสถานะระหว่างการโต้ตอบกับตลาดกลาง
รูปที่ 1: สถานะของข้อเสนอแบบเป็นโปรแกรม

คำแนะนำแบบทีละขั้นในการเจรจาต่อรอง

ในสไลด์นี้ เราจะนำคุณเข้าสู่การใช้ 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