using Mealprep.Data; using Mealprep.Models.Nutritionix; using Mealprep.Services; using Microsoft.AspNetCore.Builder; using Microsoft.AspNetCore.Hosting; using Microsoft.AspNetCore.SpaServices; using Microsoft.EntityFrameworkCore; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Hosting; using VueCliMiddleware; namespace Mealprep { public class Startup { public Startup(IConfiguration configuration, IWebHostEnvironment environment) { Configuration = configuration; Environment = environment; } public IConfiguration Configuration { get; } public IWebHostEnvironment Environment { get; } // This method gets called by the runtime. Use this method to add services to the container. public void ConfigureServices(IServiceCollection services) { services.AddControllersWithViews(); // Add AddRazorPages if the app uses Razor Pages. services.AddRazorPages(); // In production, the Vue files will be served from this directory services.AddSpaStaticFiles(configuration => configuration.RootPath = "ClientApp/dist"); if (Environment.IsDevelopment()) { services.AddDbContext(options => options.UseSqlite(Configuration.GetConnectionString("DefaultConnection"))); } else if (Environment.IsProduction()) { services.AddDbContext(options => options.UseMySQL(Configuration.GetConnectionString("DefaultConnection"))); } var apiSettings = Configuration.GetSection("Nutritionix"); services.Configure(apiSettings); services.AddScoped(); } // 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(); } else { app.UseExceptionHandler("/Error"); // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts. app.UseHsts(); //app.UseHttpsRedirection(); Not yet supported on target server } app.UseStaticFiles(); app.UseSpaStaticFiles(); app.UseRouting(); app.UseEndpoints(endpoints => { endpoints.MapControllerRoute( name: "default", pattern: "{controller}/{action=Index}/{id?}"); if (env.IsDevelopment()) { endpoints.MapToVueCliProxy( "{*path}", new SpaOptions { SourcePath = "ClientApp" }, npmScript: "serve", regex: "Compiled successfully"); } // Add MapRazorPages if the app uses Razor Pages. Since Endpoint Routing includes support for many frameworks, adding Razor Pages is now opt -in. endpoints.MapRazorPages(); }); app.UseSpa(spa => spa.Options.SourcePath = "ClientApp"); } } }