mirror of
https://code.briarproject.org/briar/briar.git
synced 2026-02-19 06:09:55 +01:00
If verification fails, delete, download and re-verify.
This commit is contained in:
@@ -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()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user