1
0
Fork 0
mirror of https://code.naskya.net/repos/ndqEd synced 2025-01-10 11:36:49 +09:00

Add settings switch for activity debug reports

This commit is contained in:
fr33domlover 2019-04-25 22:46:27 +00:00
parent d24710c46a
commit 46fb4d1512
5 changed files with 29 additions and 14 deletions

View file

@ -160,3 +160,8 @@ drop-delivery-after:
retry-delivery-every:
amount: 1
unit: hours
# How many activities to remember in the debug report list, showing latest
# activities received in local inboxes and the result of their processing.
# 'null' means disable the report page entirely.
#activity-debug-reports: 10

View file

@ -130,7 +130,10 @@ makeFoundation appSettings = do
appActorFetchShare <- newResultShare actorFetchShareAction
appActivities <- newTVarIO mempty
appActivities <-
case appInboxDebugReportLength appSettings of
Nothing -> return Nothing
Just n -> Just . (n,) <$> newTVarIO mempty
-- We need a log function to create a connection pool. We need a connection
-- pool to create our foundation. And we need our foundation to get a

View file

@ -113,7 +113,7 @@ data App = App
, appHashidsContext :: HashidsContext
, appActorFetchShare :: ActorFetchShare App
, appActivities :: TVar (Vector ActivityReport)
, appActivities :: Maybe (Int, TVar (Vector ActivityReport))
}
-- Aliases for the routes file, because it doesn't like spaces in path piece

View file

@ -105,7 +105,8 @@ import Vervis.Settings
getInboxR :: Handler Html
getInboxR = do
acts <- liftIO . readTVarIO =<< getsYesod appActivities
acts <-
liftIO . readTVarIO . snd =<< maybe notFound return =<< getsYesod appActivities
defaultLayout
[whamlet|
<p>
@ -187,17 +188,18 @@ postSharerInboxR shrRecip = do
"application/ld+json; \
\profile=\"https://www.w3.org/ns/activitystreams\""
recordActivity now result contentTypes = do
acts <- getsYesod appActivities
liftIO $ atomically $ modifyTVar' acts $ \ vec ->
let (msg, body) =
case result of
Left t -> (t, "{?}")
Right (o, t) -> (t, encodePretty o)
item = ActivityReport now msg contentTypes body
vec' = item `V.cons` vec
in if V.length vec' > 10
then V.init vec'
else vec'
macts <- getsYesod appActivities
for_ macts $ \ (size, acts) ->
liftIO $ atomically $ modifyTVar' acts $ \ vec ->
let (msg, body) =
case result of
Left t -> (t, "{?}")
Right (o, t) -> (t, encodePretty o)
item = ActivityReport now msg contentTypes body
vec' = item `V.cons` vec
in if V.length vec' > size
then V.init vec'
else vec'
postProjectInboxR :: ShrIdent -> PrjIdent -> Handler ()
postProjectInboxR _ _ = error "TODO implement postProjectInboxR"

View file

@ -148,6 +148,10 @@ data AppSettings = AppSettings
, appDropDeliveryAfter :: NominalDiffTime
-- | How much time to wait between retries of failed deliveries.
, appDeliveryRetryFreq :: TimeInterval
-- | How many activities to remember in the debug report list, showing
-- latest activities received in local inboxes and the result of their
-- processing. 'Nothing' means disable the report page entirely.
, appInboxDebugReportLength :: Maybe Int
}
instance FromJSON AppSettings where
@ -196,6 +200,7 @@ instance FromJSON AppSettings where
appRejectOnMaxKeys <- o .: "reject-on-max-keys"
appDropDeliveryAfter <- ndt <$> o .: "drop-delivery-after"
appDeliveryRetryFreq <- interval <$> o .: "retry-delivery-every"
appInboxDebugReportLength <- o .:? "activity-debug-reports"
return AppSettings {..}
where