diff options
author | Joey Hess <joey@kitenet.net> | 2014-11-03 17:23:46 -0400 |
---|---|---|
committer | Joey Hess <joey@kitenet.net> | 2014-11-03 17:23:46 -0400 |
commit | 6c707f63405d7c5e99aaa1a8dfd5333b5bc00e58 (patch) | |
tree | 6d3dd7559da6e52a65156de406de787af02dc28d /Remote | |
parent | 52639afc15095c1bc82fb3f87c29a22c2e4b2303 (diff) |
fix build
Diffstat (limited to 'Remote')
-rw-r--r-- | Remote/S3.hs | 26 |
1 files changed, 15 insertions, 11 deletions
diff --git a/Remote/S3.hs b/Remote/S3.hs index e9879b9f4..e5ed17c49 100644 --- a/Remote/S3.hs +++ b/Remote/S3.hs @@ -13,10 +13,6 @@ module Remote.S3 (remote, iaHost, configIA, iaItemUrl) where import qualified Aws as AWS import qualified Aws.Core as AWS import qualified Aws.S3 as S3 -#if MIN_VERSION_aws(0,10,6) -import qualified Aws.S3.Commands.Multipart as Multipart -import qualified Data.Conduit.List as CL -#endif import qualified Data.Text as T import qualified Data.Text.Encoding as T import qualified Data.ByteString.Lazy as L @@ -24,12 +20,18 @@ import qualified Data.ByteString as S import qualified Data.Map as M import Data.Char import Network.Socket (HostName) -import Network.HTTP.Conduit (Manager, newManager, closeManager) +import Network.HTTP.Conduit (Manager, newManager, closeManager, withManager) import Network.HTTP.Client (defaultManagerSettings, managerResponseTimeout, responseStatus, responseBody, RequestBody(..)) import Network.HTTP.Types import Control.Monad.Trans.Resource import Control.Monad.Catch import Data.Conduit +#if MIN_VERSION_aws(0,10,6) +import qualified Aws.S3.Commands.Multipart as Multipart +import qualified Data.Conduit.List as CL +import qualified Data.Conduit.Binary as CB +import Network.HTTP.Conduit (withManager) +#endif import Common.Annex import Types.Remote @@ -175,22 +177,24 @@ store r h = fileStorer $ \k f p -> do multipartupload sz k f p = do #if MIN_VERSION_aws(0,10,6) let info = hinfo h - let object = bucketObject info h + let object = bucketObject info k - uploadid <- S3.imurUploadId <$> sendS3Handle' h $ - (S3.postInitiateMultipartUpload (bucket info) object) + let req = (S3.postInitiateMultipartUpload (bucket info) object) { S3.imuStorageClass = Just (storageClass info) , S3.imuMetadata = metaHeaders info , S3.imuAutoMakeBucket = isIA info , S3.imuExpires = Nothing -- TODO set some reasonable expiry } + uploadid <- S3.imurUploadId <$> sendS3Handle h req - etags <- sourceFile f + -- TODO: progress display + etags <- liftIO $ withManager $ \mgr -> + CB.sourceFile f $= Multipart.chunkedConduit sz - $= Multipart.putConduit (hawscfg h) (hs3cfg h) (hmanager h) (bucket info) object uploadid + $= Multipart.putConduit (hawscfg h) (hs3cfg h) mgr (bucket info) object uploadid $$ CL.consume - void $ sendS3Handle' h $ S3.postCompleteMultipartUpload + void $ sendS3Handle h $ S3.postCompleteMultipartUpload (bucket info) object uploadid (zip [1..] etags) #else warning $ "Cannot do multipart upload (partsize " ++ show sz ++ "); built with too old a version of the aws library." |