1
0
Fork 0
mirror of https://code.sup39.dev/repos/Wqawg synced 2025-01-15 03:55:08 +09:00

S2S: Implement loomCreateNoteF

This commit is contained in:
fr33domlover 2022-10-16 12:24:41 +00:00
parent 2e7f9ef5e6
commit d5e913d97a
3 changed files with 71 additions and 59 deletions

View file

@ -16,7 +16,7 @@
module Vervis.Federation.Discussion module Vervis.Federation.Discussion
( personCreateNoteF ( personCreateNoteF
, deckCreateNoteF , deckCreateNoteF
--, loomCreateNoteF , loomCreateNoteF
) )
where where
@ -309,37 +309,51 @@ deckCreateNoteF now recipDeckHash author body mfwd luCreate note = do
forkWorker "projectCreateNoteF inbox-forwarding" forwardHttp forkWorker "projectCreateNoteF inbox-forwarding" forwardHttp
return "Stored to inbox, cached comment, and did inbox forwarding" return "Stored to inbox, cached comment, and did inbox forwarding"
{- loomCreateNoteF
repoCreateNoteF
:: UTCTime :: UTCTime
-> KeyHashid Repo -> KeyHashid Loom
-> RemoteAuthor -> RemoteAuthor
-> ActivityBody -> ActivityBody
-> Maybe (LocalRecipientSet, ByteString) -> Maybe (RecipientRoutes, ByteString)
-> LocalURI -> LocalURI
-> Note URIMode -> AP.Note URIMode
-> ExceptT Text Handler Text -> ExceptT Text Handler Text
repoCreateNoteF now repoRecip author body mfwd luCreate note = do loomCreateNoteF now recipLoomHash author body mfwd luCreate note = do
(luNote, published, context, mparent, source, content) <- checkNote note
case context of recipLoomID <- decodeKeyHashid404 recipLoomHash
Right _ -> return "Not using; context isn't local" (luNote, published, Comment maybeParent topic source content) <- do
Left (NoteContextProjectTicket _ _ _) -> (luId, luAuthor, published, comment) <- parseRemoteComment note
return "Context is a project-ticket, ignoring activity" unless (luAuthor == objUriLocal (remoteAuthorURI author)) $
Left (NoteContextRepoProposal shr rp ltid) -> do throwE "Create author != note author"
mremotesHttp <- runDBExcept $ do return (luId, published, comment)
(rid, ibid) <- lift getRepoRecip404
(_, _, _, Entity _ lt, _, Entity _ trl, _, _, _) <- do case topic of
mticket <- lift $ getRepoProposal shr rp ltid Right _ ->
fromMaybeE mticket "Context: No such repo-patch" pure "Topic is remote, i.e. not mine, so ignoring activity"
if ticketRepoLocalRepo trl == rid Left (CommentTopicTicket _ _) ->
then do pure "Topic is a local issue, i.e. not mine, so ignoring activity"
mractid <- lift $ insertToInbox now author body ibid luCreate False Left (CommentTopicCloth loomID clothID)
| loomID /= recipLoomID ->
pure "Topic is some other loom's MR, so ignoring activity"
| otherwise -> do
msgOrForward <- runDBExcept $ do
Entity recipActorID recipActor <- lift $ do
loom <- get404 recipLoomID
let actorID = loomActor loom
Entity actorID <$> getJust actorID
(_l, _tl, Entity _ ticket, _a, _r, _) <- do
mcloth <- lift $ getCloth recipLoomID clothID
fromMaybeE mcloth "Topic: No such cloth in DB"
mractid <- lift $ insertToInbox now author body (actorInbox recipActor) luCreate False
case mractid of case mractid of
Nothing -> return $ Left "Activity already in my inbox" Nothing -> return $ Left "Activity already in my inbox"
Just ractid -> do Just createID -> do
let did = localTicketDiscuss lt let did = ticketDiscuss ticket
meparent <- traverse (getParent did) mparent meparent <- traverse (getMessageParent did) maybeParent
mmid <- lift $ insertToDiscussion author luNote published source content did meparent ractid mmid <- lift $ insertToDiscussion author luNote published source content did meparent createID
case mmid of case mmid of
Nothing -> return $ Left "I already have this comment, just storing in inbox" Nothing -> return $ Left "I already have this comment, just storing in inbox"
Just mid -> lift $ do Just mid -> lift $ do
@ -348,26 +362,18 @@ repoCreateNoteF now repoRecip author body mfwd luCreate note = do
Nothing -> Nothing ->
return $ Left "Storing in inbox, caching comment, no inbox forwarding header" return $ Left "Storing in inbox, caching comment, no inbox forwarding header"
Just (localRecips, sig) -> Right <$> do Just (localRecips, sig) -> Right <$> do
ltkhid <- encodeKeyHashid ltid clothHash <- encodeKeyHashid clothID
let sieve = let sieve =
makeRecipientSet makeRecipientSet
[] []
[ LocalPersonCollectionRepoFollowers shrRecip rpRecip [ LocalStageLoomFollowers recipLoomHash
, LocalPersonCollectionRepoTeam shrRecip rpRecip , LocalStageClothFollowers recipLoomHash clothHash
, LocalPersonCollectionRepoProposalFollowers shrRecip rpRecip ltkhid
--, LocalPersonCollectionProjectTicketTeam shrRecip prjRecip ltkhid
] ]
remoteRecips <- insertRemoteActivityToLocalInboxes False ractid $ localRecipSieve' sieve False False localRecips forwardActivityDB
(sig,) <$> deliverRemoteDB_R (actbBL body) ractid rid sig remoteRecips (actbBL body) localRecips sig recipActorID
else return $ Left "Context is a repo-patch of another repo" (LocalActorLoom recipLoomHash) sieve createID
case mremotesHttp of case msgOrForward of
Left msg -> return msg Left msg -> return msg
Right (sig, remotesHttp) -> do Right forwardHttp -> do
forkWorker "repoCreateNoteF inbox forwarding by http" $ deliverRemoteHTTP_R now shrRecip rpRecip (actbBL body) sig remotesHttp forkWorker "projectCreateNoteF inbox-forwarding" forwardHttp
return "Stored to inbox, cached comment, and did inbox forwarding" return "Stored to inbox, cached comment, and did inbox forwarding"
where
getRepoRecip404 = do
sid <- getKeyBy404 $ UniqueSharer shrRecip
Entity rid r <- getBy404 $ UniqueRepo rpRecip sid
return (rid, repoInbox r)
-}

