2018-03-22 15:22:29 +01:00
|
|
|
package output
|
|
|
|
|
|
|
|
import (
|
2018-06-25 16:31:44 +02:00
|
|
|
"bufio"
|
|
|
|
"fmt"
|
|
|
|
"os"
|
2018-05-03 18:40:52 +02:00
|
|
|
"time"
|
|
|
|
|
2018-03-22 15:22:29 +01:00
|
|
|
"github.com/apex/log"
|
2021-02-02 10:32:46 +01:00
|
|
|
"github.com/ooni/probe-cli/v3/cmd/ooniprobe/internal/database"
|
|
|
|
"github.com/ooni/probe-cli/v3/cmd/ooniprobe/internal/utils"
|
2018-03-22 15:22:29 +01:00
|
|
|
)
|
|
|
|
|
2019-10-02 18:23:14 +02:00
|
|
|
// MeasurementJSON prints the JSON of a measurement
|
|
|
|
func MeasurementJSON(j map[string]interface{}) {
|
|
|
|
log.WithFields(log.Fields{
|
2019-11-14 12:01:40 +01:00
|
|
|
"type": "measurement_json",
|
2019-10-02 18:23:14 +02:00
|
|
|
"measurement_json": j,
|
|
|
|
}).Info("Measurement JSON")
|
|
|
|
}
|
|
|
|
|
2018-03-22 15:22:29 +01:00
|
|
|
// Progress logs a progress type event
|
2019-11-14 12:01:40 +01:00
|
|
|
func Progress(key string, perc float64, eta float64, msg string) {
|
2018-03-22 15:22:29 +01:00
|
|
|
log.WithFields(log.Fields{
|
|
|
|
"type": "progress",
|
|
|
|
"key": key,
|
|
|
|
"percentage": perc,
|
2019-11-14 12:01:40 +01:00
|
|
|
"eta": eta,
|
2018-03-22 15:22:29 +01:00
|
|
|
}).Info(msg)
|
|
|
|
}
|
2018-05-03 18:40:52 +02:00
|
|
|
|
2018-09-11 15:40:42 +02:00
|
|
|
type MeasurementSummaryData struct {
|
2018-09-13 14:54:56 +02:00
|
|
|
TotalRuntime float64
|
|
|
|
TotalCount int64
|
|
|
|
AnomalyCount int64
|
|
|
|
DataUsageUp float64
|
|
|
|
DataUsageDown float64
|
|
|
|
ASN uint
|
|
|
|
NetworkName string
|
|
|
|
NetworkCountryCode string
|
|
|
|
StartTime time.Time
|
2018-09-11 15:40:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func MeasurementSummary(msmt MeasurementSummaryData) {
|
|
|
|
log.WithFields(log.Fields{
|
2019-11-14 12:01:40 +01:00
|
|
|
"type": "measurement_summary",
|
|
|
|
"total_runtime": msmt.TotalRuntime,
|
|
|
|
"total_count": msmt.TotalCount,
|
|
|
|
"anomaly_count": msmt.AnomalyCount,
|
|
|
|
"data_usage_down": msmt.DataUsageDown,
|
|
|
|
"data_usage_up": msmt.DataUsageUp,
|
|
|
|
"asn": msmt.ASN,
|
2018-09-13 14:54:56 +02:00
|
|
|
"network_country_code": msmt.NetworkCountryCode,
|
|
|
|
"network_name": msmt.NetworkName,
|
|
|
|
"start_time": msmt.StartTime,
|
2018-09-11 15:40:42 +02:00
|
|
|
}).Info("measurement summary")
|
|
|
|
}
|
|
|
|
|
2018-09-10 18:03:32 +02:00
|
|
|
// MeasurementItem logs a progress type event
|
2018-09-13 14:54:56 +02:00
|
|
|
func MeasurementItem(msmt database.MeasurementURLNetwork, isFirst bool, isLast bool) {
|
2018-09-10 18:03:32 +02:00
|
|
|
log.WithFields(log.Fields{
|
2018-09-13 14:54:56 +02:00
|
|
|
"type": "measurement_item",
|
|
|
|
"is_first": isFirst,
|
|
|
|
"is_last": isLast,
|
|
|
|
|
2020-01-28 11:53:00 +01:00
|
|
|
"id": msmt.Measurement.ID,
|
|
|
|
"test_name": msmt.TestName,
|
|
|
|
"test_group_name": msmt.Result.TestGroupName,
|
|
|
|
"start_time": msmt.Measurement.StartTime,
|
|
|
|
"test_keys": msmt.TestKeys,
|
|
|
|
"network_country_code": msmt.Network.CountryCode,
|
|
|
|
"network_name": msmt.Network.NetworkName,
|
|
|
|
"asn": msmt.Network.ASN,
|
|
|
|
"runtime": msmt.Measurement.Runtime,
|
|
|
|
"url": msmt.URL.URL.String,
|
|
|
|
"url_category_code": msmt.URL.CategoryCode.String,
|
|
|
|
"url_country_code": msmt.URL.CountryCode.String,
|
|
|
|
"is_anomaly": msmt.IsAnomaly.Bool,
|
|
|
|
"is_uploaded": msmt.IsUploaded,
|
|
|
|
"is_upload_failed": msmt.IsUploadFailed,
|
|
|
|
"upload_failure_msg": msmt.UploadFailureMsg.String,
|
|
|
|
"is_failed": msmt.IsFailed,
|
|
|
|
"failure_msg": msmt.FailureMsg.String,
|
|
|
|
"is_done": msmt.Measurement.IsDone,
|
|
|
|
"report_file_path": msmt.ReportFilePath.String,
|
|
|
|
"measurement_file_path": msmt.MeasurementFilePath.String,
|
2018-09-10 18:03:32 +02:00
|
|
|
}).Info("measurement")
|
|
|
|
}
|
|
|
|
|
2018-05-03 18:40:52 +02:00
|
|
|
// ResultItemData is the metadata about a result
|
|
|
|
type ResultItemData struct {
|
2018-09-10 12:41:28 +02:00
|
|
|
ID int64
|
|
|
|
Name string
|
|
|
|
StartTime time.Time
|
|
|
|
TestKeys string
|
|
|
|
MeasurementCount uint64
|
|
|
|
MeasurementAnomalyCount uint64
|
|
|
|
Runtime float64
|
|
|
|
Country string
|
|
|
|
NetworkName string
|
2018-09-11 18:06:15 +02:00
|
|
|
ASN uint
|
2018-09-10 12:41:28 +02:00
|
|
|
Done bool
|
2018-09-12 13:42:16 +02:00
|
|
|
DataUsageDown float64
|
|
|
|
DataUsageUp float64
|
2018-09-10 12:41:28 +02:00
|
|
|
Index int
|
|
|
|
TotalCount int
|
2018-05-03 18:40:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// ResultItem logs a progress type event
|
|
|
|
func ResultItem(result ResultItemData) {
|
|
|
|
log.WithFields(log.Fields{
|
2018-09-10 12:41:28 +02:00
|
|
|
"type": "result_item",
|
|
|
|
"id": result.ID,
|
|
|
|
"name": result.Name,
|
|
|
|
"start_time": result.StartTime,
|
|
|
|
"test_keys": result.TestKeys,
|
|
|
|
"measurement_count": result.MeasurementCount,
|
|
|
|
"measurement_anomaly_count": result.MeasurementAnomalyCount,
|
2018-09-11 18:06:15 +02:00
|
|
|
"network_country_code": result.Country,
|
2018-09-10 12:41:28 +02:00
|
|
|
"network_name": result.NetworkName,
|
|
|
|
"asn": result.ASN,
|
|
|
|
"runtime": result.Runtime,
|
2018-09-17 13:04:48 +02:00
|
|
|
"is_done": result.Done,
|
2018-09-10 12:41:28 +02:00
|
|
|
"data_usage_down": result.DataUsageDown,
|
|
|
|
"data_usage_up": result.DataUsageUp,
|
|
|
|
"index": result.Index,
|
|
|
|
"total_count": result.TotalCount,
|
2018-05-03 18:40:52 +02:00
|
|
|
}).Info("result item")
|
|
|
|
}
|
2018-06-22 11:53:10 +02:00
|
|
|
|
|
|
|
type ResultSummaryData struct {
|
|
|
|
TotalTests int64
|
2018-09-12 13:42:16 +02:00
|
|
|
TotalDataUsageUp float64
|
|
|
|
TotalDataUsageDown float64
|
2018-06-22 11:53:10 +02:00
|
|
|
TotalNetworks int64
|
|
|
|
}
|
|
|
|
|
|
|
|
func ResultSummary(result ResultSummaryData) {
|
|
|
|
log.WithFields(log.Fields{
|
|
|
|
"type": "result_summary",
|
|
|
|
"total_tests": result.TotalTests,
|
|
|
|
"total_data_usage_up": result.TotalDataUsageUp,
|
|
|
|
"total_data_usage_down": result.TotalDataUsageDown,
|
|
|
|
"total_networks": result.TotalNetworks,
|
|
|
|
}).Info("result summary")
|
|
|
|
}
|
|
|
|
|
|
|
|
// SectionTitle is the title of a section
|
|
|
|
func SectionTitle(text string) {
|
|
|
|
log.WithFields(log.Fields{
|
|
|
|
"type": "section_title",
|
|
|
|
"title": text,
|
|
|
|
}).Info(text)
|
|
|
|
}
|
2018-06-25 16:31:44 +02:00
|
|
|
|
|
|
|
func Paragraph(text string) {
|
|
|
|
const width = 80
|
2019-12-02 14:15:50 +01:00
|
|
|
fmt.Println(utils.WrapString(text, width))
|
2018-06-25 16:31:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func Bullet(text string) {
|
|
|
|
const width = 80
|
2019-12-02 14:15:50 +01:00
|
|
|
fmt.Printf("• %s\n", utils.WrapString(text, width))
|
2018-06-25 16:31:44 +02:00
|
|
|
}
|
|
|
|
|
2020-11-24 09:19:34 +01:00
|
|
|
func PressEnterToContinue(text string) error {
|
2018-06-25 16:31:44 +02:00
|
|
|
fmt.Print(text)
|
2020-11-24 09:19:34 +01:00
|
|
|
_, err := bufio.NewReader(os.Stdin).ReadBytes('\n')
|
|
|
|
return err
|
2018-06-25 16:31:44 +02:00
|
|
|
}
|