Purpose:
To check an invoice or a reservation order status if it is ok, pending or denied.
Return value:
Integer - 1,2 or 3.
1 = OK
2 = Pending
3 = Denied
or
Throws an exception with error code and error message.
Code examples
Please note that you can find more code examples in our API-files which you will find under Download API in the left menu.
The code examples have been divided into several steps. Click on the step you would like to see the code example.
1. Initialize and setup the Klarna instance
$k = new Klarna();
$k->config(
123456, // Merchant ID
'sharedSecret', // Shared Secret
KlarnaCountry::SE, // Country
KlarnaLanguage::SV, // Language
KlarnaCurrency::SEK, // Currency
Klarna::BETA, // Server
'json', // PClass Storage
'/srv/pclasses.json', // PClass Storage URI path
true, // SSL
true // Remote logging of response times of xmlrpc calls
);
2. Check the status on your order (invoice or reservation)
$id = '123456'; // Your reservation or invoice number.
try {
$result = $k->checkOrderStatus(
$id, // Reservation, invoice number or order id.
0 // Flag specifying number type. 0 = rno or invno. 1 = order id.
);
if ($result == KlarnaFlags::ACCEPTED) {
// Status changed, you can now activate your invoice/reservation.
echo "Accepted\n";
} else if ($result == KlarnaFlags::DENIED) {
echo "Denied\n";
// Status changed, it is now denied, proceed accordingly.
} else {
echo "Pending\n";
//Order is still pending, try again later.
}
} catch (Exception $e) {
//Something went wrong, print the message:
echo "{$e->getMessage()} (#{$e->getCode()})\n";
}
The code examples have been divided into several steps. Click on the step you would like to see the code example.
1. Initialize and setup the Klarna instance
API klarna = new API ();
/** Configure the Klarna object **/
klarna.Config (new KlarnaConfig () {
EID = 123456,
Secret = "sharedsecret",
Country = API.Country.Sweden,
Language = API.Language.Swedish,
Currency = API.Currency.SEK,
Encoding = API.Encoding.Swedish,
// API.KlarnaServer.Beta or API.KlarnaServer.Live, depending
// on which server your eid is associated with
Mode = API.KlarnaServer.Beta,
PCStorage = "xml",
PCURI = @"/tmp/pclasses.xml"
});
2. Check the status on your order (invoice or reservation)
//Use the invoice or reservation id to check status on your order
string id = "";
try {
API.OrderStatus result = klarna.CheckOrderStatus (
id,
// Checks against Invoice or Reservation ID. Alternativly you can use API.OrderStatusFor.OrderID
API.OrderStatusFor.InvoiceOrReservation
);
if (result == API.OrderStatus.Accepted) {
//Status changed, you can now activate your invoice/reservation
Console.WriteLine ("Accepted");
} else if (result == API.OrderStatus.Denied) {
//Status changed, it is now denied, proceed accordingly.
Console.WriteLine ("Denied");
} else {
//order is still pending, try again later
Console.WriteLine ("Pending");
}
} catch (Exception e) {
//Something went wrong print the error:
Console.WriteLine ("Errror: " + e.Message);
}
The code examples have been divided into several steps. Click on the step you would like to see the code example.
1. Initialize and setup the Klarna instance
Klarna k = new Klarna();
/*
* Configure the Klarna object using the config() method. (Alternative 1)
*/
KlarnaConfig conf = new KlarnaConfig();
// Define values:
conf.setEid(0); // Merchant ID or Estore ID, an Integer above 0.
conf.setSecret("sharedSecret"); // The shared secret which accompanied your eid.
conf.setCountry(KlarnaCountry.DE); // The country of your store.
conf.setLanguage(KlarnaLanguage.DE); // The language of your store.
conf.setCurrency(KlarnaCurrency.EUR); // The currency of your store.
conf.setMode(Klarna.BETA); // or Klarna.LIVE when you are ready to go live.
// Define pclass settings:
conf.setPcStorage("json"); // Storage module. Currently only json is supported.
conf.setPcURI("/srv/pclasses.json"); // Where the json file for the pclasses are stored.
// Should we use SSL?
conf.setSsl(false);
// Should we error report/status report to klarna.
conf.setCandice(true); // set to false if your server doesn't support UDP
// Do we want to see normal debug information?
conf.setDebug(null); // true to debug, null or false not to debug
// Set the config object.
k.config(conf);
/*
* Configure the Klarna object using the config() method (Alternative 2)
*/
/*
* k.config(0, // e-store ID
* "sharedSecret", // shared secret
* KlarnaCountry.DE, // Country constant
* KlarnaLanguage.DE, // Language constant
* KlarnaCurrency.EUR, // Currency constant
* Klarna.BETA, // Mode, BETA or LIVE
* "json", // Storage module
* "/srv/pclasses.json", // Storage location
* true, // SSL
* true // Candice
* );
*
* k.debug = false;
*/
/*
* Configure the Klarna object using the config() method (Alternative 3)
*/
// k.config(KlarnaConfig.fromJson("/srv/klarna.json"));
/* the file would contain the following data to set the same information as above alternatives:
* {
* "eid":0,
* "secret":"sharedSecret",
** "country":"DE",
** "language":"DE",
* "currency":"EUR",
* "mode":1,
* "ssl":false,
* "candice":true,
* "pcStorage":"json",
* "pcURI":"/srv/pclasses.json"
* }
*
*/
2. Check the status on your order (invoice or reservation)
String id = request.getParameter("id"); // Your reservation or invoice number.
try {
String result = k.checkOrderStatus(
id, // Reservation, invoice number or order id.
0); // Checks against a reservation or invoice number. If it equals 1 it checks against an order id.
KlarnaFlags.OrderStatus res = KlarnaFlags.OrderStatus.get(Integer.parseInt(result));
if (res == KlarnaFlags.OrderStatus.ACCEPTED) {
// Status changed, you can now activate your invoice/reservation.
out.println(res.getText());
} else if (res == KlarnaFlags.OrderStatus.DENIED) {
// Status changed, it is now denied, proceed accordingly
} else {
// Order is still pending. Try again later.
}
} catch ( Exception e ) {
// Something went wrong, print the message.
out.println(e.getMessage());
}
The code examples have been divided into several steps. Click on the step you would like to see the code example.
1. Initialize and setup the Klarna instance
<%
Option Explicit
%>
<%
' Grab the API object
' -Merchant ID or Estore ID, an integer above 0.
' -The shared secret which accompanied your eid.
' -Country, language and currency.
Dim kAPI
Set kAPI = GetKlarna(0, "sharedsecret", "SE", "SV", "SEK")
' Do we want to see normal debug information?
kAPI.DebugInformation = True
' Set the address and port to Klarna server.
' Use LIVE or BETA depending on which server your eid is associated with.
kAPI.SetPort(HTTPS_PORT) ' or HTTP_PORT
kAPI.SetHost(BETA_HOST) ' or LIVE_HOST
' Where the XML for the PClasses are stored, e.g. "pclasses.xml"
kAPI.SetPClassesStorageUri(Server.MapPath("pclasses.xml"))
%>
2. Check the status on your order (invoice or reservation)
<%
On Error Resume Next
' Your reservation or invoice number or order id.
Dim id
id = CStr(Request.QueryString("id"))
' Checks against a reservation or invoice number, type 1 checks against an order id.
Dim orderType
orderType = 0
' Check the status on the specified invoice/reservation.
Dim result
result = kAPI.CheckOrderStatus(id, orderType)
If Err.number = 0 Then
' Success
Response.Write("Order status for order " & id &" is: ")
If result = ACCEPTED Then
' Status changed, you can now activate your invoice/reservation.
Response.Write("Accepted")
ElseIf result = DENIED Then
' Status changed, it is now denied, proceed accordingly.
Response.Write("Denied")
Else
' Order is still pending, try again later.
Response.Write("Pending")
End If
Else
' Something went wrong
Response.Write("Error occured: " & Err.number & " - " & Err.Description & "" & Err.Source & "")
End If
%>
