Swagger .NetCore не генерирует swagger.json с аутсорсингом запуска - PullRequest
0 голосов
/ 04 декабря 2018

Мы пытаемся реализовать swagger с IdentityServer4 в .NetCore.

Теперь, если я настроил мой .NetCore Project с помощью API и следующего файла startup.cs, все работает нормально, и API отображается в Swagger

public class MyStartup
{
    public MyStartup(IHostingEnvironment env)
    {
        var builder = new ConfigurationBuilder()
            .SetBasePath(env.ContentRootPath)
            .AddJsonFile("appsettings.json", true, false)
            .AddJsonFile($"appsettings.{env.EnvironmentName}.json", true, false)
            .AddEnvironmentVariables();

        Configuration = builder.Build();
    }

    protected IConfigurationRoot Configuration { get; }

    public void ConfigureServices(IServiceCollection services)
    {
        services.AddMvcCore()
            .AddApiExplorer()
            .AddVersionedApiExplorer(
                options =>
                {
                    options.GroupNameFormat = "'v'V";

                    // note: this option is only necessary when versioning by url segment. the SubstitutionFormat
                    // can also be used to control the format of the API version in route templates
                    options.SubstituteApiVersionInUrl = true;
                })
            .AddAuthorization(ConfigureAuthorization)
            .AddFormatterMappings()
            .SetCompatibilityVersion(CompatibilityVersion.Version_2_1)
            //.AddDataAnnotations()
            .AddJsonFormatters(MyWebApiFormattersConfig.SetJsonSerializerSettings)
            //.AddCors()
            //Add mvc options last - won't work in AddMvcCore.
            .AddMvcOptions(ConfigureMvc);

        services.AddHttpContextAccessor();
        services.AddAuthentication(IdentityServerAuthenticationDefaults.AuthenticationScheme)
            .AddIdentityServerAuthentication(options =>
            {
                options.Authority = "https://dev.idserver.my.ch/"; // auth server base endpoint (will use to search for disco doc)
                options.ApiName = "MySwagger"; // required audience of access tokens
                options.RequireHttpsMetadata = false; // dev only!
            });

        var provider = services.BuildServiceProvider().GetRequiredService<IApiVersionDescriptionProvider>();
        if (JsonCustomizingConfig.GetSwaggerIsEnabled(Configuration))
        {
            var securityScheme = new OAuth2Scheme()
            {
                AuthorizationUrl = JsonCustomizingConfig.GetSwaggerOAuthUrl(Configuration),
                //TokenUrl = JsonCustomizingConfig.GetSwaggerOAuthTokenUrl(config),
                Flow = JsonCustomizingConfig.GetSwaggerOAuthFlow(Configuration),
                Scopes = JsonCustomizingConfig.GetSwaggerOAuthScopes(Configuration),
            };

            services.AddSwaggerGen(options =>
            {
                foreach (var description in provider.ApiVersionDescriptions)
                {
                    options.SwaggerDoc(description.GroupName, new Info
                    {
                        Title = $"My API {description.ApiVersion}",
                        Version = description.ApiVersion.ToString(),
                        Description = "My API",
                        Contact = new Contact() { Name = "my:solutions AG", Email = "info@my.ch" }
                    });
                }

                options.AddSecurityDefinition("My swagger", securityScheme);
                options.OperationFilter<AuthorizeCheckOperationFilter>(); // Required to use access token
            });
        }
        services.AddApiVersioning(MyApiConfig.ConfigureVersioning);
        services.AddSingleton(Configuration);
    }

    private void ConfigureMvc(MvcOptions options)
    {
        options.Filters.Add(new MyAuthorizeFilter("MyAuthPolicy"));
    }

    private void ConfigureAuthorization(AuthorizationOptions options)
    {
        options.AddPolicy("MyAuthPolicy", p =>
        {
            p.RequireAuthenticatedUser();
            //p.RequireClaim(My.Def.Permission.MyClaimTypes.SysKundeId);
            p.AddAuthenticationSchemes(JwtBearerDefaults.AuthenticationScheme);
        });
        options.DefaultPolicy = options.GetPolicy("MyAuthPolicy");
    }

    public void Configure(IApplicationBuilder app, IHostingEnvironment env, IApiVersionDescriptionProvider provider)
    {
        app.UseAuthentication();
        app.UseMvc();

        if (JsonCustomizingConfig.GetSwaggerIsEnabled(Configuration))
        {
            // Swagger JSON Doc
            app.UseSwagger();

            // Swagger UI
            app.UseSwaggerUI(options =>
            {
                foreach (var description in provider.ApiVersionDescriptions)
                {
                    options.SwaggerEndpoint($"/swagger/{description.GroupName}/swagger.json", $"My API {description.GroupName.ToUpperInvariant()}");
                }
                //options.SwaggerEndpoint("/swagger/v1/swagger.json", "My API V1");
                options.RoutePrefix = string.Empty;

                options.OAuthClientId("mySwagger");
                options.OAuthAppName("My Api"); // presentation purposes only
            });

        }

    }
}

И в programm.cs:

public class Program
{
    public static void Main(string[] args)
    {
        CreateWebHostBuilder(args).Build().Run();
    }

    public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>
        new WebHostBuilder()
            .UseKestrel()
            .ConfigureServices(services => services.AddServiceContext())
            .UseContentRoot(Directory.GetCurrentDirectory())
            .UseIISIntegration()
            .UseStartup<MyStartup>();
}

Если я копирую и вставляю файл startup.cs из другого проекта, который добавлен в качестве пакета NuGet в мой исходный проект, API больше не отображается, и файл swagger.json не создается.Я просмотрел каждый пример в Интернете и не понимаю, почему он не работает.Я надеюсь, что кто-то может помочь мне здесь.

...