forked from filipg/gonito
extract title and description
This commit is contained in:
parent
b148cc37fc
commit
f3a473d83e
@ -5,6 +5,10 @@ import Yesod.Form.Bootstrap3 (BootstrapFormLayout (..), renderBootstrap3,
|
|||||||
withSmallInput)
|
withSmallInput)
|
||||||
|
|
||||||
import Handler.Shared
|
import Handler.Shared
|
||||||
|
import Handler.Extract
|
||||||
|
|
||||||
|
import System.Directory (doesFileExist)
|
||||||
|
import qualified Data.Text as T
|
||||||
|
|
||||||
getCreateChallengeR :: Handler Html
|
getCreateChallengeR :: Handler Html
|
||||||
getCreateChallengeR = do
|
getCreateChallengeR = do
|
||||||
@ -41,13 +45,22 @@ doCreateChallenge name publicUrl publicBranch privateUrl privateBranch chan = do
|
|||||||
addChallenge :: Text -> (Key Repo) -> (Key Repo) -> Channel -> Handler ()
|
addChallenge :: Text -> (Key Repo) -> (Key Repo) -> Channel -> Handler ()
|
||||||
addChallenge name publicRepoId privateRepoId chan = do
|
addChallenge name publicRepoId privateRepoId chan = do
|
||||||
msg chan "adding challenge..."
|
msg chan "adding challenge..."
|
||||||
|
let publicRepoDir = getRepoDir publicRepoId
|
||||||
|
let readmeFilePath = publicRepoDir </> readmeFile
|
||||||
|
doesReadmeExist <- liftIO $ doesFileExist readmeFilePath
|
||||||
|
(title, description) <- if doesReadmeExist
|
||||||
|
then
|
||||||
|
liftIO $ extractTitleAndDescription readmeFilePath
|
||||||
|
else do
|
||||||
|
err chan "README was not found"
|
||||||
|
return (defaultTitle, defaultDescription)
|
||||||
time <- liftIO getCurrentTime
|
time <- liftIO getCurrentTime
|
||||||
challengeId <- runDB $ insert $ Challenge {
|
challengeId <- runDB $ insert $ Challenge {
|
||||||
challengePublicRepo=publicRepoId,
|
challengePublicRepo=publicRepoId,
|
||||||
challengePrivateRepo=privateRepoId,
|
challengePrivateRepo=privateRepoId,
|
||||||
challengeName=name,
|
challengeName=name,
|
||||||
challengeTitle="[UNKNOWN TITLE]",
|
challengeTitle=(T.pack $ title),
|
||||||
challengeDescription="[UNKNOWN DESCRIPTION]",
|
challengeDescription=(T.pack $ description),
|
||||||
challengeStamp=time}
|
challengeStamp=time}
|
||||||
return ()
|
return ()
|
||||||
|
|
||||||
|
54
Handler/Extract.hs
Normal file
54
Handler/Extract.hs
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
module Handler.Extract where
|
||||||
|
|
||||||
|
import Import
|
||||||
|
|
||||||
|
import Text.Pandoc
|
||||||
|
import Text.Pandoc.Walk (walk)
|
||||||
|
import Text.Pandoc.Shared (stringify)
|
||||||
|
|
||||||
|
import Data.Maybe
|
||||||
|
|
||||||
|
import System.IO (withFile, IOMode(..))
|
||||||
|
|
||||||
|
extractHeaders :: Block -> [String]
|
||||||
|
extractHeaders (Header 1 _ x) = [stringify x]
|
||||||
|
extractHeaders _ = []
|
||||||
|
|
||||||
|
extractFirstHeader :: Pandoc -> Maybe String
|
||||||
|
extractFirstHeader doc = case queryWith extractHeaders doc of
|
||||||
|
(s:_) -> Just s
|
||||||
|
[] -> Nothing
|
||||||
|
|
||||||
|
extractParas :: Block -> [String]
|
||||||
|
extractParas (Para x) = [stringify x]
|
||||||
|
extractParas _ = []
|
||||||
|
|
||||||
|
extractFirstPara :: Pandoc -> Maybe String
|
||||||
|
extractFirstPara doc = case queryWith extractParas doc of
|
||||||
|
(s:_) -> Just s
|
||||||
|
[] -> Nothing
|
||||||
|
|
||||||
|
readDoc :: String -> Pandoc
|
||||||
|
readDoc s = case readMarkdown def s of
|
||||||
|
Right doc -> doc
|
||||||
|
Left err -> error (show err)
|
||||||
|
|
||||||
|
defaultTitle :: String
|
||||||
|
defaultTitle = "[???]"
|
||||||
|
|
||||||
|
defaultDescription :: String
|
||||||
|
defaultDescription = ""
|
||||||
|
|
||||||
|
readmeFile :: FilePath
|
||||||
|
readmeFile = "README.md"
|
||||||
|
|
||||||
|
getTitleAndDescription :: String -> (String, String)
|
||||||
|
getTitleAndDescription contents = (title, description)
|
||||||
|
where title = fromMaybe defaultTitle $ extractFirstHeader doc
|
||||||
|
description = fromMaybe defaultDescription $ extractFirstPara doc
|
||||||
|
doc = readDoc contents
|
||||||
|
|
||||||
|
extractTitleAndDescription :: FilePath -> IO (String, String)
|
||||||
|
extractTitleAndDescription fp = do
|
||||||
|
contents <- readFile fp
|
||||||
|
return $ getTitleAndDescription contents
|
@ -27,6 +27,7 @@ library
|
|||||||
Handler.Fay
|
Handler.Fay
|
||||||
Handler.Home
|
Handler.Home
|
||||||
Handler.Shared
|
Handler.Shared
|
||||||
|
Handler.Extract
|
||||||
|
|
||||||
if flag(dev) || flag(library-only)
|
if flag(dev) || flag(library-only)
|
||||||
cpp-options: -DDEVELOPMENT
|
cpp-options: -DDEVELOPMENT
|
||||||
@ -94,7 +95,8 @@ library
|
|||||||
, lifted-base
|
, lifted-base
|
||||||
, process
|
, process
|
||||||
, random
|
, random
|
||||||
|
, pandoc
|
||||||
|
, pandoc-types
|
||||||
|
|
||||||
executable gonito
|
executable gonito
|
||||||
if flag(library-only)
|
if flag(library-only)
|
||||||
|
Loading…
Reference in New Issue
Block a user