Skip to content

Commit

Permalink
修改配置文件
Browse files Browse the repository at this point in the history
  • Loading branch information
lurudong committed Jul 5, 2021
1 parent 82d9a49 commit 9db215f
Show file tree
Hide file tree
Showing 2 changed files with 92 additions and 34 deletions.
80 changes: 46 additions & 34 deletions src/Destiny.Core.Flow.API/Startups/FunctionModule.cs
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
using Microsoft.Extensions.Options;
using System;
using Destiny.Core.Flow.Shared.Options;
using Destiny.Core.Flow.Shared.Extensions;

namespace Destiny.Core.Flow.API.Startups
{
Expand All @@ -27,46 +28,57 @@ public override void ConfigureServices(ConfigureServicesContext context)
{

context.Services.AddFileProvider();
var configuration = context.Services.GetConfiguration();

if (configuration == null)
{
IConfigurationBuilder configurationBuilder = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json", optional: false, reloadOnChange: true)
.AddJsonFile("appsettings.Development.json", optional: true, reloadOnChange: true);
configuration = configurationBuilder.Build();
context.Services.AddSingleton<IConfiguration>(configuration);
}
//var configuration = context.Services.GetConfiguration();


//if (configuration == null)
//{
// IConfigurationBuilder configurationBuilder = new ConfigurationBuilder()
// .SetBasePath(Directory.GetCurrentDirectory())
// .AddJsonFile("appsettings.json", optional: false, reloadOnChange: true)
// .AddJsonFile("appsettings.Development.json", optional: true, reloadOnChange: true);
// configuration = configurationBuilder.Build();
// context.Services.AddSingleton<IConfiguration>(configuration);
//}

AppOptionSettings option = new AppOptionSettings();

if (configuration != null)
{
string key = "Destiny";

configuration.Bind(key, option);

context.Services.AddObjectAccessor(option);
context.Services.Configure<AppOptionSettings>(o=>{
o.AuditEnabled = option.AuditEnabled;
o.Auth = option.Auth;
o.Cors = option.Cors;
o.DbContexts = option.DbContexts;
o.IsAutoAddFunction = option.IsAutoAddFunction;
o.Jwt = option.Jwt;

});
context.Services.AddObjectAccessor<MongoOptions>(configuration.GetSection($"{key}:MongoDBs").Get<MongoOptions>());
//if (configuration != null)
//{
// string key = "Destiny";

}
// configuration.Bind(key, option);

// context.Services.AddObjectAccessor(option);
// context.Services.Configure<AppOptionSettings>(o=>{
// o.AuditEnabled = option.AuditEnabled;
// o.Auth = option.Auth;
// o.Cors = option.Cors;
// o.DbContexts = option.DbContexts;
// o.IsAutoAddFunction = option.IsAutoAddFunction;
// o.Jwt = option.Jwt;

// });
// context.Services.AddObjectAccessor<MongoOptions>(configuration.GetSection($"{key}:MongoDBs").Get<MongoOptions>());

//context.Services.AddFileProvider();
//IConfiguration configuration = context.GetConfiguration();
//AppOptionSettings configuration2 = context.GetConfiguration<AppOptionSettings>("Destiny");
//context.Services.AddObjectAccessor(configuration2);
//}

var configuration= context.Services.Build<AppOptionSettings>("Destiny", option,o=> {
o.AuditEnabled = option.AuditEnabled;
o.Auth = option.Auth;
o.Cors = option.Cors;
o.DbContexts = option.DbContexts;
o.IsAutoAddFunction = option.IsAutoAddFunction;
o.Jwt = option.Jwt;

});

if (configuration != null) {
context.Services.AddObjectAccessor<MongoOptions>(configuration.GetSection($"Destiny:MongoDBs").Get<MongoOptions>());
}
}


}


Expand Down
46 changes: 46 additions & 0 deletions src/Destiny.Core.Flow.Shared/Extensions/ConfigExtensions.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
using DestinyCore.Extensions;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace Destiny.Core.Flow.Shared.Extensions
{
public static class ConfigExtensions
{
public static IConfiguration Build<TOptions>(this IServiceCollection services, string key, TOptions option, Action<TOptions> actionOptions) where TOptions : class
{

var configuration = services.GetConfiguration();

if (configuration == null)
{
IConfigurationBuilder configurationBuilder = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json", optional: false, reloadOnChange: true)
.AddJsonFile("appsettings.Development.json", optional: true, reloadOnChange: true);
configuration = configurationBuilder.Build();
services.AddSingleton<IConfiguration>(configuration);
}
else
{
configuration.Bind(key, option);
services.AddObjectAccessor(option);
if (actionOptions !=null)
{
services.Configure<TOptions>(actionOptions);
} else
{
services.Configure<TOptions>(configuration.GetSection(key));
}
//services.AddObjectAccessor(option);

}
return configuration;
}
}
}

0 comments on commit 9db215f

Please sign in to comment.