{-# OPTIONS_GHC -fno-warn-deprecations #-}
module Network.Bugsnag.Notify
( notifyBugsnag
, notifyBugsnagWith
) where
import Control.Exception (SomeException)
import Control.Monad (when)
import Network.Bugsnag.App
import Network.Bugsnag.BeforeNotify
import Network.Bugsnag.Event
import Network.Bugsnag.Exception
import Network.Bugsnag.Report
import Network.Bugsnag.Reporter
import Network.Bugsnag.Settings
notifyBugsnag :: BugsnagSettings -> SomeException -> IO ()
notifyBugsnag = notifyBugsnagWith id
notifyBugsnagWith :: BeforeNotify -> BugsnagSettings -> SomeException -> IO ()
notifyBugsnagWith f settings ex = do
let event =
f
. bsBeforeNotify settings
. setGroupingHashBy (bsGroupingHash settings)
. setStackFramesInProject (bsIsInProject settings)
. filterStackFrames (bsFilterStackFrames settings)
. createApp settings
. bugsnagEvent
. pure
$ bugsnagExceptionFromSomeException ex
manager = bsHttpManager settings
apiKey = bsApiKey settings
report = bugsnagReport [event]
when (bugsnagShouldNotify settings event)
$ reportError manager apiKey report
createApp :: BugsnagSettings -> BeforeNotify
createApp settings event = event
{ beApp = Just $ bugsnagApp
{ baVersion = bsAppVersion settings
, baReleaseStage = Just $ bsReleaseStage settings
}
}