প্রোটোবাফ টাইপের সাথে কাজ করা

যেহেতু গুগল অ্যাডস এপিআই তার ডিফল্ট পেলোড ফরম্যাট হিসেবে প্রোটো৩ ব্যবহার করে, তাই এই এপিআই নিয়ে কাজ করার সময় কয়েকটি প্রোটোবাফ কনভেনশন ও টাইপ বোঝা জরুরি।

ঐচ্ছিক ক্ষেত্র

গুগল অ্যাডস এপিআই-এর অনেক ফিল্ডকে optional হিসেবে চিহ্নিত করা থাকে। এর ফলে, ফিল্ডটির মান খালি থাকা এবং সার্ভার থেকে কোনো মান ফেরত না পাঠানোর মধ্যে পার্থক্য করা যায়। এই ফিল্ডগুলো সাধারণ ফিল্ডের মতোই কাজ করে, তবে এগুলোর সাথে ফিল্ডটি খালি করার এবং সেটি সেট করা আছে কিনা তা পরীক্ষা করার জন্য অতিরিক্ত মেথডও থাকে।

উদাহরণস্বরূপ, Campaign অবজেক্টের Name ফিল্ডটিকে ঐচ্ছিক হিসেবে চিহ্নিত করা হয়েছে। তাই এই ফিল্ডটি নিয়ে কাজ করার জন্য আপনি নিম্নলিখিত পদ্ধতিগুলো ব্যবহার করতে পারেন।

// Get the name.
string name = campaign.Name;

// Set the name.
campaign.Name = name;

// Check if the campaign object has the name field set.
bool hasName = campaign.HasName();

// Clear the name field. Use this method to exclude Name field from
// being sent to the server in a subsequent API call.
campaign.ClearName();

// Set the campaign to empty string value. This value will be
// sent to the server if you use this object in a subsequent API call.
campaign.Name = "";

// This will throw a runtime error. Use ClearName() instead.
campaign.Name = null;

পুনরাবৃত্ত ক্ষেত্র

গুগল অ্যাডস এপিআই-তে একটি ফিল্ড অ্যারে একটি রিড-অনলি RepeatedField হিসেবে উপস্থাপিত হয়।

একটি উদাহরণ হলো কোনো ক্যাম্পেইনের url_custom_parameters ফিল্ডটি একটি রিপিটেড ফিল্ড, তাই এটিকে .NET ক্লায়েন্ট লাইব্রেরিতে একটি রিড-অনলি RepeatedField<CustomParameter> হিসেবে উপস্থাপন করা হয়। RepeatedField ফিল্ডটি IList<T> ইন্টারফেসটি ইমপ্লিমেন্ট করে।

একটি RepeatedField ফিল্ডে ডেটা প্রবেশ করানোর দুটি উপায় আছে।

