Switch activityId from LocalURI to Maybe LocalURI, for C2S posting without ID
This commit is contained in:
parent
1ae924558f
commit
7c30ee2d52
6 changed files with 47 additions and 30 deletions
|
@ -440,7 +440,7 @@ createNoteC host (Note mluNote luAttrib aud muParent muContext mpublished source
|
||||||
, messageRoot = did
|
, messageRoot = did
|
||||||
}
|
}
|
||||||
let activity luAct luNote = Doc host Activity
|
let activity luAct luNote = Doc host Activity
|
||||||
{ activityId = luAct
|
{ activityId = Just luAct
|
||||||
, activityActor = luAttrib
|
, activityActor = luAttrib
|
||||||
, activitySummary =
|
, activitySummary =
|
||||||
Just $ TextHtml $ TL.toStrict $ renderHtml summary
|
Just $ TextHtml $ TL.toStrict $ renderHtml summary
|
||||||
|
|
|
@ -129,10 +129,14 @@ handleSharerInbox
|
||||||
-> ExceptT Text Handler Text
|
-> ExceptT Text Handler Text
|
||||||
handleSharerInbox _now shrRecip (ActivityAuthLocalPerson pidAuthor) body = do
|
handleSharerInbox _now shrRecip (ActivityAuthLocalPerson pidAuthor) body = do
|
||||||
(shrActivity, obiid) <- do
|
(shrActivity, obiid) <- do
|
||||||
|
luAct <-
|
||||||
|
fromMaybeE
|
||||||
|
(activityId $ actbActivity body)
|
||||||
|
"Local activity: No 'id'"
|
||||||
route <-
|
route <-
|
||||||
case decodeRouteLocal $ activityId $ actbActivity body of
|
fromMaybeE
|
||||||
Nothing -> throwE "Local activity: Not a valid route"
|
(decodeRouteLocal luAct)
|
||||||
Just r -> return r
|
"Local activity: Not a valid route"
|
||||||
case route of
|
case route of
|
||||||
SharerOutboxItemR shr obikhid ->
|
SharerOutboxItemR shr obikhid ->
|
||||||
(shr,) <$> decodeKeyHashidE obikhid "Local activity: ID is invalid hashid"
|
(shr,) <$> decodeKeyHashidE obikhid "Local activity: ID is invalid hashid"
|
||||||
|
@ -169,10 +173,14 @@ handleSharerInbox _now shrRecip (ActivityAuthLocalPerson pidAuthor) body = do
|
||||||
return $ "Activity inserted to inbox of /s/" <> recip
|
return $ "Activity inserted to inbox of /s/" <> recip
|
||||||
handleSharerInbox _now shrRecip (ActivityAuthLocalProject jidAuthor) body = do
|
handleSharerInbox _now shrRecip (ActivityAuthLocalProject jidAuthor) body = do
|
||||||
(shrActivity, prjActivity, obiid) <- do
|
(shrActivity, prjActivity, obiid) <- do
|
||||||
|
luAct <-
|
||||||
|
fromMaybeE
|
||||||
|
(activityId $ actbActivity body)
|
||||||
|
"Local activity: No 'id'"
|
||||||
route <-
|
route <-
|
||||||
case decodeRouteLocal $ activityId $ actbActivity body of
|
fromMaybeE
|
||||||
Nothing -> throwE "Local activity: Not a valid route"
|
(decodeRouteLocal luAct)
|
||||||
Just r -> return r
|
"Local activity: Not a valid route"
|
||||||
case route of
|
case route of
|
||||||
ProjectOutboxItemR shr prj obikhid ->
|
ProjectOutboxItemR shr prj obikhid ->
|
||||||
(shr,prj,) <$> decodeKeyHashidE obikhid "Local activity: ID is invalid hashid"
|
(shr,prj,) <$> decodeKeyHashidE obikhid "Local activity: ID is invalid hashid"
|
||||||
|
|
|
@ -107,6 +107,8 @@ sharerCreateNoteF
|
||||||
-> Note
|
-> Note
|
||||||
-> ExceptT Text Handler Text
|
-> ExceptT Text Handler Text
|
||||||
sharerCreateNoteF now shrRecip author body (Note mluNote _ _ muParent muContext mpublished _ _) = do
|
sharerCreateNoteF now shrRecip author body (Note mluNote _ _ muParent muContext mpublished _ _) = do
|
||||||
|
luCreate <-
|
||||||
|
fromMaybeE (activityId $ actbActivity body) "Create without 'id'"
|
||||||
_luNote <- fromMaybeE mluNote "Note without note id"
|
_luNote <- fromMaybeE mluNote "Note without note id"
|
||||||
_published <- fromMaybeE mpublished "Note without 'published' field"
|
_published <- fromMaybeE mpublished "Note without 'published' field"
|
||||||
uContext <- fromMaybeE muContext "Note without context"
|
uContext <- fromMaybeE muContext "Note without context"
|
||||||
|
@ -125,7 +127,8 @@ sharerCreateNoteF now shrRecip author body (Note mluNote _ _ muParent muContext
|
||||||
valid <- checkContextParent context mparent
|
valid <- checkContextParent context mparent
|
||||||
case valid of
|
case valid of
|
||||||
Left e -> return $ Left e
|
Left e -> return $ Left e
|
||||||
Right _ -> Right <$> insertToInbox (personInbox personRecip)
|
Right _ ->
|
||||||
|
Right <$> insertToInbox luCreate (personInbox personRecip)
|
||||||
where
|
where
|
||||||
checkContextParent context mparent = runExceptT $ do
|
checkContextParent context mparent = runExceptT $ do
|
||||||
case context of
|
case context of
|
||||||
|
@ -169,11 +172,10 @@ sharerCreateNoteF now shrRecip author body (Note mluNote _ _ muParent muContext
|
||||||
did <- fromMaybeE mdid "Remote parent known, but no context RemoteDiscussion"
|
did <- fromMaybeE mdid "Remote parent known, but no context RemoteDiscussion"
|
||||||
unless (messageRoot m == did) $
|
unless (messageRoot m == did) $
|
||||||
throwE "Remote parent belongs to a different discussion"
|
throwE "Remote parent belongs to a different discussion"
|
||||||
insertToInbox ibidRecip = do
|
insertToInbox luCreate ibidRecip = do
|
||||||
let iidAuthor = remoteAuthorInstance author
|
let iidAuthor = remoteAuthorInstance author
|
||||||
luActivity = activityId $ actbActivity body
|
|
||||||
jsonObj = PersistJSON $ actbObject body
|
jsonObj = PersistJSON $ actbObject body
|
||||||
ract = RemoteActivity iidAuthor luActivity jsonObj now
|
ract = RemoteActivity iidAuthor luCreate jsonObj now
|
||||||
ractid <- either entityKey id <$> insertBy' ract
|
ractid <- either entityKey id <$> insertBy' ract
|
||||||
ibiid <- insert $ InboxItem True
|
ibiid <- insert $ InboxItem True
|
||||||
mibrid <- insertUnique $ InboxItemRemote ibidRecip ractid ibiid
|
mibrid <- insertUnique $ InboxItemRemote ibidRecip ractid ibiid
|
||||||
|
@ -199,6 +201,8 @@ projectCreateNoteF
|
||||||
-> Note
|
-> Note
|
||||||
-> ExceptT Text Handler Text
|
-> ExceptT Text Handler Text
|
||||||
projectCreateNoteF now shrRecip prjRecip author body (Note mluNote _ _ muParent muCtx mpub src content) = do
|
projectCreateNoteF now shrRecip prjRecip author body (Note mluNote _ _ muParent muCtx mpub src content) = do
|
||||||
|
luCreate <-
|
||||||
|
fromMaybeE (activityId $ actbActivity body) "Create without 'id'"
|
||||||
luNote <- fromMaybeE mluNote "Note without note id"
|
luNote <- fromMaybeE mluNote "Note without note id"
|
||||||
published <- fromMaybeE mpub "Note without 'published' field"
|
published <- fromMaybeE mpub "Note without 'published' field"
|
||||||
uContext <- fromMaybeE muCtx "Note without context"
|
uContext <- fromMaybeE muCtx "Note without context"
|
||||||
|
@ -224,7 +228,7 @@ projectCreateNoteF now shrRecip prjRecip author body (Note mluNote _ _ muParent
|
||||||
mremotesHttp <- runDBExcept $ do
|
mremotesHttp <- runDBExcept $ do
|
||||||
(sid, fsidProject, fsidTicket, jid, ibid, did, meparent) <- getContextAndParent num mparent
|
(sid, fsidProject, fsidTicket, jid, ibid, did, meparent) <- getContextAndParent num mparent
|
||||||
lift $ join <$> do
|
lift $ join <$> do
|
||||||
mmid <- insertToDiscussion luNote published ibid did meparent fsidTicket
|
mmid <- insertToDiscussion luCreate luNote published ibid did meparent fsidTicket
|
||||||
for mmid $ \ (ractid, mid) -> do
|
for mmid $ \ (ractid, mid) -> do
|
||||||
updateOrphans luNote did mid
|
updateOrphans luNote did mid
|
||||||
for msig $ \ sig -> do
|
for msig $ \ sig -> do
|
||||||
|
@ -278,12 +282,12 @@ projectCreateNoteF now shrRecip prjRecip author body (Note mluNote _ _ muParent
|
||||||
return mid
|
return mid
|
||||||
Nothing -> return $ Right $ l2f hParent luParent
|
Nothing -> return $ Right $ l2f hParent luParent
|
||||||
return (sid, fsidProject, ticketFollowers t, jid, ibid, did, meparent)
|
return (sid, fsidProject, ticketFollowers t, jid, ibid, did, meparent)
|
||||||
insertToDiscussion luNote published ibid did meparent fsid = do
|
insertToDiscussion luCreate luNote published ibid did meparent fsid = do
|
||||||
let iidAuthor = remoteAuthorInstance author
|
let iidAuthor = remoteAuthorInstance author
|
||||||
raidAuthor = remoteAuthorId author
|
raidAuthor = remoteAuthorId author
|
||||||
ractid <- either entityKey id <$> insertBy' RemoteActivity
|
ractid <- either entityKey id <$> insertBy' RemoteActivity
|
||||||
{ remoteActivityInstance = iidAuthor
|
{ remoteActivityInstance = iidAuthor
|
||||||
, remoteActivityIdent = activityId $ actbActivity body
|
, remoteActivityIdent = luCreate
|
||||||
, remoteActivityContent = PersistJSON $ actbObject body
|
, remoteActivityContent = PersistJSON $ actbObject body
|
||||||
, remoteActivityReceived = now
|
, remoteActivityReceived = now
|
||||||
}
|
}
|
||||||
|
|
|
@ -102,6 +102,7 @@ sharerOfferTicketF
|
||||||
-> ExceptT Text Handler Text
|
-> ExceptT Text Handler Text
|
||||||
sharerOfferTicketF now shrRecip author body (Offer ticket uTarget) = do
|
sharerOfferTicketF now shrRecip author body (Offer ticket uTarget) = do
|
||||||
(hProject, shrProject, prjProject) <- parseTarget uTarget
|
(hProject, shrProject, prjProject) <- parseTarget uTarget
|
||||||
|
luOffer <- fromMaybeE (activityId $ actbActivity body) "Offer without 'id'"
|
||||||
deps <- checkOffer ticket hProject shrProject prjProject
|
deps <- checkOffer ticket hProject shrProject prjProject
|
||||||
local <- hostIsLocal hProject
|
local <- hostIsLocal hProject
|
||||||
runDBExcept $ do
|
runDBExcept $ do
|
||||||
|
@ -110,7 +111,7 @@ sharerOfferTicketF now shrRecip author body (Offer ticket uTarget) = do
|
||||||
p <- getValBy404 $ UniquePersonIdent sid
|
p <- getValBy404 $ UniquePersonIdent sid
|
||||||
return $ personInbox p
|
return $ personInbox p
|
||||||
when local $ checkTargetAndDeps shrProject prjProject deps
|
when local $ checkTargetAndDeps shrProject prjProject deps
|
||||||
lift $ insertToInbox ibidRecip
|
lift $ insertToInbox luOffer ibidRecip
|
||||||
where
|
where
|
||||||
parseTarget u = do
|
parseTarget u = do
|
||||||
let (h, lu) = f2l u
|
let (h, lu) = f2l u
|
||||||
|
@ -133,9 +134,8 @@ sharerOfferTicketF now shrRecip author body (Offer ticket uTarget) = do
|
||||||
mt <- lift $ getBy $ UniqueTicket jid dep
|
mt <- lift $ getBy $ UniqueTicket jid dep
|
||||||
unless (isJust mt) $
|
unless (isJust mt) $
|
||||||
throwE "Local dep: No such ticket number in DB"
|
throwE "Local dep: No such ticket number in DB"
|
||||||
insertToInbox ibidRecip = do
|
insertToInbox luOffer ibidRecip = do
|
||||||
let iidAuthor = remoteAuthorInstance author
|
let iidAuthor = remoteAuthorInstance author
|
||||||
luOffer = activityId $ actbActivity body
|
|
||||||
jsonObj = PersistJSON $ actbObject body
|
jsonObj = PersistJSON $ actbObject body
|
||||||
ract = RemoteActivity iidAuthor luOffer jsonObj now
|
ract = RemoteActivity iidAuthor luOffer jsonObj now
|
||||||
ractid <- either entityKey id <$> insertBy' ract
|
ractid <- either entityKey id <$> insertBy' ract
|
||||||
|
@ -172,6 +172,10 @@ projectOfferTicketF
|
||||||
]
|
]
|
||||||
return t
|
return t
|
||||||
Right () -> do
|
Right () -> do
|
||||||
|
luOffer <-
|
||||||
|
fromMaybeE
|
||||||
|
(activityId $ actbActivity body)
|
||||||
|
"Offer without 'id'"
|
||||||
hLocal <- getsYesod siteInstanceHost
|
hLocal <- getsYesod siteInstanceHost
|
||||||
deps <- checkOffer ticket hLocal shrRecip prjRecip
|
deps <- checkOffer ticket hLocal shrRecip prjRecip
|
||||||
msig <- checkForward shrRecip prjRecip
|
msig <- checkForward shrRecip prjRecip
|
||||||
|
@ -181,7 +185,7 @@ projectOfferTicketF
|
||||||
mremotesHttp <- runDBExcept $ do
|
mremotesHttp <- runDBExcept $ do
|
||||||
(sid, jid, ibid, fsid, tids) <- getProjectAndDeps deps
|
(sid, jid, ibid, fsid, tids) <- getProjectAndDeps deps
|
||||||
lift $ join <$> do
|
lift $ join <$> do
|
||||||
mractid <- insertTicket jid ibid tids
|
mractid <- insertTicket luOffer jid ibid tids
|
||||||
for mractid $ \ ractid -> for msig $ \ sig -> do
|
for mractid $ \ ractid -> for msig $ \ sig -> do
|
||||||
remoteRecips <- deliverLocal ractid colls sid fsid
|
remoteRecips <- deliverLocal ractid colls sid fsid
|
||||||
(sig,) <$> deliverRemoteDB (actbBL body) ractid jid sig remoteRecips
|
(sig,) <$> deliverRemoteDB (actbBL body) ractid jid sig remoteRecips
|
||||||
|
@ -234,12 +238,12 @@ projectOfferTicketF
|
||||||
mtid <- lift $ getKeyBy $ UniqueTicket jid dep
|
mtid <- lift $ getKeyBy $ UniqueTicket jid dep
|
||||||
fromMaybeE mtid "Local dep: No such ticket number in DB"
|
fromMaybeE mtid "Local dep: No such ticket number in DB"
|
||||||
return (sid, jid, projectInbox j, projectFollowers j, tids)
|
return (sid, jid, projectInbox j, projectFollowers j, tids)
|
||||||
insertTicket jid ibid deps = do
|
insertTicket luOffer jid ibid deps = do
|
||||||
let iidAuthor = remoteAuthorInstance author
|
let iidAuthor = remoteAuthorInstance author
|
||||||
raidAuthor = remoteAuthorId author
|
raidAuthor = remoteAuthorId author
|
||||||
ractid <- either entityKey id <$> insertBy' RemoteActivity
|
ractid <- either entityKey id <$> insertBy' RemoteActivity
|
||||||
{ remoteActivityInstance = iidAuthor
|
{ remoteActivityInstance = iidAuthor
|
||||||
, remoteActivityIdent = activityId $ actbActivity body
|
, remoteActivityIdent = luOffer
|
||||||
, remoteActivityContent = PersistJSON $ actbObject body
|
, remoteActivityContent = PersistJSON $ actbObject body
|
||||||
, remoteActivityReceived = now
|
, remoteActivityReceived = now
|
||||||
}
|
}
|
||||||
|
|
|
@ -317,7 +317,7 @@ changes hLocal ctx =
|
||||||
let localUri = LocalURI "/x/y" ""
|
let localUri = LocalURI "/x/y" ""
|
||||||
fedUri = l2f "x.y" localUri
|
fedUri = l2f "x.y" localUri
|
||||||
doc = Doc "x.y" Activity
|
doc = Doc "x.y" Activity
|
||||||
{ activityId = localUri
|
{ activityId = Nothing
|
||||||
, activityActor = localUri
|
, activityActor = localUri
|
||||||
, activitySummary = Nothing
|
, activitySummary = Nothing
|
||||||
, activityAudience = Audience [] [] [] [] [] []
|
, activityAudience = Audience [] [] [] [] [] []
|
||||||
|
@ -439,7 +439,7 @@ changes hLocal ctx =
|
||||||
|
|
||||||
luAttrib = LocalURI ("/s/" <> shr2text shr) ""
|
luAttrib = LocalURI ("/s/" <> shr2text shr) ""
|
||||||
activity luAct luNote = Doc hLocal Activity
|
activity luAct luNote = Doc hLocal Activity
|
||||||
{ activityId = luAct
|
{ activityId = Just luAct
|
||||||
, activityActor = luAttrib
|
, activityActor = luAttrib
|
||||||
, activitySummary = Nothing
|
, activitySummary = Nothing
|
||||||
, activityAudience = aud
|
, activityAudience = aud
|
||||||
|
@ -684,7 +684,7 @@ changes hLocal ctx =
|
||||||
let localUri = LocalURI "/x/y" ""
|
let localUri = LocalURI "/x/y" ""
|
||||||
fedUri = l2f "x.y" localUri
|
fedUri = l2f "x.y" localUri
|
||||||
doc = Doc "x.y" Activity
|
doc = Doc "x.y" Activity
|
||||||
{ activityId = localUri
|
{ activityId = Nothing
|
||||||
, activityActor = localUri
|
, activityActor = localUri
|
||||||
, activitySummary = Nothing
|
, activitySummary = Nothing
|
||||||
, activityAudience = Audience [] [] [] [] [] []
|
, activityAudience = Audience [] [] [] [] [] []
|
||||||
|
@ -748,7 +748,7 @@ changes hLocal ctx =
|
||||||
: #{ticket20190612Title ticket}.
|
: #{ticket20190612Title ticket}.
|
||||||
|]
|
|]
|
||||||
doc luAct = Doc hLocal Activity
|
doc luAct = Doc hLocal Activity
|
||||||
{ activityId = luAct
|
{ activityId = Just luAct
|
||||||
, activityActor = author
|
, activityActor = author
|
||||||
, activitySummary =
|
, activitySummary =
|
||||||
Just $ TextHtml $ TL.toStrict $ renderHtml $
|
Just $ TextHtml $ TL.toStrict $ renderHtml $
|
||||||
|
|
|
@ -759,7 +759,7 @@ data SpecificActivity
|
||||||
| RejectActivity Reject
|
| RejectActivity Reject
|
||||||
|
|
||||||
data Activity = Activity
|
data Activity = Activity
|
||||||
{ activityId :: LocalURI
|
{ activityId :: Maybe LocalURI
|
||||||
, activityActor :: LocalURI
|
, activityActor :: LocalURI
|
||||||
, activitySummary :: Maybe TextHtml
|
, activitySummary :: Maybe TextHtml
|
||||||
, activityAudience :: Audience
|
, activityAudience :: Audience
|
||||||
|
@ -769,11 +769,12 @@ data Activity = Activity
|
||||||
instance ActivityPub Activity where
|
instance ActivityPub Activity where
|
||||||
jsonldContext _ = [as2Context, forgeContext, extContext]
|
jsonldContext _ = [as2Context, forgeContext, extContext]
|
||||||
parseObject o = do
|
parseObject o = do
|
||||||
(h, id_) <- f2l <$> o .: "id"
|
(h, actor) <- f2l <$> o .: "actor"
|
||||||
actor <- withHost h $ f2l <$> o .: "actor"
|
|
||||||
fmap (h,) $
|
fmap (h,) $
|
||||||
Activity id_ actor
|
Activity
|
||||||
<$> (fmap (TextHtml . sanitizeBalance) <$> o .:? "summary")
|
<$> withHostMaybe h (fmap f2l <$> o .:? "id")
|
||||||
|
<*> pure actor
|
||||||
|
<*> (fmap (TextHtml . sanitizeBalance) <$> o .:? "summary")
|
||||||
<*> parseAudience o
|
<*> parseAudience o
|
||||||
<*> do
|
<*> do
|
||||||
typ <- o .: "type"
|
typ <- o .: "type"
|
||||||
|
@ -788,7 +789,7 @@ instance ActivityPub Activity where
|
||||||
"Unrecognized activity type: " ++ T.unpack typ
|
"Unrecognized activity type: " ++ T.unpack typ
|
||||||
toSeries host (Activity id_ actor summary audience specific)
|
toSeries host (Activity id_ actor summary audience specific)
|
||||||
= "type" .= activityType specific
|
= "type" .= activityType specific
|
||||||
<> "id" .= l2f host id_
|
<> "id" .=? (l2f host <$> id_)
|
||||||
<> "actor" .= l2f host actor
|
<> "actor" .= l2f host actor
|
||||||
<> "summary" .=? summary
|
<> "summary" .=? summary
|
||||||
<> encodeAudience audience
|
<> encodeAudience audience
|
||||||
|
|
Loading…
Reference in a new issue