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"
|
2018-09-10 18:03:32 +02:00
|
|
|
"github.com/ooni/probe-cli/internal/database"
|
2018-06-25 16:31:44 +02:00
|
|
|
"github.com/ooni/probe-cli/internal/util"
|
2018-03-22 15:22:29 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
// Progress logs a progress type event
|
|
|
|
func Progress(key string, perc float64, msg string) {
|
|
|
|
log.WithFields(log.Fields{
|
|
|
|
"type": "progress",
|
|
|
|
"key": key,
|
|
|
|
"percentage": perc,
|
|
|
|
}).Info(msg)
|
|
|
|
}
|
2018-05-03 18:40:52 +02:00
|
|
|
|
2018-09-10 18:03:32 +02:00
|
|
|
// MeasurementItem logs a progress type event
|
|
|
|
func MeasurementItem(msmt database.MeasurementURLNetwork) {
|
|
|
|
log.WithFields(log.Fields{
|
|
|
|
"type": "measurement_item",
|
|
|
|
"id": msmt.MsmtTblID,
|
|
|
|
"test_name": msmt.TestName,
|
2018-09-11 15:19:08 +02:00
|
|
|
"test_group_name": msmt.Result.TestGroupName,
|
|
|
|
"start_time": msmt.Measurement.StartTime,
|
2018-09-10 18:03:32 +02:00
|
|
|
"test_keys": msmt.TestKeys,
|
|
|
|
"probe_cc": msmt.Network.CountryCode,
|
|
|
|
"network_name": msmt.Network.NetworkName,
|
|
|
|
"asn": msmt.Network.ASN,
|
2018-09-11 15:19:08 +02:00
|
|
|
"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,
|
2018-09-10 18:03:32 +02:00
|
|
|
"is_uploaded": msmt.IsUploaded,
|
|
|
|
"is_upload_failed": msmt.IsUploadFailed,
|
|
|
|
"upload_failure_msg": msmt.UploadFailureMsg.String,
|
|
|
|
"is_failed": msmt.IsFailed,
|
|
|
|
"failure_msg": msmt.FailureMsg.String,
|
2018-09-11 15:19:08 +02:00
|
|
|
"is_done": msmt.Measurement.IsDone,
|
2018-09-10 18:03:32 +02:00
|
|
|
"report_file_path": msmt.ReportFilePath,
|
|
|
|
}).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
|
|
|
|
ASN string
|
|
|
|
Done bool
|
|
|
|
DataUsageDown int64
|
|
|
|
DataUsageUp int64
|
|
|
|
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,
|
|
|
|
"country": result.Country,
|
|
|
|
"network_name": result.NetworkName,
|
|
|
|
"asn": result.ASN,
|
|
|
|
"runtime": result.Runtime,
|
|
|
|
"done": result.Done,
|
|
|
|
"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
|
|
|
|
TotalDataUsageUp int64
|
|
|
|
TotalDataUsageDown int64
|
|
|
|
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
|
|
|
|
fmt.Println(util.WrapString(text, width))
|
|
|
|
}
|
|
|
|
|
|
|
|
func Bullet(text string) {
|
|
|
|
const width = 80
|
|
|
|
fmt.Printf("• %s\n", util.WrapString(text, width))
|
|
|
|
}
|
|
|
|
|
|
|
|
func PressEnterToContinue(text string) {
|
|
|
|
fmt.Print(text)
|
|
|
|
bufio.NewReader(os.Stdin).ReadBytes('\n')
|
|
|
|
}
|