You can download this project as a NuGet dependency at https://www.nuget.org/packages/trustly-api-client/
You could also clone this repository, but we recommend using NuGet to keep up to date with any bug fixes, and to keep your own codebase as clean as possible.
You can easily create an instance of the client, giving a settings object with different levels of granular options.
var client = new TrustlyApiClient(TrustlyApiClientSettings.ForDefaultTest());
This is a shorthand to two different, more elaborate setups.
If there is an environment variable sent along to the application startup, it will load the username, password and certificates from the default environment variable names:
CLIENT_USERNAME
CLIENT_PASSWORD
CLIENT_CERT_PUBLIC
CLIENT_CERT_PRIVATE
These can of course be modified to something else, they are just the default names.
The CLIENT_CERT_PUBLIC
and CLIENT_CERT_PRIVATE
are not the paths to the certificate, but the certificates themselves in UTF-8 charset.
If an environment variable was found, it is virtually the same as create a client using this setup:
var client = new TrustlyApiClient(TrustlyApiClientSettings
.ForTest()
.WithCredentialsFromEnv("CLIENT_USERNAME", "CLIENT_PASSWORD")
.WithCertificatesFromEnv("CLIENT_CERT_PUBLIC", "CLIENT_CERT_PRIVATE")
.AndTrustlyCertificate());
Or if there is no environment variable set, it will look for files in the client's user home directory.
The default file names are:
trustly_client_username.txt
trustly_client_password.txt
trustly_client_public.pem
trustly_client_private.pem
var client = new TrustlyApiClient(TrustlyApiClientSettings
.ForTest()
.WithCredentialsFromUserHome("trustly_client_username.txt", "trustly_client_password.txt")
.WithCertificatesFromUserHome("trustly_client_public.pem", "trustly_client_private.pem")
.AndTrustlyCertificate());
Which can of course also be overridden and customized.
A Request is done as simply as:
var response = client.Deposit(new Trustly.Api.Domain.Requests.DepositRequestData
{
NotificationURL = "https://fake.test.notification.trustly.com",
MessageID = Guid.NewGuid().ToString(),
EndUserID = "user@email.com",
Attributes = new Trustly.Api.Domain.Requests.DepositRequestDataAttributes
{
Amount = "100.00",
Firstname = "John",
Lastname = "Doe",
Email = "user@email.com",
Currency = "EUR",
Country = "SE",
Locale = "sv_SE",
ShopperStatement = "Trustly Test Deposit"
}
});
var redirectOrIFrameUrl = response.URL;
Where the request and reponse types are typesafe and easy to handle. If there ever are properties which are not represented in the model, they will be placed under the ExtensionData
dictionary properties on the respective object graph levels.
There are three ways to insert the notifications into the client. All these will end up calling on events available on the client, these are:
OnAccount
OnCancel
OnCredit
OnDebit
OnPayoutConfirmation
OnPending
OnUnknown
(All properties will be placed inExtensionData
dictionary property)
You register to these as usual with C# events:
client.OnDebit += (sender, args) =>
{
System.Console.WriteLine($"{args.Data.Amount} was debited");
args.RespondWithOK();
};
- Automatically, by registering on the MVC Application Builder
public class Startup
{
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
// ...
// Register Trustly Notifications Middleware
app.UseTrustlyNotifications();
// ...
}
}
This will register an MVC Core Middleware that listens to HTTP POSTs on context path /trustly/notifications
.
It will automatically find all instantiated Trustly Api clients and call all of them, if there are multiple ones, until one of them has reported the notification as done by calling RespondWithOK()
or RespondWithFailed()
on the event args.
If no event listener on a client responds with OK
nor Failed
an exception will be thrown. If an unexpected exception is thrown, we will respond with a Fail
with the exception message attached.
NOTE: For this to work you MUST keep a non-garbage-collected instantiation of the API Client in memory somewhere in your code. You cannot create an API Client, do a request, and then dispose of the client. It must be kept in memory to be able to receive the middleware request's notification sent asynchronously from Trustly's server.
- Or Manually, by calling on asynchronous
client.HandleNotificationFromRequestAsync(HttpRequest request, Callback onOK, Callback onFailed)
.
This will not automatically send an OK
or Failed
response back to the Trustly server.
Instead you need to subscribe to the onOK
and onFailed
callbacks, if you want to use the event args' callback methods.
If you will not use the event args' callback methods, then you do not need to supply these callback arguments, and can respond with a JsonRpc response manually.
- Or Manually, by calling on
client.HandleNotificationFromString(String json, Callback onOK, Callback onFailed)
.
See #2 for callback comments.