This commit is contained in:
Fernando Araoz 2025-01-10 17:01:50 -05:00
commit 975c42762c
10 changed files with 179 additions and 0 deletions

39
.gitignore vendored Normal file
View File

@ -0,0 +1,39 @@
# Binary garbage
[Bb]in/
[Oo]bj/
# IDE trash
.vs/
.idea/
*.user
*.userosscache
*.sln.docstates
*.suo
# That stupid Windows file
*.DS_Store
Thumbs.db
# Rider's mess
.idea/
*.sln.iml
.idea/**/workspace.xml
# ASP.NET's "secrets" (as if anything Microsoft makes could be secure)
appsettings.*.json
!appsettings.json
!appsettings.Example.json
# MSBuild junk
*.dbmdl
*.jfm
*.pfx
*.publishsettings
# NuGet waste (because apparently one package manager wasn't enough)
*.nupkg
**/packages/*
!**/packages/build/
*.nuget.props
*.nuget.targets

View File

@ -0,0 +1,32 @@
using Microsoft.AspNetCore.Mvc;
namespace csharp.Controllers;
[ApiController]
[Route("[controller]")]
public class WeatherForecastController : ControllerBase
{
private static readonly string[] Summaries = new[]
{
"Freezing", "Bracing", "Chilly", "Cool", "Mild", "Warm", "Balmy", "Hot", "Sweltering", "Scorching"
};
private readonly ILogger<WeatherForecastController> _logger;
public WeatherForecastController(ILogger<WeatherForecastController> logger)
{
_logger = logger;
}
[HttpGet(Name = "GetWeatherForecast")]
public IEnumerable<WeatherForecast> Get()
{
return Enumerable.Range(1, 5).Select(index => new WeatherForecast
{
Date = DateOnly.FromDateTime(DateTime.Now.AddDays(index)),
TemperatureC = Random.Shared.Next(-20, 55),
Summary = Summaries[Random.Shared.Next(Summaries.Length)]
})
.ToArray();
}
}

10
Dockerfile Normal file
View File

@ -0,0 +1,10 @@
FROM mcr.microsoft.com/dotnet/sdk:9.0
WORKDIR /app
# Set ASP.NET to actually listen on all interfaces, not just localhost
ENV ASPNETCORE_URLS=http://+:5266
# Allow non-HTTPS because it's just development, who cares
ENV ASPNETCORE_ENVIRONMENT=Development
ENTRYPOINT ["dotnet", "watch", "run", "--no-launch-profile"]

23
Program.cs Normal file
View File

@ -0,0 +1,23 @@
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddControllers();
// Learn more about configuring OpenAPI at https://aka.ms/aspnet/openapi
builder.Services.AddOpenApi();
var app = builder.Build();
// Configure the HTTP request pipeline.
if (app.Environment.IsDevelopment())
{
app.MapOpenApi();
}
app.UseHttpsRedirection();
app.UseAuthorization();
app.MapControllers();
app.Run();

View File

@ -0,0 +1,23 @@
{
"$schema": "https://json.schemastore.org/launchsettings.json",
"profiles": {
"http": {
"commandName": "Project",
"dotnetRunMessages": true,
"launchBrowser": false,
"applicationUrl": "http://localhost:5266",
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development"
}
},
"https": {
"commandName": "Project",
"dotnetRunMessages": true,
"launchBrowser": false,
"applicationUrl": "https://localhost:7284;http://localhost:5266",
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development"
}
}
}
}

12
WeatherForecast.cs Normal file
View File

@ -0,0 +1,12 @@
namespace csharp;
public class WeatherForecast
{
public DateOnly Date { get; set; }
public int TemperatureC { get; set; }
public int TemperatureF => 32 + (int)(TemperatureC / 0.5556);
public string? Summary { get; set; }
}

9
appsettings.json Normal file
View File

@ -0,0 +1,9 @@
{
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft.AspNetCore": "Warning"
}
},
"AllowedHosts": "*"
}

13
csharp.csproj Normal file
View File

@ -0,0 +1,13 @@
<Project Sdk="Microsoft.NET.Sdk.Web">
<PropertyGroup>
<TargetFramework>net9.0</TargetFramework>
<Nullable>enable</Nullable>
<ImplicitUsings>enable</ImplicitUsings>
</PropertyGroup>
<ItemGroup>
<PackageReference Include="Microsoft.AspNetCore.OpenApi" Version="9.0.0" />
</ItemGroup>
</Project>

6
csharp.http Normal file
View File

@ -0,0 +1,6 @@
@csharp_HostAddress = http://localhost:5266
GET {{csharp_HostAddress}}/weatherforecast/
Accept: application/json
###

12
docker-compose.yml Normal file
View File

@ -0,0 +1,12 @@
services:
aspnet-prison:
container_name: aspnet-prison
user: "1001:1001"
build:
context: .
dockerfile: Dockerfile
ports:
- "5266:5266"
volumes:
- ./:/app