= 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]. * {Authorize.Net CIM}[http://www.authorize.net/] - US * {Authorize.Net}[http://www.authorize.net/] - US * {Beanstream.com}[http://www.beanstream.com/] - CA * {BluePay}[http://www.bluepay.com/] - US * {Braintree}[http://www.braintreepaymentsolutions.com] - US * {CardStream}[http://www.cardstream.com/] - GB * {CyberSource}[http://www.cybersource.com] - US * {DataCash}[http://www.datacash.com/] - GB * {Efsnet}[http://www.concordefsnet.com/] - US * {Elavon MyVirtualMerchant}[http://www.elavon.com] - US, CA * {ePay}[http://www.epay.dk/] - DK * {eWAY}[http://www.eway.com.au/] - AU * {E-xact}[http://www.e-xact.com] - CA, US * {FirstPay}[http://www.first-pay.com] - US * {Garanti Sanal POS}[https://ccpos.garanti.com.tr/ccRaporlar/garanti/ccReports] - US, TR * {Inspire}[http://www.inspiregateway.com] - US * {InstaPay}[http://www.instapayllc.com] - US * {Iridium}[http://www.iridiumcorp.co.uk/] - UK, ES * {JetPay}[http://www.jetpay.com] - US * {LinkPoint}[http://www.linkpoint.com/] - US * {Merchant e-Solutions}[http://merchante-solutions.com/] - US * {MerchantWare}[http://merchantwarehouse.com/merchantware] - US * {Modern Payments}[http://www.modpay.com] - US * {Moneris}[http://www.moneris.com/] - CA * {Netaxept}[http://www.betalingsterminal.no/Netthandel-forside] - NO, DK, SE, FI * {NetRegistry}[http://www.netregistry.com.au] - AU * {NELiX TransaX Gateway}[http://www.nelixtransax.com] - US * {NETbilling}[http://www.netbilling.com] - US * {Ogone DirectLink}[http://www.ogone.com] - BE, DE, FR, NL, AT, CH * {PayBox Direct}[http://www.paybox.com] - FR * {PayJunction}[http://www.payjunction.com/] - US * {PaySecure}[http://www.commsecure.com.au/paysecure.shtml] - AU * {PayPal Express Checkout}[https://www.paypal.com/cgi-bin/webscr?cmd=xpt/merchant/ExpressCheckoutIntro-outside] - US, CA, SG, AU * {PayPal Payflow Pro}[https://www.paypal.com/cgi-bin/webscr?cmd=_payflow-pro-overview-outside] - US, CA, SG, AU * {PayPal Website Payments Pro (UK)}[https://www.paypal.com/uk/cgi-bin/webscr?cmd=_wp-pro-overview-outside] - GB * {PaymentExpress}[http://www.paymentexpress.com/] - AU, MY, NZ, SG, ZA, GB, US * {PayPal Website Payments Pro (CA)}[https://www.paypal.com/cgi-bin/webscr?cmd=_wp-pro-overview-outside] - CA * {PayPal Express Checkout}[https://www.paypal.com/cgi-bin/webscr?cmd=xpt/merchant/ExpressCheckoutIntro-outside] - US * {PayPal Website Payments Pro (US)}[https://www.paypal.com/cgi-bin/webscr?cmd=_wp-pro-overview-outside] - US * {Plug'n Pay}[http://www.plugnpay.com/] - US * {Protx}[http://www.protx.com] - GB * {Psigate}[http://www.psigate.com/] - CA * {PSL Payment Solutions}[http://www.paymentsolutionsltd.com/] - GB * {Quantum}[http://www.quantumgateway.com] - US * {Quickpay}[http://quickpay.dk/] - DK * {Rabobank Nederland}[http://www.rabobank.nl/] - NL * {Realex}[http://www.realexpayments.com/] - IE, GB * {Sage Payment Solutions}[http://www.sagepayments.com] - US, CA * {Sallie Mae}[http://www.salliemae.com] - US * {SecureNet}[http://www.securenet.com] - US * {SecurePay}[http://securepay.com.au] - AU * {SecurePay}[http://www.securepay.com/] - US * {SecurePayTech}[http://www.securepaytech.com/] - NZ * {SkipJack}[http://www.skipjack.com/] - US, CA * {TransFirst}[http://www.transfirst.com/] - US * {TrustCommerce}[http://www.trustcommerce.com/] - US * {USA ePay}[http://www.usaepay.com/] - US * {Verifi}[http://www.verifi.com/] - US * {ViaKLIX}[http://viaklix.com] - US * {Wirecard}[http://www.wirecard.com] - DE == Supported Offsite Payment Gateways * {2 Checkout}[http://www.2checkout.com] * {Banca Sella GestPay}[https://www.sella.it/banca/ecommerce/gestpay/gestpay.jsp] * {Chronopay}[http://www.chronopay.com] * {DirecPay}[http://www.timesofmoney.com/direcpay/jsp/home.jsp] * {HiTRUST}[http://www.hitrust.com.hk/] * {Nochex}[http://www.nochex.com] * {PayPal Website Payments Standard}[https://www.paypal.com/cgi-bin/webscr?cmd=_wp-standard-overview-outside] * {SagePay Form}[http://www.sagepay.com/products_services/sage_pay_go/integration/form] == 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.