सामग्री पर जाएं

tsoa-next / tsoa-next

tsoa-next logotsoa-next

ऐसा प्रतीत होता है

OpenAPIREST एपीआई TypeScript और Node

build statusnpm versionQuality Gate Status

परियोजना की पृष्ठभूमि

tsoa-next मूल जारी tsoa परियोजना मूल भंडार और इसके योगदानकर्ताओं ने स्थिर स्थापित किया TypeScriptसबसे पहले और OpenAPI-पहली नींव इस काम पर बना हुआ है। जहां ऐतिहासिक रिलीज नोट्स या माइग्रेशन संदर्भ अभी भी अपस्ट्रीम इंगित करते हैं, उन्हें जानबूझकर साबित होने के लिए रखा जाता है।

लक्ष्य

  • TypeScript अपने एपीआई के लिए सत्य के एकल स्रोत के रूप में नियंत्रक और मॉडल
  • मान्य OpenAPI (formerly) Swagger2.0, 3.0, या 3.1 spec आपके नियंत्रकों और मॉडलों से उत्पन्न होता है, जिनमें शामिल हैं:
    • पथ (उदाहरण के लिए गेट / उपयोगकर्ता)
    • परिभाषाओं पर आधारित TypeScript इंटरफेस (मॉडल)
    • पैरामीटर / मॉडल गुण आवश्यकतानुसार या वैकल्पिक के आधार पर चिह्नित TypeScript (जैसे myProperty) स्ट्रिंग में वैकल्पिक है OpenAPI कल्पना)
    • ऑब्जेक्ट विवरण के लिए समर्थित jsDoc (अधिकांश अन्य मेटाडाटा से प्रभावित किया जा सकता है) TypeScript प्रकार)
  • विकल्प के मध्यवेयर के लिए रूट उत्पन्न होते हैं
    • Express, Hapi, और Koa वर्तमान में समर्थित, अन्य मिडलवेयर को एक सरल हैंडलबार टेम्पलेट का उपयोग करके समर्थित किया जा सकता है
    • मान्य अनुरोध पेलोड

दर्शन

  • पर भरोसा TypeScript यदि संभव हो तो एपीआई मेटाडाटा उत्पन्न करने के लिए टाइप एनोटेशन
  • यदि नियमित प्रकार के एनोटेशन मेटाडाटा को व्यक्त करने का उचित तरीका नहीं है, तो डेकोरेटर का उपयोग करें
  • शुद्ध पाठ मेटाडाटा (उदाहरण के लिए समापन बिंदु विवरण) के लिए jsdoc का उपयोग करें
  • बॉयलरप्लेट को छोटा करें
  • मॉडल इंटरफेस (शुद्ध डेटा संरचनाओं) द्वारा सबसे अच्छा प्रतिनिधित्व किया जाता है, लेकिन यह भी वर्गों द्वारा प्रतिनिधित्व किया जा सकता है
  • रनटाइम वैधता tsoa-next जितना संभव हो सके उतना ही व्यवहार करना चाहिए OpenAPI स्कीमा वर्णन करता है। सत्यापन तर्क में किसी भी अंतर को लॉगिंग चेतावनी द्वारा स्पष्ट किया जाता है, जिसके दौरान OpenAPI विशिष्टता (ओएएस) और/या मार्ग।
    • कृपया ध्यान दें कि सक्षम करके OpenAPI 3.0 या 3.1 आप विचलन सत्यापन तर्क की संभावनाओं को कम करते हैं क्योंकि नए स्कीमा आकार अधिक स्पष्ट हैं OpenAPI 2.0।

