Mysql
 sql >> डेटाबेस >  >> RDS >> Mysql

Google कैलेंडर API:कैलेंडर चुनना/बनाना?

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

यदि आप .NET दस्तावेज़ में जाते हैं तो यह अच्छा नया . का उल्लेख करता है विशेषताएं, विशेष रूप से प्रमाणित उपयोगकर्ताओं के लिए नए गैर-प्राथमिक कैलेंडर कैसे बनाएं और गैर-प्राथमिक कैलेंडर में ईवेंट कैसे जोड़ें।

बेशक, यह दस्तावेज़ीकरण PHP क्षेत्र में कहीं भी दिखाई नहीं देता है, और एक-से-एक सहसंबंध प्रतीत नहीं होता है। नया कैलेंडर बनाने के लिए, मैंने पहले कुछ स्पष्ट चीजों की कोशिश की, फिर, तोड़ने के लिए जा रहा था, कुछ ऐसा करने की कोशिश की जो काम नहीं कर रहा था। मैंने सोचा कि अगर रेडियो चुप्पी का कारण यह है कि कोई भी जवाब नहीं जानता लेकिन निश्चित रूप से जानना चाहता है तो मैं साझा करूंगा।

नया कैलेंडर बनाने के लिए:

इसकी दो चाबियां हैं:

  1. आपको कैलेंडर ईवेंट जोड़ने के लिए उसी विधि का उपयोग करना होगा, जो insertEvent() . है

  2. आपको पोस्ट URL को मेथड में सेट करना होगा, जो अन्यथा डिफ़ॉल्ट फ़ीड URL में चला जाता है।

यह उदाहरण यह देखने के लिए जांचता है कि क्या ऐप कैलेंडर पहले से मौजूद है और यदि नहीं, तो इसे बनाता है:

 //Standard creation of the HTTP client
 $gdataCal = new Zend_Gdata_Calendar($client);

 //Get list of existing calendars
 $calFeed = $gdataCal->getCalendarListFeed();

 //Set this to true by default, only gets set to false if calendar is found
 $noAppCal = true;

 //Loop through calendars and check name which is ->title->text
 foreach ($calFeed as $calendar) {
  if($calendar -> title -> text == "App Calendar") {
   $noAppCal = false;
  }
 }

 //If name not found, create the calendar
 if($noAppCal) {

  // I actually had to guess this method based on Google API's "magic" factory
  $appCal = $gdataCal -> newListEntry();
  // I only set the title, other options like color are available.
  $appCal -> title = $gdataCal-> newTitle("App Calendar"); 

  //This is the right URL to post to for new calendars...
  //Notice that the user's info is nowhere in there
  $own_cal = "http://www.google.com/calendar/feeds/default/owncalendars/full";

  //And here's the payoff. 
  //Use the insertEvent method, set the second optional var to the right URL
  $gdataCal->insertEvent($appCal, $own_cal);
 }

आखिर तुमने इसे हासिल कर ही लिया है। अगला लक्ष्य उस कैलेंडर में ईवेंट सम्मिलित करना है, न कि डिफ़ॉल्ट कैलेंडर में।

गैर-प्राथमिक कैलेंडर में ईवेंट जोड़ना

आप जिस आसान भाग का अनुमान लगा सकते हैं, वह यह है कि आपको उस वैकल्पिक URL को फिर से सेट करने की आवश्यकता है, जैसे:insertEvent($newEvent, $calURL) , मुश्किल हिस्सा कैलेंडर का URL प्राप्त कर रहा है। "स्वामित्व वाले कैलेंडर" पथ के विपरीत, विशिष्ट कैलेंडर में न केवल उपयोगकर्ता-विशिष्ट जानकारी होती है, बल्कि उनमें किसी प्रकार की हैश-लुकिंग आईडी भी होती है।

यह रहा कोड:

 //Set up  that loop again to find the new calendar:
 $calFeed = $gdataCal->getCalendarListFeed();
 foreach ($calFeed as $calendar) {
  if($calendar->title->text == "App Calendar")
   //This is the money, you need to use '->content-src'
   //Anything else and you have to manipulate it to get it right. 
   $appCalUrl = $calendar->content->src;
 }

 //.......... Some Assumed MySQL query and results .............

      while ($event = $result->fetch_assoc()) {
   $title = $event['description'];

   //Quick heads up
   //This is a handy way of getting the date/time in one expression.
   $eventStart = date('Y-m-d\TH:i:sP', strtotime($event['start']));
   $eventEnd = date('Y-m-d\TH:i:sP', strtotime($event['end']));

   $newEvent = $gdataCal->newEventEntry();
   $newEvent->title = $gdataCal->newTitle($title);
   $when = $gdataCal->newWhen();
   $when->startTime = $eventStart;
   $when->endTime = $eventEnd;

   $newEvent->when = array($when);

   //And at last, the insert is set to the calendar URL found above
   $createdEvent = $gdataCal->insertEvent($newEvent, $appCalUrl);
  }
  echo "<p>".$result->num_rows." added to your Google calendar.</p>";

मेरे प्रश्न को पढ़ने वाले और इस पर कोई विचार करने वाले किसी भी व्यक्ति के लिए धन्यवाद। अगर किसी को उपरोक्त कोड को कसने के तरीके के बारे में पता है (शायद मुझे दो लूप की आवश्यकता नहीं है?) मुझे फीडबैक प्राप्त करना अच्छा लगेगा।



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. एकाधिक डीबी कॉलम अनुक्रमणित करने की लागत क्या है?

  2. किसी अन्य तालिका के पंक्ति मानों से प्राप्त स्तंभ नामों वाली तालिका बनाएं

  3. MySql एक साथ दो टेबल अपडेट करें

  4. कई कॉलम में MySQL COUNT ()

  5. MySQL डिग्री, मिनट, सेकंड को डिग्री दशमलव में बदलें