* Make CopyPartSource constructor private ... and make individual record accessors exported. This change allows adding of additional record members to CopyPartSource without breaking applications. * Move high-level copyObject functions to CopyObject module * Make copyObject use SourceInfo, DestinationInfo ... to allow supporting features like client-side and server-side encryption subsequently. - fix warnings in tests/LiveServer.hs
57 lines
1.8 KiB
Haskell
Executable File
57 lines
1.8 KiB
Haskell
Executable File
#!/usr/bin/env stack
|
|
-- stack --resolver lts-9.1 runghc --package minio-hs
|
|
|
|
--
|
|
-- Minio Haskell SDK, (C) 2017 Minio, Inc.
|
|
--
|
|
-- Licensed under the Apache License, Version 2.0 (the "License");
|
|
-- you may not use this file except in compliance with the License.
|
|
-- You may obtain a copy of the License at
|
|
--
|
|
-- http://www.apache.org/licenses/LICENSE-2.0
|
|
--
|
|
-- Unless required by applicable law or agreed to in writing, software
|
|
-- distributed under the License is distributed on an "AS IS" BASIS,
|
|
-- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
-- See the License for the specific language governing permissions and
|
|
-- limitations under the License.
|
|
--
|
|
|
|
{-# LANGUAGE OverloadedStrings #-}
|
|
import Network.Minio
|
|
|
|
import Control.Monad.Catch (catchIf)
|
|
import Prelude
|
|
|
|
-- | The following example uses minio's play server at
|
|
-- https://play.minio.io:9000. The endpoint and associated
|
|
-- credentials are provided via the libary constant,
|
|
--
|
|
-- > minioPlayCI :: ConnectInfo
|
|
--
|
|
|
|
ignoreMinioErr :: ServiceErr -> Minio ()
|
|
ignoreMinioErr = return . const ()
|
|
|
|
main :: IO ()
|
|
main = do
|
|
let
|
|
bucket = "test"
|
|
object = "obj"
|
|
objectCopy = "obj-copy"
|
|
localFile = "/etc/lsb-release"
|
|
|
|
res1 <- runMinio minioPlayCI $ do
|
|
-- 1. Make a bucket; Catch BucketAlreadyOwnedByYou exception.
|
|
catchIf (== BucketAlreadyOwnedByYou) (makeBucket bucket Nothing) ignoreMinioErr
|
|
|
|
-- 2. Upload a file to bucket/object.
|
|
fPutObject bucket object localFile
|
|
|
|
-- 3. Copy bucket/object to bucket/objectCopy.
|
|
copyObject def {dstBucket = bucket, dstObject = objectCopy} def { srcBucket = bucket , srcObject = object }
|
|
|
|
case res1 of
|
|
Left e -> putStrLn $ "copyObject failed." ++ show e
|
|
Right () -> putStrLn "copyObject succeeded."
|