View file

@ -189,7 +189,7 @@ postDeckInboxR recipDeckHash =
case obj of case obj of
AP.CreateNote _ note -> AP.CreateNote _ note ->
(,Nothing) <$> deckCreateNoteF now recipDeckHash author body mfwd luActivity note (,Nothing) <$> deckCreateNoteF now recipDeckHash author body mfwd luActivity note
_ -> error "Unsupported create object type for decks" _ -> return ("Unsupported create object type for decks", Nothing)
{- {-
FollowActivity follow -> FollowActivity follow ->
(,Nothing) <$> projectFollowF shrRecip prjRecip now remoteAuthor body mfwd luActivity follow (,Nothing) <$> projectFollowF shrRecip prjRecip now remoteAuthor body mfwd luActivity follow

View file

@ -77,6 +77,7 @@ import Vervis.Access
import Vervis.API import Vervis.API
import Vervis.Federation.Auth import Vervis.Federation.Auth
import Vervis.Federation.Collab import Vervis.Federation.Collab
import Vervis.Federation.Discussion
import Vervis.Federation.Ticket import Vervis.Federation.Ticket
import Vervis.FedURI import Vervis.FedURI
import Vervis.Form.Project import Vervis.Form.Project
@ -152,6 +153,11 @@ postLoomInboxR recipLoomHash =
loomAcceptF now recipLoomHash author body mfwd luActivity accept loomAcceptF now recipLoomHash author body mfwd luActivity accept
AP.ApplyActivity apply-> AP.ApplyActivity apply->
loomApplyF now recipLoomHash author body mfwd luActivity apply loomApplyF now recipLoomHash author body mfwd luActivity apply
AP.CreateActivity (AP.Create obj _mtarget) ->
case obj of
AP.CreateNote _ note ->
(,Nothing) <$> loomCreateNoteF now recipLoomHash author body mfwd luActivity note
_ -> return ("Unsupported create object type for looms", Nothing)
AP.InviteActivity invite -> AP.InviteActivity invite ->
topicInviteF now (GrantResourceLoom recipLoomHash) author body mfwd luActivity invite topicInviteF now (GrantResourceLoom recipLoomHash) author body mfwd luActivity invite
AP.OfferActivity (AP.Offer obj target) -> AP.OfferActivity (AP.Offer obj target) ->