If verification fails, delete, download and re-verify.

This commit is contained in:
akwizgran
2018-04-18 11:03:39 +01:00
parent 0823934e28
commit ff9971b728

View File

@@ -1,6 +1,8 @@
import de.undercouch.gradle.tasks.download.Download import de.undercouch.gradle.tasks.download.Download
import de.undercouch.gradle.tasks.download.Verify import de.undercouch.gradle.tasks.download.Verify
import java.security.NoSuchAlgorithmException
apply plugin: 'com.android.library' apply plugin: 'com.android.library'
apply plugin: 'witness' apply plugin: 'witness'
apply plugin: 'de.undercouch.download' apply plugin: 'de.undercouch.download'
@@ -67,38 +69,60 @@ def torBinaries = [
"geoip" : '8239b98374493529a29096e45fc5877d4d6fdad0146ad8380b291f90d61484ea' "geoip" : '8239b98374493529a29096e45fc5877d4d6fdad0146ad8380b291f90d61484ea'
] ]
def downloadBinary(name) { def verifyOrDeleteBinary(name, chksum) {
return tasks.create("downloadBinary${name}", Download) { return tasks.create("verifyOrDeleteBinary${name}", VerifyOrDelete) {
src "${torBinaryDir}/${name}.zip"
algorithm 'SHA-256'
checksum chksum
onlyIf {
src.exists()
}
}
}
def downloadBinary(name, chksum) {
return tasks.create([
name: "downloadBinary${name}",
type: Download,
dependsOn: verifyOrDeleteBinary(name, chksum)]) {
src "${torDownloadUrl}${name}.zip" src "${torDownloadUrl}${name}.zip"
.replace('tor_', "tor-${torVersion}-") .replace('tor_', "tor-${torVersion}-")
.replace('geoip', "geoip-${geoipVersion}") .replace('geoip', "geoip-${geoipVersion}")
.replaceAll('_', '-') .replaceAll('_', '-')
dest "${torBinaryDir}/${name}.zip" dest "${torBinaryDir}/${name}.zip"
onlyIf {
!dest.exists()
}
} }
} }
def verifyBinary(name, chksum) { def verifyBinary(name, chksum) {
String filename = "${torBinaryDir}/${name}.zip" return tasks.create([
if (new File("bramble-android/${filename}").exists()) { name : "verifyBinary${name}",
return tasks.create("verifyBinary${name}", Verify) { type : Verify,
src filename dependsOn: downloadBinary(name, chksum)]) {
algorithm 'SHA-256' src "${torBinaryDir}/${name}.zip"
checksum chksum algorithm 'SHA-256'
} checksum chksum
} else {
return tasks.create([
name : "verifyBinary${name}",
type : Verify,
dependsOn: downloadBinary(name)]) {
src filename
algorithm 'SHA-256'
checksum chksum
}
} }
} }
project.afterEvaluate { project.afterEvaluate {
torBinaries.every { key, value -> torBinaries.every { name, checksum ->
preBuild.dependsOn.add(verifyBinary(key, value)) preBuild.dependsOn.add(verifyBinary(name, checksum))
}
}
class VerifyOrDelete extends Verify {
@TaskAction
@Override
void verify() throws IOException, NoSuchAlgorithmException {
try {
super.verify()
} catch (Exception e) {
println "${src} failed verification - deleting"
src.delete()
}
} }
} }