2017-11-14 21:31:35 -05:00
|
|
|
plugins {
|
|
|
|
id 'com.github.johnrengelman.shadow' version '2.0.1'
|
|
|
|
}
|
|
|
|
|
2017-06-27 17:54:07 -04:00
|
|
|
import org.elasticsearch.gradle.test.RunTask
|
2017-06-19 15:19:54 -04:00
|
|
|
|
2017-06-21 12:12:19 -04:00
|
|
|
description = 'JDBC driver for Elasticsearch'
|
|
|
|
|
2017-06-29 14:31:23 -04:00
|
|
|
forbiddenApisMain {
|
|
|
|
// does not depend on core, so only jdk and http signatures should be checked
|
|
|
|
signaturesURLs = [this.class.getResource('/forbidden/jdk-signatures.txt')]
|
|
|
|
}
|
|
|
|
|
2017-06-19 15:19:54 -04:00
|
|
|
dependencies {
|
2017-10-30 18:59:01 -04:00
|
|
|
compile project(':x-pack-elasticsearch:sql:shared-client')
|
2017-06-29 14:31:23 -04:00
|
|
|
compile project(':x-pack-elasticsearch:sql:jdbc-proto')
|
2017-07-12 17:32:13 -04:00
|
|
|
compile project(':x-pack-elasticsearch:sql:shared-proto')
|
2017-11-14 21:31:35 -05:00
|
|
|
runtime "com.fasterxml.jackson.core:jackson-core:${versions.jackson}"
|
|
|
|
/* We want to limit these dependencies so we don't have a huge jar.
|
|
|
|
* Since we shadow these dependencies we don't have to be super careful
|
|
|
|
* but we have to be *somewhat* careful because things like commons logging
|
|
|
|
* don't shadow properly. */
|
2017-06-19 15:19:54 -04:00
|
|
|
}
|
|
|
|
|
2017-06-20 15:53:39 -04:00
|
|
|
dependencyLicenses {
|
|
|
|
mapping from: /jdbc-proto.*/, to: 'elasticsearch'
|
2017-10-30 18:59:01 -04:00
|
|
|
mapping from: /shared-client.*/, to: 'elasticsearch'
|
2017-07-12 17:32:13 -04:00
|
|
|
mapping from: /shared-proto.*/, to: 'elasticsearch'
|
2017-11-14 21:31:35 -05:00
|
|
|
mapping from: /jackson-.*/, to: 'jackson'
|
2017-06-20 15:53:39 -04:00
|
|
|
ignoreSha 'jdbc-proto'
|
2017-10-30 18:59:01 -04:00
|
|
|
ignoreSha 'shared-client'
|
2017-07-12 17:32:13 -04:00
|
|
|
ignoreSha 'shared-proto'
|
2017-06-20 15:53:39 -04:00
|
|
|
}
|
|
|
|
|
2017-11-14 21:31:35 -05:00
|
|
|
/* Disable the jar task configured by the java plugin. We're not going to
|
|
|
|
* distribute an unshaded jar so there is no need making one. */
|
2017-06-19 15:19:54 -04:00
|
|
|
jar {
|
2017-11-14 21:31:35 -05:00
|
|
|
enabled = false
|
|
|
|
}
|
|
|
|
configurations.archives.artifacts.removeAll { it.archiveTask.is jar }
|
|
|
|
|
|
|
|
/* Move the shaded jar to the empty classifier because it is the only one
|
|
|
|
* we're shipping. */
|
|
|
|
shadowJar {
|
|
|
|
classifier = null
|
|
|
|
// We only need to relocate jackson
|
|
|
|
relocate 'com.fasterxml.jackson', 'org.elasticsearch.xpack.sql.jdbc.shadow.jacksonp'
|
|
|
|
manifest {
|
|
|
|
inheritFrom jar.manifest
|
2017-07-07 10:32:23 -04:00
|
|
|
}
|
2017-06-19 15:19:54 -04:00
|
|
|
}
|
2017-11-14 21:31:35 -05:00
|
|
|
assemble.dependsOn shadowJar
|
|
|
|
artifacts {
|
|
|
|
archives shadowJar
|
|
|
|
}
|
|
|
|
|
|
|
|
// And for better realism let's use the shaded jar for testing
|
|
|
|
test {
|
|
|
|
classpath -= compileJava.outputs.files
|
|
|
|
classpath -= configurations.compile
|
|
|
|
classpath -= configurations.runtime
|
|
|
|
classpath += shadowJar.outputs.files
|
|
|
|
dependsOn shadowJar
|
|
|
|
}
|