active_merchant

Active Merchant is a simple payment abstraction library used in and sponsored by Shopify. It is written by Tobias Luetke, Cody Fauser, and contributors. The aim of the project is to feel natural to Ruby users and to abstract as many parts as possible away

6 years after

= Active Merchant

This library is supposed to aid in creating e-commerce software in Ruby. In the future we want to support all "good" payment gateways.

This library is the foundation of commerce for http://www.shopify.com.

Please visit the {ActiveMerchant homepage}[http://activemerchant.org] for more resources, tutorials and other information about this project.

== Supported Direct Payment Gateways

The {ActiveMerchant Wiki}[http://github.com/Shopify/active_merchant/wikis] contains a {table of features supported by each gateway}[http://github.com/Shopify/active_merchant/wikis/gatewayfeaturematrix].

== Supported Offsite Payment Gateways

== Download

Currently this library is available with git from:

git://github.com/Shopify/active_merchant.git

== Installation

=== From Git

You can check out the latest source from git:

git pull git://github.com/Shopify/active_merchant.git

=== As a Rails plugin

ActiveMerchant includes an init.rb file. This means that Rails will automatically load ActiveMerchant on startup. Run the following command from the root directory of your Rails project to install ActiveMerchant as a Rails plugin:

./script/plugin install git://github.com/Shopify/active_merchant.git

=== From Ruby Gems

Installation from RubyGems

gem install activemerchant

== Sample Usage require 'rubygems' require 'active_merchant'

Use the TrustCommerce test servers

ActiveMerchant::Billing::Base.mode = :test

ActiveMerchant accepts all amounts as Integer values in cents

$10.00

amount = 1000

The card verification value is also known as CVV2, CVC2, or CID

credit_card = ActiveMerchant::Billing::CreditCard.new( :first_name => 'Bob', :last_name => 'Bobsen', :number => '4242424242424242', :month => '8', :year => '2012', :verification_value => '123' )

Validating the card automatically detects the card type

if credit_card.valid?

# Create a gateway object for the TrustCommerce service
gateway = ActiveMerchant::Billing::TrustCommerceGateway.new(
            :login => 'TestMerchant',
            :password => 'password'
          )

# Authorize for the amount
response = gateway.purchase(amount, credit_card)

if response.success?
  puts "Successfully charged $#{sprintf("%.2f", amount / 100)} to the credit card #{credit_card.display_number}"
else
  raise StandardError, response.message 
end

end

== Contributing

Please see the {ActiveMerchant Guide to Contributing}[http://github.com/Shopify/active_merchant/wikis/contributing] for information on adding a new gateway to ActiveMerchant.

Related Repositories

active_merchant-paypal-bogus-gateway

active_merchant-paypal-bogus-gateway

Extracted from a PR agains ActiveMerchant https://github.com/activemerchant/acti ...


Top Contributors

stopdropandrew Soleone yukster iamjwc jzw jstorimer jamesmacaulay rmcafee tobi mmangino bschwartz duncanbeevers edward tekin bjeanes cbillen dball duff erictarn guynaor jimmybaker NZKoz pdsphil robbyrussell bowsersenior infused