सुविधाओं की सूची

  • उत्पन्न करना OpenAPI सीधे अपने से 2.0, 3.0 या 3.1 दस्तावेज़ TypeScript नियंत्रक, मॉडल और JSDoc टिप्पणी।
  • इलाज TypeScript पथ, पैरामीटर, स्कीमा, उदाहरण, टैग और सुरक्षा मेटाडाटा के लिए सत्य के स्रोत के रूप में नियंत्रक और मॉडल।
  • फ्रेमवर्क-विशिष्ट मार्ग हैंडलर उत्पन्न करने के लिए Express, Koa, और Hapi, या अपने आप की आपूर्ति Handlebars कस्टम रनटाइम्स के लिए टेम्पलेट।
  • कॉन्फ़िगर करने योग्य coercion और अतिरिक्त-property हैंडलिंग के साथ रनटाइम पर अनुरोध इनपुट को मान्य करें जो उत्पन्न स्कीमा के साथ संरेखित रहता है।
  • एक्सपोजर कंट्रोलर-लोकल स्पेक एंडपॉइंट्स के साथ @SpecPath(...) अनुरोध समय पर स्थानीय डिस्क से उत्पन्न स्पेक फ़ाइल को पढ़ने के बिना।
  • सेवा में निर्मित json, yaml, swagger, redoc, और rapidoc कल्पना लक्ष्य, डॉक्स यूआई पैकेज के साथ उपलब्ध होने पर लाज़ीली को वैकल्पिक साथियों के रूप में लोड किया गया।
  • एकाधिक संलग्न करें @SpecPath(...) जब तक उनके हल पथ अद्वितीय हैं तब तक एक ही नियंत्रक के लिए सजावटकर्ता।
  • कैश में निर्मित या कस्टम स्पेक प्रतिक्रियाओं के साथ 'none', इन-प्रोसेस 'memory', या एक कस्टम कैश हैंडलर जो स्ट्रिंग्स या स्ट्रीम्स से पढ़ सकते हैं।
  • वापसी string या Readable कस्टम से जवाब @SpecPath(...) बेस्पोक प्रलेखन या डाउनस्ट्रीम एकीकरण के लिए हैंडलर।
  • उपयोग @Validate(...) बाहरी स्कीमा पुस्तकालयों जैसे समर्थित रनटाइम सत्यापन को प्रतिनिधि करने के लिए zod, joi, yup, superstructया io-ts
  • उत्पन्न द्वारा स्वीकार किए गए वैकल्पिक सत्यापन संदर्भ के माध्यम से सत्यापन अनुवाद और विफलता स्वरूपण को अनुकूलित करें RegisterRoutes(...) कार्य।
  • समर्थन प्रमाणीकरण हुक, निर्भरता इंजेक्शन, टाइपिंग वैकल्पिक उत्तरदाताओं, फ़ाइल अपलोड, कस्टम मिडलवेयर, और कस्टम सत्यापन कार्यप्रवाह।
  • उपयोग tsoa CLI कल्पना और मार्ग पीढ़ी के लिए, या प्रोग्रामेटिक एपीआई को प्रोग्रामेटिक एपीआई से कॉल करें tsoa-next/cli
  • लक्ष्य आधुनिक Node.js पिछले एलटीएस, वर्तमान एलटीएस में सीआई में सत्यापित समर्थन नीति के साथ जारी Node v next.

शुरुआत करें

पैकेज API

  • आयात सजावटकर्ता, रनटाइम सहायक, और उत्पन्न मार्ग समर्थन से tsoa-next
  • से प्रोग्रामेटिक पीढ़ी एपीआई आयात करें tsoa-next/cli
  • उपयोग tsoa के लिए द्विआधारी CLI पीढ़ी के आदेश

उदाहरण

मार्गदर्शिकाएँ देखें

चलाने योग्य उदाहरण ऐप्स और सर्वर-केंद्रित परिदृश्यों के लिए सहायक playground रिपॉज़िटरी का उपयोग करें।

उदाहरण नियंत्रक परीक्षण में देखें

उदाहरण मॉडल परीक्षण में देखें

मदद चाहिए

कोड में योगदान

योगदान करने के लिए (PR के माध्यम से), पहले योगदान मार्गदर्शिका देखें

Namespace

Classes

इंटरफेस

प्रकार उपनाम

कार्य

Contributors

No contributors

Changelog

No recent changes

TypeScript-प्रथम OpenAPI जनरेशन, रूट जनरेशन और रनटाइम वैलिडेशन।