mirror of
https://code.sup39.dev/repos/Wqawg
synced 2025-01-15 01:05:11 +09:00
S2S: Re-enable deckCreateNoteF
This commit is contained in:
parent
71bceec18b
commit
2e7f9ef5e6
2 changed files with 74 additions and 67 deletions
|
@ -15,7 +15,7 @@
|
||||||
|
|
||||||
module Vervis.Federation.Discussion
|
module Vervis.Federation.Discussion
|
||||||
( personCreateNoteF
|
( personCreateNoteF
|
||||||
--, deckCreateNoteF
|
, deckCreateNoteF
|
||||||
--, loomCreateNoteF
|
--, loomCreateNoteF
|
||||||
)
|
)
|
||||||
where
|
where
|
||||||
|
@ -53,13 +53,14 @@ import Yesod.HttpSignature
|
||||||
import Database.Persist.JSON
|
import Database.Persist.JSON
|
||||||
import Network.FedURI
|
import Network.FedURI
|
||||||
import Network.HTTP.Digest
|
import Network.HTTP.Digest
|
||||||
import Web.ActivityPub hiding (ActorLocal (..))
|
|
||||||
import Web.Text
|
import Web.Text
|
||||||
import Yesod.ActivityPub
|
import Yesod.ActivityPub
|
||||||
import Yesod.FedURI
|
import Yesod.FedURI
|
||||||
import Yesod.Hashids
|
import Yesod.Hashids
|
||||||
import Yesod.MonadSite
|
import Yesod.MonadSite
|
||||||
|
|
||||||
|
import qualified Web.ActivityPub as AP
|
||||||
|
|
||||||
import Control.Monad.Trans.Except.Local
|
import Control.Monad.Trans.Except.Local
|
||||||
import Data.Tuple.Local
|
import Data.Tuple.Local
|
||||||
import Database.Persist.Local
|
import Database.Persist.Local
|
||||||
|
@ -78,6 +79,7 @@ import Vervis.Persist.Discussion
|
||||||
import Vervis.Recipient
|
import Vervis.Recipient
|
||||||
import Vervis.Settings
|
import Vervis.Settings
|
||||||
import Vervis.Ticket
|
import Vervis.Ticket
|
||||||
|
import Vervis.Web.Delivery
|
||||||
|
|
||||||
-- | Insert the new remote comment into the discussion tree. If we didn't have
|
-- | Insert the new remote comment into the discussion tree. If we didn't have
|
||||||
-- this comment before, return the database ID of the newly created cached
|
-- this comment before, return the database ID of the newly created cached
|
||||||
|
@ -170,7 +172,7 @@ personCreateNoteF
|
||||||
-> ActivityBody
|
-> ActivityBody
|
||||||
-> Maybe (RecipientRoutes, ByteString)
|
-> Maybe (RecipientRoutes, ByteString)
|
||||||
-> LocalURI
|
-> LocalURI
|
||||||
-> Note URIMode
|
-> AP.Note URIMode
|
||||||
-> ExceptT Text Handler Text
|
-> ExceptT Text Handler Text
|
||||||
personCreateNoteF now recipPersonHash author body mfwd luCreate note = do
|
personCreateNoteF now recipPersonHash author body mfwd luCreate note = do
|
||||||
|
|
||||||
|
@ -238,68 +240,74 @@ personCreateNoteF now recipPersonHash author body mfwd luCreate note = do
|
||||||
unless (messageRoot m == did) $
|
unless (messageRoot m == did) $
|
||||||
throwE "Remote parent belongs to a different discussion"
|
throwE "Remote parent belongs to a different discussion"
|
||||||
|
|
||||||
{-
|
deckCreateNoteF
|
||||||
projectCreateNoteF
|
|
||||||
:: UTCTime
|
:: UTCTime
|
||||||
-> KeyHashid Project
|
-> KeyHashid Deck
|
||||||
-> 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
|
||||||
projectCreateNoteF now deckRecip author body mfwd luCreate note = do
|
deckCreateNoteF now recipDeckHash author body mfwd luCreate note = do
|
||||||
(luNote, published, context, mparent, source, content) <- checkNote note
|
|
||||||
case context of
|
recipDeckID <- decodeKeyHashid404 recipDeckHash
|
||||||
Right _ -> return "Not using; context isn't local"
|
(luNote, published, Comment maybeParent topic source content) <- do
|
||||||
Left (NoteContextProjectTicket shr prj ltid) -> do
|
(luId, luAuthor, published, comment) <- parseRemoteComment note
|
||||||
mremotesHttp <- runDBExcept $ do
|
unless (luAuthor == objUriLocal (remoteAuthorURI author)) $
|
||||||
(jid, ibid) <- lift getProjectRecip404
|
throwE "Create author != note author"
|
||||||
(_, _, _, Entity _ lt, _, Entity _ tpl, _, _) <- do
|
return (luId, published, comment)
|
||||||
mticket <- lift $ getProjectTicket shr prj ltid
|
|
||||||
fromMaybeE mticket "Context: No such project-ticket"
|
case topic of
|
||||||
if ticketProjectLocalProject tpl == jid
|
Right _ ->
|
||||||
then do
|
pure "Topic is remote, i.e. not mine, so ignoring activity"
|
||||||
mractid <- lift $ insertToInbox now author body ibid luCreate False
|
Left (CommentTopicCloth _ _) ->
|
||||||
case mractid of
|
pure "Topic is a local cloth, i.e. not mine, so ignoring activity"
|
||||||
Nothing -> return $ Left "Activity already in my inbox"
|
Left (CommentTopicTicket deckID taskID)
|
||||||
Just ractid -> do
|
| deckID /= recipDeckID ->
|
||||||
let did = localTicketDiscuss lt
|
pure "Topic is some other deck's ticket, so ignoring activity"
|
||||||
meparent <- traverse (getParent did) mparent
|
| otherwise -> do
|
||||||
mmid <- lift $ insertToDiscussion author luNote published source content did meparent ractid
|
msgOrForward <- runDBExcept $ do
|
||||||
case mmid of
|
|
||||||
Nothing -> return $ Left "I already have this comment, just storing in inbox"
|
Entity recipActorID recipActor <- lift $ do
|
||||||
Just mid -> lift $ do
|
deck <- get404 recipDeckID
|
||||||
updateOrphans author luNote did mid
|
let actorID = deckActor deck
|
||||||
case mfwd of
|
Entity actorID <$> getJust actorID
|
||||||
Nothing ->
|
|
||||||
return $ Left "Storing in inbox, caching comment, no inbox forwarding header"
|
(_d, _td, Entity _ ticket, _a, _r) <- do
|
||||||
Just (localRecips, sig) -> Right <$> do
|
mticket <- lift $ getTicket recipDeckID taskID
|
||||||
ltkhid <- encodeKeyHashid ltid
|
fromMaybeE mticket "Topic: No such ticket in DB"
|
||||||
let sieve =
|
|
||||||
makeRecipientSet
|
mractid <- lift $ insertToInbox now author body (actorInbox recipActor) luCreate False
|
||||||
[]
|
case mractid of
|
||||||
[ LocalPersonCollectionProjectFollowers shrRecip prjRecip
|
Nothing -> return $ Left "Activity already in my inbox"
|
||||||
, LocalPersonCollectionProjectTeam shrRecip prjRecip
|
Just createID -> do
|
||||||
, LocalPersonCollectionProjectTicketFollowers shrRecip prjRecip ltkhid
|
let did = ticketDiscuss ticket
|
||||||
--, LocalPersonCollectionProjectTicketTeam shrRecip prjRecip ltkhid
|
meparent <- traverse (getMessageParent did) maybeParent
|
||||||
]
|
mmid <- lift $ insertToDiscussion author luNote published source content did meparent createID
|
||||||
remoteRecips <- insertRemoteActivityToLocalInboxes False ractid $ localRecipSieve' sieve False False localRecips
|
case mmid of
|
||||||
(sig,) <$> deliverRemoteDB_J (actbBL body) ractid jid sig remoteRecips
|
Nothing -> return $ Left "I already have this comment, just storing in inbox"
|
||||||
else return $ Left "Context is a project-ticket of another project"
|
Just mid -> lift $ do
|
||||||
case mremotesHttp of
|
updateOrphans author luNote did mid
|
||||||
Left msg -> return msg
|
case mfwd of
|
||||||
Right (sig, remotesHttp) -> do
|
Nothing ->
|
||||||
forkWorker "projectCreateNoteF inbox forwarding by http" $ deliverRemoteHTTP_J now shrRecip prjRecip (actbBL body) sig remotesHttp
|
return $ Left "Storing in inbox, caching comment, no inbox forwarding header"
|
||||||
return "Stored to inbox, cached comment, and did inbox forwarding"
|
Just (localRecips, sig) -> Right <$> do
|
||||||
Left (NoteContextRepoProposal _ _ _) -> return "Context is a repo-patch, ignoring activity"
|
taskHash <- encodeKeyHashid taskID
|
||||||
where
|
let sieve =
|
||||||
getProjectRecip404 = do
|
makeRecipientSet
|
||||||
sid <- getKeyBy404 $ UniqueSharer shrRecip
|
[]
|
||||||
Entity jid j <- getBy404 $ UniqueProject prjRecip sid
|
[ LocalStageDeckFollowers recipDeckHash
|
||||||
a <- getJust $ projectActor j
|
, LocalStageTicketFollowers recipDeckHash taskHash
|
||||||
return (jid, actorInbox a)
|
]
|
||||||
-}
|
forwardActivityDB
|
||||||
|
(actbBL body) localRecips sig recipActorID
|
||||||
|
(LocalActorDeck recipDeckHash) sieve createID
|
||||||
|
case msgOrForward of
|
||||||
|
Left msg -> return msg
|
||||||
|
Right forwardHttp -> do
|
||||||
|
forkWorker "projectCreateNoteF inbox-forwarding" forwardHttp
|
||||||
|
return "Stored to inbox, cached comment, and did inbox forwarding"
|
||||||
|
|
||||||
{-
|
{-
|
||||||
repoCreateNoteF
|
repoCreateNoteF
|
||||||
|
|
|
@ -100,6 +100,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
|
||||||
|
@ -184,14 +185,12 @@ postDeckInboxR recipDeckHash =
|
||||||
case specific of
|
case specific of
|
||||||
AP.AcceptActivity accept ->
|
AP.AcceptActivity accept ->
|
||||||
deckAcceptF now recipDeckHash author body mfwd luActivity accept
|
deckAcceptF now recipDeckHash author body mfwd luActivity accept
|
||||||
{-
|
AP.CreateActivity (AP.Create obj mtarget) ->
|
||||||
CreateActivity (Create obj mtarget) ->
|
|
||||||
case obj of
|
case obj of
|
||||||
CreateNote _ note ->
|
AP.CreateNote _ note ->
|
||||||
(,Nothing) <$> projectCreateNoteF now shrRecip prjRecip remoteAuthor body mfwd luActivity note
|
(,Nothing) <$> deckCreateNoteF now recipDeckHash author body mfwd luActivity note
|
||||||
CreateTicket _ ticket ->
|
_ -> error "Unsupported create object type for decks"
|
||||||
(,Nothing) <$> projectCreateTicketF now shrRecip prjRecip remoteAuthor body mfwd luActivity ticket mtarget
|
{-
|
||||||
_ -> error "Unsupported create object type for projects"
|
|
||||||
FollowActivity follow ->
|
FollowActivity follow ->
|
||||||
(,Nothing) <$> projectFollowF shrRecip prjRecip now remoteAuthor body mfwd luActivity follow
|
(,Nothing) <$> projectFollowF shrRecip prjRecip now remoteAuthor body mfwd luActivity follow
|
||||||
-}
|
-}
|
||||||
|
|
Loading…
Reference in a new issue