KloudflareApi/build.gradle.kts

285 lines
7.7 KiB
Plaintext
Raw Normal View History

2019-06-24 16:42:03 +02:00
import java.time.Instant
println("\tGradle ${project.gradle.gradleVersion}")
plugins {
java
2019-07-28 16:37:56 +02:00
signing
`maven-publish`
// publish on sonatype
id("de.marcphilipp.nexus-publish") version "0.2.0"
// close and release on sonatype
id("io.codearte.nexus-staging") version "0.21.0"
2019-06-24 16:42:03 +02:00
id("com.dorkbox.Licensing") version "1.4"
2019-07-28 16:37:56 +02:00
id("com.dorkbox.VersionUpdate") version "1.6"
2019-06-24 16:42:03 +02:00
id("com.dorkbox.GradleUtils") version "1.2"
2019-07-28 16:37:56 +02:00
kotlin("jvm") version "1.3.41"
2019-06-24 16:42:03 +02:00
}
object Extras {
// set for the project
2019-06-25 21:11:16 +02:00
const val description = "Cloudflare API v4 for Kotlin"
2019-06-24 16:42:03 +02:00
const val group = "com.dorkbox"
const val version = "1.0"
// set as project.ext
const val name = "KloudflareAPI"
const val id = "KloudflareAPI"
const val vendor = "Dorkbox LLC"
const val url = "https://git.dorkbox.com/dorkbox/KloudflareAPI"
val buildDate = Instant.now().toString()
val JAVA_VERSION = JavaVersion.VERSION_1_8.toString()
2019-07-28 16:37:56 +02:00
var sonatypeUserName = ""
var sonatypePassword = ""
2019-06-24 16:42:03 +02:00
}
///////////////////////////////
///// assign 'Extras'
///////////////////////////////
GradleUtils.load("$projectDir/../../gradle.properties", Extras)
description = Extras.description
group = Extras.group
version = Extras.version
licensing {
license(License.APACHE_2) {
author(Extras.vendor)
url(Extras.url)
note(Extras.description)
}
}
sourceSets {
main {
java {
setSrcDirs(listOf("src"))
// want to include java and kotlin files for the source. 'setSrcDirs' resets includes...
include("**/*.java", "**/*.kt")
}
}
test {
java {
setSrcDirs(listOf("test"))
// want to include java and kotlin files for the source. 'setSrcDirs' resets includes...
include("**/*.java", "**/*.kt")
}
}
2019-06-24 16:42:03 +02:00
}
repositories {
mavenLocal() // this must be first!
jcenter()
}
///////////////////////////////
////// Task defaults
///////////////////////////////
tasks.withType<JavaCompile> {
options.encoding = "UTF-8"
sourceCompatibility = Extras.JAVA_VERSION
targetCompatibility = Extras.JAVA_VERSION
}
tasks.withType<Jar> {
duplicatesStrategy = DuplicatesStrategy.FAIL
}
tasks.compileJava.get().apply {
println("\tCompiling classes to Java $sourceCompatibility")
}
tasks.withType<Jar> {
duplicatesStrategy = DuplicatesStrategy.FAIL
}
tasks.jar.get().apply {
duplicatesStrategy = DuplicatesStrategy.FAIL
manifest {
2019-07-28 16:37:56 +02:00
// https://docs.oracle.com/javase/tutorial/deployment/jar/packageman.html
attributes["Name"] = Extras.name
attributes["Specification-Title"] = Extras.name
attributes["Specification-Version"] = Extras.version
attributes["Specification-Vendor"] = Extras.vendor
attributes["Implementation-Title"] = "${Extras.group}.${Extras.id}"
attributes["Implementation-Version"] = Extras.buildDate
attributes["Implementation-Vendor"] = Extras.vendor
attributes["Automatic-Module-Name"] = Extras.id
2019-06-24 16:42:03 +02:00
}
}
configurations.all {
resolutionStrategy {
// fail eagerly on version conflict (includes transitive dependencies)
// e.g. multiple different versions of the same dependency (group and name are equal)
failOnVersionConflict()
// if there is a version we specified, USE THAT VERSION (over transitive versions)
preferProjectModules()
2019-06-24 16:42:03 +02:00
// cache dynamic versions for 10 minutes
cacheDynamicVersionsFor(10 * 60, "seconds")
// don't cache changing modules at all
cacheChangingModulesFor(0, "seconds")
}
}
dependencies {
implementation("org.jetbrains.kotlin:kotlin-stdlib-jdk8")
implementation("org.jetbrains.kotlin:kotlin-stdlib")
implementation("org.jetbrains.kotlin:kotlin-stdlib-common")
implementation("org.jetbrains.kotlin:kotlin-reflect")
2019-07-28 16:37:56 +02:00
val okHttpVer = "4.0.1"
2019-06-24 16:42:03 +02:00
val moshiVer = "1.8.0"
val retroVer = "2.6.0"
2019-06-24 16:42:03 +02:00
implementation("com.squareup.okhttp3:okhttp:$okHttpVer")
implementation("com.squareup.okhttp3:logging-interceptor:$okHttpVer") // Log Network Calls
2019-06-24 16:42:03 +02:00
// For serialization. THESE ARE NOT TRANSITIVE because it screws up the kotlin version
implementation("com.squareup.retrofit2:retrofit:$retroVer")
implementation("com.squareup.retrofit2:converter-moshi:$retroVer")
implementation ("com.squareup.moshi:moshi:$moshiVer")
implementation ("com.squareup.moshi:moshi-kotlin:$moshiVer")
2019-07-28 16:37:56 +02:00
}
///////////////////////////////
////// PUBLISH TO SONATYPE / MAVEN CENTRAL
//////
////// TESTING : local maven repo <PUBLISHING - publishToMavenLocal>
//////
////// RELEASE : sonatype / maven central, <PUBLISHING - publish> then <RELEASE - closeAndReleaseRepository>
///////////////////////////////
val sourceJar = task<Jar>("sourceJar") {
description = "Creates a JAR that contains the source code."
2019-06-24 16:42:03 +02:00
2019-07-28 16:37:56 +02:00
from(sourceSets["main"].java)
archiveClassifier.set("sources")
}
val javaDocJar = task<Jar>("javaDocJar") {
description = "Creates a JAR that contains the javadocs."
archiveClassifier.set("javadoc")
}
publishing {
publications {
create<MavenPublication>("maven") {
groupId = Extras.group
artifactId = Extras.id
version = Extras.version
from(components["java"])
artifact(sourceJar)
artifact(javaDocJar)
pom {
name.set(Extras.name)
description.set(Extras.description)
url.set(Extras.url)
issueManagement {
url.set("${Extras.url}/issues")
system.set("Gitea Issues")
}
organization {
name.set(Extras.vendor)
url.set("https://dorkbox.com")
}
developers {
developer {
id.set("dorkbox")
name.set(Extras.vendor)
email.set("email@dorkbox.com")
}
}
scm {
url.set(Extras.url)
connection.set("scm:${Extras.url}.git")
}
}
}
}
2019-06-24 16:42:03 +02:00
2019-07-28 16:37:56 +02:00
repositories {
maven {
setUrl("https://oss.sonatype.org/service/local/staging/deploy/maven2")
credentials {
username = Extras.sonatypeUserName
password = Extras.sonatypePassword
}
}
}
2019-06-24 16:42:03 +02:00
2019-07-28 16:37:56 +02:00
tasks.withType<PublishToMavenRepository> {
onlyIf {
publication == publishing.publications["maven"] && repository == publishing.repositories["maven"]
}
}
tasks.withType<PublishToMavenLocal> {
onlyIf {
publication == publishing.publications["maven"]
}
}
// output the release URL in the console
tasks["releaseRepository"].doLast {
val url = "https://oss.sonatype.org/content/repositories/releases/"
val projectName = Extras.group.replace('.', '/')
val name = Extras.name
val version = Extras.version
println("Maven URL: $url$projectName/$name/$version/")
}
nexusStaging {
username = Extras.sonatypeUserName
password = Extras.sonatypePassword
}
nexusPublishing {
packageGroup.set(Extras.group)
repositoryName.set("maven")
username.set(Extras.sonatypeUserName)
password.set(Extras.sonatypePassword)
}
signing {
sign(publishing.publications["maven"])
}
task<Task>("publishAndRelease") {
group = "publish and release"
// required to make sure the tasks run in the correct order
tasks["closeAndReleaseRepository"].mustRunAfter(tasks["publishToNexus"])
dependsOn("publishToNexus", "closeAndReleaseRepository")
}
2019-06-24 16:42:03 +02:00
}