Skip to content

mattsta/stripe-erlang

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

stripe-erlang: stripe client. erlang flavored.

Status

stripe-erlang is a minimal stripe client. Currently it only supports four operations: turning a credit card into an opaque token, creating a customer with a token, charging a customer, or charging a token.

If you need refunds or transaction management, use the delightful stripe.com admin interface for now.

Usage

Quick Start

Eshell V5.8.5  (abort with ^G)
1> inets:start().
ok
2> ssl:start().
ok
3> application:start(stripe), application:set_env(stripe, auth_token, "vtUQeOtUnYr7PGCLQ96Ul4zqpDUO4sOE").
ok
4> rr(stripe).
[stripe_card,stripe_charge,stripe_customer,stripe_error,
 stripe_token]
5> #stripe_token{id = Token} = stripe:token_create("4242424242424242", 12, 2012, 123, [], [], [], [], [], []).
#stripe_token{id = <<"tok_0WwgS4mze5px3I">>,currency = usd,
              used = false,amount = 0,livemode = false,
             card = #stripe_card{last4 = <<"4242">>,exp_year = 2012,
                                  exp_month = 12,type = <<"Visa">>,
                                  cvc_check = pass,address_line1_check = nil,
                                  address_zip_check = nil,country = <<"US">>}}
6> stripe:charge_card(5000, usd, Token, "Mah Money").
#stripe_charge{id = <<"ch_tuqXu5bKbKAr9x">>,
             created = 1320814827,amount = 5000,fee = 0,currency = usd,
               description = <<"Mah Money">>,livemode = false,paid = true,
               refunded = false,
               card = #stripe_card{last4 = <<"4242">>,exp_year = 2012,
                                   exp_month = 12,type = <<"Visa">>,
                                   cvc_check = pass,address_line1_check = nil,
                                   address_zip_check = nil,
                                   country = <<"US">>}}

Configuration

You must start inets and ssl before using stripe.

By default, erlang-stripe uses the global stripe API test token. You must change this to your private API key before you can receive payments:

 inets:start(),
 ssl:start(),
 application:start(stripe),
 application:set_env(stripe, auth_token, "vtUQeOtUnYr7PGCLQ96Ul4zqpDUO4sOE").

Building

    rebar get-deps
    rebar compile

Testing

    rebar eunit skip_deps=true suite=stripe

Next Steps

In no specific order:

  • Flesh out remaining stripe API
    • Adding a new API feature requires adding: exported user function, request wrapper, result to record extractor.
    • Add support for the card fingerprint element in relevant places.
    • Add support for the fee_details structure.
    • Add support for the disputed flag.
    • Add support for the failure_message note.
  • Add tests for error conditions
  • Move from env-specified auth token to something more call specific
    • Options:
      • parameterized module (stripe:new(AuthToken))
      • Per-call auth token (stripe:charge_card(AuthToken, ...))
      • Leave env, but add per-auth token options

Contributions

Want to help? Patches welcome.

  • Add a missing API call
    • Add the record with type info in include/stripe.hrl
    • Add the exported function in src/stripe.erl
    • Add the request_* wrapper function
    • Add a new json_to_record result extractor
    • Add positive and negative tests in test/stripe_tests.erl
  • Find a bug. Fix a bug.

About

Erlang interface to the stripe.com API

Resources

Stars

Watchers

Forks

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •