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

C2S Remove handler

This commit is contained in:
Pere Lev 2023-06-17 00:28:35 +03:00
parent 7b64ab56b1
commit 9673887479
No known key found for this signature in database
GPG key ID: 5252C5C863E5E57D

View file

@ -230,9 +230,110 @@ clientInvite now personMeID (ClientMsg maybeCap localRecips remoteRecips fwdHost
fwdHosts inviteID action fwdHosts inviteID action
return inviteID return inviteID
-- Meaning: The human wants to remove someone A from a resource R
-- Behavior:
-- * Some basic sanity checks
-- * Parse the Remove
-- * Make sure not removing myself
-- * Verify that a capability is specified
-- * If resource is local, verify it exists in DB
-- * Verify the target A and resource R are addressed in the Remove
-- * Insert the Remove to my inbox
-- * Asynchrnously deliver to:
-- * Resource+followers
-- * Member+followers
-- * My followers
clientRemove
:: UTCTime
-> PersonId
-> ClientMsg
-> AP.Remove URIMode
-> ActE OutboxItemId
clientRemove now personMeID (ClientMsg maybeCap localRecips remoteRecips fwdHosts action) remove = do
-- Check input
(resource, member) <- parseRemove (Left $ LocalActorPerson personMeID) remove
_capID <- fromMaybeE maybeCap "No capability provided"
-- Verify that resource is addressed by the Remove
bitraverse_
(verifyResourceAddressed localRecips)
(verifyRemoteAddressed remoteRecips)
resource
-- Verify that member is addressed by the Remove
bitraverse_
(verifyRecipientAddressed localRecips)
(verifyRemoteAddressed remoteRecips)
member
(actorMeID, localRecipsFinal, removeID) <- withDBExcept $ do
-- If resource is local, find it in our DB
_resourceDB <-
bitraverse
(flip getGrantResource "Resource not found in DB")
pure
resource
-- If member is local, find it in our DB
_memberDB <-
bitraverse
(flip getGrantRecip "Member not found in DB")
pure
member
-- Grab me from DB
(personMe, actorMe) <- lift $ do
p <- getJust personMeID
(p,) <$> getJust (personActor p)
-- Insert the Remove activity to my outbox
removeID <- lift $ insertEmptyOutboxItem' (actorOutbox actorMe) now
_luRemove <- lift $ updateOutboxItem' (LocalActorPerson personMeID) removeID action
-- Prepare local recipients for Remove delivery
sieve <- lift $ do
resourceHash <- bitraverse hashGrantResource' pure resource
recipientHash <- bitraverse hashGrantRecip pure member
senderHash <- encodeKeyHashid personMeID
let sieveActors = catMaybes
[ case resourceHash of
Left (GrantResourceRepo r) -> Just $ LocalActorRepo r
Left (GrantResourceDeck d) -> Just $ LocalActorDeck d
Left (GrantResourceLoom l) -> Just $ LocalActorLoom l
Right _ -> Nothing
, case recipientHash of
Left (GrantRecipPerson p) -> Just $ LocalActorPerson p
Right _ -> Nothing
]
sieveStages = catMaybes
[ Just $ LocalStagePersonFollowers senderHash
, case resourceHash of
Left (GrantResourceRepo r) -> Just $ LocalStageRepoFollowers r
Left (GrantResourceDeck d) -> Just $ LocalStageDeckFollowers d
Left (GrantResourceLoom l) -> Just $ LocalStageLoomFollowers l
Right _ -> Nothing
, case recipientHash of
Left (GrantRecipPerson p) -> Just $ LocalStagePersonFollowers p
Right _ -> Nothing
]
return $ makeRecipientSet sieveActors sieveStages
return
( personActor personMe
, localRecipSieve sieve False localRecips
, removeID
)
lift $ sendActivity
(LocalActorPerson personMeID) actorMeID localRecipsFinal remoteRecips
fwdHosts removeID action
return removeID
clientBehavior :: UTCTime -> PersonId -> ClientMsg -> ActE (Text, Act (), Next) clientBehavior :: UTCTime -> PersonId -> ClientMsg -> ActE (Text, Act (), Next)
clientBehavior now personID msg = clientBehavior now personID msg =
done . T.pack . show =<< done . T.pack . show =<<
case AP.actionSpecific $ cmAction msg of case AP.actionSpecific $ cmAction msg of
AP.InviteActivity invite -> clientInvite now personID msg invite AP.InviteActivity invite -> clientInvite now personID msg invite
AP.RemoveActivity remove -> clientRemove now personID msg remove
_ -> throwE "Unsupported activity type for C2S" _ -> throwE "Unsupported activity type for C2S"