{"id":"c811d577-42a6-4578-9754-206d7262a957","shortId":"MEKwRu","kind":"skill","title":"dotnet-backend","tagline":"Build ASP.NET Core 8+ backend services with EF Core, auth, background jobs, and production API patterns.","description":"# .NET Backend Agent - ASP.NET Core & Enterprise API Expert\n\nYou are an expert .NET/C# backend developer with 8+ years of experience building enterprise-grade APIs and services.\n\n## When to Use\nUse this skill when the user asks to:\n\n- Build or refactor ASP.NET Core APIs (controller-based or Minimal APIs)\n- Implement authentication/authorization in a .NET backend\n- Design or optimize EF Core data access patterns\n- Add background workers, scheduled jobs, or integration services in C#\n- Improve reliability/performance of a .NET backend service\n\n## Your Expertise\n\n- **Frameworks**: ASP.NET Core 8+, Minimal APIs, Web API\n- **ORM**: Entity Framework Core 8+, Dapper\n- **Databases**: SQL Server, PostgreSQL, MySQL\n- **Authentication**: ASP.NET Core Identity, JWT, OAuth 2.0, Azure AD\n- **Authorization**: Policy-based, role-based, claims-based\n- **API Patterns**: RESTful, gRPC, GraphQL (HotChocolate)\n- **Background**: IHostedService, BackgroundService, Hangfire\n- **Real-time**: SignalR\n- **Testing**: xUnit, NUnit, Moq, FluentAssertions\n- **Dependency Injection**: Built-in DI container\n- **Validation**: FluentValidation, Data Annotations\n\n## Your Responsibilities\n\n1. **Build ASP.NET Core APIs**\n   - RESTful controllers or Minimal APIs\n   - Model validation\n   - Exception handling middleware\n   - CORS configuration\n   - Response compression\n\n2. **Entity Framework Core**\n   - DbContext configuration\n   - Code-first migrations\n   - Query optimization\n   - Include/ThenInclude for eager loading\n   - AsNoTracking for read-only queries\n\n3. **Authentication & Authorization**\n   - JWT token generation/validation\n   - ASP.NET Core Identity integration\n   - Policy-based authorization\n   - Custom authorization handlers\n\n4. **Background Services**\n   - IHostedService for long-running tasks\n   - Scoped services in background workers\n   - Scheduled jobs with Hangfire/Quartz.NET\n\n5. **Performance**\n   - Async/await throughout\n   - Connection pooling\n   - Response caching\n   - Output caching (.NET 8+)\n\n## Code Patterns You Follow\n\n### Minimal API with EF Core\n```csharp\nusing Microsoft.EntityFrameworkCore;\n\nvar builder = WebApplication.CreateBuilder(args);\n\n// Services\nbuilder.Services.AddDbContext<AppDbContext>(options =>\n    options.UseNpgsql(builder.Configuration.GetConnectionString(\"DefaultConnection\")));\n\nbuilder.Services.AddAuthentication().AddJwtBearer();\nbuilder.Services.AddAuthorization();\n\nvar app = builder.Build();\n\n// Create user endpoint\napp.MapPost(\"/api/users\", async (CreateUserRequest request, AppDbContext db) =>\n{\n    // Validate\n    if (string.IsNullOrEmpty(request.Email))\n        return Results.BadRequest(\"Email is required\");\n\n    // Hash password\n    var hashedPassword = BCrypt.Net.BCrypt.HashPassword(request.Password);\n\n    // Create user\n    var user = new User\n    {\n        Email = request.Email,\n        PasswordHash = hashedPassword,\n        Name = request.Name\n    };\n\n    db.Users.Add(user);\n    await db.SaveChangesAsync();\n\n    return Results.Created($\"/api/users/{user.Id}\", new UserResponse(user));\n})\n.WithName(\"CreateUser\")\n.WithOpenApi();\n\napp.Run();\n\nrecord CreateUserRequest(string Email, string Password, string Name);\nrecord UserResponse(int Id, string Email, string Name);\n```\n\n### Controller-based API\n```csharp\n[ApiController]\n[Route(\"api/[controller]\")]\npublic class UsersController : ControllerBase\n{\n    private readonly AppDbContext _db;\n    private readonly ILogger<UsersController> _logger;\n\n    public UsersController(AppDbContext db, ILogger<UsersController> logger)\n    {\n        _db = db;\n        _logger = logger;\n    }\n\n    [HttpGet]\n    public async Task<ActionResult<List<UserDto>>> GetUsers()\n    {\n        var users = await _db.Users\n            .AsNoTracking()\n            .Select(u => new UserDto(u.Id, u.Email, u.Name))\n            .ToListAsync();\n\n        return Ok(users);\n    }\n\n    [HttpPost]\n    public async Task<ActionResult<UserDto>> CreateUser(CreateUserDto dto)\n    {\n        var user = new User\n        {\n            Email = dto.Email,\n            PasswordHash = BCrypt.Net.BCrypt.HashPassword(dto.Password),\n            Name = dto.Name\n        };\n\n        _db.Users.Add(user);\n        await _db.SaveChangesAsync();\n\n        return CreatedAtAction(nameof(GetUser), new { id = user.Id }, new UserDto(user));\n    }\n}\n```\n\n### JWT Authentication\n```csharp\nusing Microsoft.IdentityModel.Tokens;\nusing System.IdentityModel.Tokens.Jwt;\nusing System.Security.Claims;\nusing System.Text;\n\npublic class TokenService\n{\n    private readonly IConfiguration _config;\n\n    public TokenService(IConfiguration config) => _config = config;\n\n    public string GenerateToken(User user)\n    {\n        var key = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(_config[\"Jwt:Key\"]!));\n        var credentials = new SigningCredentials(key, SecurityAlgorithms.HmacSha256);\n\n        var claims = new[]\n        {\n            new Claim(ClaimTypes.NameIdentifier, user.Id.ToString()),\n            new Claim(ClaimTypes.Email, user.Email),\n            new Claim(ClaimTypes.Name, user.Name)\n        };\n\n        var token = new JwtSecurityToken(\n            issuer: _config[\"Jwt:Issuer\"],\n            audience: _config[\"Jwt:Audience\"],\n            claims: claims,\n            expires: DateTime.UtcNow.AddHours(1),\n            signingCredentials: credentials\n        );\n\n        return new JwtSecurityTokenHandler().WriteToken(token);\n    }\n}\n```\n\n### Background Service\n```csharp\npublic class EmailSenderService : BackgroundService\n{\n    private readonly ILogger<EmailSenderService> _logger;\n    private readonly IServiceProvider _services;\n\n    public EmailSenderService(ILogger<EmailSenderService> logger, IServiceProvider services)\n    {\n        _logger = logger;\n        _services = services;\n    }\n\n    protected override async Task ExecuteAsync(CancellationToken stoppingToken)\n    {\n        while (!stoppingToken.IsCancellationRequested)\n        {\n            using var scope = _services.CreateScope();\n            var db = scope.ServiceProvider.GetRequiredService<AppDbContext>();\n\n            var pendingEmails = await db.PendingEmails\n                .Where(e => !e.Sent)\n                .Take(10)\n                .ToListAsync(stoppingToken);\n\n            foreach (var email in pendingEmails)\n            {\n                await SendEmailAsync(email);\n                email.Sent = true;\n            }\n\n            await db.SaveChangesAsync(stoppingToken);\n            await Task.Delay(TimeSpan.FromMinutes(1), stoppingToken);\n        }\n    }\n\n    private async Task SendEmailAsync(PendingEmail email)\n    {\n        // Send email logic\n        _logger.LogInformation(\"Sending email to {Email}\", email.To);\n    }\n}\n```\n\n## Best Practices You Follow\n\n- ✅ Async/await for all I/O operations\n- ✅ Dependency Injection for all services\n- ✅ appsettings.json for configuration\n- ✅ User Secrets for local development\n- ✅ Entity Framework migrations (Add-Migration, Update-Database)\n- ✅ Global exception handling middleware\n- ✅ FluentValidation for complex validation\n- ✅ Serilog for structured logging\n- ✅ Health checks (AddHealthChecks)\n- ✅ API versioning\n- ✅ Swagger/OpenAPI documentation\n- ✅ AutoMapper for DTO mapping\n- ✅ CQRS with MediatR (for complex domains)\n\n## Limitations\n\n- Assumes modern .NET (ASP.NET Core 8+); older .NET Framework projects may require different patterns.\n- Does not cover client-side/frontend implementations.\n- Cloud-provider-specific deployment details (Azure/AWS/GCP) are out of scope unless explicitly requested.","tags":["dotnet","backend","antigravity","awesome","skills","sickn33","agent-skills","agentic-skills","ai-agent-skills","ai-agents","ai-coding","ai-workflows"],"capabilities":["skill","source-sickn33","skill-dotnet-backend","topic-agent-skills","topic-agentic-skills","topic-ai-agent-skills","topic-ai-agents","topic-ai-coding","topic-ai-workflows","topic-antigravity","topic-antigravity-skills","topic-claude-code","topic-claude-code-skills","topic-codex-cli","topic-codex-skills"],"categories":["antigravity-awesome-skills"],"synonyms":[],"warnings":[],"endpointUrl":"https://skills.sh/sickn33/antigravity-awesome-skills/dotnet-backend","protocol":"skill","transport":"skills-sh","auth":{"type":"none","details":{"cli":"npx skills add sickn33/antigravity-awesome-skills","source_repo":"https://github.com/sickn33/antigravity-awesome-skills","install_from":"skills.sh"}},"qualityScore":"0.700","qualityRationale":"deterministic score 0.70 from registry signals: · indexed on github topic:agent-skills · 34831 github stars · SKILL.md body (7,506 chars)","verified":false,"liveness":"unknown","lastLivenessCheck":null,"agentReviews":{"count":0,"score_avg":null,"cost_usd_avg":null,"success_rate":null,"latency_p50_ms":null,"narrative_summary":null,"summary_updated_at":null},"enrichmentModel":"deterministic:skill-github:v1","enrichmentVersion":1,"enrichedAt":"2026-04-24T06:51:06.084Z","embedding":null,"createdAt":"2026-04-18T21:36:21.966Z","updatedAt":"2026-04-24T06:51:06.084Z","lastSeenAt":"2026-04-24T06:51:06.084Z","tsv":"'/api/users':293,332 '/frontend':692 '1':173,518,594 '10':575 '2':192 '2.0':128 '3':214 '4':231 '5':249 '8':7,36,106,115,260,677 'access':82 'actionresult':392,415 'ad':130 'add':84,637 'add-migr':636 'addhealthcheck':656 'addjwtbear':284 'agent':22 'annot':170 'api':18,26,44,63,69,108,110,141,177,182,266,360,364,657 'apicontrol':362 'app':287 'app.mappost':292 'app.run':340 'appdbcontext':297,372,380 'appsettings.json':625 'arg':276 'ask':56 'asnotrack':208,399 'asp.net':5,23,61,104,123,175,220,675 'assum':672 'async':294,390,413,553,597 'async/await':251,615 'audienc':510,513 'auth':13 'authent':122,215,445 'authentication/authorization':71 'author':131,216,227,229 'automapp':661 'await':328,397,432,569,583,588,591 'azur':129 'azure/aws/gcp':700 'backend':3,8,21,33,75,99 'background':14,85,147,232,243,526 'backgroundservic':149,532 'base':66,134,137,140,226,359 'bcrypt.net.bcrypt.hashpassword':312,426 'best':611 'build':4,40,58,174 'builder':274 'builder.build':288 'builder.configuration.getconnectionstring':281 'builder.services.addauthentication':283 'builder.services.addauthorization':285 'builder.services.adddbcontext':278 'built':163 'built-in':162 'c':93 'cach':256,258 'cancellationtoken':556 'check':655 'claim':139,488,491,495,499,514,515 'claims-bas':138 'claimtypes.email':496 'claimtypes.name':500 'claimtypes.nameidentifier':492 'class':367,456,530 'client':690 'client-sid':689 'cloud':695 'cloud-provider-specif':694 'code':199,261 'code-first':198 'complex':648,669 'compress':191 'config':461,465,466,467,478,507,511 'configur':189,197,627 'connect':253 'contain':166 'control':65,179,358,365 'controller-bas':64,357 'controllerbas':369 'cor':188 'core':6,12,24,62,80,105,114,124,176,195,221,269,676 'cover':688 'cqrs':665 'creat':289,314 'createdatact':435 'createus':338,416 'createuserdto':417 'createuserrequest':295,342 'credenti':482,520 'csharp':270,361,446,528 'custom':228 'dapper':116 'data':81,169 'databas':117,641 'datetime.utcnow.addhours':517 'db':298,373,381,384,385,565 'db.pendingemails':570 'db.savechangesasync':329,433,589 'db.users':398 'db.users.add':326,430 'dbcontext':196 'defaultconnect':282 'depend':160,620 'deploy':698 'design':76 'detail':699 'develop':34,632 'di':165 'differ':684 'document':660 'domain':670 'dotnet':2 'dotnet-backend':1 'dto':418,663 'dto.email':424 'dto.name':429 'dto.password':427 'e':572 'e.sent':573 'eager':206 'ef':11,79,268 'email':305,320,344,354,423,580,585,601,603,607,609 'email.sent':586 'email.to':610 'emailsenderservic':531,542 'encoding.utf8.getbytes':477 'endpoint':291 'enterpris':25,42 'enterprise-grad':41 'entiti':112,193,633 'except':185,643 'executeasync':555 'experi':39 'expert':27,31 'expertis':102 'expir':516 'explicit':706 'first':200 'fluentassert':159 'fluentvalid':168,646 'follow':264,614 'foreach':578 'framework':103,113,194,634,680 'generatetoken':470 'generation/validation':219 'getus':394,437 'global':642 'grade':43 'graphql':145 'grpc':144 'handl':186,644 'handler':230 'hangfir':150 'hangfire/quartz.net':248 'hash':308 'hashedpassword':311,323 'health':654 'hotchocol':146 'httpget':388 'httppost':411 'i/o':618 'iconfigur':460,464 'id':352,439 'ident':125,222 'ihostedservic':148,234 'ilogg':376,382,535,543 'implement':70,693 'improv':94 'include/theninclude':204 'inject':161,621 'int':351 'integr':90,223 'iserviceprovid':539,545 'issuer':506,509 'job':15,88,246 'jwt':126,217,444,479,508,512 'jwtsecuritytoken':505 'jwtsecuritytokenhandl':523 'key':474,480,485 'limit':671 'list':393 'load':207 'local':631 'log':653 'logger':377,383,386,387,536,544,547,548 'logger.loginformation':605 'logic':604 'long':237 'long-run':236 'map':664 'may':682 'mediatr':667 'microsoft.entityframeworkcore':272 'microsoft.identitymodel.tokens':448 'middlewar':187,645 'migrat':201,635,638 'minim':68,107,181,265 'model':183 'modern':673 'moq':158 'mysql':121 'name':324,348,356,428 'nameof':436 'net':20,74,98,259,674,679 'net/c':32 'new':318,334,402,421,438,441,475,483,489,490,494,498,504,522 'nunit':157 'oauth':127 'ok':409 'older':678 'oper':619 'optim':78,203 'option':279 'options.usenpgsql':280 'orm':111 'output':257 'overrid':552 'password':309,346 'passwordhash':322,425 'pattern':19,83,142,262,685 'pendingemail':568,582,600 'perform':250 'polici':133,225 'policy-bas':132,224 'pool':254 'postgresql':120 'practic':612 'privat':370,374,458,533,537,596 'product':17 'project':681 'protect':551 'provid':696 'public':366,378,389,412,455,462,468,529,541 'queri':202,213 'read':211 'read-on':210 'readon':371,375,459,534,538 'real':152 'real-tim':151 'record':341,349 'refactor':60 'reliability/performance':95 'request':296,707 'request.email':302,321 'request.name':325 'request.password':313 'requir':307,683 'respons':172,190,255 'rest':143,178 'results.badrequest':304 'results.created':331 'return':303,330,408,434,521 'role':136 'role-bas':135 'rout':363 'run':238 'schedul':87,245 'scope':240,562,704 'scope.serviceprovider.getrequiredservice':566 'secret':629 'securityalgorithms.hmacsha256':486 'select':400 'send':602,606 'sendemailasync':584,599 'serilog':650 'server':119 'servic':9,46,91,100,233,241,277,527,540,546,549,550,624 'services.createscope':563 'side':691 'signalr':154 'signingcredenti':484,519 'skill':52 'skill-dotnet-backend' 'source-sickn33' 'specif':697 'sql':118 'stoppingtoken':557,577,590,595 'stoppingtoken.iscancellationrequested':559 'string':343,345,347,353,355,469 'string.isnullorempty':301 'structur':652 'swagger/openapi':659 'symmetricsecuritykey':476 'system.identitymodel.tokens.jwt':450 'system.security.claims':452 'system.text':454 'take':574 'task':239,391,414,554,598 'task.delay':592 'test':155 'throughout':252 'time':153 'timespan.fromminutes':593 'token':218,503,525 'tokenservic':457,463 'tolistasync':407,576 'topic-agent-skills' 'topic-agentic-skills' 'topic-ai-agent-skills' 'topic-ai-agents' 'topic-ai-coding' 'topic-ai-workflows' 'topic-antigravity' 'topic-antigravity-skills' 'topic-claude-code' 'topic-claude-code-skills' 'topic-codex-cli' 'topic-codex-skills' 'true':587 'u':401 'u.email':405 'u.id':404 'u.name':406 'unless':705 'updat':640 'update-databas':639 'use':49,50,271,447,449,451,453,560 'user':55,290,315,317,319,327,336,396,410,420,422,431,443,471,472,628 'user.email':497 'user.id':333,440 'user.id.tostring':493 'user.name':501 'userdto':403,442 'userrespons':335,350 'userscontrol':368,379 'valid':167,184,299,649 'var':273,286,310,316,395,419,473,481,487,502,561,564,567,579 'version':658 'web':109 'webapplication.createbuilder':275 'withnam':337 'withopenapi':339 'worker':86,244 'writetoken':524 'xunit':156 'year':37","prices":[{"id":"3b67c6c1-c4e9-42b7-8643-3d9d2a5dac86","listingId":"c811d577-42a6-4578-9754-206d7262a957","amountUsd":"0","unit":"free","nativeCurrency":null,"nativeAmount":null,"chain":null,"payTo":null,"paymentMethod":"skill-free","isPrimary":true,"details":{"org":"sickn33","category":"antigravity-awesome-skills","install_from":"skills.sh"},"createdAt":"2026-04-18T21:36:21.966Z"}],"sources":[{"listingId":"c811d577-42a6-4578-9754-206d7262a957","source":"github","sourceId":"sickn33/antigravity-awesome-skills/dotnet-backend","sourceUrl":"https://github.com/sickn33/antigravity-awesome-skills/tree/main/skills/dotnet-backend","isPrimary":false,"firstSeenAt":"2026-04-18T21:36:21.966Z","lastSeenAt":"2026-04-24T06:51:06.084Z"}],"details":{"listingId":"c811d577-42a6-4578-9754-206d7262a957","quickStartSnippet":null,"exampleRequest":null,"exampleResponse":null,"schema":null,"openapiUrl":null,"agentsTxtUrl":null,"citations":[],"useCases":[],"bestFor":[],"notFor":[],"kindDetails":{"org":"sickn33","slug":"dotnet-backend","github":{"repo":"sickn33/antigravity-awesome-skills","stars":34831,"topics":["agent-skills","agentic-skills","ai-agent-skills","ai-agents","ai-coding","ai-workflows","antigravity","antigravity-skills","claude-code","claude-code-skills","codex-cli","codex-skills","cursor","cursor-skills","developer-tools","gemini-cli","gemini-skills","kiro","mcp","skill-library"],"license":"mit","html_url":"https://github.com/sickn33/antigravity-awesome-skills","pushed_at":"2026-04-24T06:41:17Z","description":"Installable GitHub library of 1,400+ agentic skills for Claude Code, Cursor, Codex CLI, Gemini CLI, Antigravity, and more. Includes installer CLI, bundles, workflows, and official/community skill collections.","skill_md_sha":"59ea991225a9704ac66ec7677c0464fd9e49d6ef","skill_md_path":"skills/dotnet-backend/SKILL.md","default_branch":"main","skill_tree_url":"https://github.com/sickn33/antigravity-awesome-skills/tree/main/skills/dotnet-backend"},"layout":"multi","source":"github","category":"antigravity-awesome-skills","frontmatter":{"name":"dotnet-backend","description":"Build ASP.NET Core 8+ backend services with EF Core, auth, background jobs, and production API patterns."},"skills_sh_url":"https://skills.sh/sickn33/antigravity-awesome-skills/dotnet-backend"},"updatedAt":"2026-04-24T06:51:06.084Z"}}