इस पेज पर, GTFS-टिकट की सुविधा के निर्देशों के सबसेट के बारे में बताया गया है. इस दस्तावेज़ को बनाते समय, यह सुझाव के तौर पर दिया गया है. इस पेज पर, Google की ओर से लगाई गई कई और पाबंदियां भी शामिल हैं.
ज़रूरी शर्तें
stop_times.txt में departure_time फ़ील्ड ज़रूरी है.
अन्य फ़ील्ड टाइप
इस सेक्शन में, अन्य फ़ील्ड टाइप और Google के एक्सटेंशन के बारे में बताया गया है. कुछ फ़ील्ड में यूआरआई के तौर पर वैल्यू डालनी होती हैं.
- यूआरआई: पूरी तरह से क्वालिफ़ाइड यूनिफ़ॉर्म रिसॉर्स आइडेंटिफ़ायर (यूआरआई), जिसमें स्कीम शामिल है. यूआरआई में मौजूद किसी भी खास वर्ण के लिए, सही एस्केप का इस्तेमाल किया गया हो. पूरी तरह से क्वालिफ़ाइड यूआरआई वैल्यू बनाने का तरीका जानने के लिए, आरएफ़सी 3986 यूनिफ़ॉर्म रिसॉर्स आइडेंटिफ़ायर (यूआरआई): सामान्य सिंटैक्स देखें.
फ़ाइल एक्सटेंशन या अन्य चीज़ें जोड़ना
एक्सटेंशन स्टेटस वाली टेक्स्ट फ़ाइलें, पहले से मौजूद फ़ाइलें होती हैं. इन्हें एक्सटेंशन देना होता है. आपको नीचे दी गई टेबल में बताए गए नए फ़ील्ड जोड़ने होंगे.
जोड़ी गई स्थिति वाली टेक्स्ट फ़ाइलें, Google Transit के टिकट बेचने की सुविधा के एक्सटेंशन की नई फ़ाइलें हैं. आपको ये फ़ाइलें, नीचे दी गई टेबल के बाद दी गई फ़ील्ड की परिभाषाओं के मुताबिक बनानी होंगी. अपने फ़ीड में ये फ़ाइलें ज़रूर शामिल करें.
| फ़ाइल का नाम | स्थिति | बताता है |
|---|---|---|
agency.txt |
Extension | agency.ticketing_deep_link_id जोड़ता है. |
routes.txt |
Extension | routes.ticketing_deep_link_id जोड़ता है. |
trips.txt |
Extension | इसमें trips.ticketing_trip_id और trips.ticketing_type जोड़े जाते हैं. |
stop_times.txt |
Extension | stop_times.ticketing_type जोड़ता है. |
ticketing_identifiers.txt |
जोड़ | नई फ़ाइल. ज़्यादा जानकारी के लिए, फ़ील्ड की परिभाषाएं देखें. |
ticketing_deep_links.txt |
जोड़ | नई फ़ाइल. ज़्यादा जानकारी के लिए, फ़ील्ड की परिभाषाएं देखें. |
फ़ील्ड के मतलब
agency.txt (फ़ाइल एक्सटेंड की गई)
| फ़ील्ड का नाम | मौजूदगी | विवरण |
|---|---|---|
ticketing_deep_link_id |
वैकल्पिक |
( |
routes.txt (फ़ाइल एक्सटेंड की गई)
| फ़ील्ड का नाम | मौजूदगी | विवरण |
|---|---|---|
ticketing_deep_link_id |
वैकल्पिक | (ticketing_deep_links.txt का आईडी) इस रूट के लिए इस्तेमाल किए जाने वाले डीप लिंक के बारे में
बताता है. इस पैरामीटर के मौजूद होने पर, agency.txt में मौजूद फ़ील्ड को बदल दिया जाता है. |
trips.txt (फ़ाइल एक्सटेंड की गई)
| फ़ील्ड का नाम | मौजूदगी | विवरण |
|---|---|---|
ticketing_trip_id |
वैकल्पिक |
(आईडी) डीप लिंक में पास करने के लिए आइडेंटिफ़ायर. यह यूनीक होनी ज़रूरी नहीं है. अगर |
ticketing_type |
वैकल्पिक |
(Enum) तय करें कि इस यात्रा के लिए, डीप लिंक की मदद से टिकट बुक करने की सुविधा उपलब्ध है या नहीं:
|
stop_times.txt (फ़ाइल एक्सटेंड की गई)
| फ़ील्ड का नाम | मौजूदगी | विवरण |
|---|---|---|
ticketing_type |
वैकल्पिक |
(Enum) इससे यह तय होता है कि इस स्टॉप के समय के लिए, डीप लिंक की मदद से टिकट बुक करने की सुविधा उपलब्ध है या नहीं. अगर आपने
|
ticketing_identifiers.txt (फ़ाइल जोड़ी गई)
टिकट बेचने के लिए, आम तौर पर हर स्टॉप के लिए बिलिंग प्रोसेस करने वाला आइडेंटिफ़ायर होता है. अलग-अलग एजेंसियां, किसी भी स्टॉप के लिए एक ही आइडेंटिफ़ायर का इस्तेमाल कर सकती हैं. जब एक से ज़्यादा एजेंसियां एक ही स्टॉप पर सेवा देती हैं, तो हर एजेंसी के लिए यह मैपिंग दोहराएं.
| फ़ील्ड का नाम | मौजूदगी | विवरण |
|---|---|---|
ticketing_stop_id |
ज़रूरी है | (आईडी) इस एजेंसी के लिए, इस स्टॉप का डिफ़ॉल्ट टिकट आईडी तय करता है. |
stop_id |
ज़रूरी है | (stops.txt से मिला आईडी) वह स्टॉप जिसके लिए डिफ़ॉल्ट
ticketing_stop_id तय किया गया है. |
agency_id |
ज़रूरी है | (agency.txt से मिला आईडी) उस स्टॉप की एजेंसी जिसके लिए डिफ़ॉल्ट
ticketing_stop_id तय किया गया है. |
ticketing_deep_links.txt (फ़ाइल जोड़ी गई)
| फ़ील्ड का नाम | मौजूदगी | विवरण |
|---|---|---|
ticketing_deep_link_id |
ज़रूरी है | (आईडी) डीप लिंक के लिए आईडी तय करता है. |
web_url |
वैकल्पिक |
(यूआरएल) डीप लिंक करने के लिए विज़िट किया जाने वाला यूआरएल. इस फ़ील्ड का अनुवाद |
android_intent_uri |
वैकल्पिक |
(यूआरआई) अगर यह फ़ील्ड खाली है, तो इसका मतलब है कि किसी नेटिव Android ऐप्लिकेशन को डीप लिंक नहीं किया जा सकता. Android पर डीप लिंक के बारे में ज़्यादा जानने के लिए, ऐप्लिकेशन के कॉन्टेंट के लिए डीप लिंक बनाएं लेख पढ़ें. इस फ़ील्ड का अनुवाद |
ios_universal_link_url |
वैकल्पिक |
(यूआरएल) iOS पर ट्रिगर करने के लिए यूनिवर्सल लिंक का यूआरएल. अगर यह फ़ील्ड खाली है, तो iOS पर डीप लिंकिंग की सुविधा नहीं दिखती. ज़्यादा जानकारी के लिए, iOS पर यूनिवर्सल लिंक देखें. इस फ़ील्ड का अनुवाद, |
एपीआई कॉल में फ़ील्ड प्लेसहोल्डर
Google, ticketing_deep_links.txt में बताए गए यूआरएल को इन
पैरामीटर के साथ कॉल करता है:
| फ़ील्ड का नाम | विवरण |
|---|---|
service_date |
(तारीख, दोहराया जा सकता है) यात्रा के दौरान सर्विस का दिन. इस फ़ील्ड का इस्तेमाल, यात्रा के पहले स्टॉप से निकलने की तारीख के लिए करें. यह फ़ील्ड, JSON कलेक्शन के तौर पर फ़ॉर्मैट होता है. |
ticketing_trip_id |
( यह फ़ील्ड, JSON कलेक्शन के तौर पर फ़ॉर्मैट होता है. |
from_ticketing_stop_time_id |
(दोहराया जा सकता है) उस किसी स्टॉप पर बस के रुकने के समय की वैल्यू इस तरह की होती है:
यह फ़ील्ड, JSON कलेक्शन के तौर पर फ़ॉर्मैट होता है. |
|
(दोहराया जा सकता है) उस वैल्यू का हिसाब लगाने के बारे में जानने के लिए, यह फ़ील्ड, JSON कलेक्शन के तौर पर फ़ॉर्मैट होता है. |
boarding_time |
(ISO 8601, दोहराया जा सकता है) इस फ़ील्ड का इस्तेमाल, यात्री के वाहन में बैठने की तारीख और समय की जानकारी देने के लिए करें. इस फ़ील्ड में समय की वैल्यू, ISO 8601 के मुताबिक होनी चाहिए. साथ ही, यह वैल्यू इस स्ट्रिंग फ़ॉर्मैट में होनी चाहिए:
यहां दिए गए सभी समय एक ही हैं, लेकिन अलग-अलग टाइम ज़ोन में:
यह फ़ील्ड, JSON कलेक्शन के तौर पर फ़ॉर्मैट होता है. |
arrival_time |
(ISO 8601, दोहराया जा सकता है) पहुंचने का समय, stop_time पर arrival_time, जहां लेग खत्म होता है. इस फ़ील्ड में समय की वैल्यू, ISO 8601 के मुताबिक होनी चाहिए. इसके लिए, स्ट्रिंग का यह फ़ॉर्मैट इस्तेमाल करें:
यहां दिए गए सभी समय एक ही हैं, लेकिन अलग-अलग टाइम ज़ोन में:
यह फ़ील्ड, JSON कलेक्शन के तौर पर फ़ॉर्मैट होता है. |
उदाहरण
इस उदाहरण में, यात्री की यात्रा के चरण इस तरह हैं:
- सेवा की तारीख
20190716को, ट्रिप टिकट आईडीti1, स्टॉप समय टिकट आईडी11से स्टॉप समय टिकट आईडी12तक शुरू होता है. यात्री, यूटीसी के मुताबिक दोपहर 2:00 बजे फ़्लाइट में चढ़ता है और दोपहर 2:50 बजे पहुंचता है. - सेवा की तारीख
20190716को, ट्रिप टिकट आईडीti2, स्टॉप समय टिकट आईडी21से स्टॉप समय टिकट आईडी22तक शुरू होता है. यात्री, यूटीसी समय के मुताबिक दोपहर 3:00 बजे फ़्लाइट में चढ़ता है और दोपहर 3:50 बजे पहुंचता है.
इस उदाहरण के लिए, web_url https://examplepetstore.com है.
इस पूरी जानकारी के आधार पर, इस ट्रिप के लिए फ़ीड के पैरामीटर की इन वैल्यू का इस्तेमाल करें:
| फ़ील्ड का नाम | विवरण |
|---|---|
service_date |
["20190716", "20190716"] |
ticketing_trip_id |
["ti1", "ti2"] |
from_ticketing_stop_time_id |
["11", "21"] |
to_ticketing_stop_time_id |
["12", "22"] |
boarding_time |
["2019-07-16T14:00:00+00:00", "2019-07-16T15:00:00+00:00"] |
arrival_time |
["2019-07-16T14:50:00+00:00", "2019-07-16T15:50:00+00:00"] |
एन्कोड करने के बाद, फ़ाइनल यूआरएल यह होगा:
https://examplepetstore.com?service_date=%5B%2220190716%22,%2220190716%22%5D
&ticketing_trip_id=%5B%22ti1%22,%22ti2%22%5D&from_ticketing_stop_time_id=%5B%2211%22,%2221%22%5D
&to_ticketing_stop_time_id=%5B%2212%22,%2222%22%5D&boarding_time=%5B%222019-07-16T14:00:00%2B00:00
%22,%222019-07-16T15:00:00%2B00:00%22%5D&arrival_time=%5B%222019-07-16T14:50:00%2B00:00 %22,%222019-07-16T15:50:00%2B00:00%22%5D
ticketing_stop_id की अलग-अलग वैल्यू के उदाहरण
ticketing_identifiers.txt फ़ील्ड की मदद से टिकट बेचने के लिए, स्टॉप के अलग-अलग आईडी हो सकते हैं. बोल्ड में दी गई वैल्यू, फ़ाइलों के बाद बताए गए वेब कॉल में मिलती हैं.
stop.txt |
|---|
|
|
routes.txt |
|---|
|
|
trips.txt |
|---|
|
ti1,everyday,ri1,"TGV INOUI 6603",FR_SNCF_6603 ti2,everyday,ri1,"TGV INOUI 6681",FR_SNCF_6681 ti3,everyday,ri1,"TGV INOUI 6607",FR_SNCF_6607 |
stop_times.txt |
|---|
|
ti1,1,si1,06:59:00,06:59:00 ti1,2,si2,08:56:00,08:56:00 ti2,1,si1,07:53:00,07:53:00 ti2,2,si2,10:00:00,10:00:00 ti3,1,si1,08:59:00,08:59:00 ti3,2,si2,10:56:00,10:56:00 |
ticketing_identifiers.txt |
|---|
|
si1,agency1,4924 si2,agency1,4676 |
ticketing_deep_links.txt |
|---|
|
tdl1, https://examplepetstore.com/api/gtfs/web, https://examplepetstore.com/api/gtfs/android, https://examplepetstore.com/api/gtfs/ios |
अगर अनुरोध 19-07-2019 को किया गया है और GTFS के समय, यूटीसी+1 टाइम ज़ोन में हैं, तो वेब के लिए कॉल इस तरह का होगा:
https://examplepetstore.com/api/gtfs/web?service_date=%5B%2220190719%22%5D&ticketing_trip_id=
%5B%22FR_SNCF_6603%22%5D&from_ticketing_stop_time_id=%5B%224924%22%5D&to_ticketing_stop_time_id=
%5B%224676%22%5D&boarding_time=%5B%222019-07-19T05:59:00%2B00:00%22%5&arrival_time=%5B%222019-07-19T07:56:00%2B00:00%22%5D
सुझाए गए तरीके
Google Transit के टिकट बेचने वाले एक्सटेंशन लागू करने के लिए, इन सुझावों का पालन करें:
| दिशा-निर्देश | |
|---|---|
| जब भी हो सके, एजेंसियों या रास्तों के बीच डीप लिंक शेयर करें. |
स्टैटिक फ़ीड में, जब भी एक से ज़्यादा एजेंसियों या रूट के एक जैसे डीप लिंक यूआरएल होते हैं, तो
उन्हें |
ticketing_type के लिए एक जैसी वैल्यू सेट करें. |
किसी स्टॉप के लिए |
पेरेंट और चाइल्ड स्टॉप, दोनों के लिए ticketing_stop_id का मैप. |
उन सभी पैरंट और चाइल्ड स्टॉप के लिए मैपिंग करें जिनके लिए टिकट की ज़रूरत होती है. ticketing_identifiers.txt फ़ाइल में, ticketing_stop_id वैल्यू, पेरंट स्टॉप और उसके चाइल्ड स्टॉप के बीच प्रोपेगेट नहीं होती हैं. |
फ़ीड में एक ही स्टॉप का इस्तेमाल करने वाली हर एजेंसी के लिए ticketing_stop_id को मैप करें. |
स्टैटिक फ़ीड में, अगर टिकट की सुविधा देने वाली एक से ज़्यादा एजेंसियां एक ही स्टॉप को शेयर करती हैं, तो हर एजेंसी के लिए मैपिंग मौजूद होनी चाहिए. ज़्यादा जानकारी के लिए, |
| जब किसी Android ऐप्लिकेशन के लिए डीप लिंक की ज़रूरत हो, तो Android ऐप्लिकेशन के लिंक का इस्तेमाल करें. |
अगर पार्टनर को डीप लिंक से कोई Android ऐप्लिकेशन खोलना है, तो डीप लिंक को Android ऐप्लिकेशन लिंक के तौर पर सेट अप करें. |
| iOS ऐप्लिकेशन के लिए डीप लिंक की ज़रूरत होने पर, iOS यूनिवर्सल लिंक का इस्तेमाल करें. | अगर पार्टनर को डीप लिंक से iOS ऐप्लिकेशन खोलना है, तो डीप लिंक को iOS यूनिवर्सल लिंक के तौर पर सेट अप करें. |