This commit is contained in:
2024-02-20 17:15:27 +08:00
committed by huty
parent 6706e1a633
commit 34158042ad
1529 changed files with 177765 additions and 0 deletions

View File

@@ -0,0 +1,16 @@
FROM mcr.microsoft.com/dotnet/core/sdk:3.1.301-alpine AS builder
WORKDIR /src
COPY src/LogArchiver.csproj .
RUN dotnet restore
COPY src/ .
RUN dotnet publish -c Release -o /out LogArchiver.csproj
# app image
FROM mcr.microsoft.com/dotnet/core/aspnet:3.1.5-alpine
WORKDIR /app
ENTRYPOINT ["dotnet", "LogArchiver.dll"]
COPY --from=builder /out/ .

View File

@@ -0,0 +1,48 @@
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.Logging;
using System;
using io = System.IO;
namespace LogArchiver.Controllers
{
[ApiController]
[Route("[controller]")]
public class ArchiveController : ControllerBase
{
private readonly IConfiguration _config;
public ArchiveController(IConfiguration config)
{
_config = config;
}
[HttpGet]
public IActionResult Get()
{
var path = _config["Archive:LogFile"];
if (!io.File.Exists(path))
{
return NotFound();
}
var logs = io.File.ReadAllText(path);
Console.WriteLine($"Read logs from: {path}");
try
{
//io.File.Delete(path);
//Console.WriteLine($"Deleted log file: {path}");
io.File.WriteAllText(path, string.Empty);
Console.WriteLine($"Created empty log file: {path}");
}
catch(Exception ex)
{
Console.WriteLine($"Failed to clear log file: {path}; ex: {ex}");
}
return Ok(logs);
}
}
}

View File

@@ -0,0 +1,8 @@
<Project Sdk="Microsoft.NET.Sdk.Web">
<PropertyGroup>
<TargetFramework>netcoreapp3.1</TargetFramework>
</PropertyGroup>
</Project>

View File

@@ -0,0 +1,25 @@

Microsoft Visual Studio Solution File, Format Version 12.00
# Visual Studio Version 16
VisualStudioVersion = 16.0.30309.148
MinimumVisualStudioVersion = 10.0.40219.1
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "LogArchiver", "LogArchiver.csproj", "{57C34318-344F-480E-942C-8F9B899BE808}"
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug|Any CPU = Debug|Any CPU
Release|Any CPU = Release|Any CPU
EndGlobalSection
GlobalSection(ProjectConfigurationPlatforms) = postSolution
{57C34318-344F-480E-942C-8F9B899BE808}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{57C34318-344F-480E-942C-8F9B899BE808}.Debug|Any CPU.Build.0 = Debug|Any CPU
{57C34318-344F-480E-942C-8F9B899BE808}.Release|Any CPU.ActiveCfg = Release|Any CPU
{57C34318-344F-480E-942C-8F9B899BE808}.Release|Any CPU.Build.0 = Release|Any CPU
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
EndGlobalSection
GlobalSection(ExtensibilityGlobals) = postSolution
SolutionGuid = {6EFD9D31-E6FE-493D-AA93-A004BF9B2309}
EndGlobalSection
EndGlobal

View File

@@ -0,0 +1,20 @@
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Hosting;
namespace LogArchiver
{
public class Program
{
public static void Main(string[] args)
{
CreateHostBuilder(args).Build().Run();
}
public static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.ConfigureWebHostDefaults(webBuilder =>
{
webBuilder.UseStartup<Startup>();
});
}
}

View File

@@ -0,0 +1,30 @@
{
"$schema": "http://json.schemastore.org/launchsettings.json",
"iisSettings": {
"windowsAuthentication": false,
"anonymousAuthentication": true,
"iisExpress": {
"applicationUrl": "http://localhost:51568",
"sslPort": 0
}
},
"profiles": {
"IIS Express": {
"commandName": "IISExpress",
"launchBrowser": true,
"launchUrl": "archive",
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development"
}
},
"LogArchiver": {
"commandName": "Project",
"launchBrowser": true,
"launchUrl": "archive",
"applicationUrl": "http://localhost:5000",
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development"
}
}
}
}

View File

@@ -0,0 +1,40 @@
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
namespace LogArchiver
{
public class Startup
{
public Startup(IConfiguration configuration)
{
Configuration = configuration;
}
public IConfiguration Configuration { get; }
// This method gets called by the runtime. Use this method to add services to the container.
public void ConfigureServices(IServiceCollection services)
{
services.AddControllers();
}
// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
app.UseRouting();
app.UseEndpoints(endpoints =>
{
endpoints.MapControllers();
});
}
}
}

View File

@@ -0,0 +1,11 @@
{
"Logging": {
"LogLevel": {
"Default": "Error",
"Microsoft.Hosting.Lifetime" : "Error"
}
},
"Archive": {
"LogFile": "/logs/web-ping.log"
}
}