AddRange পদ্ধতি

 Campaign campaign = new Campaign()
 {
     ResourceName = ResourceNames.Campaign(customerId, campaignId),
     Status = CampaignStatus.Paused,
 };

 // Add values to UrlCustomParameters using AddRange method.
 campaign.UrlCustomParameters.AddRange(new CustomParameter[]
 {
     new CustomParameter { Key = "season", Value = "christmas" },
     new CustomParameter { Key = "promocode", Value = "NY123" }
 });
 ```

সংগ্রহ প্রারম্ভিক সিনট্যাক্স

// Option 1: Initialize the field directly.
Campaign campaign = new Campaign()
{
    ResourceName = ResourceNames.Campaign(customerId, campaignId),
    Status = CampaignStatus.Paused,
    // Directly initialize the field.
    UrlCustomParameters =
    {
        new CustomParameter { Key = "season", Value = "christmas" },
        new CustomParameter { Key = "promocode", Value = "NY123" }
    }
};

// Option 2: Initialize using an intermediate variable.
CustomParameter[] parameters = new CustomParameter[]
{
    new CustomParameter { Key = "season", Value = "christmas" },
    new CustomParameter { Key = "promocode", Value = "NY123" }
}

Campaign campaign1 = new Campaign()
{
    ResourceName = ResourceNames.Campaign(customerId, campaignId),
    Status = CampaignStatus.Paused,
    // Initialize from an existing array.
    UrlCustomParameters = { parameters }
};

ক্ষেত্রগুলির মধ্যে একটি

গুগল অ্যাডস এপিআই-এর কিছু ফিল্ডকে oneof ফিল্ড হিসেবে চিহ্নিত করা হয়, যার অর্থ হলো ফিল্ডটি বিভিন্ন ধরনের ডেটা টাইপ ধারণ করতে পারলেও, যেকোনো সময়ে কেবল একটি ভ্যালুই ধারণ করতে পারে। oneof ফিল্ডগুলো সি প্রোগ্রামিং ল্যাঙ্গুয়েজের 'union' টাইপের অনুরূপ।

.NET লাইব্রেরিটি oneof ফিল্ড বাস্তবায়ন করে, যেখানে একটি oneof ফিল্ডে ধারণ করা যায় এমন প্রতিটি ধরণের মানের জন্য একটি করে প্রপার্টি দেওয়া হয় এবং এই সমস্ত প্রপার্টি একটি শেয়ার্ড ক্লাস ফিল্ডকে আপডেট করে।

উদাহরণস্বরূপ, ক্যাম্পেইনের campaign_bidding_strategy একটি oneof ফিল্ড হিসেবে চিহ্নিত করা হয়েছে। এই ক্লাসটি নিম্নরূপে প্রয়োগ করা হয়েছে (সংক্ষিপ্ততার জন্য কোডটি সরলীকরণ করা হয়েছে):

public sealed partial class Campaign : pb::IMessage<Campaign>
{
    object campaignBiddingStrategy_ = null;
    CampaignBiddingStrategyOneofCase campaignBiddingStrategyCase_;

    public ManualCpc ManualCpc
    {
        get
        {
            return campaignBiddingStrategyCase_ == CampaignBiddingStrategyOneofCase.ManualCpc ?
                (ManualCpc) campaignBiddingStrategy_ : null;
        }
        set
        {
            campaignBiddingStrategy_ = value;
            campaignBiddingStrategyCase_ = CampaignBiddingStrategyOneofCase.ManualCpc;
        }
    }

    public ManualCpm ManualCpm
    {
        get
        {
            return campaignBiddingStrategyCase_ == CampaignBiddingStrategyOneofCase.ManualCpm ?
                (ManualCpm) campaignBiddingStrategy_ : null;
        }
        set
        {
            campaignBiddingStrategy_ = value;
            campaignBiddingStrategyCase_ = CampaignBiddingStrategyOneofCase.ManualCpm;
        }
    }

    public CampaignBiddingStrategyOneofCase CampaignBiddingStrategyCase
    {
        get { return campaignBiddingStrategyCase_; }
    }
}

যেহেতু oneof প্রোপার্টিগুলো স্টোরেজ শেয়ার করে, তাই একটি অ্যাসাইনমেন্ট পূর্ববর্তী অ্যাসাইনমেন্টকে ওভাররাইট করতে পারে, যার ফলে সূক্ষ্ম বাগ তৈরি হয়। উদাহরণস্বরূপ,

Campaign campaign = new Campaign()
{
    ManualCpc = new ManualCpc()
    {
        EnhancedCpcEnabled = true
    },
    ManualCpm = new ManualCpm()
    {

    }
};

এই ক্ষেত্রে, campaign.ManualCpc এখন null হবে, কারণ campaign.ManualCpm ফিল্ডটি ইনিশিয়ালাইজ করার ফলে campaign.ManualCpc এর পূর্ববর্তী ইনিশিয়ালাইজেশনটি ওভাররাইট হয়ে যায়।

অন্যান্য ফরম্যাটে রূপান্তর

JSON ফরম্যাটে রূপান্তর করুন

আপনি প্রোটোবাফ অবজেক্টকে JSON ফরম্যাটে এবং এর বিপরীতক্রমে রূপান্তর করতে পারেন। এমন সিস্টেম তৈরির ক্ষেত্রে এটি উপযোগী, যেগুলোকে JSON বা XML-এর মতো টেক্সট-ভিত্তিক ফরম্যাটে ডেটা প্রয়োজন এমন অন্যান্য সিস্টেমের সাথে ইন্টারফেস করতে হয়।

GoogleAdsRow row = new GoogleAdsRow()
{
    Campaign = new Campaign()
    {
        Id = 123,
        Name = "Campaign 1",
        ResourceName = ResourceNames.Campaign(1234567890, 123)
    }
};

// Serialize to JSON and back.
string json = JsonFormatter.Default.Format(row);
row = GoogleAdsRow.Parser.ParseJson(json);

বাইটে রূপান্তর করুন

আপনি একটি অবজেক্টকে বাইটে এবং আবার বাইটে সিরিয়ালাইজ করতে পারেন। JSON ফরম্যাটের চেয়ে বাইনারি সিরিয়ালাইজেশন মেমরি এবং স্টোরেজের দিক থেকে বেশি সাশ্রয়ী।

GoogleAdsRow row = new GoogleAdsRow()
{
    Campaign = new Campaign()
    {
        Id = 123,
        Name = "Campaign 1",
        ResourceName = ResourceNames.Campaign(1234567890, 123)
    }
};
// Serialize to bytes and back.
byte[] bytes = row.ToByteArray();
row = GoogleAdsRow.Parser.ParseFrom(bytes);