Click here to Skip to main content
14,935,564 members
Posted 2 May 2009

Tagged as



6 bookmarked

I’ve “forked” the Grails PayPal Plugin…

Rate me:
Please Sign up or sign in to vote.
0.00/5 (No votes)
2 May 2009CPOL2 min read
Adding more functionality to the Grails PayPal Plugin.

I’m currently completing the finishing touches on a new e-commerce site for my wife’s stationary business. We decided a long time ago to use PayPal for all of the payment processing since we’ve had a great experience using it for our eBay selling. About a year ago, Graeme Rocher polished off the last release of a PayPal plug-in that is available in the Grails Plugin repository. It really is a very nice plug-in, yet I had a couple of problems with it:

  • It is only capable of handling payments for one item transactions via “Buy Now” buttons. I want to upload an entire shopping cart full of multiple items.
  • It currently won’t handle shipping addresses. The site I’m building allows the user to maintain a list of shipping addresses, and I’d want to send the address information they choose along to PayPal.
  • Minor issue: needed to upgrade the plug-in to Grails 1.1.

So, I decided this evening to fork the plug-in. I want to leverage all of the great work that has been done thus far (especially with the IPN processing part - superb stuff), but I have to add in these two functions and do the version upgrade. Interestingly enough, I couldn’t get the tests to run out of the box after the upgrade. No good developer likes to modify code without a stable running test suite, right? So, what I ended up doing was creating a new Grails 1.1 plug-in project and copying the original artifacts over. Once this was done, all of the tests ran perfectly.

So, at this point, I’ve added function #1. You can now redirect to the “uploadCart” action. It assumes that you have already constructed a Payment object (now containing PaymentItems) and saved it, and then passed the transactionId along. I did this so that folks with multiple different ways of handling shopping carts could have some degree of flexibility - the onus is on you to map your cart to your Payment object correctly. The original functions implemented by Graeme are backwards compatible, assuming only one PaymentItem in the Payment. I’ve run all of the original tests and also did some manual functional testing by running the plug-in app against my own PayPal Sandbox account. So far so good. Look for more updates as this evolves. Once I get something I’m totally happy with, I’ll see about getting it pushed back into the main plug-in repo.

Want to take a closer look? Visit


This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


About the Author

Matt Stine
United States United States
No Biography provided

Comments and Discussions

-- There are no messages in this forum --