/CakePHP-Paypal-IPN-Plugin

CakePHP Paypal Instant Payment Notification Plugin

Primary LanguagePHP

Paypal IPN plugin.  (Paypal Instant Payment Notification)
Version 3.5.1
Author: Nick Baker (nick@webtechnick.com)
Website: http://www.webtechnick.com

Get it
======================
Download: http://projects.webtechnick.com/paypal_ipn.tar.gz
SVN: http://svn.github.com/webtechnick/CakePHP-Paypal-IPN-Plugin
GIT: git@github.com:webtechnick/CakePHP-Paypal-IPN-Plugin.git

Required:
======================
CakePHP 1.2.x/1.3.x

More From WebTechNick
======================
http://github.com/webtechnick

CHANGELOG:
======================
1.0: Initial release
1.1: Added cleaner routes
2.0: Helper added
2.1: Added cake schema install script
2.2: Added paypal unsubscribe type
2.2.1: Bug fix with subscription issues
2.2.2: Fixed validation issues with paypal button in strict doctype
3.0: Added new basic Paypal IPN email capabality.
3.5 Added checkout feature for multiple items paypal button.  Documentation bellow
3.5.1: Renamed columns option_name_1 and option_name_2 to option_name1 and option_name2 respectively

Special thanks: Peter Butler <http://www.studiocanaria.com>

Migration Guide from 3.0 to 3.5:
======================
  open a terminal and execute the following command:
  
  cake schema run create -path plugins/paypal_ipn/config/sql -name items

Install:
======================
1) Copy plugin into your /app/plugins/paypal_ipn directory
2a) Run the paypal_ipn.sql into your database.
2b) run "cake schema run create -path plugins/paypal_ipn/config/sql -name ipn" in a terminal.
3) Add the following into your /app/config/routes.php file (optional):
  /* Paypal IPN plugin */
  Router::connect('/paypal_ipn/process', array('plugin' => 'paypal_ipn', 'controller' => 'instant_payment_notifications', 'action' => 'process'));
  /* Optional Route, but nice for administration */
  Router::connect('/paypal_ipn/:action/*', array('admin' => 'true', 'plugin' => 'paypal_ipn', 'controller' => 'instant_payment_notifications', 'action' => 'index'));
  /* End Paypal IPN plugin */
  
Paypal Setup:
======================
1) I suggest you start a sandbox account at https://developer.paypal.com
2) Enable IPN in your account.
  
Administration: (optional) If you want to use the built in admin access to IPNs:
======================
1) Make sure you're logged in as an Administrator via the Auth component.
2) Navigate to www.yoursite.com/paypal_ipn


Paypal Button Helper: (optional) if you plan on using the paypal helper for your PayNow or Subscribe Buttons
======================
1) Update /paypal_ipn/config/paypal_ipn_config.php with your paypal information
2) Add 'PaypalIpn.Paypal' to your helpers list in app_controller.php:
       var $helpers = array('Html','Form','PaypalIpn.Paypal');
3) Usage: (view the actual /paypal_ipn/views/helpers/paypal.php for more information)
       $paypal->button(String tittle, Options array);
       Examples: 
         $paypal->button('Pay Now', array('amount' => '12.00', 'item_name' => 'test item'));
         $paypal->button('Subscribe', array('type' => 'subscribe', 'amount' => '60.00', 'term' => 'month', 'period' => '2'));
         $paypal->button('Donate', array('type' => 'donate', 'amount' => '60.00'));
         $paypal->button('Add To Cart', array('type' => 'addtocart', 'amount' => '15.00'));
         $paypal->button('Unsubscribe', array('type' => 'unsubscribe'));
         $paypal->button('Checkout', array(
           'type' => 'cart',
           'items' => array(
             array('item_name' => 'Item 1', 'amount' => '120', 'quantity' => 2, 'item_number' => '1234'),
             array('item_name' => 'Item 2', 'amount' => '50'),
             array('item_name' => 'Item 3', 'amount' => '80', 'quantity' => 3),
           )
         ));
       Test Example:
         $paypal->button('Pay Now', array('test' => true, 'amount' => '12.00', 'item_name' => 'test item'));

Paypal Button:
======================
1) Use the PaypalHelper to generate your buttons for you. See Paypal Button Helper (above) for more.
 - or -
1) Make sure to use notify_url set to "http://www.yoursite.com/paypal_ipn/process" in your paypal button.
Example:
  
<form action="https://www.paypal.com/cgi-bin/webscr" method="post">
  ...
  <input type="hidden" name="notify_url" value="http://www.yoursite.com/paypal_ipn/process" />
  ...
</form>


Paypal Notification Callback:
======================
1) create a function in your /app/app_controller.php like so:

  function afterPaypalNotification($txnId){
    //Here is where you can implement code to apply the transaction to your app.
    //for example, you could now mark an order as paid, a subscription, or give the user premium access.
    //retrieve the transaction using the txnId passed and apply whatever logic your site needs.
      
    $transaction = ClassRegistry::init('PaypalIpn.InstantPaymentNotification')->findById($txnId);
    $this->log($transaction['InstantPaymentNotification']['id'], 'paypal');
  
    //Tip: be sure to check the payment_status is complete because failure 
    //     are also saved to your database for review.
  
    if($transaction['InstantPaymentNotification']['payment_status'] == 'Completed'){
      //Yay!  We have monies!
    }
    else {
      //Oh no, better look at this transaction to determine what to do; like email a decline letter.
    }
  } 
  
Basic Email Feature:
======================
 Utility method to send basic emails based on a paypal IPN transaction.
 This method is very basic, if you need something more complicated I suggest
 creating your own method in the afterPaypalNotification function you build
 in the app_controller.php

 Example Usage: (InstantPaymentNotification = IPN)
   IPN->id = '4aeca923-4f4c-49ec-a3af-73d3405bef47';
   IPN->email('Thank you for your transaction!');

   IPN->email(array(
     'id' => '4aeca923-4f4c-49ec-a3af-73d3405bef47',
     'subject' => 'Donation Complete!',
     'message' => 'Thank you for your donation!',
     'sendAs' => 'text'
   ));

  Hint: use this in your afterPaypalNotification callback in your app_controller.php
   function afterPaypalNotification($txnId){
     ClassRegistry::init('PaypalIpn.InstantPaymentNotification')->email(array(
       'id' => $txnId,
       'subject' => 'Thanks!',
       'message' => 'Thank you for the transaction!'
     ));
   }

 Email Options:
   * id: id of instant payment notification to base email off of
   * subject: subject of email (default: Thank you for your paypal transaction)
   * sendAs: html | text (default: html)
   * to: email address to send email to (default: ipn payer_email)
   * from: from email address (default: ipn business)
   * cc: array of email addresses to carbon copy to (default: array())
   * bcc: array of email addresses to blind carbon copy to (default: array())
   * layout: layout of email to send (default: default)
   * template: template of email to send (default: null)
   * log: boolean true | false if you'd like to log the email being sent. (default: true)
   * message: actual body of message to be sent (default: null)