1
0
Fork 0
mirror of https://code.naskya.net/repos/ndqEd synced 2025-01-25 17:07:53 +09:00

AP: In getSharerPatchR, provide the list of patch versions, latest first

This commit is contained in:
fr33domlover 2020-05-25 12:39:25 +00:00
parent c63479470e
commit 17e59af1c4
9 changed files with 92 additions and 9 deletions

View file

@ -401,6 +401,7 @@ TicketProjectLocal
TicketRepoLocal TicketRepoLocal
context TicketContextLocalId context TicketContextLocalId
repo RepoId repo RepoId
branch Text Maybe
UniqueTicketRepoLocal context UniqueTicketRepoLocal context

View file

@ -523,7 +523,7 @@ createTicketC (Entity pidUser personUser) sharerUser summary audience ticket muT
forkWorker "createTicketC: async HTTP Accept delivery" $ deliverRemoteHttp dont obiidAccept docAccept remotesHttpAccept forkWorker "createTicketC: async HTTP Accept delivery" $ deliverRemoteHttp dont obiidAccept docAccept remotesHttpAccept
return talid return talid
where where
checkTicket shr (AP.Ticket mlocal luAttrib mpublished mupdated mcontext summary content source massigned resolved) mtarget = do checkTicket shr (AP.Ticket mlocal luAttrib mpublished mupdated mcontext summary content source massigned resolved mmr) mtarget = do
verifyNothingE mlocal "Ticket with 'id'" verifyNothingE mlocal "Ticket with 'id'"
encodeRouteLocal <- getEncodeRouteLocal encodeRouteLocal <- getEncodeRouteLocal
unless (encodeRouteLocal (SharerR shr) == luAttrib) $ unless (encodeRouteLocal (SharerR shr) == luAttrib) $
@ -534,6 +534,7 @@ createTicketC (Entity pidUser personUser) sharerUser summary audience ticket muT
verifyNothingE massigned "Ticket with 'assignedTo'" verifyNothingE massigned "Ticket with 'assignedTo'"
when resolved $ throwE "Ticket resolved" when resolved $ throwE "Ticket resolved"
target <- fromMaybeE mtarget "Create Ticket without 'target'" target <- fromMaybeE mtarget "Create Ticket without 'target'"
verifyNothingE mmr "Ticket with 'attachment'"
return (context, summary, content, source, target) return (context, summary, content, source, target)
parseTicketContext :: (MonadSite m, SiteEnv m ~ App) => FedURI -> ExceptT Text m (Either (ShrIdent, PrjIdent) FedURI) parseTicketContext :: (MonadSite m, SiteEnv m ~ App) => FedURI -> ExceptT Text m (Either (ShrIdent, PrjIdent) FedURI)
@ -677,6 +678,7 @@ createTicketC (Entity pidUser personUser) sharerUser summary audience ticket muT
, AP.ticketSource = source , AP.ticketSource = source
, AP.ticketAssignedTo = Nothing , AP.ticketAssignedTo = Nothing
, AP.ticketIsResolved = False , AP.ticketIsResolved = False
, AP.ticketAttachment = Nothing
} }
, createTarget = Just uTarget , createTarget = Just uTarget
} }

View file

