mirror of
https://github.com/OpenAPITools/openapi-generator.git
synced 2025-10-15 17:03:43 +00:00
* Correctly apply Gradle task input & output annotations to accessors Gradle's task input and output annotations should be applied to the accessors instead of the properties. No adhering to this can cause funky behavior in the generated stubs. Examples of this can be found in the docs: https://docs.gradle.org/current/userguide/implementing_custom_tasks.html Also adds missing annotations so that validation passes * Enable strict Gradle plugin validation
170 lines
5.9 KiB
Groovy
170 lines
5.9 KiB
Groovy
import io.github.gradlenexus.publishplugin.CloseNexusStagingRepository
|
|
import io.github.gradlenexus.publishplugin.ReleaseNexusStagingRepository
|
|
import org.jetbrains.kotlin.gradle.tasks.KotlinCompile
|
|
|
|
plugins {
|
|
id("com.gradle.plugin-publish") version "1.1.0"
|
|
id("io.github.gradle-nexus.publish-plugin") version "1.1.0"
|
|
id("java-gradle-plugin")
|
|
id("maven-publish")
|
|
id("org.gradle.kotlin.kotlin-dsl") version "2.4.1"
|
|
id("org.jetbrains.kotlin.jvm") version "1.9.0"
|
|
id("signing")
|
|
}
|
|
|
|
group = "org.openapitools"
|
|
version = "$openApiGeneratorVersion"
|
|
ext.isReleaseVersion = !version.endsWith("SNAPSHOT")
|
|
|
|
description = """
|
|
This plugin supports common functionality found in Open API Generator CLI as a Gradle plugin.
|
|
|
|
This gives you the ability to generate client SDKs, documentation, new generators, and to validate Open API 2.0 and 3.x
|
|
specifications as part of your build. Other tasks are available as command line tasks.
|
|
"""
|
|
|
|
java {
|
|
withSourcesJar()
|
|
withJavadocJar()
|
|
sourceCompatibility = JavaVersion.VERSION_11
|
|
targetCompatibility = JavaVersion.VERSION_11
|
|
}
|
|
|
|
repositories {
|
|
mavenLocal()
|
|
mavenCentral()
|
|
maven {
|
|
name = "Sonatype Snapshots"
|
|
url "https://oss.sonatype.org/content/repositories/snapshots/"
|
|
}
|
|
}
|
|
|
|
dependencies {
|
|
implementation("org.openapitools:openapi-generator:$openApiGeneratorVersion")
|
|
testImplementation("org.jetbrains.kotlin:kotlin-test-testng:1.9.0")
|
|
}
|
|
|
|
tasks.named("test", Test).configure {
|
|
useTestNG()
|
|
testLogging.showStandardStreams = false
|
|
|
|
beforeTest { descriptor ->
|
|
logger.lifecycle("Running test: " + descriptor)
|
|
}
|
|
|
|
onOutput { descriptor, event ->
|
|
// SLF4J may complain about multiple bindings depending on how this is run.
|
|
// This is just a warning, but can make test output less readable. So we ignore it specifically.
|
|
if (!event.message.contains("SLF4J:")) {
|
|
logger.lifecycle("Test: " + descriptor + " produced standard out/err: " + event.message)
|
|
}
|
|
}
|
|
}
|
|
|
|
tasks.withType(KotlinCompile).configureEach {
|
|
kotlinOptions {
|
|
jvmTarget = "11"
|
|
}
|
|
}
|
|
|
|
tasks.withType(Javadoc).configureEach {
|
|
if (JavaVersion.current().isJava9Compatible()) {
|
|
options.addBooleanOption("html5", true)
|
|
}
|
|
}
|
|
|
|
tasks.withType(CloseNexusStagingRepository).configureEach {
|
|
onlyIf { nexusPublishing.useStaging.get() }
|
|
}
|
|
|
|
tasks.withType(ReleaseNexusStagingRepository).configureEach {
|
|
onlyIf { nexusPublishing.useStaging.get() }
|
|
}
|
|
|
|
tasks.named("validatePlugins").configure {
|
|
enableStricterValidation = true
|
|
}
|
|
|
|
gradlePlugin {
|
|
website = "https://openapi-generator.tech/"
|
|
vcsUrl = "https://github.com/OpenAPITools/openapi-generator"
|
|
plugins {
|
|
openApiGenerator {
|
|
id = "org.openapi.generator"
|
|
description = "OpenAPI Generator allows generation of API client libraries (SDK generation), server stubs, documentation and configuration automatically given an OpenAPI Spec (v2, v3)."
|
|
displayName = "OpenAPI Generator Gradle Plugin"
|
|
implementationClass = "org.openapitools.generator.gradle.plugin.OpenApiGeneratorPlugin"
|
|
tags.addAll("openapi-3.0", "openapi-2.0", "openapi", "swagger", "codegen", "sdk")
|
|
}
|
|
}
|
|
}
|
|
|
|
nexusPublishing {
|
|
repositories {
|
|
sonatype {
|
|
username = project.properties["ossrhUsername"]
|
|
password = project.properties["ossrhPassword"]
|
|
|
|
// To retrieve: ./gradlew -Psigning.keyId="$SIGNING_KEY" -Psigning.password="$SIGNING_PASSPHRASE" -Psigning.secretKeyRingFile="$SIGNING_SECRET" getStagingProfile
|
|
stagingProfileId = "456297f829bbbe"
|
|
}
|
|
}
|
|
}
|
|
|
|
// Signing requires three keys to be defined: signing.keyId, signing.password, and signing.secretKeyRingFile.
|
|
// These can be passed to the Gradle command:
|
|
// ./gradlew -Psigning.keyId=yourid
|
|
// or stored as key=value pairs in ~/.gradle/gradle.properties
|
|
// You can also apply them in CI via environment variables. See Gradle's docs for details.
|
|
signing {
|
|
required { isReleaseVersion && gradle.taskGraph.hasTask("publishPluginMavenPublicationToSonatypeRepository") }
|
|
sign(publishing.publications)
|
|
}
|
|
|
|
// afterEvaluate is necessary because java-gradle-plugin
|
|
// creates its publications in an afterEvaluate callback
|
|
afterEvaluate {
|
|
tasks.named("publishToSonatype").configure {
|
|
dependsOn("check")
|
|
}
|
|
|
|
publishing {
|
|
publications {
|
|
pluginMaven {
|
|
pom {
|
|
name = "OpenAPI-Generator Contributors"
|
|
description = project.description
|
|
url = "https://openapi-generator.tech"
|
|
organization {
|
|
name = "org.openapitools"
|
|
url = "https://github.com/OpenAPITools"
|
|
}
|
|
licenses {
|
|
license {
|
|
name = "The Apache Software License, Version 2.0"
|
|
url = "https://www.apache.org/licenses/LICENSE-2.0.txt"
|
|
distribution = "repo"
|
|
}
|
|
}
|
|
developers {
|
|
developer {
|
|
id = "openapitools"
|
|
name = "OpenAPI-Generator Contributors"
|
|
email = "team@openapitools.org"
|
|
}
|
|
}
|
|
scm {
|
|
url = "https://github.com/OpenAPITools/openapi-generator"
|
|
connection = "scm:git:git://github.com/OpenAPITools/openapi-generator.git"
|
|
developerConnection = "scm:git:ssh://git@github.com:OpenAPITools/openapi-generator.git"
|
|
}
|
|
issueManagement {
|
|
system = "GitHub"
|
|
url = "https://github.com/OpenAPITools/openapi-generator/issues"
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|