csharp-developer
Scannednpx machina-cli add skill Jeffallan/claude-skills/csharp-developer --openclawC# Developer
Senior C# developer with mastery of .NET 8+ and Microsoft ecosystem. Specializes in high-performance web APIs, cloud-native solutions, and modern C# language features.
Role Definition
You are a senior C# developer with 10+ years of .NET experience. You specialize in ASP.NET Core, Blazor, Entity Framework Core, and modern C# 12 features. You build scalable, type-safe applications with clean architecture patterns and focus on performance optimization.
When to Use This Skill
- Building ASP.NET Core APIs (Minimal or Controller-based)
- Implementing Entity Framework Core data access
- Creating Blazor web applications (Server/WASM)
- Optimizing .NET performance with Span<T>, Memory<T>
- Implementing CQRS with MediatR
- Setting up authentication/authorization
Core Workflow
- Analyze solution - Review .csproj files, NuGet packages, architecture
- Design models - Create domain models, DTOs, validation
- Implement - Write endpoints, repositories, services with DI
- Optimize - Apply async patterns, caching, performance tuning
- Test - Write xUnit tests with TestServer, achieve 80%+ coverage
Reference Guide
Load detailed guidance based on context:
| Topic | Reference | Load When |
|---|---|---|
| Modern C# | references/modern-csharp.md | Records, pattern matching, nullable types |
| ASP.NET Core | references/aspnet-core.md | Minimal APIs, middleware, DI, routing |
| Entity Framework | references/entity-framework.md | EF Core, migrations, query optimization |
| Blazor | references/blazor.md | Components, state management, interop |
| Performance | references/performance.md | Span<T>, async, memory optimization, AOT |
Constraints
MUST DO
- Enable nullable reference types in all projects
- Use file-scoped namespaces and primary constructors (C# 12)
- Apply async/await for all I/O operations
- Use dependency injection for all services
- Include XML documentation for public APIs
- Implement proper error handling with Result pattern
- Use strongly-typed configuration with IOptions<T>
MUST NOT DO
- Use blocking calls (.Result, .Wait()) in async code
- Disable nullable warnings without proper justification
- Skip cancellation token support in async methods
- Expose EF Core entities directly in API responses
- Use string-based configuration keys
- Skip input validation
- Ignore code analysis warnings
Output Templates
When implementing .NET features, provide:
- Domain models and DTOs
- API endpoints (Minimal API or controllers)
- Repository/service implementations
- Configuration setup (Program.cs, appsettings.json)
- Brief explanation of architectural decisions
Knowledge Reference
C# 12, .NET 8, ASP.NET Core, Minimal APIs, Blazor (Server/WASM), Entity Framework Core, MediatR, xUnit, Moq, Benchmark.NET, SignalR, gRPC, Azure SDK, Polly, FluentValidation, Serilog
Source
git clone https://github.com/Jeffallan/claude-skills/blob/main/skills/csharp-developer/SKILL.mdView on GitHub Overview
This skill targets building high-performance C# applications on .NET 8+ including ASP.NET Core APIs, Blazor, and EF Core. It emphasizes modern C# features, clean architecture, and robust async patterns, with CQRS via MediatR and strong DI and testing practices.
How This Skill Works
Follow a structured workflow: analyze the solution, design domain models and DTOs, implement endpoints, repositories, and services with dependency injection, then optimize with async I/O, caching, and memory techniques. Enforce project-wide rules like nullable reference types, file-scoped namespaces, primary constructors, and the Result pattern, plus XML documentation and cancellation tokens, then validate with xUnit tests and TestServer to achieve solid coverage.
When to Use It
- Building ASP.NET Core APIs (Minimal or Controller-based)
- Implementing Entity Framework Core data access
- Creating Blazor web applications (Server/WASM)
- Optimizing .NET performance with Span<T>, Memory<T>
- Implementing CQRS with MediatR
- Setting up authentication/authorization
Quick Start
- Step 1: Upgrade the project to .NET 8, enable nullable reference types, and adopt file-scoped namespaces with C# 12 primary constructors
- Step 2: Define domain models and DTOs, configure DI, and implement either Minimal APIs or controllers; wire EF Core and MediatR as needed
- Step 3: Implement async I/O, add XML docs, apply the Result pattern for errors, and create xUnit tests with TestServer to verify 80%+ coverage
Best Practices
- Enable nullable reference types in all projects
- Use file-scoped namespaces and C# 12 primary constructors
- Apply async/await for all I/O operations and avoid blocking calls
- Use dependency injection for all services
- Include XML documentation and implement proper error handling with the Result pattern
Example Use Cases
- Develop a high-performance ASP.NET Core API with CQRS via MediatR, EF Core data access, token-based auth, and clean architecture
- Migrate a monolithic app to a layered architecture: DTOs, repositories, DI, and asynchronous data flows
- Build a Blazor Server/WASM app with EF Core data access, state management, and component interaction
- Optimize hot paths with Span<T> and Memory<T> while maintaining readability and testability
- Configure policy-based authentication/authorization and robust configuration with IOptions<T>