REST API をドキュメント化したことがある人なら誰でも、これらのリソース、パス、リクエスト、スキーマをすべて備えた YAML ファイル全体を記述することがどのような感じかを知っていますが、突然、ファイルの最終行の長さは 5 桁です。はい、痛いです
最高のアプリケーションは自分たちで構築したものであるため、私は仕事で API を文書化しているまさに同じ場所にいて、この問題に対する実行可能な解決策が 1 つも見つからないために何度も検索しました。そこでプログラマーの本能が活きてきます。そして私たちは、自分たちのための新しいツールを構築するのに予定されていた時間の 5 倍の時間を費やしています。それがまさに私がやったことであり、OpenAPI 仕様として使用するために YAML ファイルを 1 つの Boss ファイルにマージする、Go で書かれた新しいツールを皆さんと共有したいと思います。
GOpenAPI の紹介
GOpenAPI (Golang OpenAPI) は、dirs.json というファイルを使用して、実行の最後にファイルとディレクトリ (yaml に相当するディレクトリ全体) を 1 つの swagger.yaml ファイルにスキャンするツールです。
ここでソースコードを確認できます。このリポジトリは、このツールを使用して最初の OpenAPI 仕様を作成するためのクローンを作成してドラフトとして使用できるテンプレートでもあることに注意してください (go install でインストールしたくない場合は、必ず gopenapi フォルダーを保持してください。そうでない場合は、完全にインストールされます)取り外し可能)
それはどのように機能しますか (そして、私はそれを機能させることができますか)
簡単です。gopenapi を実行すると、dirs.json ファイルが読み取られ、そこで宣言されているすべてのファイルとフォルダーを使用して OpenAPI 仕様の構築が開始されます。 dirs.json は、情報、サーバー、セキュリティなどの一意のキーのファイルと、テンプレートと呼ばれるキー (単なる空の OpenAPI yaml ファイル) を使用することに注意してください
単一のファイルに保持するのが難しいリソースとキー (パス、スキーマ、リクエストなど) はフォルダーに保存でき、それらはすべて OpenAPI で共通の #ref タグを使用して言及することもできます。マージ後は同じファイルに移動します。
このプロジェクトには、静的に提供できる Index.html も付属しており、dist フォルダー内に含まれる Swagger UI 公式バンドルとも対話します。
以上です、皆さん
(私と同じように) Reddit や github リポジトリをたくさん検索しても探していたツールが見つからなかった人のために、このツールが登場することを願っています。さて、あなたはそれを手に入れました、そしてそれは完全にオープンソースです。つまり、解決できる改善点や問題が見つかった場合は、私はあなたと協力して解決する前に躊躇しません。また、私は golang に関してはかなり初心者なので、このプロジェクトには改善すべき点がたくさんあるかもしれません。私はそれを最新の状態に保ち、常に改善するよう努めます (私もこれからよく使うので)
読んでいただきありがとうございます。私と同じように、この記事があなたにも役立つことを願っています ;)
以上が複数の YAML ファイルを含むオープン API 仕様の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、プロファイリングの有効化、データの収集、CPUやメモリの問題などの一般的なボトルネックの識別など、GOパフォーマンスを分析するためにPPROFツールを使用する方法について説明します。

この記事では、GOでユニットテストを書くことで、ベストプラクティス、モッキングテクニック、効率的なテスト管理のためのツールについて説明します。

この記事では、ユニットテストのためにGOのモックとスタブを作成することを示しています。 インターフェイスの使用を強調し、模擬実装の例を提供し、模擬フォーカスを維持し、アサーションライブラリを使用するなどのベストプラクティスについて説明します。 articl

この記事では、GENICSのGOのカスタムタイプの制約について説明します。 インターフェイスがジェネリック関数の最小タイプ要件をどのように定義するかを詳しく説明し、タイプの安全性とコードの再利用性を改善します。 この記事では、制限とベストプラクティスについても説明しています

この記事では、コードのランタイム操作に使用されるGoの反射パッケージについて説明します。シリアル化、一般的なプログラミングなどに有益です。実行やメモリの使用量の増加、賢明な使用と最高のアドバイスなどのパフォーマンスコストについて警告します

この記事では、トレースツールを使用してGOアプリケーションの実行フローを分析します。 手動および自動計装技術について説明し、Jaeger、Zipkin、Opentelemetryなどのツールを比較し、効果的なデータの視覚化を強調しています

この記事では、GOでテーブル駆動型のテストを使用して説明します。これは、テストのテーブルを使用して複数の入力と結果を持つ関数をテストする方法です。読みやすさの向上、重複の減少、スケーラビリティ、一貫性、および

この記事では、go.modを介してGOモジュールの依存関係の管理、仕様、更新、競合解決をカバーすることについて説明します。セマンティックバージョンや定期的な更新などのベストプラクティスを強調しています。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

ホットトピック









