Official .NET / C# client for the TaxJar API. For the API documentation, please visit https://developers.taxjar.com/api.
Getting Started
Package Dependencies
Authentication
Usage
Custom Options
Sandbox Environment
Error Handling
Tests
More Information
License
Support
Contributing
We recommend installing TaxJar.net via NuGet. Before authenticating, get your API key from TaxJar.
Use the NuGet package manager inside Visual Studio, Xamarin Studio, or run the following command in the Package Manager Console:
PM> Install-Package TaxJar
TaxJar.net comes with assemblies for .NET Standard 2.0. It requires the following dependencies:
These packages are automatically included when installing via NuGet.
To authenticate with our API, add a new AppSetting with your TaxJar API key to your project's Web.config
/ App.config
file or directly supply the API key when instantiating the client:
<!-- Web.config / App.config -->
<appSettings>
...
<add key="TaxjarApiKey" value="[Your TaxJar API Key]" />
...
</appSettings>
var client = new TaxjarApi(ConfigurationManager.AppSettings["TaxjarApiKey"]);
Note: This method requires System.Configuration.ConfigurationManager on .NET Framework 4.x. If you'd like to use this method on .NET Standard or Core, reference the NuGet package in your project.
var client = new TaxjarApi("[Your TaxJar API Key]");
You're now ready to use TaxJar! Check out our quickstart guide to get up and running quickly.
Categories
- List all tax categories
TaxForOrder
- Calculate sales tax for an order
ListOrders
- List order transactions
ShowOrder
- Show order transaction
CreateOrder
- Create order transaction
UpdateOrder
- Update order transaction
DeleteOrder
- Delete order transaction
ListRefunds
- List refund transactions
ShowRefund
- Show refund transaction
CreateRefund
- Create refund transaction
UpdateRefund
- Update refund transaction
DeleteRefund
- Delete refund transaction
ListCustomers
- List customers
ShowCustomer
- Show customer
CreateCustomer
- Create customer
UpdateCustomer
- Update customer
DeleteCustomer
- Delete customer
RatesForLocation
- List tax rates for a location (by zip/postal code)
NexusRegions
- List nexus regions
ValidateAddress
- Validate an address
ValidateVat
- Validate a VAT number
SummaryRates
- Summarize tax rates for all regions
The TaxJar API provides product-level tax rules for a subset of product categories. These categories are to be used for products that are either exempt from sales tax in some jurisdictions or are taxed at reduced rates. You need not pass in a product tax code for sales tax calculations on product that is fully taxable. Simply leave that parameter out.
var categories = client.Categories();
// Async Method
var categories = await client.CategoriesAsync();
Shows the sales tax that should be collected for a given order.
var tax = client.TaxForOrder(new {
from_country = "US",
from_zip = "07001",
from_state = "NJ",
from_city = "Avenel",
from_street = "305 W Village Dr",
to_country = "US",
to_zip = "07446",
to_state = "NJ",
to_city = "Ramsey",
to_street = "63 W Main St",
amount = 16.50,
shipping = 1.50,
line_items = new[] {
new {
id = "1",
quantity = 1,
product_tax_code = "31000",
unit_price = 15,
discount = 0
}
}
});
// Async Method
var tax = await client.TaxForOrderAsync(new {
from_country = "US",
from_zip = "07001",
from_state = "NJ",
from_city = "Avenel",
from_street = "305 W Village Dr",
to_country = "US",
to_zip = "07446",
to_state = "NJ",
to_city = "Ramsey",
to_street = "63 W Main St",
amount = 16.50,
shipping = 1.50,
line_items = new[] {
new {
id = "1",
quantity = 1,
product_tax_code = "31000",
unit_price = 15,
discount = 0
}
}
});
// Request Entity
var taxEntity = new Tax {
from_country = "US",
from_zip = "07001",
from_state = "NJ",
from_city = "Avenel",
from_street = "305 W Village Dr",
to_country = "US",
to_zip = "07446",
to_state = "NJ",
to_city = "Ramsey",
to_street = "63 W Main St",
amount = 16.50,
shipping = 1.50,
line_items = new[] {
new {
id = "1",
quantity = 1,
product_tax_code = "31000",
unit_price = 15,
discount = 0
}
}
};
var tax = client.TaxForOrder(taxEntity);
Lists existing order transactions created through the API.
var orders = client.ListOrders(new {
from_transaction_date = "2015/05/01",
to_transaction_date = "2015/05/31"
});
// Async Method
var orders = await client.ListOrdersAsync(new {
from_transaction_date = "2015/05/01",
to_transaction_date = "2015/05/31"
});
// Request Entity
var orderFilter = new OrderFilter {
FromTransactionDate = "2015/05/01",
ToTransactionDate = "2015/05/31"
};
var orders = client.ListOrders(orderFilter);
Shows an existing order transaction created through the API.
var order = client.ShowOrder("123");
// Async Method
var order = await client.ShowOrderAsync("123");
Creates a new order transaction.
var order = client.CreateOrder(new {
transaction_id = "123",
transaction_date = "2015/05/04",
from_country = "US",
from_zip = "92093",
from_state = "CA",
from_city = "La Jolla",
from_street = "9500 Gilman Drive",
to_country = "US",
to_zip = "90002",
to_state = "CA",
to_city = "Los Angeles",
to_street = "123 Palm Grove Ln",
amount = 17,
shipping = 2,
sales_tax = 0.95,
line_items = new[] {
new {
id = "1",
quantity = 1,
product_identifier = "12-34243-0",
description = "Heavy Widget",
unit_price = 15,
discount = 0,
sales_tax = 0.95
}
}
});
// Async Method
var order = await client.CreateOrderAsync(new {
transaction_id = "123",
transaction_date = "2015/05/04",
from_country = "US",
from_zip = "92093",
from_state = "CA",
from_city = "La Jolla",
from_street = "9500 Gilman Drive",
to_country = "US",
to_zip = "90002",
to_state = "CA",
to_city = "Los Angeles",
to_street = "123 Palm Grove Ln",
amount = 17,
shipping = 2,
sales_tax = 0.95,
line_items = new[] {
new {
id = "1",
quantity = 1,
product_identifier = "12-34243-0",
description = "Heavy Widget",
unit_price = 15,
discount = 0,
sales_tax = 0.95
}
}
});
// Request Entity
var orderEntity = new Order {
transaction_id = "123",
transaction_date = "2015/05/04",
from_country = "US",
from_zip = "92093",
from_state = "CA",
from_city = "La Jolla",
from_street = "9500 Gilman Drive",
to_country = "US",
to_zip = "90002",
to_state = "CA",
to_city = "Los Angeles",
to_street = "123 Palm Grove Ln",
amount = 17,
shipping = 2,
sales_tax = 0.95,
line_items = new[] {
new {
id = "1",
quantity = 1,
product_identifier = "12-34243-0",
description = "Heavy Widget",
unit_price = 15,
discount = 0,
sales_tax = 0.95
}
}
};
var order = client.CreateOrder(orderEntity);
Updates an existing order transaction created through the API.
var order = client.UpdateOrder(new {
transaction_id = "123",
amount = 17,
shipping = 2,
line_items = new[] {
new {
quantity = 1,
product_identifier = "12-34243-0",
description = "Heavy Widget",
unit_price = 15,
discount = 0,
sales_tax = 0.95
}
}
});
// Async Method
var order = await client.UpdateOrderAsync(new {
transaction_id = "123",
amount = 17,
shipping = 2,
line_items = new[] {
new {
quantity = 1,
product_identifier = "12-34243-0",
description = "Heavy Widget",
unit_price = 15,
discount = 0,
sales_tax = 0.95
}
}
});
// Request Entity
var orderEntity = new Order {
TransactionId = "123",
Amount = 17,
Shipping = 2,
LineItems = new List<LineItem> {
new LineItem {
Quantity = 1,
ProductIdentifier = "12-34243-0",
Description = "Heavy Widget",
UnitPrice = 15,
Discount = 0,
SalesTax = 0.95
}
}
};
var order = client.UpdateOrder(orderEntity);
Deletes an existing order transaction created through the API.
var order = client.DeleteOrder("123");
// Async Method
var order = await client.DeleteOrderAsync("123");
Lists existing refund transactions created through the API.
var refunds = client.ListRefunds(new {
from_transaction_date = "2015/05/01",
to_transaction_date = "2015/05/31"
});
// Async Method
var refunds = await client.ListRefundsAsync(new {
from_transaction_date = "2015/05/01",
to_transaction_date = "2015/05/31"
});
// Request Entity
var refundFilter = new RefundFilter {
FromTransactionDate = "2015/05/01",
ToTransactionDate = "2015/05/31"
};
var refunds = client.ListRefunds(refundFilter);
Shows an existing refund transaction created through the API.
var refund = client.ShowRefund("123-refund");
// Async Method
var refund = await client.ShowRefundAsync("123-refund");
Creates a new refund transaction.
var refund = client.CreateRefund(new {
transaction_id = "123-refund",
transaction_reference_id = "123",
transaction_date = "2015/05/04",
from_country = "US",
from_zip = "92093",
from_state = "CA",
from_city = "La Jolla",
from_street = "9500 Gilman Drive",
to_country = "US",
to_zip = "90002",
to_state = "CA",
to_city = "Los Angeles",
to_street = "123 Palm Grove Ln",
amount = -17,
shipping = -2,
sales_tax = -0.95,
line_items = new[] {
new {
id = "1",
quantity = 1,
product_identifier = "12-34243-0",
description = "Heavy Widget",
unit_price = -15,
discount = -0,
sales_tax = -0.95
}
}
});
// Async Method
var refund = await client.CreateRefundAsync(new {
transaction_id = "123-refund",
transaction_reference_id = "123",
transaction_date = "2015/05/04",
from_country = "US",
from_zip = "92093",
from_state = "CA",
from_city = "La Jolla",
from_street = "9500 Gilman Drive",
to_country = "US",
to_zip = "90002",
to_state = "CA",
to_city = "Los Angeles",
to_street = "123 Palm Grove Ln",
amount = -17,
shipping = -2,
sales_tax = -0.95,
line_items = new[] {
new {
id = "1",
quantity = 1,
product_identifier = "12-34243-0",
description = "Heavy Widget",
unit_price = -15,
discount = -0,
sales_tax = -0.95
}
}
});
// Request Entity
var refundEntity = new Refund {
transaction_id = "123-refund",
transaction_reference_id = "123",
transaction_date = "2015/05/04",
from_country = "US",
from_zip = "92093",
from_state = "CA",
from_city = "La Jolla",
from_street = "9500 Gilman Drive",
to_country = "US",
to_zip = "90002",
to_state = "CA",
to_city = "Los Angeles",
to_street = "123 Palm Grove Ln",
amount = -17,
shipping = -2,
sales_tax = -0.95,
line_items = new[] {
new {
id = "1",
quantity = 1,
product_identifier = "12-34243-0",
description = "Heavy Widget",
unit_price = -15,
discount = -0,
sales_tax = -0.95
}
}
};
var refund = client.CreateRefund(refundEntity);
Updates an existing refund transaction created through the API.
var refund = client.UpdateRefund(new {
transaction_id = "123-refund",
transaction_reference_id = "123",
amount = -17,
shipping = -2,
line_items = new[] {
new {
id = "1",
quantity = 1,
product_identifier = "12-34243-0",
description = "Heavy Widget",
unit_price = -15,
discount = -0,
sales_tax = -0.95
}
}
});
// Async Method
var refund = await client.UpdateRefundAsync(new {
transaction_id = "123-refund",
transaction_reference_id = "123",
amount = -17,
shipping = -2,
line_items = new[] {
new {
id = "1",
quantity = 1,
product_identifier = "12-34243-0",
description = "Heavy Widget",
unit_price = -15,
discount = -0,
sales_tax = -0.95
}
}
});
// Request Entity
var refundEntity = new Refund {
transaction_id = "123-refund",
transaction_reference_id = "123",
amount = -17,
shipping = -2,
line_items = new[] {
new {
id = "1",
quantity = 1,
product_identifier = "12-34243-0",
description = "Heavy Widget",
unit_price = -15,
discount = -0,
sales_tax = -0.95
}
}
};
var refund = client.UpdateRefund(refundEntity);
Deletes an existing refund transaction created through the API.
var refund = client.DeleteRefund("123-refund");
// Async Method
var refund = await client.DeleteRefundAsync("123-refund");
Lists existing customers created through the API.
var customers = client.ListCustomers();
// Async Method
var customers = await client.ListCustomersAsync();
Shows an existing customer created through the API.
var customer = client.ShowCustomer("123");
// Async Method
var customer = await client.ShowCustomerAsync("123");
Creates a new customer.
var customer = client.CreateCustomer(new {
customer_id = "123",
exemption_type = "wholesale",
name = "Dunder Mifflin Paper Company",
exempt_regions = new[] {
new {
country = "US",
state = "FL"
},
new {
country = "US",
state = "PA"
}
},
country = "US",
state = "PA",
zip = "18504",
city = "Scranton",
street = "1725 Slough Avenue"
});
// Async Method
var customer = await client.CreateCustomerAsync(new {
customer_id = "123",
exemption_type = "wholesale",
name = "Dunder Mifflin Paper Company",
exempt_regions = new[] {
new {
country = "US",
state = "FL"
},
new {
country = "US",
state = "PA"
}
},
country = "US",
state = "PA",
zip = "18504",
city = "Scranton",
street = "1725 Slough Avenue"
});
// Request Entity
var customerEntity = new Customer {
CustomerId = "123",
ExemptionType = "wholesale",
Name = "Dunder Mifflin Paper Company",
ExemptRegions = new List<ExemptRegion> {
new ExemptRegion {
Country = "US",
State = "FL"
},
new ExemptRegion {
Country = "US",
State = "PA"
}
},
Country = "US",
State = "PA",
Zip = "18504",
City = "Scranton",
Street = "1725 Slough Avenue"
};
var customer = client.CreateCustomer(customerEntity);
Updates an existing customer created through the API.
var customer = client.UpdateCustomer(new {
customer_id = "123",
exemption_type = "wholesale",
name = "Sterling Cooper",
exempt_regions = new[] {
new {
country = "US",
state = "NY"
}
},
country = "US",
state = "NY",
zip = "10010",
city = "New York",
street = "405 Madison Ave"
});
// Async Method
var customer = await client.UpdateCustomerAsync(new {
customer_id = "123",
exemption_type = "wholesale",
name = "Sterling Cooper",
exempt_regions = new[] {
new {
country = "US",
state = "NY"
}
},
country = "US",
state = "NY",
zip = "10010",
city = "New York",
street = "405 Madison Ave"
});
// Request Entity
var customerEntity = new Customer {
CustomerId = "123",
ExemptionType = "wholesale",
Name = "Sterling Cooper",
ExemptRegions = new List<ExemptRegion> {
new ExemptRegion {
Country = "US",
State = "NY"
}
},
Country = "US",
State = "NY",
Zip = "10010",
City = "New York",
Street = "405 Madison Ave"
};
var customer = client.UpdateCustomer(customerEntity);
Deletes an existing customer created through the API.
var customer = client.DeleteCustomer("123");
// Async Method
var customer = await client.DeleteCustomerAsync("123");
Shows the sales tax rates for a given location.
Please note this method only returns the full combined rate for a given location. It does not support nexus determination, sourcing based on a ship from and ship to address, shipping taxability, product exemptions, customer exemptions, or sales tax holidays. We recommend using
TaxForOrder
to accurately calculate sales tax for an order.
var rates = client.RatesForLocation("90002", new {
city = "LOS ANGELES",
country = "US"
});
// Async Method
var rates = await client.RatesForLocationAsync("90002", new {
city = "LOS ANGELES",
country = "US"
});
// Request Entity
var rateEntity = new Rate {
City = "LOS ANGELES",
Country = "US"
};
var rates = client.RatesForLocation("90002", rateEntity);
Lists existing nexus locations for a TaxJar account.
var nexusRegions = client.NexusRegions();
// Async Method
var nexusRegions = await client.NexusRegionsAsync();
Validates a customer address and returns back a collection of address matches. Address validation requires a TaxJar Plus subscription.
var addresses = client.ValidateAddress(new {
country = "US",
state = "AZ",
zip = "85297",
city = "Gilbert",
street = "3301 South Greenfield Rd"
});
// Async Method
var addresses = client.ValidateAddressAsync(new {
country = "US",
state = "AZ",
zip = "85297",
city = "Gilbert",
street = "3301 South Greenfield Rd"
});
Validates an existing VAT identification number against VIES.
var validation = client.ValidateVat(new {
vat = "FR40303265045"
});
// Async Method
var validation = await client.ValidateVatAsync(new {
vat = "FR40303265045"
});
// Request Entity
var vatEntity = new Validation {
Vat = "FR40303265045"
};
var validation = client.ValidateVat(vatEntity);
Retrieve minimum and average sales tax rates by region as a backup.
This method is useful for periodically pulling down rates to use if the TaxJar API is unavailable. However, it does not support nexus determination, sourcing based on a ship from and ship to address, shipping taxability, product exemptions, customer exemptions, or sales tax holidays. We recommend using
TaxForOrder
to accurately calculate sales tax for an order.
var summaryRates = client.SummaryRates();
// Async Method
var summaryRates = await client.SummaryRatesAsync();
You can pass additional options using SetApiConfig
or when instantiating the client for the following:
// Custom timeout when instantiating the client
var client = new TaxjarApi("[Your TaxJar API Key]", new { apiUrl = "https://api.taxjar.com", timeout = 30 * 1000 });
// Custom timeout via `SetApiConfig`
client.SetApiConfig("timeout", 30 * 1000);
// Custom API version when instantiating the client
var client = new TaxjarApi("[Your TaxJar API Key]", new { apiUrl = "https://api.taxjar.com", headers = new Dictionary<string, string> {
{ "x-api-version", "2020-08-07" }
}});
// Custom API version via `SetApiConfig`
client.SetApiConfig("headers", new Dictionary<string, string> {
{ "x-api-version", "2020-08-07" }
});
You can easily configure the client to use the TaxJar Sandbox:
var client = new TaxjarApi("[Your TaxJar Sandbox API Key]", new { apiUrl = "https://api.sandbox.taxjar.com" });
For testing specific error response codes, pass the custom X-TJ-Expected-Response
header:
client.SetApiConfig("headers", new Dictionary<string, string> {
{ "X-TJ-Expected-Response", "422" }
});
When invalid data is sent to TaxJar or we encounter an error, we’ll throw a TaxjarException
with the HTTP status code and error message. To catch these exceptions, refer to the example below. Click here for a list of common error response classes.
using Taxjar;
var client = new TaxjarApi();
try
{
// Invalid request
var order = client.CreateOrder(new {
transaction_date = "2015/05/04",
from_country = "US",
from_zip = "07001",
from_state = "NJ",
from_city = "Avenel",
from_street = "305 W Village Dr",
to_country = "US",
to_zip = "90002",
to_state = "CA",
to_city = "Ramsey",
to_street = "63 W Main St",
amount = 17.45,
shipping = 1.5,
sales_tax = 0.95
line_items = new[] {
new {
id = "1",
quantity = 1,
product_tax_code = "31000",
unit_price = 15,
discount = 0,
sales_tax = 0.95
}
}
});
}
catch(TaxjarException e)
{
// 406 Not Acceptable – transaction_id is missing
e.TaxjarError.Error;
e.TaxjarError.Detail;
e.TaxjarError.StatusCode;
}
We use NUnit and WireMock.Net for testing. Before running the specs, create a secrets.json
file inside the Taxjar.Tests
directory with your sandbox API Token:
{
"ApiToken": "YOUR_SANDBOX_KEY"
}
More information can be found at TaxJar Developers.
TaxJar.net is released under the MIT License.
Bug reports and feature requests should be filed on the GitHub issue tracking page.
git checkout -b my-new-feature
)git commit -am 'Add some feature'
)git push origin my-new-feature
)