Skip to content

callmewa/avangate

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

27 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

avangate

Nodejs Avangate IPN confirmation

Usage:

var ipn = require("avangate")
    .initWithKey("YOUR SECRET KEY");

// ipn directly extends [EventEmitter](http://nodejs.org/api/events.html#events_class_events_eventemitter)
// add a handler for validated IPNs
ipn.on(ipn.EVENTS.VALIDATED,
  function(ipn){
    console.log("Validate:\n" + JSON.stringify(ipn, null, 2));
  });

// add handler for rejected IPNs
ipn.on(ipn.EVENTS.REJECTED,
  function(ipn){
    console.log("Rejected:\n" + JSON.stringify(ipn, null, 2));
  });


//confirm the avangate IPN
ipn.confirmIpn(req, res);

Sample Express usage for Avangate IPN confirmation

//This requires body-parse version > 1.2.2
var express = require('express');
var ipn = require('../lib/ipn').initWithKey("YOUR SECRET KEY");
var app = express();

var bodyParser = require('body-parser');

app.use(bodyParser.json());
//NOTE: this tells bodyParser to use the querystring modules instead of qs module
// this is required to parse Avangate IPNS
app.use(bodyParser.urlencoded({extended:false}));

app.post('/', ipn.confirmIpn);
app.listen(8888);

additional relevant documentation can be found in [lib/ipn.js] Checkout [samples/ipn_server.js] and [[test/express_test.js] ] for an working examples

The secret key in this example is: AABBCCDDEEFF For this example, the response is built in the same way, only using shorter data formats for date values. HMAC source string is built from the following:

Field name, Length, Field value

IPN_PID[0] 1 1

IPN_PNAME[0] 16 Software program

IPN_DATE 14 20050303123434

DATE 14 20050303123434

Therefore, the HMAC source string will be:

1116Software program14200503031234341420050303123434

while the HMAC MD5 string will be:

7bf97ed39681027d0c45aa45e3ea98f0

The response to output anywhere in the page defined as the IPN URL has to be:

20050303123434|7bf97ed39681027d0c45aa45e3ea98f0

If the string above is valid, and acknowledged by Avangate, the notification is marked in the Avangate system as "successfully sent". Contrary to this situation, the IPN notification will be re-sent at increasing time intervals, until successfully confirmed. Also, an error notification will be displayed in the Control Panel Dashboard area.

About

Nodejs Avangate IPN confirmation

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published