0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

openapi-generatorを用いての自動生成

Posted at

1.目的

 Java Spring BootにてWeb APIを作成する際に、プラグインの「openapi-generatorr」を使用することにより、作成したOpenAPIを元に、Spring BootでRest APIのリクエスト、レスポンスで使用する項目のプロパティを自動生成でき、また、RestAPIのコントローラで使用する呼び出し用のメソッドやレスポンスモデルを自動生成してくれます。
これらについて、記事を残します。

2.環境

   eclipse(Version: 2022-12 (4.26.0))
   java(ver.17)
   spring boot 3.1.1
   Gradle - Groovy

3.手順

(1) 資材をコピーする階層を確認する。

a.png

(2) (1)の階層に、 git(※事前にGitをダウンロードしておく)などを使用して、以下のサイトより資材をコピーする。

https://github.com/OpenAPITools/openapi-generator
b.png

※コピー時は「git clone 【URL】」でダウンロードする。
c.png

(3) コピーできたことを確認する。(openapi-generator)

  ①【clone中】
a.png

  ②【clone後】
image.png

(4) EclipseでJavaのSpring Boot(Gradle)を作成(事前に作っていても問題なし)

またプロジェクト内にOpenApi用のフォルダに対象のOpenAPIを配置する
image.png

【対象のOpenAPI】
image.png

(5) eclipseのプラグイン用のフォルダへ3.でダウンロードしたフォルダを配置(コピー)する。

  ①(コピー先)【C:\pleiades\2022-12\eclipse\plugins】
  ②(コピー元)(1)の階層
  ③【配置時】
d.png

(6) フォルダ名称を「org.openapi.generator」へ変更する(その他のライブラリ名と合わせる)

  ①【コピー後(名称変換前】
image.png

  ②【コピー後(名称変換後】
image.png

(7) eclipseで、「openapi-generator」を表示させる。

  ①「build.gradle」を開く。
image.png

  ② 初期の内容に対して「// 追加」のところを変更する。

build.gradle
plugins {
	id 'java'
	id 'org.springframework.boot' version '3.1.1'
	id 'io.spring.dependency-management' version '1.1.0'
	id "org.openapi.generator" version "6.2.0" // 追加
}

group = 'com.example'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = '17' // 追加

java {
	sourceCompatibility = '17'
}

configurations {
	compileOnly {
		extendsFrom annotationProcessor
	}
}

// 追加 Start
ext {
        // 出力先を設定
        openApiOutputDir = "$rootDir/generated"
}
// 出力したソースをビルドパスに追加
sourceSets.main.java.srcDirs += ["$openApiOutputDir/src/main/java"]
// 追加 End

repositories {
	mavenCentral()
}

dependencies {
	implementation 'org.springframework.boot:spring-boot-starter-web'
// 追加 Start
	// 依存性を追加
	implementation 'org.openapitools:jackson-databind-nullable:0.2.1'
	implementation 'org.springframework.boot:spring-boot-starter-validation'
	implementation group: 'org.springdoc', name: 'springdoc-openapi-ui', version: '1.6.9'
	compileOnly 'io.swagger:swagger-annotations:1.6.2'
// 追加 End
	compileOnly 'org.projectlombok:lombok'
	developmentOnly 'org.springframework.boot:spring-boot-devtools'
	annotationProcessor 'org.projectlombok:lombok'
	testImplementation 'org.springframework.boot:spring-boot-starter-test'
}
// 追加 Start
// (openApiの設定を追加)
openApiGenerate {
        generatorName = 'spring'
        inputSpec = "$rootDir/openapi/shukanTalentJohoBFF.yaml".toString() //対象のOpenAPI
        outputDir = "$openApiOutputDir"
        apiPackage = 'com.api'
        modelPackage = 'com.model'
        invokerPackage = "org.openapi.example.invoker"
        configOptions = [
                dateLibrary: 'java8',
                interfaceOnly: 'true',
                skipDefaultInterface: 'true'
        ]
}
// 追加 End
tasks.named('test') {
	useJUnitPlatform()
}

  ③ 出力先と取込元の設定を行う
   出力先:
image.png

※ 「$rootDir/」は固定で、後ろに作成結果を格納したディレクトリ名を指定する。

   取込元:
image.png

※ 「$rootDir/」は固定で、後ろにシート「事前準備系」②で用意したフォルダ名と今回対象とするOpenAPIのyamlの名称を指定する。

  ④ 再度、eclipseを開きなおし、Gradleタスクの表示の確認をする。
  ⑤ 一覧の「openapi tools」が表示されていることを確認する。
image.png

(8) openApiGenerateの実行

  ① 一覧の「openapi tools」内に、「openApiGenerate」をダブルクリックする。
image.png

  ② コンソールに以下のように表示されれれば、実行は成功(エラーの場合、赤文字のトレース分が表示される)
image.png

  ③ 出力先に以下のように資材が出力されていた場合、問題なし。
image.png

(9) 出力先の確認

 以下の階層でできていることを確認

  ①【ApiUtil.java】
image.png

  ②【ShukanTalentJohoBFFApi.java】(Controllerにおいてのメソッドの定義)
image.png

  ③【ShukanTalentJohoBFF.java】(Responseのモデル定義)
image.png

4.終わりに

この後、Controllerを作る際に、「ShukanTalentJohoBFFApi.java」のメソッドを継承し、
作成することができます。またその中で、「ShukanTalentJohoBFF.java」を参照することでモデルを利用できます。
次回は、「SQLGenerator」について記事を残します。

0
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?