File: uploadFile.hs

package info (click to toggle)
haskell-hs3 0.5.6-2
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 184 kB
  • sloc: haskell: 1,219; makefile: 2
file content (40 lines) | stat: -rw-r--r-- 1,361 bytes parent folder | download | duplicates (2)
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
#!/usr/local/bin/runhaskell

-----------------------------------------------------------------------------
-- |
-- Program     :  Upload File
-- Copyright   :  (c) Greg Heartsfield 2007
-- License     :  BSD3
--
-- Upload a file to S3 with a given bucket and object name.
-- Usage:
--    uploadFile.hs bucket-name object-name filename
--
-- This requires the following environment variables to be set with
-- your Amazon keys:
--   AWS_ACCESS_KEY_ID
--   AWS_ACCESS_KEY_SECRET
-----------------------------------------------------------------------------

import Network.AWS.S3Bucket
import Network.AWS.S3Object
import Network.AWS.AWSConnection
import Network.AWS.AWSResult
import System.Environment
import Data.Maybe
import System.IO
import qualified Data.ByteString.Lazy.Char8 as L
import System.Posix.Files

main = do argv <- getArgs
          let bucket : key : filename : xs = argv
          f <- L.readFile filename
          contentFS <- getFileStatus filename
          let offset = fileSize contentFS
          mConn <- amazonS3ConnectionFromEnv
          let conn = fromJust mConn
          let obj = S3Object bucket key "text/plain" [("Content-Length",(show offset))] f
          res <- sendObject conn obj
          either (putStrLn . prettyReqError)
                 (const $ putStrLn ("Creation of " ++ key ++ " successful."))
                 res