Data API कोड स्निपेट

निर्देश

इंटरैक्टिव कोड स्निपेट टूल की मदद से, एपीआई अनुरोधों के टेस्ट आसानी से किए जा सकते हैं. साथ ही, इन अनुरोधों के लिए खास कोड सैंपल जनरेट किए जा सकते हैं. किसी भी दिए गए तरीके के लिए, टूल एक या ज़्यादा इस्तेमाल के उदाहरणों के लिए कोड स्निपेट दिखाता है और इस्तेमाल के हर उदाहरण में उस तरीके को कॉल करने का एक आम तरीका बताया गया है. उदाहरण के लिए, किसी खास चैनल या मौजूदा उपयोगकर्ता के चैनल का डेटा पाने के लिए, channels.list तरीके पर कॉल किया जा सकता है.

एपीआई के अनुरोध चलाना

अनुरोध के अनुरोधों की सूची के बगल में दिए गए चलाएं बटन पर क्लिक करके, अनुरोधों को एक्ज़ीक्यूट किया जा सकता है. अगर आपने पहले से ही आपकी ओर से एपीआई अनुरोध सबमिट करने के लिए ऐप्लिकेशन को अनुमति नहीं दी है, तो आपको ऐसा करने के लिए कहा जाएगा. एक और सावधानी के तौर पर, अगर आपका अनुरोध एक लिखित कार्रवाई करता है – अपने चैनल से जुड़े संसाधनों को शामिल करना, अपडेट करना या मिटाना – तो अनुरोध को असल में लागू करने से पहले आपको इसकी पुष्टि करने के लिए कहा जाएगा.

कोड स्निपेट और सभी सैंपल टॉगल करें

इस्तेमाल के हर उदाहरण के लिए, टूल एक कोड स्निपेट दिखाता है. इस कोड में, कॉल करने के खास तरीके से जुड़े कोड की पहचान की जाती है. हर स्निपेट, कॉल करने के तरीके के साथ-साथ एपीआई अनुरोध में इस्तेमाल किए गए पैरामीटर और प्रॉपर्टी की वैल्यू की भी पहचान करता है.

इसके अलावा, टूल एक पूरा कोड सैंपल भी दिखाता है, जो उस कोड स्निपेट को एक ऐसे टेंप्लेट में रखता है जो एपीआई अनुरोधों को अनुमति देने और एपीआई अनुरोधों को बनाने के लिए, बॉयलरप्लेट फ़ंक्शन को तय करता है. स्निपेट और पूरे सैंपल के बीच स्विच करने के लिए, सैंपल के ऊपर मौजूद स्लाइडर का इस्तेमाल किया जा सकता है:

स्थानीय भाषा में पूरे कोड सैंपल चलाएं

पूरे कोड सैंपल को इस तरह से डिज़ाइन किया जाता है कि उन्हें कॉपी करके स्थानीय तौर पर चलाया जा सके. कृपया निम्न शर्तों पर ध्यान दें और पूरे कोड के नमूने चलाने के लिए ज़रूरी कदम सेट अप करें:

जावा

ज़रूरी शर्तें

  • Java 1.7 या इसके बाद का वर्शन
  • Gradle 2.3 या इससे ज़्यादा

