File: sendObject.hs

package info (click to toggle)
haskell-hs3 0.5.7-3
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 184 kB
  • sloc: haskell: 1,219; makefile: 2
file content (37 lines) | stat: -rw-r--r-- 1,334 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
#!/usr/local/bin/runhaskell

-----------------------------------------------------------------------------
-- |
-- Program     :  Send Object
-- Copyright   :  (c) Greg Heartsfield 2007
-- License     :  BSD3
--
-- Create a new public object with some content.  This can be viewed through
-- a web browser afterwards by visiting http://bucket.s3.amazonaws.com/object
-- Usage:
--    sendObject.hs bucket-name object-name "Some Object Content."
--
-- 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 qualified Data.ByteString.Lazy.Char8 as L

main = do argv <- getArgs
          let bucket : key : content : xs = argv
          mConn <- amazonS3ConnectionFromEnv
          let conn = fromJust mConn
          let obj = S3Object bucket key "text/html" [("x-amz-acl", "public-read")]
                    (L.pack content)
          res <- sendObject conn obj
          either (putStrLn . prettyReqError)
                 (const $ putStrLn ("Creation of " ++ key ++ " successful."))
                 res