KloudflareApi/build.gradle.kts
2019-06-25 21:11:16 +02:00

167 lines
4.4 KiB
Plaintext

import java.time.Instant
println("\tGradle ${project.gradle.gradleVersion}")
plugins {
java
id("com.dorkbox.Licensing") version "1.4"
id("com.dorkbox.VersionUpdate") version "1.4.1"
id("com.dorkbox.GradleUtils") version "1.2"
kotlin("jvm") version "1.3.31"
}
object Extras {
// set for the project
const val description = "Cloudflare API v4 for Kotlin"
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()
}
///////////////////////////////
///// 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")
}
}
}
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 {
attributes["Implementation-Version"] = Extras.version
attributes["Build-Date"] = Extras.buildDate
attributes["Main-Class"] = "dorkbox.UndertowServerTest"
}
}
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()
// 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")
implementation("org.jetbrains.kotlinx:kotlinx-coroutines-core:1.2.1") {
isTransitive = false
}
implementation("org.jetbrains.kotlinx:kotlinx-coroutines-core-common:1.2.1") {
isTransitive = false
}
val okHttpVer = "3.14.2"
val moshiVer = "1.8.0"
implementation("com.squareup.okhttp3:okhttp:$okHttpVer")
// Log Network Calls
implementation("com.squareup.okhttp3:logging-interceptor:3.14.2")
// For serialization. THESE ARE NOT TRANSITIVE because it screws up the kotlin version
implementation("com.squareup.retrofit2:retrofit:2.5.0") {
isTransitive = false
}
implementation("com.squareup.retrofit2:converter-moshi:2.5.0") {
isTransitive = false
}
implementation ("com.squareup.moshi:moshi:$moshiVer") {
isTransitive = false
}
implementation ("com.squareup.moshi:moshi-kotlin:$moshiVer") {
isTransitive = false
}
// awesome logging framework for kotlin.
// https://www.reddit.com/r/Kotlin/comments/8gbiul/slf4j_loggers_in_3_ways/
// https://github.com/MicroUtils/kotlin-logging
implementation("io.github.microutils:kotlin-logging:1.6.26") {
isTransitive = false
}
implementation("io.github.microutils:kotlin-logging-common:1.6.26") {
isTransitive = false
}
implementation("org.slf4j:slf4j-api:1.7.26")
implementation("ch.qos.logback:logback-core:1.2.3")
implementation("ch.qos.logback:logback-classic:1.2.3") {
isTransitive = false
}
}