Welcome to the Stark Infra .NET SDK! This tool is made for .NET developers who want to easily integrate with our API. This SDK version is compatible with the Stark Infra API v2.
- Introduction
- Setup
- Resource listing and manual pagination
- Testing in Sandbox
- Usage
- Issuing
- Products: View available sub-issuer card products (a.k.a. card number ranges or BINs)
- Holders: Manage card holders
- Cards: Create virtual and/or physical cards
- Design: View your current card or package designs
- EmbossingKit: View your current embossing kits
- Stock: View your current stock of a certain IssuingDesign linked to an Embosser on the workspace
- Restock: Create restock orders of a specific IssuingStock object
- EmbossingRequest: Create embossing requests
- Purchases: Authorize and view your past purchases
- Invoices: Add money to your issuing balance
- Withdrawals: Send money back to your Workspace from your issuing balance
- Balance: View your issuing balance
- Transactions: View the transactions that have affected your issuing balance
- Enums: Query enums related to the issuing purchases, such as merchant categories, countries and card purchase methods
- Pix
- PixRequests: Create Pix transactions
- PixReversals: Reverse Pix transactions
- PixBalance: View your account balance
- PixStatement: Request your account statement
- PixKey: Create a PixKey
- PixClaim: Claim a PixKey
- PixDirector: Create a Pix Director
- PixInfraction: Create Pix Infraction reports
- PixChargeback: Create Pix Chargeback requests
- PixDomain: View registered SPI participants certificates
- StaticBrcode: Create static Pix BR codes
- DynamicBrcode: Create dynamic Pix BR codes
- BrcodePreview: Read data from BR Codes before paying them
- Lending
- CreditNote: Create credit notes
- CreditPreview: Create credit previews
- CreditHolmes: Create credit holmes debt verification
- Identity
- IndividualIdentity: Create individual identities
- IndividualDocument: Create individual documents
- Webhook:
- Webhook: Configure your webhook endpoints and subscriptions
- WebhookEvents: Manage webhook events
- WebhookEventAttempts: Query failed webhook event deliveries
- Issuing
- Handling errors
- Help and Feedback
This library supports the following .NET versions:
- .NET Standard 2.0+
Feel free to take a look at our API docs.
This project adheres to the following versioning pattern:
Given a version number MAJOR.MINOR.PATCH, increment:
- MAJOR version when the API version is incremented. This may include backwards incompatible changes;
- MINOR version when breaking changes are introduced OR new functionalities are added in a backwards compatible manner;
- PATCH version when backwards compatible bug fixes are implemented.
StarkInfra`s .NET SDK is available on NuGet as starkinfra 0.5.2
1.1 To install the Package Manager:
Install-Package starkinfra -Version 0.5.2
1.2 To install the .NET CLI:
dotnet add package starkinfra --version 0.5.2
1.3 To install by PackageReference:
<PackageReference Include="starkinfra" Version="0.5.2" />
1.4 To install with Packet CLI:
packet add starkinfra --version 0.5.2
We use ECDSA. That means you need to generate a secp256k1 private key to sign your requests to our API, and register your public key with us, so we can validate those requests.
You can use one of the following methods:
2.1. Check out the options in our tutorial.
2.2. Use our SDK:
using System;
using StarkInfra;
(string privateKey, string publicKey) = StarkInfra.Key.Create();
// or, to also save .pem files in a specific path
(string privateKey, string publicKey) = StarkInfra.Key.Create("file/keys");
NOTE: When you are creating new credentials, it is recommended that you create the keys inside the infrastructure that will use it, in order to avoid risky internet transmissions of your private-key. Then you can export the public-key alone to the computer where it will be used in the new Project creation.
You can interact directly with our API using two types of users: Projects and Organizations.
- Projects are workspace-specific users, that is, they are bound to the workspaces they are created in. One workspace can have multiple Projects.
- Organizations are general users that control your entire organization. They can control all your Workspaces and even create new ones. The Organization is bound to your company's tax ID only. Since this user is unique in your entire organization, only one credential can be linked to it.
3.1. To create a Project in Sandbox:
3.1.1. Log into StarkInfra Sandbox
3.1.2. Go to Menu > Integrations
3.1.3. Click on the "New Project" button
3.1.4. Create a Project: Give it a name and upload the public key you created in section 2
3.1.5. After creating the Project, get its Project ID
3.1.6. Use the Project ID and private key to create the object below:
// Get your private key from an environment variable or an encrypted database.
// This is only an example of a private key content. You should use your own key.
using System;
using StarkInfra;
string privateKeyContent = "-----BEGIN EC PARAMETERS-----\nBgUrgQQACg==\n-----END EC PARAMETERS-----\n-----BEGIN EC PRIVATE KEY-----\nMHQCAQEEIMCwW74H6egQkTiz87WDvLNm7fK/cA+ctA2vg/bbHx3woAcGBSuBBAAK\noUQDQgAE0iaeEHEgr3oTbCfh8U2L+r7zoaeOX964xaAnND5jATGpD/tHec6Oe9U1\nIF16ZoTVt1FzZ8WkYQ3XomRD4HS13A==\n-----END EC PRIVATE KEY-----";
StarkInfra.Project project = new StarkInfra.Project(
environment: "sandbox",
id: "5656565656565656",
privateKey: privateKeyContent
);
3.2. To create Organization credentials in Sandbox:
3.2.1. Log into StarkInfra Sandbox
3.2.2. Go to Menu > Integrations
3.2.3. Click on the "Organization public key" button
3.2.4. Upload the public key you created in section 2 (only a legal representative of the organization can upload the public key)
3.2.5. Click on your profile picture and then on the "Organization" menu to get the Organization ID
3.2.6. Use the Organization ID and private key to create the object below:
// Get your private key from an environment variable or an encrypted database.
// This is only an example of a private key content. You should use your own key.
using System;
using StarkInfra;
string privateKeyContent = "-----BEGIN EC PARAMETERS-----\nBgUrgQQACg==\n-----END EC PARAMETERS-----\n-----BEGIN EC PRIVATE KEY-----\nMHQCAQEEIMCwW74H6egQkTiz87WDvLNm7fK/cA+ctA2vg/bbHx3woAcGBSuBBAAK\noUQDQgAE0iaeEHEgr3oTbCfh8U2L+r7zoaeOX964xaAnND5jATGpD/tHec6Oe9U1\nIF16ZoTVt1FzZ8WkYQ3XomRD4HS13A==\n-----END EC PRIVATE KEY-----";
StarkInfra.Organization organization = new StarkInfra.Organization(
environment: "sandbox",
id: "5656565656565656",
privateKey: privateKeyContent,
workspaceID: null // You only need to set the workspaceID when you are operating a specific workspaceID
);
// To dynamically use your organization credentials in a specific workspaceID,
// you can use the Organization.Replace() method:
StarkInfra.PixBalance.Get(user: Organization.Replace(organization, "4848484848484848"));
NOTE 1: Never hard-code your private key. Get it from an environment variable or an encrypted database.
NOTE 2: We support 'sandbox'
and 'production'
as environments.
NOTE 3: The credentials you registered in sandbox
do not exist in production
and vice versa.
There are three kinds of users that can access our API: Organization, Project, and Member.
Project
andOrganization
are designed for integrations and are the ones meant for our SDKs.Member
is the one you use when you log into our webpage with your e-mail.
There are two ways to inform the user to the SDK:
4.1 Passing the user as an argument in all functions:
using System;
using StarkInfra;
StarkInfra.PixBalance balance = StarkInfra.PixBalance.Get(user: project); //or organization
4.2 Set it as a default user in the SDK:
using System;
using StarkInfra;
StarkInfra.Settings.User = project; //or organization
StarkInfra.PixBalance balance = StarkInfra.PixBalance.Get();
Just select the way of passing the user that is more convenient to you. On all following examples, we will assume a default user has been set.
The error language can also be set in the same way as the default user:
StarkInfra.Settings.Language = "en-US";
Language options are "en-US" for English and "pt-BR" for Brazilian Portuguese. English is the default.
Almost all SDK resources provide a query
and a page
function.
- The
query
function provides a straightforward way to efficiently iterate through all results that match the filters you inform, seamlessly retrieving the next batch of elements from the API only when you reach the end of the current batch. If you are not worried about data volume or processing time, this is the way to go.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.PixRequest> requests = StarkInfra.PixRequest.Query(
after: DateTime.Today.Date.AddDays(-10),
before: DateTime.Today.Date.AddDays(-1)
);
foreach(StarkInfra.PixRequest request in requests) {
Console.WriteLine(request);
}
- The
page
function gives you full control over the API pagination. With each function call, you receive up to 100 results and the cursor to retrieve the next batch of elements. This allows you to stop your queries and pick up from where you left off whenever it is convenient. When there are no more elements to be retrieved, the returned cursor will benull
.
using System;
using System.Collections.Generic;
using StarkInfra;
List<StarkInfra.PixRequest> page;
string cursor = null;
while (true)
{
(page, cursor) = StarkInfra.PixRequest.Page(cursor: cursor);
foreach (StarkInfra.PixRequest entity in page)
{
Console.WriteLine(entity);
}
if (cursor == null)
{
break;
}
}
To simplify the following SDK examples, we will only use the query
function, but feel free to use page
instead.
Your initial balance is zero. For many operations in Stark Infra, you'll need funds in your account, which can be added to your balance by creating a StarkBank.Invoice.
In the Sandbox environment, most of the created StarkBank.Invoices will be automatically paid, so there's nothing else you need to do to add funds to your account. Just create a few StarkBank.Invoice and wait around a bit.
In Production, you (or one of your clients) will need to actually pay this Pix Request for the value to be credited to your account.
Here are a few examples on how to use the SDK. If you have any doubts, check out the function or class docstring to get more info or go straight to our [API docs].
To take a look at the sub-issuer card products available to you, just run the following:
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.IssuingProduct> products = StarkInfra.IssuingProduct.Query()
foreach (StarkInfra.IssuingProduct product in products) {
Console.Write(product);
}
This will tell which card products and card number prefixes you have at your disposal.
You can create card holders to which your cards will be bound. They support spending rules that will apply to all underlying cards.
using System;
using System.Collections.Generic;
using StarkInfra;
List<StarkInfra.IssuingHolder> holders = StarkInfra.IssuingHolder.Create(
new List<StarkInfra.IssuingHolder> {
new StarkInfra.IssuingHolder(
name: "Jamie Lanister",
externalID : "external_id_12345",
taxID : "012.345.678-90",
tags : new List<string> { "Traveler Employee" },
rules: new List<StarkInfra.IssuingRule> {
new StarkInfra.IssuingRule(
name: "general",
interval: "week",
amount: 100000,
currencyCode: "USD"
)
}
)
}
);
foreach (StarkInfra.IssuingHolder holder in holders) {
Console.Write(holder);
}
Note: Instead of using IssuingHolder objects, you can also pass each element in dictionary format
You can query multiple holders according to filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.IssuingHolder> holders = StarkInfra.IssuingHolder.Query(
after: new DateTime(2019, 1, 1),
before: new DateTime(2022, 3, 1)
);
foreach(StarkInfra.IssuingHolder holder in holders)
{
Console.Write(holder);
}
To cancel a single Issuing Holder by its id, run:
using System;
using StarkInfra;
StarkInfra.IssuingHolder holder = StarkInfra.IssuingHolder.Cancel("5353197895942144");
Console.Write(holder);
After its creation, information on a holder may be retrieved by its id.
using System;
using StarkInfra;
StarkInfra.IssuingHolder holder = StarkInfra.IssuingHolder.Get("5353197895942144");
Console.Write(holder);
You can query holder logs to better understand holder life cycles.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.IssuingHolder.Log> logs = StarkInfra.IssuingHolder.Log.Query(limit: 10);
foreach (StarkInfra.IssuingHolder.Log log in logs)
{
Console.Write(log);
}
You can also get a specific log by its id.
using System;
using StarkInfra;
StarkInfra.IssuingHolder.Log log = StarkInfra.IssuingHolder.Log.Get("6299741604282368");
Console.Write(log);
You can issue cards with specific spending rules.
using System;
using System.Collections.Generic;
using StarkInfra;
List<StarkInfra.IssuingCard> cards = StarkInfra.IssuingCard.Create(
new List<StarkInfra.IssuingCard> {
new StarkInfra.IssuingCard(
holderName : "Developers",
holderTaxID : "012.345.678-90",
holderExternalID : "672",
rules: new List<StarkInfra.IssuingRule> {
new StarkInfra.IssuingRule(
name: "general",
interval: "week",
amount: 100000,
currencyCode: "USD"
)
}
)
}
);
foreach(StarkInfra.IssuingCard card in cards)
{
Console.Write(card);
}
You can get a list of created cards given some filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.IssuingCard> cards = StarkInfra.IssuingCard.Query(
after: new DateTime(2019, 1, 1),
before: new DateTime(2022, 3, 1)
);
foreach(StarkInfra.IssuingCard card in cards)
{
Console.Write(card);
}
After its creation, information on a card may be retrieved by its id.
using System;
using StarkInfra;
StarkInfra.IssuingCard card = StarkInfra.IssuingCard.Get("5353197895942144");
Console.Write(card);
You can update a specific card by its id.
using System;
using System.Collections.Generic;
using StarkInfra;
Dictionary<string, object> patchData = new Dictionary<string, object> {
{ "status", "blocked" }
};
StarkInfra.IssuingCard card = StarkInfra.IssuingCard.Update("5353197895942144", patchData);
Console.Write(card);
You can also cancel a card by its id.
using System;
using StarkInfra;
StarkInfra.IssuingCard card = StarkInfra.IssuingCard.Cancel("5353197895942144");
Console.Write(card);
You can query card logs to better understand card life cycles.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.IssuingCard.Log> logs = StarkInfra.IssuingCard.Log.Query(limit: 10);
foreach (StarkInfra.IssuingCard.Log log in logs)
{
Console.Write(log);
}
You can also get a specific log by its id.
using System;
using StarkInfra;
StarkInfra.IssuingCard.Log log = StarkInfra.IssuingCard.Log.Get("6299741604282368");
Console.Write(log);
You can get a list of available designs given some filters.
using System;
using System.Collections.Generic;
IEnumerable<StarkInfra.IssuingDesign> designs = StarkInfra.IssuingDesign.Query(limit: 10);
foreach (StarkInfra.IssuingDesign design in designs) {
Console.Write(design);
}
Information on a design may be retrieved by its id.
using System;
StarkInfra.IssuingDesign design = StarkInfra.IssuingDesign.Get("5353197895942144");
Console.Write(design);
You can get a list of existing embossing kits given some filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.IssuingEmbossingKit> kits = StarkInfra.IssuingEmbossingKit.Query(
after: new DateTime(2022, 01, 01),
before: new DateTime(2022, 12, 01)
);
foreach (StarkInfra.IssuingEmbossingKit kit in kits)
{
Console.Write(kit);
}
After its creation, information on an embossing kit may be retrieved by its id.
using System;
using StarkInfra;
StarkInfra.IssuingEmbossingKit kit = StarkInfra.IssuingEmbossingKit.Get("5155165527080960");
Console.Write(kit);
You can get a list of available stocks given some filters.
using System;
using System.Collections.Generic;
IEnumerable<StarkInfra.IssuingStock> stocks = StarkInfra.IssuingStock.Query(
after: new DateTime(2020, 1, 1),
before: new DateTime(2022, 3, 1)
);
foreach (StarkInfra.IssuingStock stock in stocks) {
Console.Write(stock);
}
Information on a stock may be retrieved by its id.
using System;
StarkInfra.IssuingStock stock = StarkInfra.IssuingStock.Get("5353197895942144");
Console.Write(stock);
Logs are pretty important to understand the life cycle of a stock.
using System;
using System.Collections.Generic;
IEnumerable<StarkInfra.IssuingStock.Log> logs = StarkInfra.IssuingStock.Log.Query(limit: 10);
foreach (StarkInfra.IssuingStock.Log log in logs){
Console.Write(log);
}
You can get a single log by its id.
using System;
using System.Collections.Generic;
StarkInfra.IssuingStock.Log log = StarkInfra.IssuingStock.Log.Get("5353197895942144");
Console.Write(log);
You can order restocks for a specific IssuingStock.
using System;
using System.Collections.Generic;
List<StarkInfra.IssuingRestock> restocks = StarkInfra.IssuingRestock.Create(
new List<IssuingRestock>{
new IssuingRestock(
count: 100,
id: "5136459887542272"
)
};
);
foreach (StarkInfra.IssuingRestock restock in restocks){
Console.Write(restock);
}
You can get a list of created restocks given some filters.
using System;
using System.Collections.Generic;
IEnumerable<StarkInfra.IssuingRestock> restocks = StarkInfra.IssuingRestock.Query(
after: new DateTime(2020, 1, 1),
before: new DateTime(2022, 3, 1)
);
foreach (StarkInfra.IssuingRestock restock in restocks){
Console.Write(restock);
}
After its creation, information on a restock may be retrieved by its id.
using System;
StarkInfra.IssuingRestock restock = StarkInfra.IssuingRestock.Get("5353197895942144");
Console.Write(restock);
Logs are pretty important to understand the life cycle of a restock.
using System;
using System.Collections.Generic;
IEnumerable<StarkInfra.IssuingRestock.Log> logs = StarkInfra.IssuingRestock.Log.Query(limit: 50);
foreach (StarkInfra.IssuingRestock.Log log in logs){
Console.Write(log);
}
You can get a single log by its id.
using System;
StarkInfra.IssuingRestock.Log log = StarkInfra.IssuingRestock.Log.Get("5353197895942144");
Console.Write(log);
You can create a request to emboss a physical card.
using System;
using System.Collections.Generic;
List<StarkInfra.IssuingEmbossingRequest> requests = StarkInfra.IssuingEmbossingRequest.Create(
new List<IssuingEmbossingRequest>() {
new IssuingEmbossingRequest(
cardID: "5714424132272128",
cardDesignID: "5648359658356736",
displayName1: "Antonio Stark",
envelopeDesignID: "5747368922185728",
shippingCity: "Sao Paulo",
shippingCountryCode: "BRA",
shippingDistrict: "Bela Vista",
shippingService: "loggi",
shippingStateCode: "SP",
shippingStreetLine1: "Av. Paulista, 200",
shippingStreetLine2: "10 andar",
shippingTrackingNumber: "My_custom_tracking_number",
shippingZipCode: "12345-678",
embosserID: "5746980898734080"
);
}
);
foreach (StarkInfra.IssuingEmbossingRequest request in requests){
Console.Write(request);
}
You can get a list of created embossing requests given some filters.
using System;
using System.Collections.Generic;
IEnumerable<StarkInfra.IssuingEmbossingRequest> requests = StarkInfra.IssuingEmbossingRequest.Query(
after: new DateTime(2020, 1, 1),
before: new DateTime(2022, 3, 1)
);
foreach (StarkInfra.IssuingEmbossingRequest request in requests){
Console.Write(request);
}
After its creation, information on an embossing request may be retrieved by its id.
using System;
StarkInfra.IssuingEmbossingRequest request = StarkInfra.IssuingEmbossingRequest.Get("5353197895942144");
Console.Write(request);
Logs are pretty important to understand the life cycle of an embossing request.
using System;
using System.Collections.Generic;
IEnumerable<StarkInfra.IssuingEmbossingRequest.Log> logs = StarkInfra.IssuingEmbossingRequest.Log.Query(
after: new DateTime(2020, 1, 1),
before: new DateTime(2022, 3, 1)
);
foreach (StarkInfra.IssuingEmbossingRequest.Log log in logs){
Console.Write(log);
}
You can get a single log by its id.
using System;
StarkInfra.IssuingEmbossingRequest.Log log = StarkInfra.IssuingEmbossingRequest.Log.Get("5353197895942144");
Console.Write(log);
It's easy to process purchase authorizations delivered to your endpoint. Remember to pass the signature header so the SDK can make sure it's StarkInfra that sent you the event. If you do not approve or decline the authorization within 2 seconds, the authorization will be denied.
using System;
using System.Collections.Generic;
using StarkInfra;
Response response = listen(); // this is the method you made to get the events posted to your webhook endpoint
StarkInfra.IssuingPurchase authorization = StarkInfra.IssuingPurchase.Parse(
content: response.Content,
signature: response.Headers["Digital-Signature"]
);
sendResponse( // you should also implement this method
StarkInfra.IssuingPurchase.Response( // this optional method just helps you build the response JSON
status: "accepted",
amount: authorization.amount,
tags= new List<string> { "my-purchase-id/123"}
)
)
// or
sendResponse(
StarkInfra.IssuingPurchase.Response(
status: "denied",
reason: "other",
tags: new List<string> { "other-id/456" },
)
)
You can get a list of created purchases given some filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.IssuingPurchase> purchases = StarkInfra.IssuingPurchase.Query(
after: new DateTime(2019, 1, 1),
before: new DateTime(2022, 3, 1)
);
foreach (StarkInfra.IssuingPurchase purchase in purchases)
{
Console.Write(purchase);
}
After its creation, information on a purchase may be retrieved by its id.
using System;
StarkInfra.IssuingPurchase purchase = StarkInfra.IssuingPurchase.Get("5642359077339136");
Console.Write(purchase);
You can query purchase logs to better understand purchase life cycles.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.IssuingPurchase.Log> logs = StarkInfra.IssuingPurchase.Log.Query(limit: 10);
foreach (StarkInfra.IssuingPurchase.Log log in logs)
{
Console.Write(log);
}
You can get a specific log by its id.
using System;
using StarkInfra;
StarkInfra.IssuingPurchase.Log log = StarkInfra.IssuingPurchase.Log.Get("6428086769811456");
Console.Write(log);
You can create Pix invoices to transfer money from accounts you have in any bank to your Issuing balance, allowing you to run your issuing operation.
using System;
StarkInfra.IssuingInvoice invoice = StarkInfra.IssuingInvoice.Create(
new StarkInfra.IssuingInvoice(
amount: 10000
)
);
Console.Write(invoice);
Note: Instead of using IssuingInvoice objects, you can also pass each element in dictionary format
You can get a list of created invoices given some filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.IssuingInvoice> invoices = StarkInfra.IssuingInvoice.Query(
after: new DateTime(2019, 1, 1),
before: new DateTime(2022, 3, 1)
);
foreach (StarkInfra.IssuingInvoice invoice in invoices)
{
Console.Write(invoice);
}
After its creation, information on an invoice may be retrieved by its id.
using System;
using StarkInfra;
StarkInfra.IssuingInvoice invoice = StarkInfra.IssuingInvoice.Get("5709933853016064");
Console.Write(invoice);
You can query invoice logs to better understand invoice life cycles.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.IssuingInvoice.Log> logs = StarkInfra.IssuingInvoice.Log.Query(limit: 10);
foreach (StarkInfra.IssuingInvoice.Log log in logs)
{
Console.Write(log);
}
Logs are pretty important to understand the life cycle of an invoice.
using System;
using System.Collections.Generic;
using StarkInfra;
StarkInfra.IssuingInvoice.Log log = StarkInfra.IssuingInvoice.Log.Get("4649340324806656");
Console.Write(log);
You can create withdrawals to send cash back from your Issuing balance to your Banking balance by using the Withdrawal resource.
using System;
using StarkInfra;
StarkInfra.IssuingWithdrawal withdrawal = StarkInfra.IssuingWithdrawal.Create(
new StarkInfra.IssuingWithdrawal(
amount: 10000,
externalID: "3257",
description: "Sending back"
)
);
Console.Write(withdrawal);
Note: Instead of using IssuingWithdrawal objects, you can also pass each element in dictionary format
After its creation, information on a withdrawal may be retrieved by its id.
using System;
using StarkInfra;
StarkInfra.IssuingWithdrawal withdrawal = StarkInfra.IssuingWithdrawal.Get("5440727945314304");
Console.Write(withdrawal);
You can get a list of created withdrawals given some filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.IssuingWithdrawal> withdrawals = StarkInfra.IssuingWithdrawal.Query(
after: new DateTime(2019, 1, 1),
before: new DateTime(2022, 3, 1)
);
foreach (StarkInfra.IssuingWithdrawal withdrawal in withdrawals)
{
Console.Write(withdrawal);
}
To know how much money you have available to run authorizations, run:
using System;
using StarkInfra;
StarkInfra.IssuingBalance balance = StarkInfra.IssuingBalance.Get();
Console.Write(balance);
To understand your balance changes (issuing statement), you can query transactions. Note that our system creates transactions for you when you make purchases, withdrawals, receive issuing invoice payments, for example.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.IssuingTransaction> transactions = StarkInfra.IssuingTransaction.Query(
after: new DateTime(2019, 1, 1),
before: new DateTime(2022, 3, 1)
);
foreach (StarkInfra.IssuingTransaction transaction in transactions)
{
Console.Write(transaction);
}
After its creation, information on a transaction may be retrieved by its id.
using System;
using StarkInfra;
StarkInfra.IssuingTransaction transaction = StarkInfra.IssuingTransaction.Get("6539944898068480");
Console.Write(transaction);
You can query any merchant categories using this resource. You may also use MerchantCategories to define specific category filters in IssuingRules. Either codes (which represents specific MCCs) or types (code groups) will be accepted as filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.MerchantCategory> categories = StarkInfra.MerchantCategory.Query(
search: "food"
);
foreach (StarkInfra.MerchantCategory category in categories)
{
Console.Write(category);
}
You can query any merchant countries using this resource. You may also use MerchantCountries to define specific country filters in IssuingRules.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.MerchantCountry> countries = StarkInfra.MerchantCountry.Query(
search: "brazil"
);
foreach (StarkInfra.MerchantCountry country in countries)
{
Console.Write(country);
}
You can query available card methods using this resource. You may also use CardMethods to define specific purchase method filters in IssuingRules.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.CardMethod> methods = StarkInfra.CardMethod.Query(
search: "token"
);
foreach (StarkInfra.CardMethod method in methods)
{
Console.Write(method);
}
You can create a Pix request to transfer money from one of your users to anyone else:
using System;
using System.Collections.Generic;
using StarkInfra;
List<StarkInfra.PixRequest> requests = StarkInfra.PixRequest.Create(
new List<StarkInfra.PixRequest> {
new StarkInfra.PixRequest(
amount: 100, // (R$ 1.00)
externalID: "141234121", // so we can block anything you send twice by mistake
senderBranchCode: "0000",
senderAccountNumber: "00000-0",
senderAccountType: "checking",
senderName: "Tyrion Lannister",
senderTaxID: "012.345.678-90",
receiverBankCode: "00000001",
receiverBranchCode: "0001",
receiverAccountNumber: "00000-1",
receiverAccountType: "checking",
receiverName: "Jamie Lannister",
receiverTaxID: "45.987.245/0001-92",
endToEndID: EndToEndID.Create(bankCode: Environment.GetEnvironmentVariable("BANK_CODE")),
description: "For saving my life"
),
new StarkInfra.PixRequest(
amount: 200, // (R$ 2.00)
externalID: "2135613462", // so we can block anything you send twice by mistake
senderAccountNumber: "00000-0",
senderBranchCode: "0000",
senderAccountType: "checking",
senderName: "Arya Stark",
senderTaxID: "012.345.678-90",
receiverBankCode: "00000001",
receiverAccountNumber: "00000-1",
receiverBranchCode: "0001",
receiverAccountType: "checking",
receiverName: "John Snow",
receiverTaxID: "012.345.678-90",
endToEndID: EndToEndID.Create(bankCode: Environment.GetEnvironmentVariable("BANK_CODE")),
tags: new List<string> { "Needle", "sword" }
)
}
);
foreach(StarkInfra.PixRequest request in requests) {
Console.WriteLine(request);
}
Note: Instead of using PixRequest objects, you can also pass each element in dictionary format
You can query multiple Pix requests according to filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.PixRequest> requests = StarkInfra.PixRequest.Query(
after: DateTime.Today.Date.AddDays(-10),
before: DateTime.Today.Date.AddDays(-1)
);
foreach(StarkInfra.PixRequest request in requests) {
Console.WriteLine(request);
}
After its creation, information on a request may be retrieved by its id.
using System;
using StarkInfra;
StarkInfra.PixRequest request = StarkInfra.PixRequest.Get("5155165527080960");
Console.WriteLine(request);
It's easy to process authorization requests that arrived at your endpoint. Remember to pass the signature header so the SDK can make sure it's StarkInfra that sent you the event. If you do not approve or decline the authorization within 1 second, the authorization will be denied.
using System;
using StarkInfra;
Response response = listen(); // this is your handler to listen for authorization requests
StarkInfra.PixRequest request= StarkInfra.PixRequest.Parse(
content: response.Content,
signature: response.Headers["Digital-Signature"]
)
Console.WriteLine(request);
sendResponse( // you should also implement this method
StarkInfra.PixRequest.Response( // this optional method just helps you build the response JSON
status: "approved"
)
)
// or
sendResponse( // you should also implement this method
StarkInfra.PixRequest.Response( // this optional method just helps you build the response JSON
status: "denied",
reason: "orderRejected"
)
)
You can query Pix request logs to better understand PixRequest life cycles.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.PixRequest.Log> logs = StarkInfra.PixRequest.Log.Query(
after: new DateTime(2019, 4, 1),
before: new DateTime(2021, 4, 30)
);
foreach(StarkInfra.PixRequest.Log log in logs) {
Console.WriteLine(log);
}
You can also get a specific log by its id.
using System;
StarkInfra.PixRequest.Log log = StarkInfra.PixRequest.Log.Get("4701727546671104");
Console.WriteLine(log);
You can reverse a PixRequest either partially or totally using a PixReversal.
using System;
using System.Collections.Generic;
using StarkInfra;
List<StarkInfra.PixReversal> reversal = StarkInfra.PixReversal.Create(
new List<StarkInfra.PixReversal> {
new StarkInfra.PixReversal(
amount: 100,
endToEndID: "E20018183202201060100rzsJzG9PzMg",
externalID: "17238435823958934",
reason: "bankError"
)
}
);
foreach(StarkInfra.PixReversal reversal in reversals) {
Console.WriteLine(reversal);
}
You can query multiple Pix reversals according to filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.PixReversal> reversals = StarkInfra.PixReversal.Query(
after: DateTime.Today.Date.AddDays(-10),
before: DateTime.Today.Date.AddDays(-1)
);
foreach(StarkInfra.PixReversal reversal in reversals) {
Console.WriteLine(reversal);
}
After its creation, information on a Pix reversal may be retrieved by its id. Its status indicates whether it has been successfully processed.
using System;
using StarkInfra;
StarkInfra.PixReversal reversal = StarkInfra.PixReversal.Get("5155165527080960");
Console.WriteLine(reversal);
It's easy to process authorization requests that arrived at your endpoint. Remember to pass the signature header so the SDK can make sure it's StarkInfra that sent you the event. If you do not approve or decline the authorization within 1 second, the authorization will be denied.
using System;
using StarkInfra;
Response response = listen(); // this is your handler to listen for authorization reversals
StarkInfra.PixReversal reversal= StarkInfra.PixReversal.Parse(
content: response.Content,
signature: response.Headers["Digital-Signature"]
)
Console.WriteLine(reversal);
sendResponse( // you should also implement this method
StarkInfra.PixReversal.Response( // this optional method just helps you build the response JSON
status: "approved"
)
)
// or
sendResponse( // you should also implement this method
StarkInfra.PixReversal.Response( // this optional method just helps you build the response JSON
status: "denied",
reason: "orderRejected"
)
)
You can query PixReversal logs to better understand PixReversal life cycles.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.PixReversal.Log> logs = StarkInfra.PixReversal.Log.Query(
after: new DateTime(2019, 4, 1),
before: new DateTime(2021, 4, 30)
);
foreach(StarkInfra.PixReversal.Log log in logs) {
Console.WriteLine(log);
}
You can also get a specific log by its id.
using System;
using StarkInfra;
StarkInfra.PixReversal.Log log = StarkInfra.PixReversal.Log.Get("4701727546671104");
Console.WriteLine(log);
To see how much money you have in your account, run:
using System;
using StarkInfra;
StarkInfra.PixBalance balance = StarkInfra.PixBalance.Get();
Console.WriteLine(reversal);
Statements are generated directly by the Central Bank and are only available for direct participants. To create a statement of all the transactions that happened on your account during a specific day, run:
using System;
using System.Collections.Generic;
using StarkInfra;
List<StarkInfra.PixStatement> statement = StarkInfra.PixStatement.Create(
new List<StarkInfra.PixStatement> {
new StarkInfra.PixStatement(
after: DateTime.Today.Date.AddDays(-1), // This is the date that you want to create a statement.
before: DateTime.Today.Date.AddDays(-1), // After and before must be the same date.
type: "transaction" // Options are "interchange", "interchangeTotal", "transaction".
)
}
);
foreach(StarkInfra.PixStatement statement in statements) {
Console.WriteLine(statement);
}
You can query multiple PixStatements according to filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.PixStatement> statements = StarkInfra.PixStatement.Query(
limit: 50,
after: DateTime.Today.Date.AddDays(-10), // Note that this after and before parameters are different from the ones used in the creation of the statement.
before: DateTime.Today.Date.AddDays(-1)
);
foreach(StarkInfra.PixStatement statement in statements) {
Console.WriteLine(statement);
}
After its creation, information on a statement may be retrieved by its id.
using System;
using StarkInfra;
StarkInfra.PixStatement statement = StarkInfra.PixStatement.Get("5155165527080960");
Console.WriteLine(statement);
To get a .csv file of a Pix statement using its id, run:
using System;
using StarkInfra;
byte[] csv = StarkInfra.PixStatement.Csv("5155165527080960");
System.IO.File.WriteAllBytes("statement.zip", csv);
You can create a PixKey to link a bank account information to a key id:
using System;
using StarkInfra;
StarkInfra.PixKey key = StarkInfra.PixKey.Create(
new StarkInfra.PixKey(
accountCreated: new DateTime(2022, 02, 01),
accountNumber: "00000",
accountType: "savings",
branchCode: "0000",
name: "Jamie Lannister",
taxID: "012.345.678-90",
id: "+5511989898989"
)
);
Console.Write(key);
You can query multiple PixKeys you own according to filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.PixKey> keys = StarkInfra.PixKey.Query(
limit: 10,
after: new DateTime(2022, 01, 01),
before: new DateTime(2022, 01, 12),
status: new List<string> { "created" },
ids: new List<string> { "+5511989898989" },
type: "phone"
);
foreach (StarkInfra.PixKey key in keys)
{
Console.Write(key);
}
Information on a Pix key may be retrieved by its id and the tax ID of the consulting agent. An endToEndID must be informed so you can link any resulting purchases to this query, avoiding sweep blocks by the Central Bank.
using System;
using StarkInfra.Utils;
using StarkInfra;
StarkInfra.PixKey key = StarkInfra.PixKey.Get(
id: "5155165527080960",
payerID: "012.345.678-90",
parameters: new Dictionary<string, object> {
{ "endToEndID", EndToEndID.Create("20018183") }
}
);
Console.Write(key);
Update the account information linked to a Pix key.
using System;
using StarkInfra;
StarkInfra.PixKey key = StarkInfra.PixKey.Update(
id: "+5511998989898",
reason: "branchTransfer",
patchData: new Dictionary<string, object> {
{ "name", "Jamie Lannister" }
}
);
Console.Write(key);
Cancel a specific Pix key using its id.
using System;
using StarkInfra;
StarkInfra.PixKey key = StarkInfra.PixKey.Cancel("+5511912345678");
Console.Write(key);
You can query PixKey logs to better understand a PixKey life cycle.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.PixKey.Log> logs = StarkInfra.PixKey.Log.Query(
limit: 50,
ids: new List<string> { "6126693430525952" },
after: new DateTime(2022, 01, 01),
before: new DateTime(2022, 05, 20),
types: new List<string> { "created" },
keyIds: new List<string> { "+5511912345678" }
);
foreach(StarkInfra.PixKey.Log log in logs)
{
Console.Write(log);
}
You can also get a specific log by its id.
using System;
using StarkInfra;
StarkInfra.PixKey.Log log = StarkInfra.PixKey.Log.Get("5566693430525952");
Console.Write(log);
You can create a PixClaim to request the transfer of a Pix key from another bank to one of your accounts:
using System;
using StarkInfra;
StarkInfra.PixClaim claim = StarkInfra.PixClaim.Create(
new StarkInfra.PixClaim(
accountCreated: new DateTime(2022, 02, 01),
accountNumber: "5692908409716736",
accountType: "checking",
branchCode: "0001",
name: "testKey",
taxID: "012.345.678-90",
keyID: "+5511989298469"
)
);
Console.Write(claim);
You can query multiple PixClaims according to filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.PixClaim> claims = StarkInfra.PixClaim.Query(
limit: 10,
after: new DateTime(2022, 01, 01),
before: new DateTime(2022, 09, 12),
status: new List<string> { "delivered" },
ids: new List<string> { "6481646396112896" },
type: "ownership",
agent: "claimer",
keyType: "phone",
keyID: "+5511989298469"
);
foreach(StarkInfra.PixClaim claim in claims)
{
Console.Write(claim);
}
After its creation, information on a PixClaim may be retrieved by its id.
using System;
using StarkInfra;
StarkInfra.PixClaim claim = StarkInfra.PixClaim.Get("6481646396112896");
Console.Write(claim);
A PixClaim can be confirmed or canceled by patching its status. A received PixClaim must be confirmed by the donor to be completed. Ownership PixClaims can only be canceled by the donor if the reason is "fraud". A sent PixClaim can also be canceled.
using System;
using StarkInfra;
Dictionary<string, object> patchData = new Dictionary<string, object> {
{ "status", "canceled" }
};
StarkInfra.PixClaim claim = StarkInfra.PixClaim.Update(id: "4508444895739904", patchData: patchData);
Console.Write(claim);
You can query PixClaim logs to better understand Pix claim life cycles.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.PixClaim.Log> logs = StarkInfra.PixClaim.Log.Query(
limit: 10,
after: new DateTime(2022, 01, 01),
before: new DateTime(2022, 12, 01),
types: new List<string> { "canceled" },
claimIds: new List<string> { "4508444895739904" }
);
foreach(StarkInfra.PixClaim.Log log in logs)
{
Console.Write(log);
}
You can also get a specific log by its id.
using System;
using StarkInfra;
StarkInfra.PixClaim.Log log = StarkInfra.PixClaim.Log.Get("4598641893310464");
Console.Write(log);
To register the Pix director contact information at the Central Bank, run the following:
using System;
using StarkInfra;
StarkInfra.PixDirector director = StarkInfra.PixDirector.Create(
new StarkInfra.PixDirector(
name: "Edward Stark",
taxID: "012.345.678-90",
phone: "+5511999999999",
email: "ned.stark@company.com",
password: "12345678",
teamEmail: "pix.team@company.com",
teamPhones: new List<string> { "+5511988889999", "+5511988889998" }
)
);
Console.Write(director);
Pix Infraction reports are used to report transactions that raise fraud suspicion, to request a refund or to reverse a refund. Infraction reports can be created by either participant of a transaction.
using System;
using StarkInfra;
StarkInfra.PixInfraction infractions = StarkInfra.PixInfraction.Create(
new List<StarkInfra.PixInfraction>{
new StarkInfra.PixInfraction(
referenceID: "E20018183202204951450u34sDGd19lz",
type: "fraud"
)
}
);
foreach(StarkInfra.PixInfraction infraction in infractions)
{
Console.Write(infraction);
}
You can query multiple infraction reports according to filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.PixInfraction> infractions = StarkInfra.PixInfraction.Query(
limit: 10,
after: new DateTime(2022, 01, 01),
before: new DateTime(2022, 12, 01),
status: "created",
ids: new List<string> { "5724541800153088" }
);
foreach(StarkInfra.PixInfraction infraction in infractions)
{
Console.Write(infraction);
}
After its creation, information on a Pix Infraction may be retrieved by its id.
using System;
using StarkInfra;
StarkInfra.PixInfraction infraction = StarkInfra.PixInfraction.Get("5724541800153088");
Console.Write(infraction);
A received Pix infraction can be confirmed or declined by patching its status. After a Pix infraction is patched, its status changes to closed.
using System;
using StarkInfra;
StarkInfra.PixInfraction infraction = StarkInfra.PixInfraction.Update(id: "5586201146818560", result: "agreed");
Console.Write(infraction);
Cancel a specific Pix Chargeback using its id.
using System;
using StarkInfra;
StarkInfra.PixInfraction infraction = StarkInfra.PixInfraction.Cancel("5586201146818560");
Console.Write(infraction);
You can query Pix infraction logs to better understand their life cycles.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.PixInfraction.Log> logs = StarkInfra.PixInfraction.Log.Query(
limit: 50,
ids: new List<string> { "6307030096674816" },
after: new DateTime(2022, 01, 01),
before: new DateTime(2022, 12, 01),
types: new List<string> { "closed" },
infractionIds: new List<string> { "5586201146818560" }
);
foreach(StarkInfra.PixInfraction.Log log in logs)
{
Console.Write(log);
}
You can also get a specific log by its id.
using System;
using StarkInfra;
StarkInfra.PixInfraction.Log log = StarkInfra.PixInfraction.Log.Get("6307030096674816");
Console.Write(log);
Pix chargebacks can be created when fraud is detected on a transaction or a system malfunction results in an erroneous transaction.
using System;
using StarkInfra;
StarkInfra.PixChargeback chargebacks = StarkInfra.PixChargeback.Create(
new List<StarkInfra.PixChargeback>{
new StarkInfra.PixChargeback(
amount: 100,
referenceID: "E20018183202201201450u34sDGd19lz",
reason: "fraud"
)
}
);
foreach(StarkInfra.PixChargeback chargeback in chargebacks)
{
Console.Write(chargeback);
}
You can query multiple PixChargebacks according to filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.PixChargeback> chargebacks = StarkInfra.PixChargeback.Query(
limit: 10,
after: new DateTime(2022, 01, 01),
before: new DateTime(2022, 12, 01),
status: "delivered",
ids: new List<string> { "6689875965247488" }
);
foreach(StarkInfra.PixChargeback chargeback in chargebacks)
{
Console.Write(chargeback);
}
After its creation, information on a Pix Chargebacks may be retrieved by its.
using System;
using StarkInfra;
StarkInfra.PixChargeback chargeback = StarkInfra.PixChargeback.Get("6689875965247488");
Console.Write(chargeback);
A received Pix Chargeback can be accepted or rejected by patching its status. After a Pix Chargeback is patched, its status changes to closed.
using System;
using StarkInfra.Utils;
using StarkInfra;
StarkInfra.PixChargeback chargeback = StarkInfra.PixChargeback.Update(
id: "6689875965247488",
result: "accepted",
patchData: new Dictionary<string, object> {
{ "reversalReferenceID", ReturnID.Create("20018183") }
}
);
Console.Write(chargeback);
Cancel a specific Pix reversal using its id.
using System;
using StarkInfra;
StarkInfra.PixChargeback chargeback = StarkInfra.PixChargeback.Cancel("6689875965247488");
Console.Write(chargeback);
You can query PixChargeback logs to better understand Pix chargeback life cycles.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.PixChargeback.Log> logs = StarkInfra.PixChargeback.Log.Query(
limit: 50,
ids: new List<string> { "5036445332930560" },
after: new DateTime(2022, 01, 01),
before: new DateTime(2022, 12, 01),
types: new List<string> { "closed" },
chargebackIds: new List<string> { "4806677870149632" }
);
foreach (StarkInfra.PixChargeback.Log log in logs)
{
Console.Write(log);
}
You can also get a specific log by its id.
using System;
using StarkInfra;
StarkInfra.PixChargeback.Log log = StarkInfra.PixChargeback.Log.Get("5036445332930560");
Console.Write(log);
Here you can list all Pix Domains registered at the Brazilian Central Bank. The Pix Domain object displays the domain name and the QR Code domain certificates of registered Pix participants able to issue dynamic QR Codes.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.PixDomain> domains = StarkInfra.PixDomain.Query();
foreach (StarkInfra.PixDomain domain in domains)
{
Console.Write(domain);
}
StaticBrcodes store account information via a BR code or an image (QR code) that represents a PixKey and a few extra fixed parameters, such as an amount and a reconciliation ID. They can easily be used to receive Pix transactions.
using System;
using System.Collections.Generic;
using StarkInfra;
List<StarkInfra.StaticBrcode> brcodes = StarkInfra.StaticBrcode.Create(
new List<StarkInfra.StaticBrcode>
{
new StarkInfra.StaticBrcode(
name: "Jamie Lannister",
keyID: "+5511988887777",
amount: 100,
reconciliationID: "123",
city: "Rio de Janeiro"
)
}
);
foreach (StarkInfra.StaticBrcode brcode in brcodes)
{
Console.Write(brcode);
}
You can query multiple StaticBrcodes according to filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.StaticBrcode> brcodes = StarkInfra.StaticBrcode.Query(
limit: 1,
after: new DateTime(2022, 06, 01),
before: new DateTime(2022, 06, 30),
uuids: new List<string> { "5ddde28043a245c2848b08cf315effa2" }
);
foreach (StarkInfra.StaticBrcode brcode in brcodes)
{
Console.Write(brcode);
}
After its creation, information on a StaticBrcode may be retrieved by its UUID.
using System;
using System.Collections.Generic;
using StarkInfra;
StarkInfra.StaticBrcode brcode = StarkInfra.StaticBrcode.Get("5ddde28043a245c2848b08cf315effa2");
Console.Write(brcode);
BR codes store information represented by Pix QR Codes, which are used to send or receive Pix transactions in a convenient way. DynamicBrcodes represent charges with information that can change at any time, since all data needed for the payment is requested dynamically to an URL stored in the BR Code. Stark Infra will receive the GET request and forward it to your registered endpoint with a GET request containing the UUID of the BR code for identification.
using System;
using System.Collections.Generic;
using StarkInfra;
List<StarkInfra.DynamicBrcode> brcodes = StarkInfra.DynamicBrcode.Create(
new List<StarkInfra.DynamicBrcode>
{
new StarkInfra.DynamicBrcode(
name: "Jamie Lannister",
city: "Rio de Janeiro",
externalID: "my_unique_id_01",
type: "instant"
)
}
);
foreach (StarkInfra.DynamicBrcode brcode in brcodes)
{
Console.Write(brcode);
}
You can query multiple DynamicBrcodes according to filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.DynamicBrcode> brcodes = StarkInfra.DynamicBrcode.Query(
limit: 1,
after: new DateTime(2022, 06, 01),
before: new DateTime(2022, 06, 30),
uuids: new List<string> { "ac7caa14e601461dbd6b12bf7e4cc48e" }
);
foreach (StarkInfra.DynamicBrcode brcode in brcodes)
{
Console.Write(brcode);
}
After its creation, information on a DynamicBrcode may be retrieved by its UUID.
using System;
using System.Collections.Generic;
using StarkInfra;
StarkInfra.DynamicBrcode brcode = StarkInfra.DynamicBrcode.Get("ac7caa14e601461dbd6b12bf7e4cc48e");
Console.Write(brcode);
When a DynamicBrcode is read by your user, a GET request will be made to the your registered URL to retrieve additional information needed to complete the transaction. Use this method to verify the authenticity of a GET request received at your registered endpoint. If the provided digital signature does not check out with the StarkInfra public key, a Error.InvalidSignatureException will be raised.
using System;
using StarkInfra;
Response response = listen(); // this is the method you made to get the read requests posted to your registered endpoint
string uuid = StarkInfra.DynamicBrcode.Verify(
uuid: response.Url.getParameter("uuid"),
signature: response.Headers["Digital-Signature"]
);
When a Due DynamicBrcode is read by your user, a GET request containing the BR code UUID will be made to your registered URL to retrieve additional information needed to complete the transaction.
The GET request must be answered in the following format within 5 seconds and with an HTTP status code 200.
using System;
using StarkInfra;
Response response = listen(); // this is the method you made to get the read requests posted to your registered endpoint
string uuid = StarkInfra.DynamicBrcode.Verify(
uuid: response.Url.getParameter("uuid"),
signature: response.Headers["Digital-Signature"]
);
List<StarkInfra.Invoice> invoice = getMyInvoice(uuid); // you should implement this method to get the information of the BR code from its uuid
sendResponse( // you should also implement this method to respond the read request
StarkInfra.DynamicBrcode.responseDue(
version: invoice.version,
created: invoice.created,
due: invoice.due,
keyID: invoice.keyID,
status: invoice.status,
reconciliationID: invoice.reconciliationID,
amount: invoice.amount,
senderName: invoice.senderName,
senderTaxID: invoice.senderTaxID,
receiverName: invoice.receiverName,
receiverTaxID: invoice.receiverTaxid,
receiverStreetLine: invoice.receiverStreetLine,
receiverCity: invoice.receiverCity,
receiverStateCode: invoice.receiverStateCode,
receiverZipCode: invoice.receiverZipCode
);
);
When an Instant DynamicBrcode is read by your user, a GET request containing the BR code UUID will be made to your registered URL to retrieve additional information needed to complete the transaction.
The get request must be answered in the following format within 5 seconds and with an HTTP status code 200.
using System;
using StarkInfra;
Response response = listen(); // this is the method you made to get the read requests posted to your registered endpoint
string uuid = StarkInfra.DynamicBrcode.Verify(
uuid: response.Url.getParameter("uuid"),
signature: response.Headers["Digital-Signature"]
);
List<StarkInfra.Invoice> invoice = getMyInvoice(uuid); // you should implement this method to get the information of the BR code from its uuid
sendResponse( // you should also implement this method to respond the read request
StarkInfra.DynamicBrcode.responseInstant(
version: invoice.version,
created: invoice.created,
keyID: invoice.keyID,
status: invoice.status,
reconciliationID: invoice.reconciliationID,
amount: invoice.amount,
cashierType: invoice.cashierType,
cashierBankCode: invoice.cashierBankCode,
cashAmount: invoice.cashAmount
);
);
You can create BrcodePreviews to preview BR Codes before paying them.
using System;
using System.Collections.Generic;
using StarkInfra;
List<StarkInfra.BrcodePreview> previews = StarkInfra.BrcodePreview.Create(
new List<StarkInfra.BrcodePreview>
{
new StarkInfra.BrcodePreview(
id: "00020126420014br.gov.bcb.pix0120nedstark@hotmail.com52040000530398654075000.005802BR5909Ned Stark6014Rio de Janeiro621605126674869738606304FF71"
),
new StarkInfra.BrcodePreview(
id: "00020126430014br.gov.bcb.pix0121aryastark@hotmail.com5204000053039865406100.005802BR5910Arya Stark6014Rio de Janeiro6216051262678188104863042BA4"
)
}
);
foreach (StarkInfra.BrcodePreview preview in previews)
{
Console.Write(preview);
}
If you want to establish a lending operation, you can use Stark Infra to create a CCB contract. This will enable your business to lend money without requiring a banking license, as long as you use a Credit Fund or Securitization company.
The required steps to initiate the operation are:
- Have funds in your Credit Fund or Securitization account
- Request the creation of an Identity Check for the credit receiver (make sure you have their documents and express authorization)
- (Optional) Create a Credit Simulation with the desired installment plan to display information for the credit receiver
- Create a Credit Note with the desired installment plan
You can create CreditNotes to generate a CCB contracts:
using System;
using StarkInfra;
List<StarkInfra.CreditNote> notes = StarkInfra.CreditNote.Create(
new List<StarkInfra.CreditNote>() {
new StarkInfra.CreditNote(
templateID: "5707012469948416",
name: "Jamie Lannister",
taxID: "012.345.678-90",
nominalAmount: 500000,
scheduled: new DateTime(2022, 01, 01),
invoices: new List<Invoice> {
new StarkInfra.CreditNote.Invoice(
amount: 510000,
due: new DateTime(2023, 01, 21)
)
},
payment: new StarkInfra.CreditNote.Transfer(
bankCode: "00000000",
branchCode: "1234",
accountNumber: "129340-1",
name: "Jamie Lannister",
taxID: "012.345.678-90",
),
paymentType: "transfer",
signers: new List<StarkInfra.CreditNote.Signer>{
new StarkInfra.CreditNote.Signer(
name: "Jamie Lannister",
contact: "jamie.lannister@gmail.com",
method: "link"
)
},
externalID: "my_external_id_10",
streetLine1: "Av. Paulista, 200",
streetLine2: "10 andar",
district: "Bela Vista",
city: "SĂŁo Paulo",
stateCode: "SP",
zipCode: "01310-000"
)
}
);
foreach(StarkInfra.CreditNote note in notes)
{
Console.Write(note);
}
Note: Instead of using CreditNote objects, you can also pass each element in dictionary format
You can query multiple CreditNotes according to filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.CreditNote> notes = StarkInfra.CreditNote.Query(
limit: 10,
after: new DateTime(2022, 01, 01),
before: new DateTime(2022, 12, 01),
status: new List<string>{ "signed" },
tags: new List<string>{ "iron", "suit" }
);
foreach(StarkInfra.CreditNote note in notes)
{
Console.Write(note);
}
After its creation, information on a CreditNote may be retrieved by its id.
using System;
using StarkInfra;
StarkInfra.CreditNote note = StarkInfra.CreditNote.Get("5155165527080960");
Console.Write(note);
You can cancel a CreditNote if it has not been signed yet.
using System;
using StarkInfra;
StarkInfra.CreditNote note = StarkInfra.CreditNote.Cancel("5155165527080960");
Console.Write(note);
You can query CreditNote logs to better understand CreditNote life cycles.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.CreditNote.Log> logs = StarkInfra.CreditNote.Log.Query(
limit: 50,
after: new DateTime(2022, 01, 01),
before: new DateTime(2022, 12, 01)
);
foreach (StarkInfra.CreditNote.Log log in logs)
{
Console.Write(log);
}
You can also get a specific log by its id.
using System;
using StarkInfra;
StarkInfra.CreditNote.Log log = StarkInfra.CreditNote.Log.Get("5155165527080960");
Console.Write(log);
You can preview a credit operation before creating them (Currently we only have CreditNote / CCB previews):
using System;
using StarkInfra;
List<StarkInfra.CreditPreview> previews = StarkInfra.CreditPreview.Create(
new List<StarkInfra.CreditPreview>() {
new StarkInfra.CreditPreview(
type: "credit-note",
credit: new StarkInfra.CreditPreview.CreditNotePreview(
initialAmount: 2478,
initialDue: new DateTime(2022, 10, 22),
nominalAmount: 90583,
nominalInterest: 3.7F,
rebateAmount: 23,
scheduled: new DateTime(2022, 09, 28),
taxID: "477.954.506-44",
type: "sac"
)
),
new StarkInfra.CreditPreview(
type: "credit-note",
credit: new StarkInfra.CreditPreview.CreditNotePreview(
initialAmount: 4449,
initialDue: new DateTime(2022, 10, 16),
interval: "year",
nominalAmount: 96084,
nominalInterest: 3.1F,
rebateAmount: 239,
scheduled: new DateTime(2022, 10, 02),
taxID: "81.882.684/0001-02",
type: "price"
)
),
new StarkInfra.CreditPreview(
type: "credit-note",
credit: new StarkInfra.CreditPreview.CreditNotePreview(
count: 8,
initialDue: new DateTime(2022, 10, 18),
nominalAmount: 6161,
nominalInterest: 3.2F,
scheduled: new DateTime(2022, 10, 03),
taxID: "59.352.830/0001-20",
type: "american"
)
),
new StarkInfra.CreditPreview(
type: "credit-note",
credit: new StarkInfra.CreditPreview.CreditNotePreview(
initialDue: new DateTime(2022, 10, 13),
nominalAmount: 86237,
nominalInterest: 2.6F,
scheduled: new DateTime(2022, 10, 03),
taxID: "37.293.955/0001-94",
type: "bullet"
)
),
new StarkInfra.CreditPreview(
type: "credit-note",
credit: new StarkInfra.CreditPreview.CreditNotePreview(
invoices: new List<StarkInfra.Invoice> {
new StarkInfra.Invoice(
amount: 14500,
due: new DateTime(2022, 11, 19)
),
new StarkInfra.Invoice(
amount: 14500,
due: new DateTime(2022, 12, 25)
)
},
nominalAmount: 29000,
rebateAmount: 900,
scheduled: new DateTime(2022, 10, 31),
taxID: "36.084.400/0001-70",
type: "custom"
)
)
}
);
foreach (StarkInfra.CreditPreview preview in previews)
{
Console.Write(preview);
}
Note: Instead of using CreditPreview objects, you can also pass each element in dictionary format
Before you request a credit operation, you may want to check previous credit operations the credit receiver has taken.
For that, open up a CreditHolmes investigation to receive information on all debts and credit operations registered for that individual or company inside the Central Bank's SCR.
using System;
using StarkInfra;
List<StarkInfra.CreditHolmes> holmes = StarkInfra.CreditHolmes.Create(
new List<StarkInfra.CreditHolmes>() {
new StarkInfra.CreditHolmes(
taxID: "123.456.789-00",
competence: "2022-09"
),
new StarkInfra.CreditHolmes(
taxID: "123.456.789-00",
competence: "2022-08"
),
new StarkInfra.CreditHolmes(
taxID: "123.456.789-00",
competence: "2022-07"
)
}
);
foreach (StarkInfra.CreditHolmes sherlock in holmes)
{
Console.Write(sherlock);
}
You can query multiple credit holmes according to filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.CreditHolmes> holmes = StarkInfra.CreditHolmes.Query(
limit: 10,
after: new DateTime(2022, 01, 01),
before: new DateTime(2022, 12, 01),
status: new List<string>{ "success" }
);
foreach(StarkInfra.CreditHolmes sherlock in holmes)
{
Console.Write(sherlock);
}
After its creation, information on a credit holmes may be retrieved by its id.
using System;
using StarkInfra;
StarkInfra.CreditHolmes holmes = StarkInfra.CreditHolmes.Get("5657818854064128");
Console.Write(holmes);
You can query credit holmes logs to better understand their life cycles.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.CreditHolmes.Log> logs = StarkInfra.CreditHolmes.Log.Query(
limit: 50,
ids: new List<string>{ "5729405850615808" },
after: new DateTime(2022, 01, 01),
before: new DateTime(2022, 12, 01),
types: new List<string>{ "created" }
);
foreach (StarkInfra.CreditHolmes.Log log in logs)
{
Console.Write(log);
}
You can also get a specific log by its id.
using System;
using StarkInfra;
StarkInfra.CreditNote.Log log = StarkInfra.CreditNote.Log.Get("5155165527080960");
Console.Write(log);
Several operations, especially credit ones, require that the identity of a person or business is validated beforehand.
Identities are validated according to the following sequence:
- The Identity resource is created for a specific Tax ID
- Documents are attached to the Identity resource
- The Identity resource is updated to indicate that all documents have been attached
- The Identity is sent for validation and returns a webhook notification to reflect the success or failure of the operation
You can create an IndividualIdentity to validate a document of a natural person
using System;
using StarkInfra;
List<StarkInfra.IndividualIdentity> identities = StarkInfra.IndividualIdentity.Create(
new List<StarkInfra.IndividualIdentity>() {
new StarkInfra.IndividualIdentity(
name: "Walter White",
taxID: "012.345.678-90",
tags: new List<string>{ "breaking", "bad" }
);
}
);
foreach(StarkInfra.IndividualIdentity identity in identities)
{
Console.Write(identity);
}
Note: Instead of using IndividualIdentity objects, you can also pass each element in dictionary format
You can query multiple individual identities according to filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.IndividualIdentity> identities = StarkInfra.IndividualIdentity.Query(
limit: 10,
after: new DateTime(2022, 01, 01),
before: new DateTime(2022, 12, 01),
status: new List<string>{ "success" },
tags: new List<string>{ "breaking", "bad" }
);
foreach(StarkInfra.IndividualIdentity identity in identities)
{
Console.Write(identity);
}
After its creation, information on an individual identity may be retrieved by its id.
using System;
using StarkInfra;
StarkInfra.IndividualIdentity identity = StarkInfra.IndividualIdentity.Get("5155165527080960");
Console.Write(identity);
You can update a specific identity status to "processing" for send it to validation.
using System;
using StarkInfra;
StarkInfra.IndividualIdentity identity = StarkInfra.IndividualIdentity.Update("5155165527080960", "processing");
Console.Write(identity);
Note: Before sending your individual identity to validation by patching its status, you must send all the required documents using the create method of the CreditDocument resource. Note that you must reference the individual identity in the create method of the CreditDocument resource by its id.
You can cancel an individual identity before updating its status to processing.
using System;
using StarkInfra;
StarkInfra.IndividualIdentity identity = StarkInfra.IndividualIdentity.Cancel("5155165527080960");
Console.Write(identity);
You can query individual identity logs to better understand individual identity life cycles.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.IndividualIdentity.Log> logs = StarkInfra.IndividualIdentity.Log.Query(
limit: 50,
after: new DateTime(2022, 01, 01),
before: new DateTime(2022, 12, 01)
);
foreach (StarkInfra.IndividualIdentity.Log log in logs)
{
Console.Write(log);
}
You can also get a specific log by its id.
using System;
using StarkInfra;
StarkInfra.IndividualIdentity.Log log = StarkInfra.IndividualIdentity.Log.Get("5155165527080960");
Console.Write(log);
You can create an individual document to attach images of documents to a specific individual Identity. You must reference the desired individual identity by its id.
using System;
using StarkInfra;
List<StarkInfra.IndividualDocument> documents = StarkInfra.IndividualDocument.Create(
new List<StarkInfra.IndividualDocument>() {
new StarkInfra.IndividualDocument(
type: "identity-front",
content: "data:image/jpeg;base64,/9j/4AAQSkZJRgABAQAASABIAAD...",
identityID: '5155165527080960',
tags: new List<string>{ "breaking", "bad" }
)
}
);
documents = StarkInfra.IndividualDocument.Create(
new List<StarkInfra.IndividualDocument>() {
new StarkInfra.IndividualDocument(
type: "identity-back",
content: "data:image/jpeg;base64,/9j/4AAQSkZJRgABAQAASABIAAD...",
identityID: '5155165527080960',
tags: new List<string>{ "breaking", "bad" }
)
}
);
documents = StarkInfra.IndividualDocument.Create(
new List<StarkInfra.IndividualDocument>() {
new StarkInfra.IndividualDocument(
type: "selfie",
content: "data:image/jpeg;base64,/9j/4AAQSkZJRgABAQAASABIAAD...",
identityID: '5155165527080960',
tags: new List<string>{ "breaking", "bad" }
)
}
);
foreach(StarkInfra.CreditNote document in documents)
{
Console.Write(document);
}
Note: Instead of using IndividualDocument objects, you can also pass each element in dictionary format
You can query multiple individual documents according to filters.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.IndividualDocument> documents = StarkInfra.IndividualDocument.Query(
limit: 10,
after: new DateTime(2022, 01, 01),
before: new DateTime(2022, 12, 01),
status: new List<string>{ "success" },
tags: new List<string>{ "breaking", "bad" }
);
foreach(StarkInfra.IndividualDocument document in documents)
{
Console.Write(document);
}
After its creation, information on an individual document may be retrieved by its id.
using System;
using StarkInfra;
StarkInfra.IndividualDocument document = StarkInfra.IndividualDocument.Get("5155165527080960");
Console.Write(document);
You can query individual document logs to better understand individual document life cycles.
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.IndividualDocument.Log> logs = StarkInfra.IndividualDocument.Log.Query(
limit: 50,
after: new DateTime(2022, 01, 01),
before: new DateTime(2022, 12, 01)
);
foreach (StarkInfra.IndividualDocument.Log log in logs)
{
Console.Write(log);
}
You can also get a specific log by its id.
using System;
using StarkInfra;
StarkInfra.IndividualDocument.Log log = StarkInfra.IndividualDocument.Log.Get("5155165527080960");
Console.Write(log);
To create a webhook subscription and be notified whenever an event occurs, run:
using System;
using StarkInfra;
StarkInfra.Webhook webhook = StarkInfra.Webhook.Create(
url: "https://webhook.site/6cd3c98d-60ca-4f4a-97c6-a7d0365b15B7",
subscription: new List<string> {
"credit-note",
"issuing-card",
"issuing-invoice",
"issuing-purchase",
"pix-request.in",
"pix-request.out",
"pix-reversal.in",
"pix-reversal.out",
"pix-claim",
"pix-key",
"pix-chargeback",
"pix-infraction"
}
);
Console.Write(webhook);
To search for registered webhooks, run:
using System;
using System.Collections.Generic;
using StarkInfra;
IEnumerable<StarkInfra.Webhook> webhooks = StarkInfra.Webhook.Query();
foreach (StarkInfra.Webhook webhook in webhooks)
{
Console.Write(webhook);
}
After its creation, information on a webhook may be retrieved by its id.
using System;
using StarkInfra;
StarkInfra.Webhook webhook = StarkInfra.Webhook.Get("1082736198236817");
Console.Write(webhook);
You can also delete a specific webhook by its id.
using System;
using StarkInfra;
StarkInfra.Webhook webhook = StarkInfra.Webhook.Delete("1082736198236817");
Console.Write(webhook);
It's easy to process events delivered to your Webhook endpoint. Remember to pass the signature header so the SDK can make sure it was StarkInfra that sent you the event.
using System;
using StarkInfra;
Response response = listen(); // this is the method you made to get the events posted to your webhook endpoint
StarkInfra.Event parsedEvent = StarkInfra.Event.Parse(
content: response.Content,
signature: response.Headers["Digital-Signature"]
);
if (parsedEvent.Subscription.Contains("pix-key") {
StarkInfra.PixKey.Log log = parsedEvent.Log as StarkInfra.PixKey.Log;
Console.WriteLine(log.PixKey);
}
if (parsedEvent.Subscription.Contains("pix-claim") {
StarkInfra.PixClaim.Log log = parsedEvent.Log as StarkInfra.PixClaim.Log;
Console.WriteLine(log.PixClaim);
}
if (parsedEvent.Subscription.Contains("pix-infraction") {
StarkInfra.PixInfraction.Log log = parsedEvent.Log as StarkInfra.PixInfraction.Log;
Console.WriteLine(log.PixInfraction);
}
if (parsedEvent.Subscription.Contains("pix-chargeback") {
StarkInfra.PixChargeback.Log log = parsedEvent.Log as StarkInfra.PixChargeback.Log;
Console.WriteLine(log.PixChargeback);
}
if (parsedEvent.Subscription.Contains("pix-request") {
StarkInfra.PixRequest.Log log = parsedEvent.Log as StarkInfra.PixRequest.Log;
Console.WriteLine(log.PixRequest);
}
if (parsedEvent.Subscription.Contains("pix-reversal") {
StarkInfra.PixReversal.Log log = parsedEvent.Log as StarkInfra.PixReversal.Log;
Console.WriteLine(log.PixReversal);
}
if (parsedEvent.Subscription.Contains("credit-note") {
StarkInfra.CreditNote.Log log = parsedEvent.Log as StarkInfra.CreditNote.Log;
Console.WriteLine(log.CreditNote);
}
if (parsedEvent.Subscription.Contains("issuing-card") {
StarkInfra.IssuingCard.Log log = parsedEvent.Log as StarkInfra.IssuingCard.Log;
Console.WriteLine(log.IssuingCard);
}
if (parsedEvent.Subscription.Contains("issuing-invoice") {
StarkInfra.IssuingInvoice.Log log = parsedEvent.Log as StarkInfra.IssuingInvoice.Log;
Console.WriteLine(log.IssuingInvoice);
}
if (parsedEvent.Subscription.Contains("issuing-purchase") {
StarkInfra.IssuingPurchase.Log log = parsedEvent.Log as StarkInfra.IssuingPurchase.Log;
Console.WriteLine(log.IssuingPurchase);
}
To search for webhook events, run:
using System;
using System.Collections.Generic;
IEnumerable<StarkInfra.Event> events = StarkInfra.Event.Query(
after: DateTime.Today,
isDelivered: false
);
foreach(StarkInfra.Event event in events) {
Console.WriteLine(event);
}
You can get a specific webhook event by its id.
using System;
using StarkInfra;
StarkInfra.Event event = StarkInfra.Event.Get("1082736198236817");
Console.WriteLine(event);
You can also delete a specific webhook event by its id.
using System;
using StarkInfra;
StarkInfra.Event event = StarkInfra.Event.Delete("1082736198236817");
Console.WriteLine(event);
This can be used in case you"ve lost events.
With this function, you can manually set events retrieved from the API as
"delivered" to help future event queries with isDelivered: false
.
using System;
using StarkInfra;
StarkInfra.Event event = StarkInfra.Event.Update("1298371982371921", isDelivered: true);
Console.WriteLine(event);
You can also get information on failed webhook event delivery attempts.
using System;
using StarkInfra;
List<StarkInfra.Event.Attempt> attempts = StarkInfra.Event.Attempt.Query(after: "2020-03-20").ToList();
foreach(StarkInfra.Event.Attempt attempt in attempts) {
Console.WriteLine(attempt);
}
To retrieve information on a single attempt, use the following function:
using System;
using StarkInfra;
StarkInfra.Event.Attempt attempt = StarkInfra.Event.Attempt.Get("1616161616161616");
Console.WriteLine(attempt);
This resource allows you to send HTTP requests to StarkInfra routes.
You can perform a GET request to any StarkInfra route.
It's possible to get a single resource using its id in the path.
using StarkInfra;
string exampleId = "5155165527080960"
JObejct request = Request.Get(
path="/pix-request/" + exampleId
).Json();
Console.WriteLine(request.ToString());
You can also get the specific resource log,
using StarkInfra;
string exampleId = "5155165527080960";
JObejct request = Request.Get(
path="/pix-request/log/" + exampleId
).Json();
Console.WriteLine(request.ToString());
This same method will be used to list all created items for the requested resource.
using StarkInfra;
string after = "2024-01-01";
string before = "2024-02-01";
string cursor = "";
JObject request = Request.Get(
path="/pix-request/",
query={
"after": after,
"before": before,
"cursor": cursor
}
).Json();
Console.WriteLine(request.ToString());
To list logs, you will use the same logic as for getting a single log.
using StarkInfra;
string after = "2024-01-01";
string before = "2024-02-01";
string cursor = "";
JObject request = Request.Get(
path="/pix-request/log",
query={
"after": after,
"before": before,
"cursor": cursor
}
).Json();
Console.WriteLine(request.ToString());
You can get a resource file using this method.
using StarkInfra;
string exampleId = "5155165527080960";
[]byte pdf = Request.Get(
path="/pix-request/" + exampleId + "/pdf",
).ByteContent;
System.IO.File.WriteAllBytes("request.pdf", pdf);
You can perform a POST request to any StarkInfra route.
This will create an object for each item sent in your request
Note: It's not possible to create multiple resources simultaneously. You need to send separate requests if you want to create multiple resources, such as requests and boletos.
using StarkInfra;
Dictionary<string, object> data = new Dictionary<string, object>() {
{
"holders", new List<Dictionary<string, object>>() { new Dictionary<string, object>()
{
{ "name", "Jaime Lannister " + Guid.NewGuid().ToString() },
{ "externalId", Guid.NewGuid().ToString() },
{ "taxId", "20.018.183/0001-80" }
},
}
}
};
JObject request = Request.Post(
path="/issuing-holder",
body=data,
).Json();
Console.WriteLine(request.ToString())
You can perform a PATCH request to any StarkInfra route.
It's possible to update a single item of a StarkInfra resource.
using StarkInfra;
string exampleId = "5155165527080960"
Dictionary<string, object> data = new Dictionary<string, object>() { { "tags", new List<string> { Guid.NewGuid().ToString() } } };
JObject request = Request.Patch(
path="/issuing-holder/" + exampleId,
body=data,
).Json();
Console.WriteLine(request.ToString());
You can perform a DELETE request to any StarkInfra route.
It's possible to delete a single item of a StarkInfra resource.
using StarkInfra;
string exampleId = "5155165527080960"
JObject request = Request.Delete(
path="/issuing-holder/" + exampleId,
).Json();
Console.WriteLine(request.ToString());
The SDK may raise one of four types of errors: InputErrors, InternalServerError, UnknownError, InvalidSignatureError
InputErrors will be raised whenever the API detects an error in your request (status code 400). If you catch such an error, you can get its elements to verify each of the individual errors that were detected in your request by the API. For example:
using System;
using System.Collections.Generic;
using System.Error;
using StarkInfra;
try {
List<StarkInfra.PixReversal> reversal = StarkInfra.PixReversal.Create(
new List<StarkInfra.PixReversal> {
new StarkInfra.PixReversal(
amount: 100,
endToEndID: "E00000000202201060100rzsJzG9PzMg",
externalID: "1723843582395893",
reason: "bankError"
)
}
);
} catch (InputErrors e) {
foreach (ErrorElement error in e.Errors) {
Console.WriteLine(error.Code);
Console.WriteLine(error.Message);
}
}
InternalServerError will be raised if the API runs into an internal error. If you ever stumble upon this one, rest assured that the development team is already rushing in to fix the mistake and get you back up to speed.
UnknownError will be raised if a request encounters an error that is neither InputErrors nor an InternalServerError, such as connectivity problems.
InvalidSignatureError will be raised specifically by StarkInfra.Event.Parse() when the provided content and signature do not check out with the Stark Infra public key.
If you have any questions about our SDK, just send us an email. We will respond you quickly, pinky promise. We are here to help you integrate with us ASAP. We also love feedback, so don't be shy about sharing your thoughts with us.
Email: help@starkbank.com