feat: 移除自动发布功能
#Comment Linux 下权限问题导致无法自动发布脚本成功执行 相关提交 commit:dcef1e4c1aaacb8f6a07a6fdc4abac52afa4657b
This commit is contained in:
parent
951dcd6c14
commit
5f5f2f53e2
|
@ -1,25 +0,0 @@
|
|||
using Bootstrap.Client.Tasks;
|
||||
using Microsoft.AspNetCore.Authorization;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
|
||||
namespace Bootstrap.Client.Controllers.Api
|
||||
{
|
||||
/// <summary>
|
||||
/// 自动发布 WebApi 接口
|
||||
/// </summary>
|
||||
[Route("api/[controller]")]
|
||||
[ApiController]
|
||||
[AllowAnonymous]
|
||||
public class DeployController : ControllerBase
|
||||
{
|
||||
/// <summary>
|
||||
/// 自动发布 webhook 接口
|
||||
/// </summary>
|
||||
/// <param name="args"></param>
|
||||
[HttpPost]
|
||||
public void Post([FromBody]GiteePushEventArgs args)
|
||||
{
|
||||
DeployTaskManager.Add(args);
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,9 +1,7 @@
|
|||
using Bootstrap.Client.DataAccess;
|
||||
using Longbow.Web;
|
||||
using Microsoft.AspNetCore.Authorization;
|
||||
using Microsoft.AspNetCore.Builder;
|
||||
using Microsoft.AspNetCore.Hosting;
|
||||
using Microsoft.AspNetCore.Http;
|
||||
using Microsoft.AspNetCore.HttpOverrides;
|
||||
using Microsoft.AspNetCore.Mvc.Filters;
|
||||
using Microsoft.Extensions.Configuration;
|
||||
|
@ -48,7 +46,6 @@ namespace Bootstrap.Client
|
|||
services.AddBootstrapHttpClient();
|
||||
services.AddIPLocator(DictHelper.ConfigIPLocator);
|
||||
services.AddOnlineUsers();
|
||||
services.AddAutoPublish();
|
||||
services.AddBootstrapAdminAuthentication(Configuration);
|
||||
services.AddAuthorization(options => options.DefaultPolicy = new AuthorizationPolicyBuilder().RequireBootstrapAdminAuthorizate().Build());
|
||||
|
||||
|
|
|
@ -1,21 +0,0 @@
|
|||
using Bootstrap.Client.Tasks;
|
||||
|
||||
namespace Microsoft.Extensions.DependencyInjection
|
||||
{
|
||||
/// <summary>
|
||||
/// 自动发布服务扩展操作类
|
||||
/// </summary>
|
||||
public static class DeployExtensions
|
||||
{
|
||||
/// <summary>
|
||||
/// 注入自动发布到容器内
|
||||
/// </summary>
|
||||
/// <param name="services"></param>
|
||||
/// <returns></returns>
|
||||
public static IServiceCollection AddAutoPublish(this IServiceCollection services)
|
||||
{
|
||||
DeployTaskManager.RegisterServices(services);
|
||||
return services;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,28 +0,0 @@
|
|||
namespace Bootstrap.Client.Tasks
|
||||
{
|
||||
/// <summary>
|
||||
/// 自动发布配置类
|
||||
/// </summary>
|
||||
public class DeployOptions
|
||||
{
|
||||
/// <summary>
|
||||
/// 获得/设置 是否启用自动部署功能
|
||||
/// </summary>
|
||||
public bool Enabled { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// 获得/设置 自动部署脚本文件
|
||||
/// </summary>
|
||||
public string DeployFile { get; set; } = "";
|
||||
|
||||
/// <summary>
|
||||
/// 获得/设置 自动部署分支
|
||||
/// </summary>
|
||||
public string Branch { get; set; } = "release";
|
||||
|
||||
/// <summary>
|
||||
/// 获得/设置 自动部署平台
|
||||
/// </summary>
|
||||
public string OSPlatform { get; set; } = "Windows";
|
||||
}
|
||||
}
|
|
@ -1,115 +0,0 @@
|
|||
using Bootstrap.Client.Controllers.Api;
|
||||
using Microsoft.Extensions.Configuration;
|
||||
using Microsoft.Extensions.DependencyInjection;
|
||||
using Microsoft.Extensions.Logging;
|
||||
using System;
|
||||
using System.Collections.Concurrent;
|
||||
using System.Diagnostics;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Runtime.InteropServices;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace Bootstrap.Client.Tasks
|
||||
{
|
||||
/// <summary>
|
||||
/// 发布任务管理操作类
|
||||
/// </summary>
|
||||
public static class DeployTaskManager
|
||||
{
|
||||
private static BlockingCollection<GiteePushEventArgs> _pool = new BlockingCollection<GiteePushEventArgs>(new ConcurrentQueue<GiteePushEventArgs>());
|
||||
private static IServiceCollection? _services;
|
||||
|
||||
/// <summary>
|
||||
/// IServiceCollection 实例
|
||||
/// </summary>
|
||||
/// <param name="services"></param>
|
||||
internal static void RegisterServices(IServiceCollection services) => _services = services;
|
||||
|
||||
/// <summary>
|
||||
/// 添加自动发布任务到队列中
|
||||
/// </summary>
|
||||
/// <param name="args"></param>
|
||||
public static void Add(GiteePushEventArgs args)
|
||||
{
|
||||
// 判断是否需要自动发布
|
||||
if (_services != null)
|
||||
{
|
||||
var sp = _services.BuildServiceProvider();
|
||||
var config = sp.GetRequiredService<IConfiguration>();
|
||||
var logger = sp.GetRequiredService<ILogger<DeployController>>();
|
||||
var option = config.GetSection<DeployOptions>().Get<DeployOptions>();
|
||||
if (option.Enabled && !string.IsNullOrEmpty(option.DeployFile))
|
||||
{
|
||||
if (!_pool.IsAddingCompleted)
|
||||
{
|
||||
_pool.Add(args);
|
||||
}
|
||||
|
||||
RunAsync(logger, option).ConfigureAwait(false);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private static bool _running;
|
||||
private static object _locker = new object();
|
||||
|
||||
private static async Task RunAsync(ILogger<DeployController> logger, DeployOptions options)
|
||||
{
|
||||
if (!_running)
|
||||
{
|
||||
await Task.Run(() =>
|
||||
{
|
||||
// 线程等待防止多个部署任务同时执行
|
||||
lock (_locker)
|
||||
{
|
||||
if (!_running)
|
||||
{
|
||||
_running = true;
|
||||
while (_pool.TryTake(out var args))
|
||||
{
|
||||
// 分析提交分支
|
||||
if (args.Ref.SpanSplit("/").LastOrDefault().Equals(options.Branch, StringComparison.OrdinalIgnoreCase) && CanDeploy(options.OSPlatform))
|
||||
{
|
||||
// 仅部署配置分支代码
|
||||
Deploy(logger, options.DeployFile);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
_running = false;
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
private static bool CanDeploy(string osPlatform)
|
||||
{
|
||||
var os = OSPlatform.Create(osPlatform);
|
||||
return !RuntimeInformation.IsOSPlatform(os);
|
||||
}
|
||||
|
||||
private static void Deploy(ILogger<DeployController> logger, string deployFile)
|
||||
{
|
||||
// 调用部署脚本
|
||||
try
|
||||
{
|
||||
//var psi = new ProcessStartInfo("sh", "~/BootstrapAdmin/deploy-admin.sh");
|
||||
var cmd = deployFile;
|
||||
if (File.Exists(cmd))
|
||||
{
|
||||
var psi = new ProcessStartInfo("sh", $"\"{cmd}\"");
|
||||
psi.RedirectStandardOutput = true;
|
||||
psi.UseShellExecute = false;
|
||||
var p = Process.Start(psi);
|
||||
p.WaitForExit();
|
||||
var result = p.StandardOutput.ReadToEnd();
|
||||
logger.LogError("deploy success: {0}", result);
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
logger.LogError(ex, "");
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -52,12 +52,6 @@
|
|||
"From": "honeywell_mes@163.com",
|
||||
"To": "argo@163.com"
|
||||
},
|
||||
"DeployOptions": {
|
||||
"Enabled": false,
|
||||
"DeployFile": "..\\..\\publish-admin.sh",
|
||||
"OSPlatform": "Windows",
|
||||
"Branch": "release"
|
||||
},
|
||||
"AllowOrigins": "http://localhost:50852",
|
||||
"LongbowCache": {
|
||||
"Enabled": true,
|
||||
|
|
Loading…
Reference in New Issue