@ -241,6 +241,7 @@ offerTicket shrAuthor (TextHtml title) (TextPandocMarkdown desc) shr prj = runEx
, AP.ticketSource = TextPandocMarkdown desc , AP.ticketSource = TextPandocMarkdown desc
, AP.ticketAssignedTo = Nothing , AP.ticketAssignedTo = Nothing
, AP.ticketIsResolved = False , AP.ticketIsResolved = False
, AP.ticketAttachment = Nothing
} }
offer = Offer offer = Offer
{ offerObject = ticket { offerObject = ticket
@ -308,6 +309,7 @@ createTicket shrAuthor (TextHtml title) (TextPandocMarkdown desc) target context
, AP.ticketSource = TextPandocMarkdown desc , AP.ticketSource = TextPandocMarkdown desc
, AP.ticketAssignedTo = Nothing , AP.ticketAssignedTo = Nothing
, AP.ticketIsResolved = False , AP.ticketIsResolved = False
, AP.ticketAttachment = Nothing
} }
create = Create create = Create
{ createObject = CreateTicket ticket { createObject = CreateTicket ticket

View file

@ -88,6 +88,7 @@ checkOffer ticket hProject shrProject prjProject = do
-- verifyNothingE (AP.ticketName ticket) "Ticket with 'name'" -- verifyNothingE (AP.ticketName ticket) "Ticket with 'name'"
verifyNothingE (AP.ticketAssignedTo ticket) "Ticket with 'assignedTo'" verifyNothingE (AP.ticketAssignedTo ticket) "Ticket with 'assignedTo'"
when (AP.ticketIsResolved ticket) $ throwE "Ticket resolved" when (AP.ticketIsResolved ticket) $ throwE "Ticket resolved"
verifyNothingE (AP.ticketAttachment ticket) "Ticket with 'attachment'"
sharerOfferTicketF sharerOfferTicketF
:: UTCTime :: UTCTime
@ -445,7 +446,7 @@ checkCreateTicket author ticket muTarget = do
else return $ Right u else return $ Right u
checkTicket (AP.Ticket mlocal attrib mpublished mupdated muContext _summary checkTicket (AP.Ticket mlocal attrib mpublished mupdated muContext _summary
_content _source muAssigned resolved) = do _content _source muAssigned resolved mmr) = do
(hTicket, tlocal) <- fromMaybeE mlocal "Ticket without 'id'" (hTicket, tlocal) <- fromMaybeE mlocal "Ticket without 'id'"
hl <- hostIsLocal hTicket hl <- hostIsLocal hTicket
when hl $ throwE "Remote author claims to create local ticket" when hl $ throwE "Remote author claims to create local ticket"
@ -460,6 +461,7 @@ checkCreateTicket author ticket muTarget = do
verifyNothingE mupdated "Ticket has 'updated'" verifyNothingE mupdated "Ticket has 'updated'"
verifyNothingE muAssigned "Ticket has 'assignedTo'" verifyNothingE muAssigned "Ticket has 'assignedTo'"
when resolved $ throwE "Ticket is resolved" when resolved $ throwE "Ticket is resolved"
verifyNothingE mmr "Ticket has 'attachment'"
return (context, tlocal, pub) return (context, tlocal, pub)

View file

@ -399,6 +399,7 @@ postPublishR = do
, ticketSource = TextPandocMarkdown desc , ticketSource = TextPandocMarkdown desc
, ticketAssignedTo = Nothing , ticketAssignedTo = Nothing
, ticketIsResolved = False , ticketIsResolved = False
, ticketAttachment = Nothing
} }
offer = Offer offer = Offer
{ offerObject = ticketAP { offerObject = ticketAP

View file

@ -34,6 +34,7 @@ import Database.Persist
import Yesod.Core import Yesod.Core
import Yesod.Persist.Core import Yesod.Persist.Core
import qualified Data.List.NonEmpty as NE
import qualified Database.Esqueleto as E import qualified Database.Esqueleto as E
import Network.FedURI import Network.FedURI
@ -99,14 +100,14 @@ getSharerPatchesR =
getSharerPatchR getSharerPatchR
:: ShrIdent -> KeyHashid TicketAuthorLocal -> Handler TypedContent :: ShrIdent -> KeyHashid TicketAuthorLocal -> Handler TypedContent
getSharerPatchR shr talkhid = do getSharerPatchR shr talkhid = do
(ticket, repo, massignee) <- runDB $ do (ticket, repo, massignee, ptids') <- runDB $ do
(_, _, Entity _ t, tp) <- getSharerPatch404 shr talkhid (_, _, Entity tid t, tp) <- getSharerPatch404 shr talkhid
(,,) t (,,,) t
<$> bitraverse <$> bitraverse
(\ (_, Entity _ trl) -> do (\ (_, Entity _ trl) -> do
r <- getJust $ ticketRepoLocalRepo trl r <- getJust $ ticketRepoLocalRepo trl
s <- getJust $ repoSharer r s <- getJust $ repoSharer r
return (s, r) return (s, r, ticketRepoLocalBranch trl)
) )
(\ (Entity _ tpr, _) -> do (\ (Entity _ tpr, _) -> do
roid <- roid <-
@ -124,10 +125,17 @@ getSharerPatchR shr talkhid = do
p <- getJust pidAssignee p <- getJust pidAssignee
getJust $ personIdent p getJust $ personIdent p
) )
<*> selectKeysList [PatchTicket ==. tid] [Desc PatchId]
let ptids =
case NE.nonEmpty ptids' of
Nothing -> error "No patches found!"
Just ne -> ne
hLocal <- getsYesod siteInstanceHost hLocal <- getsYesod siteInstanceHost
encodeRouteLocal <- getEncodeRouteLocal encodeRouteLocal <- getEncodeRouteLocal
encodeRouteHome <- getEncodeRouteHome encodeRouteHome <- getEncodeRouteHome
let patchAP = AP.Ticket encodePatchId <- getEncodeKeyHashid
let versionUrl = SharerPatchVersionR shr talkhid . encodePatchId
patchAP = AP.Ticket
{ AP.ticketLocal = Just { AP.ticketLocal = Just
( hLocal ( hLocal
, AP.TicketLocal , AP.TicketLocal
@ -152,7 +160,7 @@ getSharerPatchR shr talkhid = do
, AP.ticketContext = , AP.ticketContext =
Just $ Just $
case repo of case repo of
Left (s, r) -> Left (s, r, _) ->
encodeRouteHome $ encodeRouteHome $
RepoR (sharerIdent s) (repoIdent r) RepoR (sharerIdent s) (repoIdent r)
Right (i, ro) -> Right (i, ro) ->
@ -163,6 +171,23 @@ getSharerPatchR shr talkhid = do
, AP.ticketAssignedTo = , AP.ticketAssignedTo =
encodeRouteHome . SharerR . sharerIdent <$> massignee encodeRouteHome . SharerR . sharerIdent <$> massignee
, AP.ticketIsResolved = ticketStatus ticket == TSClosed , AP.ticketIsResolved = ticketStatus ticket == TSClosed
, AP.ticketAttachment = Just
( hLocal
, MergeRequest
{ mrOrigin = Nothing
, mrTarget =
case repo of
Left (s, r, Nothing) ->
encodeRouteHome $
RepoR (sharerIdent s) (repoIdent r)
Left (s, r, Just b) ->
encodeRouteHome $
RepoBranchR (sharerIdent s) (repoIdent r) b
Right (i, ro) ->
ObjURI (instanceHost i) (remoteObjectIdent ro)
, mrPatch = NE.map (encodeRouteLocal . versionUrl) ptids
}
)
} }
provideHtmlAndAP patchAP $ redirectToPrettyJSON here provideHtmlAndAP patchAP $ redirectToPrettyJSON here
where where

View file

@ -418,6 +418,7 @@ getProjectTicketR shar proj ltkhid = do
, AP.ticketAssignedTo = , AP.ticketAssignedTo =
encodeRouteHome . SharerR . sharerIdent . fst <$> massignee encodeRouteHome . SharerR . sharerIdent . fst <$> massignee
, AP.ticketIsResolved = ticketStatus ticket == TSClosed , AP.ticketIsResolved = ticketStatus ticket == TSClosed
, AP.ticketAttachment = Nothing
} }
provideHtmlAndAP' host ticketAP $ provideHtmlAndAP' host ticketAP $
let followButton = let followButton =
@ -1230,6 +1231,7 @@ getSharerTicketR shr talkhid = do
, AP.ticketAssignedTo = , AP.ticketAssignedTo =
encodeRouteHome . SharerR . sharerIdent <$> massignee encodeRouteHome . SharerR . sharerIdent <$> massignee
, AP.ticketIsResolved = ticketStatus ticket == TSClosed , AP.ticketIsResolved = ticketStatus ticket == TSClosed
, AP.ticketAttachment = Nothing
} }
provideHtmlAndAP ticketAP $ redirectToPrettyJSON here provideHtmlAndAP ticketAP $ redirectToPrettyJSON here
where where

View file

@ -766,6 +766,7 @@ changes hLocal ctx =
TextPandocMarkdown $ ticket20190612Source ticket TextPandocMarkdown $ ticket20190612Source ticket
, ticketAssignedTo = Nothing , ticketAssignedTo = Nothing
, ticketIsResolved = False , ticketIsResolved = False
, ticketAttachment = Nothing
} }
summary = summary =
[hamlet| [hamlet|
@ -1582,6 +1583,8 @@ changes hLocal ctx =
, addEntities model_2020_05_17 , addEntities model_2020_05_17
-- 250 -- 250
, addFieldPrimRequired "Patch" defaultTime "created" , addFieldPrimRequired "Patch" defaultTime "created"
-- 251
, addFieldPrimOptional "TicketRepoLocal" (Nothing :: Maybe Text) "branch"
] ]
migrateDB migrateDB

