mirror of
https://github.com/torproject/collector.git
synced 2024-11-23 01:19:43 +00:00
Include OnionPerf analysis files when syncing.
This commit is contained in:
parent
9834cec8c0
commit
06c0d78e4a
@ -4,8 +4,8 @@
|
||||
- Clean up descriptors written to the `out/` directory by deleting
|
||||
files that are older than seven weeks.
|
||||
- Correctly index files that are moved away and back.
|
||||
- Include microdescriptors and certs when syncing from another
|
||||
CollecTor instance.
|
||||
- Include microdescriptors, certs, and OnionPerf analysis files when
|
||||
syncing from another CollecTor instance.
|
||||
- Update to metrics-lib 2.15.0.
|
||||
|
||||
|
||||
|
@ -57,6 +57,7 @@ public class OnionPerfDownloader extends CollecTorMain {
|
||||
public OnionPerfDownloader(Configuration config) {
|
||||
super(config);
|
||||
this.mapPathDescriptors.put("recent/torperf", TorperfResult.class);
|
||||
this.mapPathDescriptors.put("recent/onionperf", TorperfResult.class);
|
||||
}
|
||||
|
||||
/** File containing the download history, which is necessary, because
|
||||
|
@ -6,12 +6,21 @@ package org.torproject.metrics.collector.persist;
|
||||
import org.torproject.descriptor.TorperfResult;
|
||||
import org.torproject.metrics.collector.conf.Annotation;
|
||||
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.nio.file.Files;
|
||||
import java.nio.file.Path;
|
||||
import java.nio.file.Paths;
|
||||
import java.nio.file.StandardOpenOption;
|
||||
|
||||
public class OnionPerfPersistence
|
||||
extends DescriptorPersistence<TorperfResult> {
|
||||
|
||||
private static final Logger logger
|
||||
= LoggerFactory.getLogger(OnionPerfPersistence.class);
|
||||
|
||||
private static final String ONIONPERF = "torperf";
|
||||
|
||||
public OnionPerfPersistence(TorperfResult desc) {
|
||||
@ -32,18 +41,55 @@ public class OnionPerfPersistence
|
||||
name).toString();
|
||||
}
|
||||
|
||||
/** OnionPerf default storage appends. */
|
||||
/** If the original descriptor file was a .tpf file, append the parsed Torperf
|
||||
* result to the destination .tpf file, but if it was a .json.xz file, just
|
||||
* copy over the entire file, unless it already exists. */
|
||||
@Override
|
||||
public boolean storeOut(String outRoot) {
|
||||
return super.storeOut(outRoot, StandardOpenOption.APPEND);
|
||||
public boolean storeOut(String outRoot, StandardOpenOption option) {
|
||||
if (desc.getDescriptorFile().getName().endsWith(".tpf")) {
|
||||
return super.storeOut(outRoot, StandardOpenOption.APPEND);
|
||||
} else {
|
||||
String fileName = desc.getDescriptorFile().getName();
|
||||
String[] dateParts = fileName.split("\\.")[0].split("-");
|
||||
return this.copyIfNotExists(
|
||||
Paths.get(outRoot,
|
||||
"onionperf",
|
||||
dateParts[0], // year
|
||||
dateParts[1], // month
|
||||
dateParts[2], // day
|
||||
fileName));
|
||||
}
|
||||
}
|
||||
|
||||
/** OnionPerf default storage appends. */
|
||||
/** If the original descriptor file was a .tpf file, append the parsed Torperf
|
||||
* result to the destination .tpf file, but if it was a .json.xz file, just
|
||||
* copy over the entire file, unless it already exists. */
|
||||
@Override
|
||||
public boolean storeAll(String recentRoot, String outRoot) {
|
||||
return super.storeAll(recentRoot, outRoot, StandardOpenOption.APPEND,
|
||||
StandardOpenOption.APPEND);
|
||||
public boolean storeRecent(String recentRoot, StandardOpenOption option) {
|
||||
if (desc.getDescriptorFile().getName().endsWith(".tpf")) {
|
||||
return super.storeRecent(recentRoot, StandardOpenOption.APPEND);
|
||||
} else {
|
||||
String fileName = desc.getDescriptorFile().getName();
|
||||
return this.copyIfNotExists(
|
||||
Paths.get(recentRoot,
|
||||
"onionperf",
|
||||
fileName));
|
||||
}
|
||||
}
|
||||
|
||||
private boolean copyIfNotExists(Path destinationFile) {
|
||||
if (Files.exists(destinationFile)) {
|
||||
return false;
|
||||
}
|
||||
Path originalFile = this.desc.getDescriptorFile().toPath();
|
||||
try {
|
||||
Files.createDirectories(destinationFile.getParent());
|
||||
Files.copy(originalFile, destinationFile);
|
||||
} catch (IOException e) {
|
||||
logger.warn("Unable to copy file.", e);
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -175,7 +175,7 @@ ExitlistUrl = https://check.torproject.org/exit-addresses
|
||||
######## OnionPerf downloader ########
|
||||
#
|
||||
## Define descriptor sources
|
||||
# possible values: Remote,Sync (.tpf files only!)
|
||||
# possible values: Remote, Sync
|
||||
OnionPerfSources = Remote
|
||||
# Retrieve files from the following CollecTor instances.
|
||||
# List of URLs separated by comma.
|
||||
|
Loading…
Reference in New Issue
Block a user