mirror of
https://code.sup39.dev/repos/Wqawg
synced 2025-01-15 04:15:11 +09:00
C2S: offerTicketC: Add VCS-type and patch-type consistency checks
This commit is contained in:
parent
23b5343ec2
commit
e7ab9e701c
1 changed files with 48 additions and 13 deletions
|
@ -2572,18 +2572,56 @@ offerTicketC (Entity senderPersonID senderPerson) senderActor summary audience t
|
||||||
unless (repoLoom targetRepo == Just loomID) $
|
unless (repoLoom targetRepo == Just loomID) $
|
||||||
throwE "Offer target loom doesn't have repo's consent to serve it"
|
throwE "Offer target loom doesn't have repo's consent to serve it"
|
||||||
|
|
||||||
|
for_ (justThere originOrBundle) $ \ (Material typ diffs) -> do
|
||||||
|
unless (repoVcs targetRepo == patchMediaTypeVCS typ) $
|
||||||
|
throwE "Patch type and local target repo VCS mismatch"
|
||||||
|
case (typ, diffs) of
|
||||||
|
(PatchMediaTypeDarcs, _ :| _ : _) ->
|
||||||
|
throwE "More than one Darcs dpatch file provided"
|
||||||
|
_ -> pure ()
|
||||||
|
|
||||||
originOrBundle' <-
|
originOrBundle' <-
|
||||||
bitraverse
|
bitraverse
|
||||||
(bitraverse
|
(\ origin -> do
|
||||||
(\ (repoID, maybeBranch) -> do
|
(vcs, origin') <-
|
||||||
|
case origin of
|
||||||
|
Left (repoID, maybeBranch) -> do
|
||||||
repo <- getE repoID "MR origin local repo not found in DB"
|
repo <- getE repoID "MR origin local repo not found in DB"
|
||||||
return (repoID, repoVcs repo, maybeBranch)
|
return (repoVcs repo, Left (repoID, maybeBranch))
|
||||||
)
|
Right (vcs, remoteActorID, maybeBranch) ->
|
||||||
pure
|
pure (vcs, Right (remoteActorID, maybeBranch))
|
||||||
|
unless (vcs == repoVcs targetRepo) $
|
||||||
|
throwE "Origin repo VCS differs from target repo VCS"
|
||||||
|
return origin'
|
||||||
)
|
)
|
||||||
pure
|
pure
|
||||||
originOrBundle
|
originOrBundle
|
||||||
|
|
||||||
|
-- Verify that the VCS of target repo, origin repo and patches
|
||||||
|
-- all match, and that branches are specified for Git and
|
||||||
|
-- aren't specified for Darcs
|
||||||
|
_ <- case repoVcs targetRepo of
|
||||||
|
VCSGit -> do
|
||||||
|
targetBranch <- fromMaybeE maybeTargetBranch "Local target repo is Git but no target branch specified"
|
||||||
|
maybeOrigin <- for (justHere originOrBundle') $ \case
|
||||||
|
Left (originRepoID, maybeOriginBranch) -> do
|
||||||
|
originBranch <- fromMaybeE maybeOriginBranch "Local origin repo is Git but no origin branch specified"
|
||||||
|
return (Left originRepoID, originBranch)
|
||||||
|
Right (remoteActorID, maybeOriginBranch) -> do
|
||||||
|
(_maybeURI, originBranch) <- fromMaybeE maybeOriginBranch "Remote origin repo is Git but no origin branch specified"
|
||||||
|
return (Right remoteActorID, originBranch)
|
||||||
|
return $ Left (targetBranch, maybeOrigin)
|
||||||
|
VCSDarcs -> do
|
||||||
|
verifyNothingE maybeTargetBranch "Local target repo is Darcs but target branch specified"
|
||||||
|
maybeOriginRepo <- for (justHere originOrBundle') $ \case
|
||||||
|
Left (originRepoID, maybeOriginBranch) -> do
|
||||||
|
verifyNothingE maybeOriginBranch "Local origin repo is Darcs but origin branch specified"
|
||||||
|
return $ Left originRepoID
|
||||||
|
Right (remoteActorID, maybeOriginBranch) -> do
|
||||||
|
verifyNothingE maybeOriginBranch "Remote origin repo is Darcs but origin branch specified"
|
||||||
|
return $ Right remoteActorID
|
||||||
|
return $ Right $ maybeOriginRepo
|
||||||
|
|
||||||
return (loomID, loomActor loom, originOrBundle', targetRepoID, maybeTargetBranch)
|
return (loomID, loomActor loom, originOrBundle', targetRepoID, maybeTargetBranch)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -2712,9 +2750,6 @@ offerTicketC (Entity senderPersonID senderPerson) senderActor summary audience t
|
||||||
|
|
||||||
return offerID
|
return offerID
|
||||||
|
|
||||||
--unless (repoVcs r == patchMediaTypeVCS typ) $
|
|
||||||
-- throwE "Patch type and repo VCS mismatch"
|
|
||||||
|
|
||||||
where
|
where
|
||||||
|
|
||||||
fetchRepoE h lu = do
|
fetchRepoE h lu = do
|
||||||
|
@ -2823,17 +2858,17 @@ offerTicketC (Entity senderPersonID senderPerson) senderActor summary audience t
|
||||||
-> Maybe Text
|
-> Maybe Text
|
||||||
-> These
|
-> These
|
||||||
(Either
|
(Either
|
||||||
(RepoId, VersionControlSystem, Maybe Text)
|
(RepoId, Maybe Text)
|
||||||
(VersionControlSystem, RemoteActorId, Maybe (Maybe LocalURI, Text))
|
(RemoteActorId, Maybe (Maybe LocalURI, Text))
|
||||||
)
|
)
|
||||||
Material
|
Material
|
||||||
-> AppDB (Route App)
|
-> AppDB (Route App)
|
||||||
insertMerge now loomID ticketID maybeBranch originOrBundle = do
|
insertMerge now loomID ticketID maybeBranch originOrBundle = do
|
||||||
clothID <- insert $ TicketLoom ticketID loomID maybeBranch
|
clothID <- insert $ TicketLoom ticketID loomID maybeBranch
|
||||||
for_ (justHere originOrBundle) $ \case
|
for_ (justHere originOrBundle) $ \case
|
||||||
Left (repoID, _, maybeOriginBranch) ->
|
Left (repoID, maybeOriginBranch) ->
|
||||||
insert_ $ MergeOriginLocal clothID repoID maybeOriginBranch
|
insert_ $ MergeOriginLocal clothID repoID maybeOriginBranch
|
||||||
Right (_, remoteActorID, maybeOriginBranch) -> do
|
Right (remoteActorID, maybeOriginBranch) -> do
|
||||||
originID <- insert $ MergeOriginRemote clothID remoteActorID
|
originID <- insert $ MergeOriginRemote clothID remoteActorID
|
||||||
for_ maybeOriginBranch $ \ (mlu, b) ->
|
for_ maybeOriginBranch $ \ (mlu, b) ->
|
||||||
insert_ $ MergeOriginRemoteBranch originID mlu b
|
insert_ $ MergeOriginRemoteBranch originID mlu b
|
||||||
|
|
Loading…
Reference in a new issue