View file

@ -49,6 +49,7 @@ module Web.ActivityPub
, PatchType (..) , PatchType (..)
, Patch (..) , Patch (..)
, TicketLocal (..) , TicketLocal (..)
, MergeRequest (..)
, Ticket (..) , Ticket (..)
, Author (..) , Author (..)
, Hash (..) , Hash (..)
@ -924,6 +925,44 @@ encodeTicketLocal
<> "dependencies" .= ObjURI a deps <> "dependencies" .= ObjURI a deps
<> "dependants" .= ObjURI a rdeps <> "dependants" .= ObjURI a rdeps
data MergeRequest u = MergeRequest
{ mrOrigin :: Maybe (ObjURI u)
, mrTarget :: ObjURI u
, mrPatch :: NonEmpty LocalURI
}
instance ActivityPub MergeRequest where
jsonldContext _ = [as2Context, forgeContext]
parseObject o = do
typ <- o .: "type"
unless (typ == ("Offer" :: Text)) $
fail "type isn't Offer"
(hPatch, patches) <- do
c <- o .: "object"
ctyp <- c .: "type"
unless (ctyp == ("OrderedCollection" :: Text)) $
fail "type isn't OrderedCollection"
ObjURI h lu :| us <- c .: "items" <|> c .: "orderedItems"
let (hs, lus) = unzip $ map (\ (ObjURI h lu) -> (h, lu)) us
unless (all (== h) hs) $ fail "Version hosts differ"
return (h, lu :| lus)
fmap (hPatch,) $
MergeRequest
<$> o .:? "origin"
<*> o .: "target"
<*> pure patches
toSeries hPatch (MergeRequest morigin target patches)
= "type" .= ("Offer" :: Text)
<> "origin" .=? morigin
<> "target" .= target
<> "object" .= object
[ "type" .= ("OrderedCollection" :: Text)
, "totalItems" .= length patches
, "orderedItems" .= NE.map (ObjURI hPatch) patches
]
data Ticket u = Ticket data Ticket u = Ticket
{ ticketLocal :: Maybe (Authority u, TicketLocal) { ticketLocal :: Maybe (Authority u, TicketLocal)
, ticketAttributedTo :: LocalURI , ticketAttributedTo :: LocalURI
@ -936,6 +975,7 @@ data Ticket u = Ticket
, ticketSource :: TextPandocMarkdown , ticketSource :: TextPandocMarkdown
, ticketAssignedTo :: Maybe (ObjURI u) , ticketAssignedTo :: Maybe (ObjURI u)
, ticketIsResolved :: Bool , ticketIsResolved :: Bool
, ticketAttachment :: Maybe (Authority u, MergeRequest u)
} }
instance ActivityPub Ticket where instance ActivityPub Ticket where
@ -969,10 +1009,11 @@ instance ActivityPub Ticket where
<*> source .: "content" <*> source .: "content"
<*> o .:? "assignedTo" <*> o .:? "assignedTo"
<*> o .: "isResolved" <*> o .: "isResolved"
<*> (traverse parseObject =<< o .:? "attachment")
toSeries authority toSeries authority
(Ticket local attributedTo published updated context {-name-} (Ticket local attributedTo published updated context {-name-}
summary content source assignedTo isResolved) summary content source assignedTo isResolved mmr)
= maybe mempty (uncurry encodeTicketLocal) local = maybe mempty (uncurry encodeTicketLocal) local
<> "type" .= ("Ticket" :: Text) <> "type" .= ("Ticket" :: Text)
@ -990,6 +1031,10 @@ instance ActivityPub Ticket where
] ]
<> "assignedTo" .=? assignedTo <> "assignedTo" .=? assignedTo
<> "isResolved" .= isResolved <> "isResolved" .= isResolved
<> maybe
mempty
(\ (h, mr) -> "attachment" `pair` pairs (toSeries h mr))
mmr
data Author = Author data Author = Author
{ authorName :: Text { authorName :: Text