silverpop-dotnet-api-xml
2.2.0
dotnet add package silverpop-dotnet-api-xml --version 2.2.0
NuGet\Install-Package silverpop-dotnet-api-xml -Version 2.2.0
<PackageReference Include="silverpop-dotnet-api-xml" Version="2.2.0" />
paket add silverpop-dotnet-api-xml --version 2.2.0
#r "nuget: silverpop-dotnet-api-xml, 2.2.0"
// Install silverpop-dotnet-api-xml as a Cake Addin #addin nuget:?package=silverpop-dotnet-api-xml&version=2.2.0 // Install silverpop-dotnet-api-xml as a Cake Tool #tool nuget:?package=silverpop-dotnet-api-xml&version=2.2.0
Silverpop .NET API
This is a .NET API wrapper for Silverpop Transact XML email sending.
Installation
The recommended installation method is the silverpop-dotnet-api NuGet package.
PM> Install-Package silverpop-dotnet-api
Requirements
- .NET Framework 4.6.1 /
netstandard2.0
Usage
Create the client
// Create the TransactClient with standard authentication only.
// Note: This does not enable OAuth scenarios.
// OAuth is typically used when an application is hosted
// somewhere with a non-static IP address (Azure Websites, etc.),
// or when you don't want to specify IP address(es) with Silverpop.
var client = TransactClient.Create(YourPodNumberInteger, YourUsername, YourPassword);
// ------------------------- OR -------------------------
// Create the TransactClient enabling all features.
// OAuth will be used for non-batch message scenarios.
var client = TransactClient.CreateIncludingOAuth(
YourPodNumberInteger,
YourUsername,
YourPassword,
YourOAuthClientId,
YourOAuthClientSecret,
YourOAuthRefreshToken);
// ------------------------- OR -------------------------
// Create the TransactClient with OAuth authentication only.
// Note: This cannot be used with batch sending.
var client = TransactClient.CreateOAuthOnly(
YourPodNumberInteger,
YourOAuthClientId,
YourOAuthClientSecret,
YourOAuthRefreshToken);
// ------------------------- OR -------------------------
var client = TransactClient.CreateUsingConfiguration();
When using TransactClient.CreateUsingConfiguration()
the configuration can be defined using TransactClientConfigurationSection or appSettings. Both can be used, too -- they'll be combined, with appSettings overwriting any settings defined in TransactClientConfigurationSection.
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections>
<section name="transactClientConfiguration" type="Silverpop.Client.TransactClientConfigurationSection, Silverpop.Client" />
</configSections>
<transactClientConfiguration
podNumber="0"
username=""
password=""
oAuthClientId=""
oAuthClientSecret=""
oAuthRefreshToken="" />
<appSettings>
<add key="silverpop-dotnet-api:PodNumber" value="" />
<add key="silverpop-dotnet-api:Username" value="" />
<add key="silverpop-dotnet-api:Password" value="" />
<add key="silverpop-dotnet-api:OAuthClientId" value="" />
<add key="silverpop-dotnet-api:OAuthClientSecret" value="" />
<add key="silverpop-dotnet-api:OAuthRefreshToken" value="" />
</appSettings>
</configuration>
Create a simple message
var message = TransactMessage.Create("123456", TransactMessageRecipient.Create("user@example.com");
Send a message using the client (1-10 recipients)
TransactMessageResponse response = client.SendMessage(message);
Send a message using the client asynchronously (1-10 recipients)
TransactMessageResponse response = await client.SendMessageAsync(message);
Send a message batch using the client (1 or more recipients -- intended for bulk usage rather than sending an email to a single user)
// This may send multiple XML files to Silverpop depending on the number of recipients.
IEnumerable<string> batchResponse = client.SendMessageBatch(message);
Send a message batch using the client asynchronously (1 or more recipients -- intended for bulk usage rather than sending an email to a single user)
// This may send multiple XML files to Silverpop depending on the number of recipients.
IEnumerable<string> batchResponse = await client.SendMessageBatchAsync(message);
Get the status of a message batch
// This checks the status for the first batch only from one of the above calls
// (there may be more than one XML file sent to Silverpop).
TransactMessageResponse response = client.GetStatusOfMessageBatch(batchResponse[0]);
Get the status of a message batch asynchronously
// This checks the status for the first batch only from one of the above calls
// (there may be more than one XML file sent to Silverpop).
TransactMessageResponse response = await client.GetStatusOfMessageBatchAsync(batchResponse[0]);
Messages with personalization tags
First, we recommend creating a class as a model for the personalization tags.
public class MyPersonalizationTags
{
// The SilverpopPersonalizationTag attribute is optional
// and specifies the actual tag name configured in Silverpop.
//
// This is useful when you want the model properties to differ
// from the Silverpop tag names, or you are unable to specify
// the tag name as a property. For example: spaces are not permitted
// in C# property names.
[SilverpopPersonalizationTag("First Name")]
public string FirstName { get; set; }
[SilverpopPersonalizationTag("Last Name")]
public string LastName { get; set; }
public decimal Amount { get; set; }
}
Then, use the model class when constructing a message.
var message = TransactMessage.Create(
"123456",
TransactMessageRecipient.Create(
"user@example.com",
new MyPersonalizationTags()
{
FirstName = "TheFirstName",
LastName = "TheLastName",
Amount = 123.45M
}));
License
MIT License
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
- Newtonsoft.Json (>= 12.0.1)
- SSH.NET (>= 2016.1.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Add Contact XML API fow working.