skills/dotnet/templates/create-api-adapter-skill/SKILL.md
Create adapter structure for integrating third-party APIs in Clean Architecture applications. Use when: - Integrating external APIs or services - Creating HTTP client adapters for third-party services - Implementing API integration with error handling - Setting up adapter pattern for external dependencies - Building resilient external service integrations Triggers: "api adapter", "third-party api", "external service", "http client adapter", "api integration"
npx skillsauth add yeeehaooo/WorkSpace create-api-adapterInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Create adapter structure for integrating third-party APIs.
Applies to:
Interface (Application Layer):
public interface I{ProviderName}Service
{
Task<Result<{ResponseType}>> ExecuteAsync({RequestType} request, CancellationToken ct = default);
}
Implementation (Infrastructure Layer):
public class {ProviderName}Service : I{ProviderName}Service
{
private readonly HttpClient _httpClient;
private readonly IRetryPolicy _retryPolicy;
private readonly ILogger<{ProviderName}Service> _logger;
public {ProviderName}Service(
HttpClient httpClient,
IRetryPolicy retryPolicy,
ILogger<{ProviderName}Service> logger)
{
_httpClient = httpClient;
_retryPolicy = retryPolicy;
_logger = logger;
}
public async Task<Result<{ResponseType}>> ExecuteAsync({RequestType} request, CancellationToken ct = default)
{
return await _retryPolicy.ExecuteAsync(async () =>
{
var response = await _httpClient.PostAsJsonAsync("endpoint", request, ct);
response.EnsureSuccessStatusCode();
var content = await response.Content.ReadFromJsonAsync<{ResponseType}>(ct);
return Result<{ResponseType}>.Success(content!);
}, ct);
}
}
DI Registration:
services.AddHttpClient<I{ProviderName}Service, {ProviderName}Service>(client =>
{
client.BaseAddress = new Uri(configuration["{ProviderName}:BaseUrl"]);
client.Timeout = TimeSpan.FromSeconds(30);
});
development
Create reusable .NET atomic capability code snippets that can be directly copied and pasted. Use when: - Creating single-purpose code snippets - Building reusable code templates - Implementing atomic technical capabilities - Creating copy-pasteable code blocks - Building snippet library for common patterns Triggers: "create snippet", "code snippet", "reusable snippet", "atomic snippet", "copy-paste code"
development
Create Docker Compose configuration for containerized .NET application development and deployment. Use when: - Containerizing .NET applications - Setting up local development environment with dependencies - Creating multi-container setups (API + DB + Redis) - Defining service dependencies and networking - Building docker-compose.yml for development or production Triggers: "docker compose", "containerize", "multi-container", "docker-compose.yml", "docker setup"
development
Enterprise backend structure built on Clean Architecture, DDD, CQRS, and Vertical Slice API Design with Dapper-first persistence. Use when: - Creating new enterprise backend projects - Implementing Clean Architecture with DDD and CQRS - Building vertical slice API endpoints - Using Dapper as primary persistence mechanism - Organizing modules by UseCase-driven and Model-driven separation Triggers: "dmis structure", "clean architecture", "enterprise backend", "DDD CQRS", "vertical slice", "dapper"
development
Layered architecture with vertical slice organization following Clean Architecture principles. Use when: - Creating new .NET backend projects requiring strict layer separation - Building applications with Clean Architecture principles - Implementing vertical slice API organization - Projects requiring framework-agnostic domain layer - Applications that need CQRS support Triggers: "clean architecture", "layered architecture", "vertical slice", "clean structure", "layer separation"