Skip to content

Latest commit

 

History

History
74 lines (54 loc) · 2.18 KB

README.mkd

File metadata and controls

74 lines (54 loc) · 2.18 KB

Created by Michael Schade (@michaelschade).

Description

This is an unofficial Haskell implementation of the Stripe API.

Note that this has worked in my tests, but I have not used it in production yet. Try it thoroughly and let me know if you find any bugs or have any improvements.

Installation

Installation is simple. If you have cabal installed, just run:

cabal install stripe

and you'll be on your way!

Example Usage

import Web.Stripe.Charge  ( Charge(..), Amount(..), Count(..), Currency(..)
                          , Offset(..), getCharges
                          )
import Web.Stripe.Client  ( APIKey(..), SConfig, defaultConfig, runStripeT )

conf :: SConfig
conf  = defaultConfig $ APIKey ""

main :: IO ()
main  = do
    amounts <- runStripeT conf $ do
        charges <- getCharges Nothing (Just $ Count 5) (Just $ Offset 1)
        return   $ map getAmt charges
    either err (putStrLn . show) amounts
    where
        getAmt c = (unAmount $ chargeAmount c, unCurrency $ chargeCurrency c)
        err _    = putStrLn "Uh-oh! It didn't work :-("

Which produces the output along the lines of: [(842,"usd"),(2048,"usd"),(1010,"usd"),(4096,"usd"),(4200,"usd")].

Limitations

  • This package currently does not implement Stripe invoices.

Help

First, consult the Haddock and Stripe API docs to be certain you're using the API correctly. It's a good idea to try another library first to see if it works there. If you think you might be misunderstanding the API, or having an issue with Stripe itself, it's best to contact them.

If all of that fails, or if you otherwise think it's an issue with this implementation of the API, please submit an issue here. Better yet, submit a pull request with a proposed solution!

License

I like the MIT license. See LICENSE.