Add support for crash reporting via sentry and change the send_crash_reports key

This commit is contained in:
Arturo Filastò 2018-06-29 15:29:05 +02:00
parent b8dff783e1
commit d88764aa34
7 changed files with 72 additions and 19 deletions

View File

@ -3,7 +3,6 @@ package main
import ( import (
// commands // commands
"github.com/apex/log" "github.com/apex/log"
"github.com/getsentry/raven-go"
_ "github.com/ooni/probe-cli/internal/cli/geoip" _ "github.com/ooni/probe-cli/internal/cli/geoip"
_ "github.com/ooni/probe-cli/internal/cli/info" _ "github.com/ooni/probe-cli/internal/cli/info"
@ -16,14 +15,15 @@ import (
_ "github.com/ooni/probe-cli/internal/cli/version" _ "github.com/ooni/probe-cli/internal/cli/version"
"github.com/ooni/probe-cli/internal/cli/app" "github.com/ooni/probe-cli/internal/cli/app"
"github.com/ooni/probe-cli/internal/crashreport"
) )
func main() { func main() {
raven.SetDSN("https://cb4510e090f64382ac371040c19b2258:8448daeebfa643c289ef398f8645980b@sentry.io/1234954") crashreport.CapturePanicAndWait(func() {
err := app.Run()
err := app.Run() if err == nil {
if err == nil { return
return }
} log.WithError(err).Fatal("main exit")
log.WithError(err).Fatal("main exit") }, nil)
} }

View File

@ -5,6 +5,8 @@ import (
"io/ioutil" "io/ioutil"
"sync" "sync"
"github.com/apex/log"
"github.com/ooni/probe-cli/internal/crashreport"
"github.com/ooni/probe-cli/utils" "github.com/ooni/probe-cli/utils"
"github.com/pkg/errors" "github.com/pkg/errors"
) )
@ -39,6 +41,10 @@ func ParseConfig(b []byte) (*Config, error) {
if err := c.Validate(); err != nil { if err := c.Validate(); err != nil {
return nil, errors.Wrap(err, "validating") return nil, errors.Wrap(err, "validating")
} }
if c.Advanced.SendCrashReports == false {
log.Info("Disabling crash reporting.")
crashreport.Disabled = true
}
return &c, nil return &c, nil
} }

View File

@ -110,17 +110,17 @@ type Notifications struct {
// Sharing settings // Sharing settings
type Sharing struct { type Sharing struct {
IncludeIP bool `json:"include_ip"` IncludeIP bool `json:"include_ip"`
IncludeASN bool `json:"include_asn"` IncludeASN bool `json:"include_asn"`
IncludeGPS bool `json:"include_gps"` IncludeGPS bool `json:"include_gps"`
UploadResults bool `json:"upload_results"` UploadResults bool `json:"upload_results"`
SendCrashReports bool `json:"send_crash_reports"`
} }
// Advanced settings // Advanced settings
type Advanced struct { type Advanced struct {
IncludeCountry bool `json:"include_country"` IncludeCountry bool `json:"include_country"`
UseDomainFronting bool `json:"use_domain_fronting"` UseDomainFronting bool `json:"use_domain_fronting"`
SendCrashReports bool `json:"send_crash_reports"`
} }
// AutomatedTesting settings // AutomatedTesting settings

View File

@ -7,8 +7,7 @@
"include_ip": false, "include_ip": false,
"include_asn": true, "include_asn": true,
"include_gps": true, "include_gps": true,
"upload_results": true, "upload_results": true
"send_crash_reports": true
}, },
"notifications": { "notifications": {
"enabled": true, "enabled": true,
@ -58,6 +57,7 @@
}, },
"advanced": { "advanced": {
"include_country": true, "include_country": true,
"use_domain_fronting": false "use_domain_fronting": false,
"send_crash_reports": true
} }
} }

View File

@ -8,7 +8,6 @@
"include_asn": true, "include_asn": true,
"include_gps": true, "include_gps": true,
"upload_results": true, "upload_results": true,
"send_crash_reports": true
}, },
"notifications": { "notifications": {
"enabled": true, "enabled": true,
@ -58,6 +57,7 @@
}, },
"advanced": { "advanced": {
"include_country": true, "include_country": true,
"use_domain_fronting": false "use_domain_fronting": false,
"send_crash_reports": true
}, },
} }

View File

@ -0,0 +1,47 @@
package crashreport
import (
"github.com/getsentry/raven-go"
)
// Disabled flag is used to globally disable crash reporting and make all the
// crash reporting logic a no-op.
var Disabled = false
// CapturePanic is a wrapper around raven.CapturePanic that becomes a noop if
// `Disabled` is set to true.
func CapturePanic(f func(), tags map[string]string) (interface{}, string) {
if Disabled == true {
return nil, ""
}
return raven.CapturePanic(f, tags)
}
// CapturePanicAndWait is a wrapper around raven.CapturePanicAndWait that becomes a noop if
// `Disabled` is set to true.
func CapturePanicAndWait(f func(), tags map[string]string) (interface{}, string) {
if Disabled == true {
return nil, ""
}
return raven.CapturePanicAndWait(f, tags)
}
// CaptureError is a wrapper around raven.CaptureError
func CaptureError(err error, tags map[string]string) string {
if Disabled == true {
return ""
}
return raven.CaptureError(err, tags)
}
// CaptureErrorAndWait is a wrapper around raven.CaptureErrorAndWait
func CaptureErrorAndWait(err error, tags map[string]string) string {
if Disabled == true {
return ""
}
return raven.CaptureErrorAndWait(err, tags)
}
func init() {
raven.SetDSN("https://cb4510e090f64382ac371040c19b2258:8448daeebfa643c289ef398f8645980b@sentry.io/1234954")
}

View File

@ -127,10 +127,10 @@ func Onboarding(config *config.Config) error {
config.Lock() config.Lock()
config.InformedConsent = true config.InformedConsent = true
config.Advanced.IncludeCountry = settings.IncludeCountry config.Advanced.IncludeCountry = settings.IncludeCountry
config.Advanced.SendCrashReports = settings.SendCrashReports
config.Sharing.IncludeIP = settings.IncludeIP config.Sharing.IncludeIP = settings.IncludeIP
config.Sharing.IncludeASN = settings.IncludeNetwork config.Sharing.IncludeASN = settings.IncludeNetwork
config.Sharing.UploadResults = settings.UploadResults config.Sharing.UploadResults = settings.UploadResults
config.Sharing.SendCrashReports = settings.SendCrashReports
config.Unlock() config.Unlock()
if err := config.Write(); err != nil { if err := config.Write(); err != nil {