अपना प्रोजेक्ट सेट अप करना और कोड सैंपल चलाना

  1. एपीआई कंसोल में प्रोजेक्ट बनाएं और वेब ऐप्लिकेशन के लिए क्रेडेंशियल सेट अप करें. अनुमति वाले रीडायरेक्ट यूआरआई को सही के तौर पर सेट करें.

  2. अपना प्रोजेक्ट बनाने के लिए, एपीआई Java क्विकस्टार्ट गाइड में दिए गए निर्देशों का पालन करें. हालांकि, डिफ़ॉल्ट build.gradle फ़ाइल के कॉन्टेंट को इस कोड से बदलें:

    apply plugin: 'java'
    apply plugin: 'application'
    
    mainClassName = 'ApiExample'
    sourceCompatibility = 1.7
    targetCompatibility = 1.7
    version = '1.0'
    
    repositories {
        mavenCentral()
    }
    
    dependencies {
        compile 'com.google.api-client:google-api-client:1.22.0'
        compile 'com.google.oauth-client:google-oauth-client-jetty:1.22.0'
        compile 'com.google.apis:google-api-services-youtube:v3-rev182-1.22.0'
        compile group: 'com.google.code.gson', name: 'gson', version: '1.7.2'
        compile group: 'com.fasterxml.jackson.core', name: 'jackson-databind', version: '2.4.4'
    }
    
    compileJava {
        options.compilerArgs << "-Xlint:unchecked" << "-Xlint:deprecation"
    }
  3. अपनी काम करने वाली डायरेक्ट्री से, अपने क्रेडेंशियल से जुड़ी client_secrets.json फ़ाइल को src/main/resources/client_secret.json में सेव करें.

  4. अपनी चालू डायरेक्ट्री से, पूरे कोड के नमूने को src/main/java/ApiExample.java में कॉपी करें. (हर नमूने में कक्षा का नाम ApiExample है, ताकि अलग-अलग नमूने देखने के लिए आपको build.gradle फ़ाइल में बदलाव करने की ज़रूरत न पड़े.)

  5. कमांड लाइन से सैंपल चलाएं:

    gradle -q run
  6. ज़्यादातर नमूने, STDOUT में कुछ प्रिंट करते हैं. इसके अलावा, YouTube की वेबसाइट पर जाकर, डेटा को लिखने वाले अनुरोधों का असर देखा जा सकता है. इनमें, प्लेलिस्ट या चैनल सेक्शन बनाने वाले अनुरोध शामिल हैं.

