Skip to content

10. Startup

CodeDesignPlus edited this page Jan 5, 2021 · 3 revisions

La librería CodeDesignPlus.EFCore que hace parte del SDK de CodeDesignPlus provee los siguientes métodos de extensión para una correcta configuración.

Method Description
AddEFCore Lee las configuraciones del appsettings.json y las registra en con el tipo IOptiones<EFCoreOptions>
AddRepositories<TKey, TUserKey, TContext> Obtiene todos los repositorios y los registra en el contenedor de dependencias de .net Core
AddIdentityService<TKeyUser> Registra el servicio IHttpContextAccessor, IAuthenticateUser<TKeyUser>, IIdentityService<TKeyUser>.
UseIdentityService<TKeyUser> Registra el Middleware IdentityServiceMiddleware<TUserKey>
using AutoMapper;
using CodeDesignPlus.EfCore.Sample.Api.SqlServer;
using CodeDesignPlus.EFCore.Extensions;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using System;
using System.Reflection;

namespace CodeDesignPlus.EFCore.Sample.Api
{
    public class Startup
    {
        public Startup(IConfiguration configuration)
        {
            Configuration = configuration;
        }

        public IConfiguration Configuration { get; }

        // This method gets called by the runtime. Use this method to add services to the container.
        public void ConfigureServices(IServiceCollection services)
        {
            services.AddControllers();

            services.AddAutoMapper(typeof(Startup));

            this.AddDbContext(services);

            services.AddEFCore(this.Configuration)
                    .AddIdentityService<string>()
                    .AddRepositories<long, string, SqlServerContext>();
        }


        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
        {
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }

            app.UseHttpsRedirection();

            app.UseRouting();

            app.UseSwagger();
            app.UseSwaggerUI(x =>
            {
                x.SwaggerEndpoint("/swagger/v1/swagger.json", "CodeDesignPlus.EFCore.Sample.Api");
            });

            //app.UseAuthentication();
            app.UseAuthorization();
            app.UseIdentityService<string>();

            app.UseEndpoints(endpoints =>
            {
                endpoints.MapControllers();
            });
        }

        private void AddDbContext(IServiceCollection services)
        {
            var migration = typeof(Startup).GetTypeInfo().Assembly.GetName().Name;

            services.AddDbContext<SqlServerContext>(options =>
            {
                if (!options.IsConfigured)
                {
                    options.UseSqlServer(this.Configuration.GetConnectionString("DefeaultConnection"), sqlOptions =>
                    {
                        sqlOptions.MigrationsAssembly(migration);

                        sqlOptions.EnableRetryOnFailure(maxRetryCount: 10, maxRetryDelay: TimeSpan.FromSeconds(10), errorNumbersToAdd: null);
                    });
                }
            });
        }
    }
}

Donaciones

Si deseas apoyarnos económicamente lo puedes hacer a partir de:

Badges

Las siguientes insignias te muestran el estado del proyecto en su última versión:

Build status
Bugs
Code Smells
Coverage
Duplicated Lines (%)
Lines of Code
Maintainability Rating
Quality Gate Status
Reliability Rating
Technical Debt
Vulnerabilities
Security Rating

Clone this wiki locally