apideck-dotnet
Compare original and translation side by side
🇺🇸
Original
English🇨🇳
Translation
ChineseApideck .NET SDK Skill
Apideck .NET SDK 技能文档
Overview
概述
The Apideck Unified API provides a single integration layer to connect with 200+ third-party services across accounting, CRM, HRIS, file storage, ATS, e-commerce, and more. The official .NET SDK () provides typed clients for all unified APIs.
ApideckUnifySdkApideck Unified API 提供了一个统一的集成层,可连接会计、CRM、HRIS、文件存储、ATS、电商等领域的200+款第三方服务。官方.NET SDK()为所有统一API提供了类型化客户端。
ApideckUnifySdkInstallation
安装
sh
dotnet add package ApideckUnifySdksh
dotnet add package ApideckUnifySdkIMPORTANT RULES
重要规则
- ALWAYS use the NuGet package. DO NOT make raw
ApideckUnifySdkcalls to the Apideck API.HttpClient - ALWAYS pass ,
apiKey, andappIdwhen initializing the client.consumerId - USE to specify which downstream connector to use (e.g.,
ServiceId,"salesforce")."quickbooks" - USE async/await for all API calls — all operations return .
Task<T> - ALWAYS handle errors with try/catch using as the base class.
BaseException - DO NOT store API keys in source code. Use environment variables or a secrets manager.
- 始终使用NuGet包。请勿直接使用
ApideckUnifySdk调用Apideck API。HttpClient - 初始化客户端时,必须传入、
apiKey和appId。consumerId - 使用指定要连接的下游连接器(例如:
ServiceId、"salesforce")。"quickbooks" - 所有API调用均使用async/await —— 所有操作都返回。
Task<T> - 始终使用作为基类,通过try/catch处理错误。
BaseException - 请勿在源代码中存储API密钥。请使用环境变量或密钥管理器。
Quick Start
快速开始
csharp
using ApideckUnifySdk;
using ApideckUnifySdk.Models.Requests;
var sdk = new Apideck(
consumerId: "your-consumer-id",
appId: "your-app-id",
apiKey: Environment.GetEnvironmentVariable("APIDECK_API_KEY") ?? ""
);
var res = await sdk.Crm.Contacts.ListAsync(new CrmContactsAllRequest {
ServiceId = "salesforce",
Limit = 20,
});
while (res != null)
{
foreach (var contact in res.GetContactsResponse?.Data ?? [])
{
Console.WriteLine($"{contact.Name} - {contact.Emails?.FirstOrDefault()?.Email}");
}
res = await res.Next!();
}csharp
using ApideckUnifySdk;
using ApideckUnifySdk.Models.Requests;
var sdk = new Apideck(
consumerId: "your-consumer-id",
appId: "your-app-id",
apiKey: Environment.GetEnvironmentVariable("APIDECK_API_KEY") ?? ""
);
var res = await sdk.Crm.Contacts.ListAsync(new CrmContactsAllRequest {
ServiceId = "salesforce",
Limit = 20,
});
while (res != null)
{
foreach (var contact in res.GetContactsResponse?.Data ?? [])
{
Console.WriteLine($"{contact.Name} - {contact.Emails?.FirstOrDefault()?.Email}");
}
res = await res.Next!();
}SDK Patterns
SDK 使用模式
Client Setup
客户端设置
csharp
using ApideckUnifySdk;
var sdk = new Apideck(
consumerId: "your-consumer-id",
appId: "your-app-id",
apiKey: Environment.GetEnvironmentVariable("APIDECK_API_KEY") ?? ""
);csharp
using ApideckUnifySdk;
var sdk = new Apideck(
consumerId: "your-consumer-id",
appId: "your-app-id",
apiKey: Environment.GetEnvironmentVariable("APIDECK_API_KEY") ?? ""
);CRUD Operations
CRUD 操作
All resources follow the pattern: .
sdk.{Api}.{Resource}.{Operation}Async(request)csharp
using ApideckUnifySdk;
using ApideckUnifySdk.Models.Requests;
using ApideckUnifySdk.Models.Components;
// LIST
var listRes = await sdk.Crm.Contacts.ListAsync(new CrmContactsAllRequest {
ServiceId = "salesforce",
Limit = 20,
Filter = new ContactsFilter { Email = "john@example.com" },
Sort = new ContactsSort {
By = ContactsSortBy.UpdatedAt,
Direction = SortDirection.Desc,
},
});
// CREATE
var createRes = await sdk.Crm.Contacts.CreateAsync(new CrmContactsAddRequest {
ServiceId = "salesforce",
Contact = new ContactInput {
FirstName = "John",
LastName = "Doe",
Emails = new List<Email> {
new Email { EmailAddress = "john@example.com", Type = EmailType.Primary },
},
PhoneNumbers = new List<PhoneNumber> {
new PhoneNumber { Number = "+1234567890", Type = PhoneNumberType.Mobile },
},
},
});
Console.WriteLine(createRes.CreateContactResponse?.Data?.Id);
// GET
var getRes = await sdk.Crm.Contacts.GetAsync(new CrmContactsOneRequest {
Id = "contact_123",
ServiceId = "salesforce",
});
// UPDATE
var updateRes = await sdk.Crm.Contacts.UpdateAsync(new CrmContactsUpdateRequest {
Id = "contact_123",
ServiceId = "salesforce",
Contact = new ContactInput { FirstName = "Jane" },
});
// DELETE
await sdk.Crm.Contacts.DeleteAsync(new CrmContactsDeleteRequest {
Id = "contact_123",
ServiceId = "salesforce",
});所有资源均遵循以下模式:。
sdk.{Api}.{Resource}.{Operation}Async(request)csharp
using ApideckUnifySdk;
using ApideckUnifySdk.Models.Requests;
using ApideckUnifySdk.Models.Components;
// 列表查询
var listRes = await sdk.Crm.Contacts.ListAsync(new CrmContactsAllRequest {
ServiceId = "salesforce",
Limit = 20,
Filter = new ContactsFilter { Email = "john@example.com" },
Sort = new ContactsSort {
By = ContactsSortBy.UpdatedAt,
Direction = SortDirection.Desc,
},
});
// 创建
var createRes = await sdk.Crm.Contacts.CreateAsync(new CrmContactsAddRequest {
ServiceId = "salesforce",
Contact = new ContactInput {
FirstName = "John",
LastName = "Doe",
Emails = new List<Email> {
new Email { EmailAddress = "john@example.com", Type = EmailType.Primary },
},
PhoneNumbers = new List<PhoneNumber> {
new PhoneNumber { Number = "+1234567890", Type = PhoneNumberType.Mobile },
},
},
});
Console.WriteLine(createRes.CreateContactResponse?.Data?.Id);
// 查询详情
var getRes = await sdk.Crm.Contacts.GetAsync(new CrmContactsOneRequest {
Id = "contact_123",
ServiceId = "salesforce",
});
// 更新
var updateRes = await sdk.Crm.Contacts.UpdateAsync(new CrmContactsUpdateRequest {
Id = "contact_123",
ServiceId = "salesforce",
Contact = new ContactInput { FirstName = "Jane" },
});
// 删除
await sdk.Crm.Contacts.DeleteAsync(new CrmContactsDeleteRequest {
Id = "contact_123",
ServiceId = "salesforce",
});Pagination
分页处理
Use the method on the response. Returns when no more pages:
Nextnullcsharp
var res = await sdk.Accounting.Invoices.ListAsync(new AccountingInvoicesAllRequest {
ServiceId = "quickbooks",
Limit = 50,
});
while (res != null)
{
foreach (var invoice in res.GetInvoicesResponse?.Data ?? [])
{
Console.WriteLine($"{invoice.Number}: {invoice.Total}");
}
res = await res.Next!();
}使用响应对象的方法。当没有更多页面时返回:
Nextnullcsharp
var res = await sdk.Accounting.Invoices.ListAsync(new AccountingInvoicesAllRequest {
ServiceId = "quickbooks",
Limit = 50,
});
while (res != null)
{
foreach (var invoice in res.GetInvoicesResponse?.Data ?? [])
{
Console.WriteLine($"{invoice.Number}: {invoice.Total}");
}
res = await res.Next!();
}Error Handling
错误处理
csharp
using ApideckUnifySdk.Models.Errors;
try
{
var res = await sdk.Crm.Contacts.GetAsync(new CrmContactsOneRequest { Id = "invalid" });
}
catch (BadRequestResponse e)
{
Console.Error.WriteLine($"Bad request: {e.Message}");
}
catch (UnauthorizedResponse e)
{
Console.Error.WriteLine("Invalid API key or missing credentials");
}
catch (NotFoundResponse e)
{
Console.Error.WriteLine("Record not found");
}
catch (PaymentRequiredResponse e)
{
Console.Error.WriteLine("API limit reached");
}
catch (UnprocessableResponse e)
{
Console.Error.WriteLine($"Validation error: {e.Message}");
}
catch (BaseException e)
{
Console.Error.WriteLine($"API error: {e.Message}");
Console.Error.WriteLine($"Status: {e.Response.StatusCode}");
}csharp
using ApideckUnifySdk.Models.Errors;
try
{
var res = await sdk.Crm.Contacts.GetAsync(new CrmContactsOneRequest { Id = "invalid" });
}
catch (BadRequestResponse e)
{
Console.Error.WriteLine($"请求错误: {e.Message}");
}
catch (UnauthorizedResponse e)
{
Console.Error.WriteLine("API密钥无效或凭据缺失");
}
catch (NotFoundResponse e)
{
Console.Error.WriteLine("记录未找到");
}
catch (PaymentRequiredResponse e)
{
Console.Error.WriteLine("API调用额度已耗尽");
}
catch (UnprocessableResponse e)
{
Console.Error.WriteLine($"验证错误: {e.Message}");
}
catch (BaseException e)
{
Console.Error.WriteLine($"API错误: {e.Message}");
Console.Error.WriteLine($"状态码: {e.Response.StatusCode}");
}Retry Configuration
重试配置
csharp
var sdk = new Apideck(
retryConfig: new RetryConfig(
strategy: RetryConfig.RetryStrategy.BACKOFF,
backoff: new BackoffStrategy(
initialIntervalMs: 1L,
maxIntervalMs: 50L,
maxElapsedTimeMs: 100L,
exponent: 1.1
),
retryConnectionErrors: false
),
consumerId: "your-consumer-id",
appId: "your-app-id",
apiKey: Environment.GetEnvironmentVariable("APIDECK_API_KEY") ?? ""
);csharp
var sdk = new Apideck(
retryConfig: new RetryConfig(
strategy: RetryConfig.RetryStrategy.BACKOFF,
backoff: new BackoffStrategy(
initialIntervalMs: 1L,
maxIntervalMs: 50L,
maxElapsedTimeMs: 100L,
exponent: 1.1
),
retryConnectionErrors: false
),
consumerId: "your-consumer-id",
appId: "your-app-id",
apiKey: Environment.GetEnvironmentVariable("APIDECK_API_KEY") ?? ""
);API Namespaces
API 命名空间
| Namespace | Resources |
|---|---|
| Invoices, Bills, Payments, Customers, Suppliers, LedgerAccounts, JournalEntries, TaxRates, CreditNotes, PurchaseOrders, BalanceSheet, ProfitAndLoss, and more |
| Contacts, Companies, Leads, Opportunities, Activities, Notes, Pipelines, Users |
| Employees, Companies, Departments, Payrolls, TimeOffRequests |
| Files, Folders, Drives, DriveGroups, SharedLinks, UploadSessions |
| Applicants, Applications, Jobs |
| Connections, Consumers, Sessions, CustomMappings, Logs |
| Webhooks, EventLogs |
| 命名空间 | 资源 |
|---|---|
| 发票、账单、付款、客户、供应商、分类账账户、日记账分录、税率、贷项通知单、采购订单、资产负债表、损益表等 |
| 联系人、公司、销售线索、销售机会、活动、备注、销售漏斗、用户 |
| 员工、公司、部门、工资单、休假申请 |
| 文件、文件夹、驱动器、驱动器组、共享链接、上传会话 |
| 申请人、申请记录、职位 |
| 连接、消费者、会话、自定义映射、日志 |
| Webhook、事件日志 |