Smart HTTP ref discovery
This commit is contained in:
parent
8856bd2344
commit
19471d4ca2
4 changed files with 64 additions and 6 deletions
42
src/Vervis/Content.hs
Normal file
42
src/Vervis/Content.hs
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
{- This file is part of Vervis.
|
||||||
|
-
|
||||||
|
- Written in 2016 by fr33domlover <fr33domlover@riseup.net>.
|
||||||
|
-
|
||||||
|
- ♡ Copying is an act of love. Please copy, reuse and share.
|
||||||
|
-
|
||||||
|
- The author(s) have dedicated all copyright and related and neighboring
|
||||||
|
- rights to this software to the public domain worldwide. This software is
|
||||||
|
- distributed without any warranty.
|
||||||
|
-
|
||||||
|
- You should have received a copy of the CC0 Public Domain Dedication along
|
||||||
|
- with this software. If not, see
|
||||||
|
- <http://creativecommons.org/publicdomain/zero/1.0/>.
|
||||||
|
-}
|
||||||
|
|
||||||
|
-- | Custom HTTP response content types.
|
||||||
|
module Vervis.Content
|
||||||
|
( GitRefDiscovery (..)
|
||||||
|
)
|
||||||
|
where
|
||||||
|
|
||||||
|
import Prelude
|
||||||
|
|
||||||
|
import Data.Monoid ((<>))
|
||||||
|
import Yesod.Core.Content
|
||||||
|
|
||||||
|
import qualified Data.ByteString as B
|
||||||
|
import qualified Data.ByteString.Lazy as BL
|
||||||
|
|
||||||
|
data GitRefDiscovery = GitRefDiscovery
|
||||||
|
{ grdContent :: BL.ByteString
|
||||||
|
, grdService :: B.ByteString
|
||||||
|
}
|
||||||
|
|
||||||
|
instance ToContent GitRefDiscovery where
|
||||||
|
toContent (GitRefDiscovery c _) = toContent c
|
||||||
|
|
||||||
|
instance ToTypedContent GitRefDiscovery where
|
||||||
|
toTypedContent grd@(GitRefDiscovery _ s) =
|
||||||
|
let t = "application/x-" <> s <> "-advertisement"
|
||||||
|
c = toContent grd
|
||||||
|
in TypedContent t c
|
|
@ -21,22 +21,35 @@ where
|
||||||
import Prelude
|
import Prelude
|
||||||
|
|
||||||
import Control.Monad.IO.Class (liftIO)
|
import Control.Monad.IO.Class (liftIO)
|
||||||
import Data.Git.Storage (isRepo)
|
import Data.Git.Storage (isRepo, withRepo)
|
||||||
import Data.String (fromString)
|
import Data.String (fromString)
|
||||||
import Data.Text (Text)
|
import Data.Text (Text)
|
||||||
|
import Network.Git.Fetch.RefDiscovery
|
||||||
import Yesod.Core.Handler
|
import Yesod.Core.Handler
|
||||||
|
|
||||||
|
import Vervis.Content (GitRefDiscovery (..))
|
||||||
import Vervis.Foundation (Handler)
|
import Vervis.Foundation (Handler)
|
||||||
import Vervis.Path (askRepoDir)
|
import Vervis.Path (askRepoDir)
|
||||||
|
|
||||||
getGitRefDiscoverR :: Text -> Text -> Handler Text
|
getGitRefDiscoverR :: Text -> Text -> Handler GitRefDiscovery
|
||||||
getGitRefDiscoverR sharer repo = do
|
getGitRefDiscoverR sharer repo = do
|
||||||
path <- askRepoDir sharer repo
|
path <- askRepoDir sharer repo
|
||||||
seemsThere <- liftIO $ isRepo $ fromString path
|
let pathG = fromString path
|
||||||
|
seemsThere <- liftIO $ isRepo pathG
|
||||||
if seemsThere
|
if seemsThere
|
||||||
then do
|
then do
|
||||||
rq <- getRequest
|
rq <- getRequest
|
||||||
case reqGetParams rq of
|
case reqGetParams rq of
|
||||||
[("service", _)] -> permissionDenied "Service not supported"
|
[("service", serv)] ->
|
||||||
_ -> notFound
|
if serv == "git-upload-pack"
|
||||||
|
then do
|
||||||
|
rd <- liftIO $ withRepo pathG $
|
||||||
|
flip buildRefDiscover' $ Just "git-upload-pack"
|
||||||
|
setHeader "Cache-Control" "no-cache"
|
||||||
|
return GitRefDiscovery
|
||||||
|
{ grdContent = serializeRefDiscover rd
|
||||||
|
, grdService = "git-upload-pack"
|
||||||
|
}
|
||||||
|
else permissionDenied "Service not supported"
|
||||||
|
_ -> notFound
|
||||||
else notFound
|
else notFound
|
||||||
|
|
|
@ -10,12 +10,14 @@ packages:
|
||||||
- '.'
|
- '.'
|
||||||
- '../../../other-work/ssh'
|
- '../../../other-work/ssh'
|
||||||
- '../hit-graph'
|
- '../hit-graph'
|
||||||
|
- '../hit-network'
|
||||||
|
|
||||||
# Packages to be pulled from upstream that are not in the resolver (e.g.,
|
# Packages to be pulled from upstream that are not in the resolver (e.g.,
|
||||||
# acme-missiles-0.3)
|
# acme-missiles-0.3)
|
||||||
extra-deps:
|
extra-deps:
|
||||||
- highlighter2-0.2.5
|
- highlighter2-0.2.5
|
||||||
- hit-graph-0.1
|
- hit-graph-0.1
|
||||||
|
- hit-network-0.1
|
||||||
- SimpleAES-0.4.2
|
- SimpleAES-0.4.2
|
||||||
# - ssh-0.3.2
|
# - ssh-0.3.2
|
||||||
# Required for M.alter used in hit-graph
|
# Required for M.alter used in hit-graph
|
||||||
|
|
|
@ -41,6 +41,7 @@ library
|
||||||
Network.SSH.Local
|
Network.SSH.Local
|
||||||
Text.FilePath.Local
|
Text.FilePath.Local
|
||||||
Vervis.Application
|
Vervis.Application
|
||||||
|
Vervis.Content
|
||||||
Vervis.Field.Key
|
Vervis.Field.Key
|
||||||
Vervis.Field.Person
|
Vervis.Field.Person
|
||||||
Vervis.Field.Project
|
Vervis.Field.Project
|
||||||
|
@ -91,7 +92,6 @@ library
|
||||||
, attoparsec
|
, attoparsec
|
||||||
, base
|
, base
|
||||||
, base64-bytestring
|
, base64-bytestring
|
||||||
, binary
|
|
||||||
, blaze-html
|
, blaze-html
|
||||||
, byteable
|
, byteable
|
||||||
, bytestring
|
, bytestring
|
||||||
|
@ -114,6 +114,7 @@ library
|
||||||
, highlighting-kate
|
, highlighting-kate
|
||||||
, hit
|
, hit
|
||||||
, hit-graph >= 0.1
|
, hit-graph >= 0.1
|
||||||
|
, hit-network >= 0.1
|
||||||
, hjsmin
|
, hjsmin
|
||||||
, hourglass
|
, hourglass
|
||||||
, http-conduit
|
, http-conduit
|
||||||
|
|
Loading…
Reference in a new issue