forked from scotty-web/scotty
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathupload.hs
62 lines (53 loc) · 2.41 KB
/
upload.hs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
{-# LANGUAGE OverloadedStrings #-}
{-# language ScopedTypeVariables #-}
module Main (main) where
import Web.Scotty
import Control.Exception (SomeException)
import Data.Foldable (for_)
import qualified Data.Text.Lazy as TL
import Network.Wai.Middleware.RequestLogger
import Network.Wai.Middleware.Static
import Network.Wai.Parse (fileName, fileContent, defaultParseRequestBodyOptions)
import qualified Text.Blaze.Html5 as H
import Text.Blaze.Html5.Attributes
import Text.Blaze.Html.Renderer.Text (renderHtml)
import qualified Data.ByteString.Lazy as B
import qualified Data.ByteString.Char8 as BS
import System.FilePath ((</>))
{-| NB : the file paths where files are saved and looked up are relative, so make sure
to run this program from the root directory of the 'scotty' repo, or adjust the paths
accordingly.
-}
main :: IO ()
main = scotty 3000 $ do
middleware logStdoutDev
middleware $ staticPolicy (noDots >-> addBase "examples/uploads")
get "/" $ do
html $ renderHtml
$ H.html $ do
H.body $ do
H.form H.! method "post" H.! enctype "multipart/form-data" H.! action "/upload" $ do
H.input H.! type_ "file" H.! name "file_1"
H.br
H.input H.! type_ "file" H.! name "file_2"
H.br
H.input H.! type_ "submit"
post "/upload" $ do
filesOpts defaultParseRequestBodyOptions $ \_ fs -> do
let
fs' = [(fieldName, BS.unpack (fileName fi), fileContent fi) | (fieldName, fi) <- fs]
-- write the files to disk, so they can be served by the static middleware
for_ fs' $ \(_, fnam, fpath) -> do
-- copy temp file to local dir
liftIO (do
fc <- B.readFile fpath
B.writeFile ("examples" </> "uploads" </> fnam) fc
) `catch` (\(e :: SomeException) -> do
liftIO $ putStrLn $ unwords ["upload: something went wrong while saving temp files :", show e]
)
-- generate list of links to the files just uploaded
html $ mconcat [ mconcat [ TL.fromStrict fName
, ": "
, renderHtml $ H.a (H.toHtml fn) H.! (href $ H.toValue fn) >> H.br
]
| (fName,fn,_) <- fs' ]