How to automate Moneybookers (Skrill) using status_url (IPN)
Moneybookers is quickly becoming a viable competitor to PayPal. And because of this users / developers have been asking for a completely automated payment form example similar to how our PayPal example works. That is, the customer enters the number of licenses they want, they click “Buy now”, they enter their info on the PayPal page, then they click “Order”, and a few seconds later the customer is magically sent their shiny new product key.
With PayPal this whole process is simple — just use the PayPal IPN (instant payment notification). That is, you specify an URL for PayPal to talk to once the order is complete. From there you can validate the order and take any action you like (e.g. sending product keys).
Moneybookers has a similar process except there are hardly any examples showing how to use it properly. And the example code that is on the web is riddled with very serious security vulnerabilities (SQL injections, failing to validate the order comes from Moneybookers, etc., etc.).
This article will show you how to use the Moneybookers equivalent to PayPal’s IPN. That is, you’ll be able to automatically generate product keys once a customer orders your software using Moneybookers.
Step 1. Signup for a Moneybookers test account
The first thing you need to do is get a test “merchant” account from Moneybookers. Unfortunately Moneybookers still doesn’t have a streamlined process for creating a test account, and their support staff is rather surly, so follow the instructions carefully:
- Sign up for a Moneybookers “Business account”. Do not use the same email you’ll be using for your real account.
- Sign up for a Moneybookers “Personal account”. Use a different email than the “Business account”. Do not use the same email you’ll be using for your real account.
- Contact Moneybookers and ask them to convert these 2 accounts to test accounts. It doesn’t need to be a long email. Just something simple like:
We need you to turn 2 accounts to test accounts:
“Buyer account”:
Email: buyer-email@example.com
Customer ID: 12456789
“Merchant account”:
Email: merchant-email@example.com
Customer ID: 98765421
Step 2. Create a “secret word”
In your new merchant account you’ll need to create a “Secret Word” on the “Merchant tools” page:
Now that you’ve created your test Moneybookers accounts and set your secret word you’re ready to add the payment form to your website.
Step 3 (option 1). Use our pre-built payment form
Just configure a few settings, add the payment form to your site, and you’re ready to go. See the “Automate license generation with Skrill (a.k.a. Moneybookers)” article.
Step 3 (option 2). Create your own payment form
If you don’t want to use the pre-built payment example in the LimeLM API Pack, or you’re not using C#, VB.NET, or PHP, then you can still automate your orders with Moneybookers. The first step is to add the Moneybookers payment form to your website:
<form action="https://www.moneybookers.com/app/payment.pl" method="post"> <input type="hidden" name="pay_to_email" value="merchant-email@example.com"/> <input type="hidden" name="status_url" value="http://example.com/verify.cgi"/> <input type="hidden" name="language" value="EN"/> <input type="hidden" name="amount" value="Total amount (e.g. 39.60)"/> <input type="hidden" name="currency" value="Currency code (e.g. USD)"/> <input type="hidden" name="detail1_description" value="YourApp"/> <input type="hidden" name="detail1_text" value="License"/> <input type="submit" value="Pay!"/> </form>
Change the “status_url” field to point to your script that will verify and generate the product keys and change the “pay_to_email” field to the test “merchant email” you created earlier. Then configure the price, currency code, and product name.
Optionally set your logo
You can customize the Moneybookers payment screen with your own logo. The logo must be hosted on a secure site — that is, the link must start with https:// not http://. Also, the logo must be at most 200px wide and 50px tall. If you have a logo that meets those requirements then add a “logo_url” field to your form. For example:
<input type="hidden" name="logo_url" value="https://example.com/logo.png"/>
This is an example showing what the wyDay logo looks like on the Moneybookers checkout page:
Step 4. Verify the Moneybookers order
After a customer has completed their order through Moneybookers, Moneybookers will contact the script you provided in the “status_url” argument (e.g. “http://example.com/verify.cgi”). Moneybookers will POST the order information to your script and it’s up to you to verify that it’s a valid order and not just some hacker trying to get free product key from you.
Luckily Moneybookers gives the prescribed method for verifying orders in their gateway integration manual. Quoting from their manual:
A hidden text field called md5sig is included in the form submitted to the Merchant’s server. The value of this field is a 128 bit message digest, expressed as a string of thirty-two hexadecimal digits in UPPERCASE. The md5sig is constructed by performing an MD5 calculation on a string built up by concatenating the other fields returned to the status_url. Specifically the MD5 hash is a concatenation of the following fields:
- merchant_id
- transaction_id
- the uppercase MD5 value of the ASCII equivalent of the secret word submitted in the “Merchant Tools” section of the Merchant’s online Moneybookers account.
- mb_amount
- mb_currency
- status
C# (ASP.NET) example code
In C# (for ASP.NET) first create a simple helper function that creates the uppercase MD5 hash of a string:
static string StringToMD5(string str) { MD5CryptoServiceProvider cryptHandler = new MD5CryptoServiceProvider(); byte[] ba = cryptHandler.ComputeHash(Encoding.UTF8.GetBytes(str)); StringBuilder hex = new StringBuilder(ba.Length * 2); foreach (byte b in ba) hex.AppendFormat("{0:X2}", b); return hex.ToString(); }
Then, the validation code will look something like this:
// Validate the Moneybookers signature string concatFields = Request.Form["merchant_id"] + Request.Form["transaction_id"] + StringToMD5("Paste your secret word here") + Request.Form["mb_amount"] + Request.Form["mb_currency"] + Request.Form["status"]; string MBEmail = "merchant-email@example.com"; // Ensure the signature is valid, the status code == 2, // and that the money is going to you if (Request.Form["md5sig"] == StringToMD5(concatFields) && Request.Form["status"] == "2" && Request.Form["pay_to_email"] == MBEmail) { // Valid transaction. //TODO: generate the product keys and // send them to your customer. } else { // Invalid transaction. Bail out return; }
Step 5. Further verification, generating product keys, etc.
There’s one further step of verification I didn’t talk about: making sure the customer paid the correct amount. That is, verifying the “mb_amount” field is correct. For instance you don’t want to send a user a product key if they only pay 1 penny instead of the full amount. Also, you can further extend the payment form and the verification code to handle quantity. But this is a bit beyond the scope of the article.
Step 6. Test the payment form
Now that you have everything configured you’re ready to test your Moneybookers payment. Run through the complete payment process to see everything works how you expect it to work.
Step 7. Create a real Moneybookers account, change the setting
After you’ve finished testing your payment process you’re ready to sign up for a real Moneybookers “Business account” and change the “pay_to_email” field to the email you used to create this account.
*** The Original document have been taken from http://wyday.com/blog/2011/automate-moneybookers-skrill-using-status_url-ipn-php-asp-net/
By, Akash Roy, CEO, JPR Infoserve, http://jprinfoserve.com
Exactly what i was looking for..Thanks for the article..
ReplyDeleteThanks..But please mention your identity from next time. otherwise your comment will not be published.
Delete