Program.cs 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. using DinkToPdf;
  2. using DinkToPdf.Contracts;
  3. using Microsoft.Extensions.Configuration;
  4. using Microsoft.Extensions.DependencyInjection;
  5. using Microsoft.Extensions.DependencyInjection.Extensions;
  6. using Microsoft.Extensions.Hosting;
  7. using System;
  8. using System.Collections.Concurrent;
  9. using System.Collections.Generic;
  10. using System.Configuration;
  11. using System.Diagnostics;
  12. using System.IO;
  13. using System.Linq;
  14. using System.Net.Http;
  15. using System.Runtime.InteropServices;
  16. using System.Text;
  17. using System.Text.Json;
  18. using System.Text.RegularExpressions;
  19. using System.Threading;
  20. using System.Threading.Tasks;
  21. using TEAMModelOS.FunctionV4;
  22. using TEAMModelOS.FunctionV4.ServiceBus;
  23. using TEAMModelOS.Models;
  24. using TEAMModelOS.SDK;
  25. using TEAMModelOS.SDK.DI;
  26. using TEAMModelOS.SDK.DI.Mail;
  27. using TEAMModelOS.SDK.DI.Multiple;
  28. namespace TEAMModelOS.FunctionV4
  29. {
  30. public static class Program
  31. {
  32. public static async Task Main(string[] args)
  33. {
  34. #if DEBUG
  35. Debugger.Launch();
  36. #endif
  37. //var host = new HostBuilder()
  38. //.ConfigureFunctionsWorkerDefaults(funccontext => {
  39. // funccontext.UseMiddleware<TimeMonitorMiddleware>();
  40. //} )
  41. var host = new HostBuilder().ConfigureFunctionsWorkerDefaults()
  42. .ConfigureAppConfiguration((context, configure) =>
  43. {
  44. //configure.AddCommandLine(args);
  45. // configure.AddJsonFile("local.settings.json", optional: true, reloadOnChange: true).AddEnvironmentVariables();
  46. })
  47. .ConfigureServices((context, services) =>
  48. {
  49. //services.Configure<Option>(options => context. Configuration.GetSection("Option").Bind(options));
  50. services.AddHttpClient();
  51. services.AddHttpClient<DingDing>();
  52. services.AddHttpClient<HttpTrigger>();
  53. //services.AddCoreAPIHttpService(context.Configuration);
  54. services.AddHttpClient<CoreAPIHttpService>().ConfigureHttpMessageHandlerBuilder(builder =>
  55. {
  56. builder.PrimaryHandler = new HttpClientHandler
  57. {
  58. ServerCertificateCustomValidationCallback = (message, cert, chain, errors) => true
  59. };
  60. });
  61. List<(string name, string connectionString)> cosmosDBConnects = new();
  62. cosmosDBConnects.Add(("Default", context.Configuration.GetSection("Azure:Cosmos:ConnectionString").Get<string>()));
  63. cosmosDBConnects.Add(("CoreServiceV1", context.Configuration.GetSection("CoreServiceV1:Cosmos:ConnectionString").Get<string>())); //CoreService V1 read only
  64. cosmosDBConnects.Add(("CoreServiceV2", context.Configuration.GetSection("CoreServiceV2:Cosmos:ConnectionString").Get<string>())); //CoreService V2
  65. cosmosDBConnects.Add(("CoreServiceV2CnRead", context.Configuration.GetSection("CoreServiceV2:CosmosCnRead:ConnectionString").Get<string>())); //CoreService V2 CN read only
  66. services.AddMultipleAzureCosmos(cosmosDBConnects);
  67. //services.AddAzureCosmos(context.Configuration.GetSection("Azure:Cosmos:ConnectionString").Get<string>());
  68. services.AddAzureServiceBus(context.Configuration.GetSection("Azure:ServiceBus:ConnectionString").Get<string>());
  69. services.AddAzureRedis(context.Configuration.GetSection("Azure:Redis:ConnectionString").Get<string>());
  70. services.AddSingleton(typeof(IConverter), new SynchronizedConverter(new PdfTools()));
  71. services.AddSnowflakeId(Convert.ToInt64(context.Configuration.GetSection("Option:LocationNum").Get<Int32>()), 1);
  72. List<(string name, string connectionString)> storageConnects = new();
  73. storageConnects.Add(("Default", context.Configuration.GetSection("Azure:Storage:ConnectionString").Get<string>()));
  74. string LogStorageConnectionString = context.Configuration.GetSection("Azure:LogStorage:ConnectionString").Get<string>(); //防火墙日志统计文件
  75. if (!string.IsNullOrWhiteSpace(LogStorageConnectionString)) {
  76. storageConnects.Add(("LogStorage", LogStorageConnectionString)); //防火墙日志统计文件
  77. }
  78. services.AddMultipleAzureStorage(storageConnects);
  79. //services.AddHostedService<BlobRootServiceBusSub>();
  80. services.AddSingleton<BackgroundWorkerQueue>();
  81. services.AddHostedService<LongRunningService>();
  82. // services.AddIPSearcher("");
  83. })
  84. .Build();
  85. await host.RunAsync();
  86. }
  87. public class BackgroundWorkerQueue
  88. {
  89. private readonly ConcurrentQueue<Func<CancellationToken, Task>> _workItems = new();
  90. private readonly SemaphoreSlim _signal = new(0);
  91. public async Task<Func<CancellationToken, Task>> DequeueAsync(CancellationToken cancellationToken)
  92. {
  93. await _signal.WaitAsync(cancellationToken);
  94. _workItems.TryDequeue(out var workItem);
  95. return workItem;
  96. }
  97. public void QueueBackgroundWorkItem(Func<CancellationToken, Task> workItem)
  98. {
  99. ArgumentNullException.ThrowIfNull(workItem);
  100. _workItems.Enqueue(workItem);
  101. _signal.Release();
  102. }
  103. }
  104. public class LongRunningService : BackgroundService
  105. {
  106. public LongRunningService(BackgroundWorkerQueue queue)
  107. {
  108. _queue = queue;
  109. }
  110. private readonly BackgroundWorkerQueue _queue;
  111. protected override async Task ExecuteAsync(CancellationToken stoppingToken)
  112. {
  113. while (!stoppingToken.IsCancellationRequested)
  114. {
  115. var workItem = await _queue.DequeueAsync(stoppingToken);
  116. await workItem(stoppingToken);
  117. }
  118. }
  119. }
  120. }
  121. }