Skip to content

Latest commit

 

History

History
177 lines (122 loc) · 6.5 KB

README.md

File metadata and controls

177 lines (122 loc) · 6.5 KB

Amazonka

Build Status

Description

A comprehensive Amazon Web Services SDK for Haskell supporting all of the publicly available services.

Parts of the code contained in this repository are auto-generated and auto-magically kept up to date with Amazon's latest service APIs.

An introductory blog post detailing some of the motivation and design decisions can be found here.

Haddock documentation which is in sync with the develop branch can be found here.

Organisation

This repository is organised into the following directory structure:

  • amazonka: Monad transformer and send/receive/paginate/presign logic.
  • amazonka-*: Each of the individually supported Amazon Web Service libraries.
  • amazonka-*/examples: An example project for the parent service which can be loaded using make install && make repl.
  • core: The amazonka-core library upon which each of the services depends.
  • gen: Code, templates, and assets for the amazonka-gen executable.
  • script: Scripts to manage the release and life-cycle of the service libraries.
  • share: Makefile plumbing common to all service libraries

Usage

You will typically add an amazonka dependency in your project's cabal file, and any additional services you wish to use.

For example the build-depends section of a cabal file which utilises EC2 and S3 might look like:

build-depends:
      amazonka
    , amazonka-ec2
    , amazonka-s3
    , base

Credentials

Credentials can either be specified explicitly, or obtained from the underlying environment in a number of ways.

Usually the most convenient is to use Discover, which will attempt to read the AWS_ACCESS_KEY and AWS_SECRET_KEY variables from the environment. If either of these variables are not set, amazonka will then attempt to retrieve IAM profile information from http://169.254.169.254.

This allows you to seamlessly move between development environments (where you specify or set the keys) and production EC2 instances (which have an IAM role + profile assigned).

Type Signatures

Type families are used to associate requests with their respective error, signing algorithm, and response type.

If you are not familiar with type families, the easiest way to translate signatures or type errors is:

type Response a = Either (ServiceError (Er (Sv a))) (Rs a)

Translated: the Left branch is the error type of the service to which the request is being sent, a being the request in the above alias.

The Right branch is the successful response associated with a.

For EC2's DescribeInstances operation the reduced type would be:

type Response DescribeInstances = Either (ServiceError EC2Error) DescribeInstancesResponse

Every operation's response type is typically the operation name suffixed by Response, with the exception being responses shared by multiple operations.

Sending Requests

There are two separate styles of sending requests in amazonka. The explicit parameter passing from Network.AWS, or the Monad Transformer stack in Control.Monad.Trans.AWS.

For the parameter passing style, you send a typical request by:

import Network.AWS
import Network.AWS.EC2

main = do
    e <- getEnv Ireland Discover
    r <- send e describeInstances
    ...

The main purposes of the Monad Transformer stack is to carry around the Env state, manage the resource cleanup safely using ResourceT, and encapsulate manageable errors using ExceptT to allow conveniently chaining successful requests.

A trivial example of using the AWST transformer is:

import Control.Monad.Trans.AWS
import Network.AWS.EC2

main = do
    e <- getEnv Ireland Discover
    runAWST env $ do
        x <- send describeInstances
        y <- send describeTags
        ...

If either of the responses to send are failures, the first will cause the computation to exit and the Either result of runAWST will contain the error in the Left case, or the result of the entire monadic computation in the Right case.

The *Catch variants in Control.Monad.Trans.AWS are used when you wish to handle any specific service errors related to the sent request without exiting the computation.

Pagination

Pagination is supported by requests which are an instance of AWSPager.

The paginate method returns a conduit Source which will seamlessly return pages of results based on the initial (or default) parameters to the first request, stopping when the service signals there are no more results.

AWSRequest is a super-class of AWSPager, so you can typically send a request such as DescribeAutoScalingGroups instead of fully paginating it. This can be a convenient way to obtain only the first page of results without using any conduit operators.

Presigned URLs

Presigned URLs can be generated for services which are an instance of AWSPresigner.

The presign method is used to specify the request to sign and the expiry time.

Asynchronous Actions

AWST is an instance of MonadControl, which allows actions to be run asynchronously with the use of async and wait from the lifted-async package.

Contribute

For any problems, comments, or feedback please create an issue here on GitHub.

Licence

Amazonka is released under the Mozilla Public License Version 2.0.

Parts of the code are derived from AWS service descriptions, licensed under Apache 2.0. Source files subject to this contain an additional licensing clause in their header.