JavaScript
  1. एपीआई कंसोल में प्रोजेक्ट बनाएं और वेब ऐप्लिकेशन के लिए क्रेडेंशियल सेट अप करें. अनुमति वाले JavaScript ऑरिजिन को सेट करें, ताकि उस यूआरएल की पहचान की जा सके जिससे आप अनुरोध भेजेंगे. उदाहरण के लिए, http://localhost.

  2. पूरे कोड का नमूना ऐसी लोकल फ़ाइल में कॉपी करें जिसे आपके वेब सर्वर से ऐक्सेस किया जा सके (उदाहरण के लिए, /var/www/html/example.html).

  3. कोड सैंपल में वह लाइन ढूंढें जो अनुरोध के लिए इस्तेमाल होने वाला क्लाइंट आईडी सेट करती है. साथ ही, वैल्यू को अपने क्रेडेंशियल के लिए क्लाइंट आईडी से बदलें:

    gapi.client.init({
        'clientId': 'REPLACE_ME',
  4. अपने ब्राउज़र में फ़ाइल खोलें (जैसे, http://localhost/example.html. यह सुझाव दिया जाता है कि आप ब्राउज़र ब्राउज़र का इस्तेमाल करें, जैसे कि Google Chrome.

  5. अगर ज़रूरी हो, तो अनुरोध की पुष्टि करें. अगर अनुरोध को अनुमति दी गई है, तो डीबग करने वाले कंसोल को, अनुरोध का एपीआई रिस्पॉन्स JSON ऑब्जेक्ट के तौर पर दिखाना चाहिए.

Node.js

ज़रूरी शर्तें

  • Node.js इंस्टॉल करना ज़रूरी है.
  • npm पैकेज प्रबंधन टूल (Node.js के साथ आता है).
  • Node.js के लिए Google API क्लाइंट लाइब्रेरी:
    npm install googleapis --save
  • इंटरनेट और वेब ब्राउज़र का ऐक्सेस.
  • एक Google खाता.

अपना प्रोजेक्ट सेट अप करना और कोड सैंपल चलाना

  1. एपीआई कंसोल में प्रोजेक्ट बनाएं और Google API कंसोल में OAuth 2.0 क्रेडेंशियल सेट अप करें. अपने क्रेडेंशियल सेट अप करते समय, ऐप्लिकेशन टाइप को अन्य पर सेट करें.

  2. अपने क्रेडेंशियल से जुड़ी client_secret.json फ़ाइल को स्थानीय फ़ाइल में सेव करें.

  3. पूरे कोड के नमूने को client_secret.json फ़ाइल की तरह, उसी डायरेक्ट्री में स्थानीय फ़ाइल में कॉपी करें (या उस फ़ाइल की जगह की सही पहचान करने के लिए नमूने में बदलाव करें).

  4. कमांड लाइन से सैंपल चलाएं:

    node sample.js
  5. ज़्यादातर नमूने, STDOUT या वेब ऐप्लिकेशन के उदाहरणों के लिए, उस वेब पेज पर कुछ प्रिंट करते हैं जिसे आप देख रहे हैं. इसके अलावा, YouTube की वेबसाइट पर जाकर, डेटा को लिखने वाले अनुरोधों का असर देखा जा सकता है. इनमें, प्लेलिस्ट या चैनल सेक्शन बनाने वाले अनुरोध शामिल हैं.

Python

ज़रूरी शर्तें

  • Python 2.6 या इसके बाद का वर्शन
  • पीआईपी पैकेज मैनेजमेंट टूल
  • Python के लिए Google API क्लाइंट लाइब्रेरी:
    pip install --upgrade google-api-python-client
  • उपयोगकर्ता की अनुमति के लिए google-auth, google-auth-oauthlib, और google-auth-httplib2.
    pip install --upgrade google-auth google-auth-oauthlib google-auth-httplib2
  • Flask Python वेब ऐप्लिकेशन फ़्रेमवर्क (अगर आप वेब सर्वर ऐप्लिकेशन के लिए Python नमूने चला रहे हैं).
    pip install --upgrade flask
  • एचटीटीपी लाइब्रेरी का अनुरोध.
    pip install --upgrade requests

अपना प्रोजेक्ट सेट अप करना और कोड सैंपल चलाना

  1. एपीआई कंसोल में प्रोजेक्ट बनाएं और Google API कंसोल में OAuth 2.0 क्रेडेंशियल सेट अप करें. अपने क्रेडेंशियल सेट अप करते समय, फ़्लैस्क Python वेब ऐप्लिकेशन फ़्रेमवर्क का इस्तेमाल करने वाले नमूनों के लिए ऐप्लिकेशन टाइप को वेब ऐप्लिकेशन पर सेट करें और उन क्रेडेंशियल के लिए अनुमति वाले रीडायरेक्ट यूआरआई भी सेट करें. नहीं तो, ऐप्लिकेशन टाइप को अन्य पर सेट करें.

  2. अपने क्रेडेंशियल से जुड़ी client_secret.json फ़ाइल को स्थानीय फ़ाइल में सेव करें.

  3. पूरे कोड के नमूने को client_secret.json फ़ाइल की तरह, उसी डायरेक्ट्री में स्थानीय फ़ाइल में कॉपी करें (या उस फ़ाइल की जगह की सही पहचान करने के लिए नमूने में बदलाव करें).

  4. कमांड लाइन से सैंपल चलाएं:

    python sample.py
    वेब सर्वर ऐप्लिकेशन के लिए नोट:

    अगर वेब सर्वर ऐप्लिकेशन के लिए Python के सैंपल इस्तेमाल किए जा रहे हैं, तो स्क्रिप्ट चलाने पर लोकल वेब सर्वर शुरू हो जाएगा. एपीआई अनुरोध को चलाने के लिए, आपको किसी ब्राउज़र में वेब पेज पर जाना होगा. उदाहरण के लिए, फ़्लास्क वेब ऐप्लिकेशन फ़्रेमवर्क का इस्तेमाल करने वाले Python सैंपल में एक लाइन इस तरह की होती है:

    app.run('localhost', 8080, debug=True)

    यह कोड http://localhost:8080 पर एक स्थानीय वेब सर्वर शुरू करता है. हालांकि, स्क्रिप्ट तब तक एपीआई के अनुरोध को लागू करने की कोशिश नहीं करती, जब तक आप असल में ब्राउज़र पर http://localhost:8080 पर नहीं जाते. आपके ऑथराइज़ेशन क्रेडेंशियल के लिए, आपके स्थानीय सर्वर का यूआरएल, एक आधिकारिक रीडायरेक्ट यूआरआई के तौर पर सेट होना चाहिए.
  5. ज़्यादातर नमूने, STDOUT या वेब ऐप्लिकेशन के उदाहरणों के लिए, उस वेब पेज पर कुछ प्रिंट करते हैं जिसे आप देख रहे हैं. इसके अलावा, YouTube की वेबसाइट पर जाकर, डेटा को लिखने वाले अनुरोधों का असर देखा जा सकता है. इनमें, प्लेलिस्ट या चैनल सेक्शन बनाने वाले अनुरोध शामिल हैं.

पीएचपी

ज़रूरी शर्तें

  • इंस्टॉल किया गया कमांड-लाइन इंटरफ़ेस (CLI) और JSON एक्सटेंशन के साथ, PHP 5.4 या इसके बाद का वर्शन.
  • कंपोज़र डिपेंडेंसी मैनेजमेंट टूल.
  • PHP के लिए Google API क्लाइंट लाइब्रेरी:
    php composer.phar require google/apiclient:^2.0

अपना प्रोजेक्ट सेट अप करना और कोड सैंपल चलाना

  1. एपीआई कंसोल में प्रोजेक्ट बनाएं और Google API कंसोल में OAuth 2.0 क्रेडेंशियल सेट अप करें. अपने क्रेडेंशियल सेट अप करते समय, ऐप्लिकेशन टाइप को अन्य पर सेट करें.

  2. अपने क्रेडेंशियल से जुड़ी client_secret.json फ़ाइल को स्थानीय फ़ाइल में सेव करें.

  3. पूरे कोड के नमूने को client_secret.json फ़ाइल की तरह, उसी डायरेक्ट्री में स्थानीय फ़ाइल में कॉपी करें (या उस फ़ाइल की जगह की सही पहचान करने के लिए नमूने में बदलाव करें).

  4. कमांड लाइन से सैंपल चलाएं:

    php sample.php
  5. ज़्यादातर नमूने, STDOUT या वेब ऐप्लिकेशन के उदाहरणों के लिए, उस वेब पेज पर कुछ प्रिंट करते हैं जिसे आप देख रहे हैं. इसके अलावा, YouTube की वेबसाइट पर जाकर, डेटा को लिखने वाले अनुरोधों का असर देखा जा सकता है. इनमें, प्लेलिस्ट या चैनल सेक्शन बनाने वाले अनुरोध शामिल हैं.

रूबी

ज़रूरी शर्तें

  • Ruby 2.0 या इसके बाद का वर्शन
  • Ruby के लिए Google API क्लाइंट लाइब्रेरी:
    gem install google-api-client

अपना प्रोजेक्ट सेट अप करना और कोड सैंपल चलाना

  1. एपीआई कंसोल में प्रोजेक्ट बनाएं और Google API कंसोल में OAuth 2.0 क्रेडेंशियल सेट अप करें. अपने क्रेडेंशियल सेट अप करते समय, ऐप्लिकेशन टाइप को अन्य पर सेट करें.

  2. अपने क्रेडेंशियल से जुड़ी client_secret.json फ़ाइल को स्थानीय फ़ाइल में सेव करें.

  3. पूरे कोड के नमूने को client_secret.json फ़ाइल की तरह, उसी डायरेक्ट्री में स्थानीय फ़ाइल में कॉपी करें (या उस फ़ाइल की जगह की सही पहचान करने के लिए नमूने में बदलाव करें).

  4. कमांड लाइन से सैंपल चलाएं:

    ruby sample.rb
  5. ज़्यादातर नमूने, STDOUT या वेब ऐप्लिकेशन के उदाहरणों के लिए, उस वेब पेज पर कुछ प्रिंट करते हैं जिसे आप देख रहे हैं. इसके अलावा, YouTube की वेबसाइट पर जाकर, डेटा को लिखने वाले अनुरोधों का असर देखा जा सकता है. इनमें, प्लेलिस्ट या चैनल सेक्शन बनाने वाले अनुरोध शामिल हैं.

Apps Script
YouTube की सुविधाएं चालू करने के लिए, Google की बेहतर सेवाएं चालू करने के निर्देशों का पालन करें.
शुरू करें
  1. एपीआई कंसोल में प्रोजेक्ट बनाएं और Google API कंसोल में OAuth 2.0 क्रेडेंशियल सेट अप करें. अपने क्रेडेंशियल सेट अप करते समय, ऐप्लिकेशन टाइप को अन्य पर सेट करें.

  2. अपने क्रेडेंशियल से जुड़ी client_secret.json फ़ाइल को स्थानीय फ़ाइल में सेव करें.

  3. पूरे कोड के नमूने को client_secret.json फ़ाइल की तरह, उसी डायरेक्ट्री में स्थानीय फ़ाइल में कॉपी करें (या उस फ़ाइल की जगह की सही पहचान करने के लिए नमूने में बदलाव करें).

  4. कमांड लाइन से सैंपल चलाएं:

    go run sample.go
  5. ज़्यादातर नमूने, STDOUT या वेब ऐप्लिकेशन के उदाहरणों के लिए, उस वेब पेज पर कुछ प्रिंट करते हैं जिसे आप देख रहे हैं. इसके अलावा, YouTube की वेबसाइट पर जाकर, डेटा को लिखने वाले अनुरोधों का असर देखा जा सकता है. इनमें, प्लेलिस्ट या चैनल सेक्शन बनाने वाले अनुरोध शामिल हैं.

बॉयलरप्लेट फ़ंक्शन का इस्तेमाल करना

जैसा कि ऊपर बताया गया है, एपीआई कोड को बनाने और अनुमति देने के लिए, पूरे कोड के सैंपल में बॉयलरप्लेट कोड का इस्तेमाल किया जाता है. उदाहरण के लिए, Python सैंपल में build_resource फ़ंक्शन ऐसी डिक्शनरी का इस्तेमाल करता है जो रिसॉर्स प्रॉपर्टी की वैल्यू को मैप करके, एक ऐसा संसाधन बनाता है जिसे डाला या अपडेट किया जा सकता है. JavaScript, PHP, Ruby, Go, और Apps Script के लिए एक जैसे फ़ंक्शन दिए जाते हैं.

उदाहरण के लिए, नीचे दिए गए टैब बताते हैं कि बिल्डिंग संसाधन के लिए, बॉयलरप्लेट फ़ंक्शन को playlist संसाधन बनाने के लिए कैसे कॉल किया जाता है. ध्यान दें कि बॉयलरप्लेट फ़ंक्शन को यह जानने की ज़रूरत नहीं है कि किस तरह का संसाधन बनाया जा रहा है.

JavaScript
function createResource(properties) {
  var resource = {};
  var normalizedProps = properties;
  for (var p in properties) {
    var value = properties[p];
    if (p && p.substr(-2, 2) == '[]') {
      var adjustedName = p.replace('[]', '');
      if (value) {
        normalizedProps[adjustedName] = value.split(',');
      }
      delete normalizedProps[p];
    }
  }
  for (var p in normalizedProps) {
    // Leave properties that don't have values out of inserted resource.
    if (normalizedProps.hasOwnProperty(p) && normalizedProps[p]) {
      var propArray = p.split('.');
      var ref = resource;
      for (var pa = 0; pa < propArray.length; pa++) {
        var key = propArray[pa];
        if (pa == propArray.length - 1) {
          ref[key] = normalizedProps[p];
        } else {
          ref = ref[key] = ref[key] || {};
        }
      }
    };
  }
  return resource;
}
var resource = createResource({
    'snippet.title': 'Sample playlist ',
    'snippet.description': 'This is a sample playlist description.',
    'snippet.tags[]': 'JavaScript code, interactive',
    'snippet.defaultLanguage': '',
    'status.privacyStatus': 'private'
}
Python
# Build a resource based on a list of properties given as key-value pairs.
# Leave properties with empty values out of the inserted resource.
def build_resource(properties):
  resource = {}
  for p in properties:
    # Given a key like "snippet.title", split into "snippet" and "title", where
    # "snippet" will be an object and "title" will be a property in that object.
    prop_array = p.split('.')
    ref = resource
    for pa in range(0, len(prop_array)):
      is_array = False
      key = prop_array[pa]
      # Convert a name like "snippet.tags[]" to snippet.tags, but handle
      # the value as an array.
      if key[-2:] == '[]':
        key = key[0:len(key)-2:]
        is_array = True
      if pa == (len(prop_array) - 1):
        # Leave properties without values out of inserted resource.
        if properties[p]:
          if is_array:
            ref[key] = properties[p].split(',')
          else:
            ref[key] = properties[p]
      elif key not in ref:
        # For example, the property is "snippet.title", but the resource does
        # not yet have a "snippet" object. Create the snippet object here.
        # Setting "ref = ref[key]" means that in the next time through the
        # "for pa in range ..." loop, we will be setting a property in the
        # resource's "snippet" object.
        ref[key] = {}
        ref = ref[key]
      else:
        # For example, the property is "snippet.description", and the resource
        # already has a "snippet" object.
        ref = ref[key]
  return resource

resource = build_resource({
    'snippet.title': 'Sample playlist ',
    'snippet.description': 'This is a sample playlist description.',
    'snippet.tags[]': 'Python code, interactive',
    'snippet.defaultLanguage': '',
    'status.privacyStatus': 'private'}
  
PHP
// Add a property to the resource.
function addPropertyToResource(&$ref, $property, $value) {
    $keys = explode(".", $property);
    $is_array = false;
    foreach ($keys as $key) {
        // Convert a name like "snippet.tags[]" to "snippet.tags" and
        // set a boolean variable to handle the value like an array.
        if (substr($key, -2) == "[]") {
            $key = substr($key, 0, -2);
            $is_array = true;
        }
        $ref = &$ref[$key];
    }

    // Set the property value. Make sure array values are handled properly.
    if ($is_array && $value) {
        $ref = $value;
        $ref = explode(",", $value);
    } elseif ($is_array) {
        $ref = array();
    } else {
        $ref = $value;
    }
}

// Build a resource based on a list of properties given as key-value pairs.
function createResource($properties) {
    $resource = array();
    foreach ($properties as $prop => $value) {
        if ($value) {
            addPropertyToResource($resource, $prop, $value);
        }
    }
    return $resource;
}

$propertyObject = createResource(array(
    'snippet.title' => 'Sample playlist ',
    'snippet.description' => 'This is a sample playlist description.',
    'snippet.tags[]' => 'Python code, interactive',
    'snippet.defaultLanguage' => '',
    'status.privacyStatus' => 'private'));
रूबी
# Build a resource based on a list of properties given as key-value pairs.
def create_resource(properties)
  resource = {}
  properties.each do |prop, value|
    ref = resource
    prop_array = prop.to_s.split(".")
    for p in 0..(prop_array.size - 1)
      is_array = false
      key = prop_array[p]
      if key[-2,2] == "[]"
        key = key[0...-2]
        is_array = true
      end
      if p == (prop_array.size - 1)
        if is_array
          if value == ""
            ref[key.to_sym] = []
          else
            ref[key.to_sym] = value.split(",")
          end
        elsif value != ""
          ref[key.to_sym] = value
        end
      elsif ref.include?(key.to_sym)
        ref = ref[key.to_sym]
      else
        ref[key.to_sym] = {}
        ref = ref[key.to_sym]
      end
    end
  end
  return resource
end

resource = create_resource({
    'snippet.title': 'Sample playlist ',
    'snippet.description': 'This is a sample playlist description.',
    'snippet.tags[]': 'Ruby code, interactive',
    'snippet.default_language': '',
    'status.privacy_status': 'private'})
Apps Script
// Build an object from an object containing properties as key-value pairs
function createResource(properties) {
  var res = {};
  var normalizedProps = {};
  for (var p in properties) {
    var value = properties[p];
    if (p.substr(-2, 2) == '[]' && value) {
      var adjustedName = p.replace('[]', '');
      normalizedProps[adjustedName] = value.split(',');
    } else {
      normalizedProps[p] = value;
    }
  }
  for (var p in normalizedProps) {
    if (normalizedProps.hasOwnProperty(p) && normalizedProps[p]) {
      var propArray = p.split('.');
      var ref = res;
      for (var pa = 0; pa < propArray.length; pa++) {
        var key = propArray[pa];
        if (pa == propArray.length - 1) {
          ref[key] = normalizedProps[p];
        } else {
          ref = ref[key] = ref[key] || {};
        }
      }
    };
  }
  return res;
}

var resource = createResource({
    'snippet.title': 'Sample playlist ',
    'snippet.description': 'This is a sample playlist description.',
    'snippet.tags[]': 'Apps Script code, interactive',
    'snippet.defaultLanguage': '',
    'status.privacyStatus': 'private'
});
शुरू करें
func addPropertyToResource(ref map[string]interface{}, keys []string, value string, count int) map[string]interface{} {
        for k := count; k < (len(keys) - 1); k++ {
                switch val := ref[keys[k]].(type) {
                case map[string]interface{}:
                        ref[keys[k]] = addPropertyToResource(val, keys, value, (k + 1))
                case nil:
                        next := make(map[string]interface{})
                        ref[keys[k]] = addPropertyToResource(next, keys, value, (k + 1))
                }
        }
        // Only include properties that have values.
        if (count == len(keys) - 1 && value != "") {
                valueKey := keys[len(keys)-1]
                if valueKey[len(valueKey)-2:] == "[]" {
                        ref[valueKey[0:len(valueKey)-2]] = strings.Split(value, ",")
                } else if len(valueKey) > 4 && valueKey[len(valueKey)-4:] == "|int" {
                        ref[valueKey[0:len(valueKey)-4]], _ = strconv.Atoi(value)
                } else if value == "true" {
                        ref[valueKey] = true
                } else if value == "false" {
                        ref[valueKey] = false
                } else {
                        ref[valueKey] = value
                }
        }
        return ref
}

func createResource(properties map[string]string) string {
        resource := make(map[string]interface{})
        for key, value := range properties {
                keys := strings.Split(key, ".")
                ref := addPropertyToResource(resource, keys, value, 0)
                resource = ref
        }
        propJson, err := json.Marshal(resource)
        if err != nil {
               log.Fatal("cannot encode to JSON ", err)
        }
        return string(propJson)
}

func main() {
        properties := (map[string]string{
                 "snippet.title": "Sample playlist ",
                 "snippet.description": "This is a sample playlist description.",
                 "snippet.tags[]": "Go code, interactive",
                 "snippet.defaultLanguage": "",
                 "status.privacyStatus": "private",
        })
        res := createResource(properties)

मौजूदा रिसॉर्स लोड करें

किसी मौजूदा संसाधन को अपडेट करने के अनुरोध की जांच करने के लिए, आप उस संसाधन के मौजूदा प्रॉपर्टी मानों को अपडेट फ़ॉर्म में लोड कर सकते हैं. उदाहरण के लिए, किसी वीडियो का मेटाडेटा अपडेट करने के लिए, id प्रॉपर्टी फ़ील्ड में वीडियो आईडी डालें और संसाधन लोड करें बटन पर क्लिक करें. प्रॉपर्टी की मौजूदा वैल्यू फ़ॉर्म में लोड होती हैं और सिर्फ़ वे वैल्यू अपडेट की जा सकती हैं जिन्हें आपको बदलना है.