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:
parent
c63479470e
commit
17e59af1c4
9 changed files with 92 additions and 9 deletions
|
@ -401,6 +401,7 @@ TicketProjectLocal
|
||||||
TicketRepoLocal
|
TicketRepoLocal
|
||||||
context TicketContextLocalId
|
context TicketContextLocalId
|
||||||
repo RepoId
|
repo RepoId
|
||||||
|
branch Text Maybe
|
||||||
|
|
||||||
UniqueTicketRepoLocal context
|
UniqueTicketRepoLocal context
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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)
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Add table
Reference in a new issue