mirror of
https://code.naskya.net/repos/ndqEd
synced 2025-01-10 17:16:47 +09:00
C2S: Enable creation of new decks, with automatic Grant and Follow
This commit is contained in:
parent
87bb369120
commit
a12409548f
2 changed files with 94 additions and 27 deletions
|
@ -1036,16 +1036,17 @@ verifyProjectRecip (Left (WITRepo shr rp _ _ _)) localRecips =
|
||||||
|
|
||||||
createTicketTrackerC
|
createTicketTrackerC
|
||||||
:: Entity Person
|
:: Entity Person
|
||||||
|
-> Actor
|
||||||
-> Maybe TextHtml
|
-> Maybe TextHtml
|
||||||
-> Audience URIMode
|
-> Audience URIMode
|
||||||
-> AP.ActorDetail
|
-> AP.ActorDetail
|
||||||
|
-> Maybe (Host, AP.ActorLocal URIMode)
|
||||||
-> Maybe FedURI
|
-> Maybe FedURI
|
||||||
-> ExceptT Text Handler OutboxItemId
|
-> ExceptT Text Handler OutboxItemId
|
||||||
createTicketTrackerC (Entity pidUser personUser) summary audience tracker muTarget = do
|
createTicketTrackerC (Entity pidUser personUser) senderActor summary audience tracker mlocal muTarget = do
|
||||||
error "Temporarily disabled"
|
|
||||||
|
|
||||||
{-
|
|
||||||
-- Check input
|
-- Check input
|
||||||
|
verifyNothingE mlocal "'id' not allowed in new TicketTracker to create"
|
||||||
(name, msummary) <- parseTracker tracker
|
(name, msummary) <- parseTracker tracker
|
||||||
senderHash <- encodeKeyHashid pidUser
|
senderHash <- encodeKeyHashid pidUser
|
||||||
now <- liftIO getCurrentTime
|
now <- liftIO getCurrentTime
|
||||||
|
@ -1056,14 +1057,14 @@ createTicketTrackerC (Entity pidUser personUser) summary audience tracker muTarg
|
||||||
checkFederation remoteRecips
|
checkFederation remoteRecips
|
||||||
(obiid, deliverHttpCreate, deliverHttpGrant) <- runDBExcept $ do
|
(obiid, deliverHttpCreate, deliverHttpGrant) <- runDBExcept $ do
|
||||||
|
|
||||||
-- Insert new project to DB
|
-- Insert new deck to DB
|
||||||
obiidCreate <- lift $ insertEmptyOutboxItem (personOutbox personUser) now
|
obiidCreate <- lift $ insertEmptyOutboxItem (actorOutbox senderActor) now
|
||||||
wid <- findWorkflow $ personIdent personUser
|
wid <- findWorkflow
|
||||||
(jid, obidDeck, ibidDeck) <- lift $ insertDeck now name msummary obiidCreate wid
|
(jid, obidDeck, ibidDeck, aidDeck, fsidDeck) <- lift $ insertDeck now name msummary obiidCreate wid
|
||||||
|
|
||||||
-- Insert the Create activity to author's outbox
|
-- Insert the Create activity to author's outbox
|
||||||
deckHash <- encodeKeyHashid jid
|
deckHash <- encodeKeyHashid jid
|
||||||
docCreate <- lift $ insertCreateToOutbox shrUser now blinded name msummary obiidCreate deckHash
|
docCreate <- lift $ insertCreateToOutbox senderHash now blinded name msummary obiidCreate deckHash
|
||||||
|
|
||||||
-- Deliver the Create activity to local recipients, and schedule
|
-- Deliver the Create activity to local recipients, and schedule
|
||||||
-- delivery for unavailable remote recipients
|
-- delivery for unavailable remote recipients
|
||||||
|
@ -1071,16 +1072,16 @@ createTicketTrackerC (Entity pidUser personUser) summary audience tracker muTarg
|
||||||
let sieve =
|
let sieve =
|
||||||
makeRecipientSet [] [LocalStagePersonFollowers senderHash]
|
makeRecipientSet [] [LocalStagePersonFollowers senderHash]
|
||||||
moreRemoteRecips <-
|
moreRemoteRecips <-
|
||||||
lift $ deliverLocal' True (LocalActorPerson senderHash) (personInbox personUser) obiidCreate $
|
lift $ deliverLocal' True (LocalActorPerson senderHash) (personActor personUser) obiidCreate $
|
||||||
localRecipSieve sieve False localRecips
|
localRecipSieve sieve False localRecips
|
||||||
checkFederation moreRemoteRecips
|
checkFederation moreRemoteRecips
|
||||||
lift $ deliverRemoteDB'' fwdHosts obiidCreate remoteRecips moreRemoteRecips
|
lift $ deliverRemoteDB'' fwdHosts obiidCreate remoteRecips moreRemoteRecips
|
||||||
|
|
||||||
-- Insert collaboration access for project's creator
|
-- Insert collaboration access for deck's creator
|
||||||
obiidGrant <- lift $ insertEmptyOutboxItem obidDeck now
|
obiidGrant <- lift $ insertEmptyOutboxItem obidDeck now
|
||||||
lift $ insertCollab jid obiidGrant
|
lift $ insertCollab jid obiidGrant
|
||||||
|
|
||||||
-- Insert a Grant activity to project's outbox
|
-- Insert a Grant activity to deck's outbox
|
||||||
let grantRecipActors = [LocalActorPerson senderHash]
|
let grantRecipActors = [LocalActorPerson senderHash]
|
||||||
grantRecipStages = [LocalStagePersonFollowers senderHash]
|
grantRecipStages = [LocalStagePersonFollowers senderHash]
|
||||||
docGrant <-
|
docGrant <-
|
||||||
|
@ -1090,11 +1091,29 @@ createTicketTrackerC (Entity pidUser personUser) summary audience tracker muTarg
|
||||||
-- delivery for unavailable remote recipients
|
-- delivery for unavailable remote recipients
|
||||||
remoteRecipsHttpGrant <- do
|
remoteRecipsHttpGrant <- do
|
||||||
remoteRecips <-
|
remoteRecips <-
|
||||||
lift $ deliverLocal' True (LocalActorDeck shrUser deckHash) ibidDeck obiidGrant $
|
lift $ deliverLocal' True (LocalActorDeck deckHash) aidDeck obiidGrant $
|
||||||
makeRecipientSet grantRecipActors grantRecipStages
|
makeRecipientSet grantRecipActors grantRecipStages
|
||||||
checkFederation remoteRecips
|
checkFederation remoteRecips
|
||||||
lift $ deliverRemoteDB'' [] obiidGrant [] remoteRecips
|
lift $ deliverRemoteDB'' [] obiidGrant [] remoteRecips
|
||||||
|
|
||||||
|
-- Insert follow record
|
||||||
|
obiidFollow <- lift $ insertEmptyOutboxItem (actorOutbox senderActor) now
|
||||||
|
obiidAccept <- lift $ insertEmptyOutboxItem obidDeck now
|
||||||
|
lift $ insert_ $ Follow (personActor personUser) fsidDeck True obiidFollow obiidAccept
|
||||||
|
|
||||||
|
-- Insert a Follow activity to sender's outbox, and an Accept to the
|
||||||
|
-- deck's outbox
|
||||||
|
luFollow <- lift $ insertFollowToOutbox senderHash deckHash obiidFollow
|
||||||
|
lift $ insertAcceptToOutbox senderHash deckHash obiidAccept luFollow
|
||||||
|
|
||||||
|
-- Deliver the Follow and Accept by simply manually inserting them to
|
||||||
|
-- deck and sender inboxes respectively
|
||||||
|
lift $ do
|
||||||
|
ibiidF <- insert $ InboxItem False
|
||||||
|
insert_ $ InboxItemLocal ibidDeck obiidFollow ibiidF
|
||||||
|
ibiidA <- insert $ InboxItem False
|
||||||
|
insert_ $ InboxItemLocal (actorInbox senderActor) obiidAccept ibiidA
|
||||||
|
|
||||||
-- Return instructions for HTTP delivery to remote recipients
|
-- Return instructions for HTTP delivery to remote recipients
|
||||||
return
|
return
|
||||||
( obiidCreate
|
( obiidCreate
|
||||||
|
@ -1117,7 +1136,7 @@ createTicketTrackerC (Entity pidUser personUser) summary audience tracker muTarg
|
||||||
return (name, msummary)
|
return (name, msummary)
|
||||||
|
|
||||||
findWorkflow = do
|
findWorkflow = do
|
||||||
mw <- lift $ selectFirst ([] :: Filter Workflow) []
|
mw <- lift $ selectFirst ([] :: [Filter Workflow]) []
|
||||||
entityKey <$> fromMaybeE mw "Can't find a workflow"
|
entityKey <$> fromMaybeE mw "Can't find a workflow"
|
||||||
|
|
||||||
insertDeck now name msummary obiidCreate wid = do
|
insertDeck now name msummary obiidCreate wid = do
|
||||||
|
@ -1141,7 +1160,7 @@ createTicketTrackerC (Entity pidUser personUser) summary audience tracker muTarg
|
||||||
, deckCollabUser = Nothing
|
, deckCollabUser = Nothing
|
||||||
, deckCreate = obiidCreate
|
, deckCreate = obiidCreate
|
||||||
}
|
}
|
||||||
return (did, obid, ibid)
|
return (did, obid, ibid, aid, fsid)
|
||||||
|
|
||||||
insertCreateToOutbox senderHash now blinded name msummary obiidCreate deckHash = do
|
insertCreateToOutbox senderHash now blinded name msummary obiidCreate deckHash = do
|
||||||
encodeRouteLocal <- getEncodeRouteLocal
|
encodeRouteLocal <- getEncodeRouteLocal
|
||||||
|
@ -1176,9 +1195,9 @@ createTicketTrackerC (Entity pidUser personUser) summary audience tracker muTarg
|
||||||
update obiidCreate [OutboxItemActivity =. persistJSONObjectFromDoc create]
|
update obiidCreate [OutboxItemActivity =. persistJSONObjectFromDoc create]
|
||||||
return create
|
return create
|
||||||
|
|
||||||
insertCollab jid obiidGrant = do
|
insertCollab did obiidGrant = do
|
||||||
cid <- insert Collab
|
cid <- insert Collab
|
||||||
insert_ $ CollabTopicLocalProject cid jid
|
insert_ $ CollabTopicLocalDeck cid did
|
||||||
insert_ $ CollabSenderLocal cid obiidGrant
|
insert_ $ CollabSenderLocal cid obiidGrant
|
||||||
insert_ $ CollabRecipLocal cid pidUser
|
insert_ $ CollabRecipLocal cid pidUser
|
||||||
insert_ $ CollabFulfillsLocalTopicCreation cid
|
insert_ $ CollabFulfillsLocalTopicCreation cid
|
||||||
|
@ -1210,7 +1229,50 @@ createTicketTrackerC (Entity pidUser personUser) summary audience tracker muTarg
|
||||||
}
|
}
|
||||||
update obiidGrant [OutboxItemActivity =. persistJSONObjectFromDoc grant]
|
update obiidGrant [OutboxItemActivity =. persistJSONObjectFromDoc grant]
|
||||||
return grant
|
return grant
|
||||||
-}
|
|
||||||
|
insertFollowToOutbox senderHash deckHash obiidFollow = do
|
||||||
|
encodeRouteLocal <- getEncodeRouteLocal
|
||||||
|
encodeRouteHome <- getEncodeRouteHome
|
||||||
|
hLocal <- asksSite siteInstanceHost
|
||||||
|
|
||||||
|
obikhid <- encodeKeyHashid obiidFollow
|
||||||
|
let luFollow = encodeRouteLocal $ PersonOutboxItemR senderHash obikhid
|
||||||
|
recips = [encodeRouteHome $ DeckR deckHash]
|
||||||
|
doc = Doc hLocal Activity
|
||||||
|
{ activityId = Just luFollow
|
||||||
|
, activityActor = encodeRouteLocal $ PersonR senderHash
|
||||||
|
, activityCapability = Nothing
|
||||||
|
, activitySummary = Nothing
|
||||||
|
, activityAudience = AP.Audience recips [] [] [] [] []
|
||||||
|
, activitySpecific = FollowActivity AP.Follow
|
||||||
|
{ AP.followObject = encodeRouteHome $ DeckR deckHash
|
||||||
|
, AP.followContext = Nothing
|
||||||
|
, AP.followHide = False
|
||||||
|
}
|
||||||
|
}
|
||||||
|
update obiidFollow [OutboxItemActivity =. persistJSONObjectFromDoc doc]
|
||||||
|
return luFollow
|
||||||
|
|
||||||
|
insertAcceptToOutbox senderHash deckHash obiidAccept luFollow = do
|
||||||
|
hLocal <- asksSite siteInstanceHost
|
||||||
|
encodeRouteLocal <- getEncodeRouteLocal
|
||||||
|
encodeRouteHome <- getEncodeRouteHome
|
||||||
|
|
||||||
|
obikhid <- encodeKeyHashid obiidAccept
|
||||||
|
|
||||||
|
let recips = [encodeRouteHome $ PersonR senderHash]
|
||||||
|
doc = Doc hLocal Activity
|
||||||
|
{ activityId = Just $ encodeRouteLocal $ DeckOutboxItemR deckHash obikhid
|
||||||
|
, activityActor = encodeRouteLocal $ DeckR deckHash
|
||||||
|
, activityCapability = Nothing
|
||||||
|
, activitySummary = Nothing
|
||||||
|
, activityAudience = Audience recips [] [] [] [] []
|
||||||
|
, activitySpecific = AcceptActivity Accept
|
||||||
|
{ acceptObject = ObjURI hLocal luFollow
|
||||||
|
, acceptResult = Nothing
|
||||||
|
}
|
||||||
|
}
|
||||||
|
update obiidAccept [OutboxItemActivity =. persistJSONObjectFromDoc doc]
|
||||||
|
|
||||||
data Followee
|
data Followee
|
||||||
= FolloweePerson (KeyHashid Person)
|
= FolloweePerson (KeyHashid Person)
|
||||||
|
|
|
@ -61,6 +61,7 @@ import Database.Persist.Local
|
||||||
import Vervis.ActivityPub
|
import Vervis.ActivityPub
|
||||||
import Vervis.Actor
|
import Vervis.Actor
|
||||||
import Vervis.ActorKey
|
import Vervis.ActorKey
|
||||||
|
import Vervis.API
|
||||||
import Vervis.Foundation
|
import Vervis.Foundation
|
||||||
import Vervis.Model
|
import Vervis.Model
|
||||||
import Vervis.Model.Ident
|
import Vervis.Model.Ident
|
||||||
|
@ -127,7 +128,9 @@ postPersonOutboxR personHash = do
|
||||||
unless federation badMethod
|
unless federation badMethod
|
||||||
|
|
||||||
personID <- decodeKeyHashid404 personHash
|
personID <- decodeKeyHashid404 personHash
|
||||||
person <- runDB $ get404 personID
|
(person, actor) <- runDB $ do
|
||||||
|
p <- get404 personID
|
||||||
|
(p,) <$> getJust (personActor p)
|
||||||
|
|
||||||
verifyPermission personID
|
verifyPermission personID
|
||||||
verifyContentTypeAP
|
verifyContentTypeAP
|
||||||
|
@ -138,7 +141,7 @@ postPersonOutboxR personHash = do
|
||||||
|
|
||||||
result <- runExceptT $ do
|
result <- runExceptT $ do
|
||||||
verifyAttribution $ AP.activityActor activity
|
verifyAttribution $ AP.activityActor activity
|
||||||
handle (Entity personID person) activity
|
handle (Entity personID person) actor activity
|
||||||
case result of
|
case result of
|
||||||
Left err -> invalidArgs [err]
|
Left err -> invalidArgs [err]
|
||||||
Right outboxItemID -> do
|
Right outboxItemID -> do
|
||||||
|
@ -157,8 +160,17 @@ postPersonOutboxR personHash = do
|
||||||
Just (PersonR actorHash) | actorHash == personHash -> return ()
|
Just (PersonR actorHash) | actorHash == personHash -> return ()
|
||||||
_ -> throwE "Can't post activity attributed to someone else"
|
_ -> throwE "Can't post activity attributed to someone else"
|
||||||
|
|
||||||
handle eperson (AP.Activity _mid actor mcap summary audience specific) =
|
handle eperson actorDB (AP.Activity _mid _actorAP mcap summary audience specific) =
|
||||||
case specific of
|
case specific of
|
||||||
|
AP.CreateActivity (AP.Create obj mtarget) ->
|
||||||
|
case obj of
|
||||||
|
{-
|
||||||
|
CreateNote _ note ->
|
||||||
|
createNoteC eperson sharer summary audience note mtarget
|
||||||
|
-}
|
||||||
|
AP.CreateTicketTracker detail mlocal ->
|
||||||
|
createTicketTrackerC eperson actorDB summary audience detail mlocal mtarget
|
||||||
|
_ -> throwE "Unsupported Create 'object' type"
|
||||||
{-
|
{-
|
||||||
AddActivity (AP.Add obj target) ->
|
AddActivity (AP.Add obj target) ->
|
||||||
case obj of
|
case obj of
|
||||||
|
@ -167,13 +179,6 @@ postPersonOutboxR personHash = do
|
||||||
_ -> throwE "Unsupported Add 'object' type"
|
_ -> throwE "Unsupported Add 'object' type"
|
||||||
ApplyActivity apply ->
|
ApplyActivity apply ->
|
||||||
applyC eperson sharer summary audience mcap apply
|
applyC eperson sharer summary audience mcap apply
|
||||||
CreateActivity (Create obj mtarget) ->
|
|
||||||
case obj of
|
|
||||||
CreateNote _ note ->
|
|
||||||
createNoteC eperson sharer summary audience note mtarget
|
|
||||||
CreateTicket _ ticket ->
|
|
||||||
createTicketC eperson sharer summary audience ticket mtarget
|
|
||||||
_ -> throwE "Unsupported Create 'object' type"
|
|
||||||
FollowActivity follow ->
|
FollowActivity follow ->
|
||||||
followC shr summary audience follow
|
followC shr summary audience follow
|
||||||
OfferActivity (Offer obj target) ->
|
OfferActivity (Offer obj target) ->
|
||||||
|
|
Loading…
Reference in a new issue