123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185 |
- using DFS.Core.Mvc;
- using DFS.Infrastructure.Redis.Extension;
- using FreeSql;
- using Fuel.Application;
- using Fuel.Application.Repositories;
- using Fuel.Application.Service;
- using Fuel.Infrastructure;
- using Fuel.Payment.Service.AliPaymentProcessor.Alipay;
- using Fuel.Payment.Service.AllInPayProcessor.AllInPay;
- using Fuel.Payment.Service.Factory;
- using Fuel.Payment.Service.Pay;
- using Fuel.Payment.Service.UnionPayProcessor;
- using Fuel.PaymentServer.MicServer;
- using Fuel.Infrastructure.Extension;
- using CSRedis;
- using Microsoft.Extensions.Logging;
- using Fuel.Core;
- using Microsoft.AspNetCore.Authorization;
- using Fuel.Application.Authorization;
- using Microsoft.Extensions.DependencyInjection;
- using Microsoft.AspNetCore.Authentication.JwtBearer;
- using Microsoft.IdentityModel.Tokens;
- using System.Text;
- using DFS.Core.Mvc.Middlewares;
- using Fuel.Payment.Service.WeChatPaymentProcessor.Wechat;
- using Fuel.Application.MqttService;
- using System.Text.Json;
- var builder = WebApplication.CreateBuilder(args);
- builder.Services.AddScoped<IPayService, PayService>();
- AsyncPaymentProcessorFactory.Default.Regist(o => o.Channel == "ALI_SCAN", new AlipayPaymentProcessor());
- AsyncPaymentProcessorFactory.Default.Regist(o => o.Channel == "WX_SCAN", new WechatPaymentProcessor());
- AsyncPaymentProcessorFactory.Default.Regist(o => o.Channel == "ALL_IN_SCAN", new AllInPayProcessor());
- AsyncPaymentProcessorFactory.Default.Regist(o => o.Channel == "ALI_ORDER_SCAN", new AlipayPaymentProcessor());
- AsyncPaymentProcessorFactory.Default.Regist(o => o.Channel == "UNION_MINI", new MiniUnionPayProcessor());
- AsyncPaymentProcessorFactory.Default.Regist(o => o.Channel == "UNION_SCAN", new UnionPayProcessor());
- builder.Services.AddFreeSql(builder.Configuration);
- builder.Services.AddMicService(builder.Environment);
- builder.Services.AddHttpContextAccessor();
- builder.Services.AddScoped<INozzleRepository, NozzleRepository>();
- builder.Services.AddScoped<INozzleService, NozzleService>();
- builder.Services.AddScoped<ITransactionsService, TransactionsService>();
- builder.Services.AddScoped<IUserService, UserService>();
- builder.Services.AddScoped<IApplyService, ApplyService>();
- builder.Services.AddScoped<ISiteService, SiteService>();
- builder.Services.AddScoped<Authorization>();
- builder.Services.AddEndpointsApiExplorer();
- builder.Services.AddSwaggerGen();
- builder.Services.AddTransient<IAuthorizationHandler, PermissionHandler>();
- Fuel.Infrastructure.Extension.RedisOptions redisOptions = builder.Configuration.GetSection("Redis").Get<Fuel.Infrastructure.Extension.RedisOptions>();
- builder.Services.UseRedisClient(redisOptions);
- void AddPermissionPolicies(AuthorizationOptions options)
- {
-
-
-
-
-
-
- using (var scope = builder.Services.BuildServiceProvider().CreateScope())
- {
- var userService = scope.ServiceProvider.GetRequiredService<IUserService>();
- var applyService = scope.ServiceProvider.GetRequiredService<IApplyService>();
- var authorization = new Authorization(userService, applyService);
- var permissions = authorization.GetPermissions();
- foreach (var permission in permissions)
- {
- options.AddPolicy($"Permission_{permission}", policy =>
- policy.Requirements.Add(new PermissionRequirement(permission)));
- }
- }
- }
- builder.Services.AddAuthorization(options =>
- {
- AddPermissionPolicies(options);
- });
- builder.Services.Configure<MqttOptions>(builder.Configuration.GetSection("Mqtt"));
- builder.Services.AddScoped<IMqttClientService, MqttClientService>();
- builder.Logging.ClearProviders();
- builder.Services.AddCors(options =>
- {
- options.AddPolicy("AllowAll", policy =>
- {
- policy.AllowAnyOrigin()
- .AllowAnyMethod()
- .AllowAnyHeader()
- .SetPreflightMaxAge(TimeSpan.FromSeconds(86400));
- });
- });
- builder.WebHost.ConfigureKestrel(options =>
- {
-
-
- options.Listen(System.Net.IPAddress.Parse("::1"), 5007);
- });
- builder.Services.AddControllers()
- .AddJsonOptions(options =>
- {
- options.JsonSerializerOptions.PropertyNamingPolicy = JsonNamingPolicy.CamelCase;
- options.JsonSerializerOptions.DictionaryKeyPolicy = JsonNamingPolicy.CamelCase;
- });
- var app = builder.Build();
- app.UseRouting();
- app.UseCors("AllowAll");
- app.Use(async (context, next) =>
- {
- context.Response.Headers["Referrer-Policy"] = "strict-origin-when-cross-origin";
- context.Request.EnableBuffering();
- var requestBody = await new StreamReader(context.Request.Body).ReadToEndAsync();
- Console.WriteLine($"Request Body: {requestBody}");
- context.Request.Body.Position = 0;
- await next();
- });
- var loggerFactory = LoggerFactory.Create(builder =>
- {
- builder.AddConsole();
- });
- var logger = loggerFactory.CreateLogger<DFS.Core.Mvc.Middlewares.SignatureValidator>();
- var signatureValidator = new DFS.Core.Mvc.Middlewares.SignatureValidator(logger);
- app.UseMiddleware<SignatureValidationMiddleware>(signatureValidator);
- var httpContextAccessor = app.Services.GetRequiredService<IHttpContextAccessor>();
- HttpRequestReader.Configure(httpContextAccessor);
- if (app.Environment.IsDevelopment())
- {
- app.UseSwagger();
- app.UseSwaggerUI();
- }
- app.UseDFSServer();
- app.UseHttpsRedirection();
- app.UseAuthentication();
- app.UseAuthorization();
- app.MapControllers();
- app.Run();
|