Merge branch 'docker-sql' of https://dev.azure.com/MDCSB-Telecommuters/Emergency%20Preparedness%20Disaster%20Recovery%20Project%20%28EPDRP%29/_git/Backend-API-Services into docker-sql
This commit is contained in:
commit
4b9ab46901
@ -32,6 +32,10 @@ builder.Services.AddDbContext<AnswerDbContext>(option =>
|
|||||||
option.UseSqlServer("AnswerConnection");
|
option.UseSqlServer("AnswerConnection");
|
||||||
});
|
});
|
||||||
|
|
||||||
|
builder.Services.AddCors(p => p.AddPolicy("DamageAppCorsPolicy", build => {
|
||||||
|
build.WithOrigins("*").AllowAnyMethod().AllowAnyHeader().AllowAnyOrigin();
|
||||||
|
}));
|
||||||
|
|
||||||
var app = builder.Build();
|
var app = builder.Build();
|
||||||
|
|
||||||
// Configure the HTTP request pipeline.
|
// Configure the HTTP request pipeline.
|
||||||
@ -40,7 +44,8 @@ if (app.Environment.IsDevelopment())
|
|||||||
app.UseSwagger();
|
app.UseSwagger();
|
||||||
app.UseSwaggerUI();
|
app.UseSwaggerUI();
|
||||||
}
|
}
|
||||||
|
app.UseCors("DamageAppCorsPolicy");
|
||||||
|
app.UseAuthorization();
|
||||||
|
|
||||||
// Enable CORS, authentication, and authorization middleware.
|
// Enable CORS, authentication, and authorization middleware.
|
||||||
app.UseCors("DamageAppCorsPolicy");
|
app.UseCors("DamageAppCorsPolicy");
|
||||||
|
@ -42,6 +42,9 @@ builder.Services.Configure<FormOptions>(o =>
|
|||||||
o.MultipartBodyLengthLimit = int.MaxValue;
|
o.MultipartBodyLengthLimit = int.MaxValue;
|
||||||
o.MemoryBufferThreshold = int.MaxValue;
|
o.MemoryBufferThreshold = int.MaxValue;
|
||||||
});
|
});
|
||||||
|
builder.Services.AddCors(p => p.AddPolicy("DamageAppCorsPolicy", build => {
|
||||||
|
build.WithOrigins("*").AllowAnyMethod().AllowAnyHeader().AllowAnyOrigin();
|
||||||
|
}));
|
||||||
|
|
||||||
var app = builder.Build();
|
var app = builder.Build();
|
||||||
|
|
||||||
@ -53,10 +56,10 @@ if (app.Environment.IsDevelopment())
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Enable CORS, authentication, and authorization middleware.
|
// Enable CORS, authentication, and authorization middleware.
|
||||||
|
|
||||||
app.UseCors("DamageAppCorsPolicy");
|
app.UseCors("DamageAppCorsPolicy");
|
||||||
app.UseAuthorization();
|
app.UseAuthorization();
|
||||||
app.UseHttpsRedirection();
|
app.UseHttpsRedirection();
|
||||||
|
|
||||||
app.MapControllers();
|
app.MapControllers();
|
||||||
app.UseStaticFiles();
|
app.UseStaticFiles();
|
||||||
app.Run();
|
app.Run();
|
||||||
|
@ -33,6 +33,9 @@ builder.Services.AddDbContext<DoculinkDbContext>(option =>
|
|||||||
{
|
{
|
||||||
option.UseSqlServer("DoculinConnection");
|
option.UseSqlServer("DoculinConnection");
|
||||||
});
|
});
|
||||||
|
builder.Services.AddCors(p => p.AddPolicy("DamageAppCorsPolicy", build => {
|
||||||
|
build.WithOrigins("*").AllowAnyMethod().AllowAnyHeader().AllowAnyOrigin();
|
||||||
|
}));
|
||||||
var app = builder.Build();
|
var app = builder.Build();
|
||||||
|
|
||||||
// Configure the HTTP request pipeline.
|
// Configure the HTTP request pipeline.
|
||||||
@ -44,6 +47,7 @@ if (app.Environment.IsDevelopment())
|
|||||||
|
|
||||||
|
|
||||||
// Enable CORS, authentication, and authorization middleware.
|
// Enable CORS, authentication, and authorization middleware.
|
||||||
|
|
||||||
app.UseCors("DamageAppCorsPolicy");
|
app.UseCors("DamageAppCorsPolicy");
|
||||||
app.UseAuthorization();
|
app.UseAuthorization();
|
||||||
|
|
||||||
|
@ -32,7 +32,9 @@ builder.Services.AddDbContext<EmployeeDbContext>(option =>
|
|||||||
{
|
{
|
||||||
option.UseSqlServer("EmployeeConnection");
|
option.UseSqlServer("EmployeeConnection");
|
||||||
});
|
});
|
||||||
|
builder.Services.AddCors(p => p.AddPolicy("DamageAppCorsPolicy", build => {
|
||||||
|
build.WithOrigins("*").AllowAnyMethod().AllowAnyHeader().AllowAnyOrigin();
|
||||||
|
}));
|
||||||
var app = builder.Build();
|
var app = builder.Build();
|
||||||
|
|
||||||
// Configure the HTTP request pipeline.
|
// Configure the HTTP request pipeline.
|
||||||
@ -49,6 +51,8 @@ if (app.Environment.IsDevelopment())
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
app.UseCors("DamageAppCorsPolicy");
|
||||||
|
|
||||||
// Enable CORS, authentication, and authorization middleware.
|
// Enable CORS, authentication, and authorization middleware.
|
||||||
app.UseCors("DamageAppCorsPolicy");
|
app.UseCors("DamageAppCorsPolicy");
|
||||||
|
|
||||||
|
@ -31,6 +31,9 @@ builder.Services.AddDbContext<LocationDbContext>(option =>
|
|||||||
{
|
{
|
||||||
option.UseSqlServer("LocationConnection");
|
option.UseSqlServer("LocationConnection");
|
||||||
});
|
});
|
||||||
|
builder.Services.AddCors(p => p.AddPolicy("DamageAppCorsPolicy", build => {
|
||||||
|
build.WithOrigins("*").AllowAnyMethod().AllowAnyHeader().AllowAnyOrigin();
|
||||||
|
}));
|
||||||
var app = builder.Build();
|
var app = builder.Build();
|
||||||
|
|
||||||
// Configure the HTTP request pipeline.
|
// Configure the HTTP request pipeline.
|
||||||
@ -49,6 +52,8 @@ if (app.Environment.IsDevelopment())
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
app.UseCors("DamageAppCorsPolicy");
|
||||||
|
|
||||||
// Enable CORS, authentication, and authorization middleware.
|
// Enable CORS, authentication, and authorization middleware.
|
||||||
app.UseCors("DamageAppCorsPolicy");
|
app.UseCors("DamageAppCorsPolicy");
|
||||||
|
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
using DamageAssesment.Api.Questions.Interfaces;
|
using DamageAssesment.Api.Questions.Interfaces;
|
||||||
|
using DamageAssesment.Api.Questions.Models;
|
||||||
using Microsoft.AspNetCore.Mvc;
|
using Microsoft.AspNetCore.Mvc;
|
||||||
|
|
||||||
namespace DamageAssesment.Api.Questions.Controllers
|
namespace DamageAssesment.Api.Questions.Controllers
|
||||||
@ -108,6 +109,27 @@ namespace DamageAssesment.Api.Questions.Controllers
|
|||||||
}
|
}
|
||||||
return CreatedAtRoute("DefaultApi",questions);
|
return CreatedAtRoute("DefaultApi",questions);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// POST request for creating a multiple question (multilingual).
|
||||||
|
/// </summary>
|
||||||
|
[HttpPut("questions/multiple/{surveyid}")]
|
||||||
|
public async Task<IActionResult> UpdateQuestions(int surveyid, List<Models.Question> questions)
|
||||||
|
{
|
||||||
|
if (questions != null)
|
||||||
|
{
|
||||||
|
var result = await this.questionsProvider.PutQuestionsAsync(surveyid,questions);
|
||||||
|
if (result.IsSuccess)
|
||||||
|
{
|
||||||
|
return Ok(result.Question);
|
||||||
|
}
|
||||||
|
if (result.ErrorMessage == "Not Found")
|
||||||
|
return NotFound(result.ErrorMessage);
|
||||||
|
|
||||||
|
return BadRequest(result.ErrorMessage);
|
||||||
|
}
|
||||||
|
return CreatedAtRoute("DefaultApi", questions);
|
||||||
|
}
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// POST request for creating a new question (multilingual).
|
/// POST request for creating a new question (multilingual).
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -9,6 +9,7 @@ namespace DamageAssesment.Api.Questions.Interfaces
|
|||||||
Task<(bool IsSuccess, List<SurveyQuestions> SurveyQuestions, string ErrorMessage)> GetSurveyQuestionAsync(int surveyId,string language);
|
Task<(bool IsSuccess, List<SurveyQuestions> SurveyQuestions, string ErrorMessage)> GetSurveyQuestionAsync(int surveyId,string language);
|
||||||
Task<(bool IsSuccess, Models.MultiLanguage Question, string ErrorMessage)> PostQuestionAsync(Models.Question Question);
|
Task<(bool IsSuccess, Models.MultiLanguage Question, string ErrorMessage)> PostQuestionAsync(Models.Question Question);
|
||||||
Task<(bool IsSuccess, IEnumerable<Models.MultiLanguage> Question, string ErrorMessage)> PostQuestionsAsync(List<Models.Question> Questions);
|
Task<(bool IsSuccess, IEnumerable<Models.MultiLanguage> Question, string ErrorMessage)> PostQuestionsAsync(List<Models.Question> Questions);
|
||||||
|
Task<(bool IsSuccess, IEnumerable<Models.MultiLanguage> Question, string ErrorMessage)> PutQuestionsAsync(int surveyId, List<Models.Question> Questions);
|
||||||
Task<(bool IsSuccess, Models.MultiLanguage Question, string ErrorMessage)> UpdateQuestionAsync(Models.Question Question);
|
Task<(bool IsSuccess, Models.MultiLanguage Question, string ErrorMessage)> UpdateQuestionAsync(Models.Question Question);
|
||||||
Task<(bool IsSuccess, Models.MultiLanguage Question, string ErrorMessage)> DeleteQuestionAsync(int id);
|
Task<(bool IsSuccess, Models.MultiLanguage Question, string ErrorMessage)> DeleteQuestionAsync(int id);
|
||||||
|
|
||||||
|
@ -34,6 +34,9 @@ builder.Services.AddDbContext<QuestionDbContext>(option =>
|
|||||||
{
|
{
|
||||||
option.UseSqlServer("QuestionConnection");
|
option.UseSqlServer("QuestionConnection");
|
||||||
});
|
});
|
||||||
|
builder.Services.AddCors(p => p.AddPolicy("DamageAppCorsPolicy", build => {
|
||||||
|
build.WithOrigins("*").AllowAnyMethod().AllowAnyHeader().AllowAnyOrigin();
|
||||||
|
}));
|
||||||
var app = builder.Build();
|
var app = builder.Build();
|
||||||
|
|
||||||
// Configure the HTTP request pipeline.
|
// Configure the HTTP request pipeline.
|
||||||
@ -50,6 +53,7 @@ if (app.Environment.IsDevelopment())
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Enable CORS, authentication, and authorization middleware.
|
// Enable CORS, authentication, and authorization middleware.
|
||||||
app.UseCors("DamageAppCorsPolicy");
|
app.UseCors("DamageAppCorsPolicy");
|
||||||
app.UseAuthorization();
|
app.UseAuthorization();
|
||||||
|
@ -376,6 +376,22 @@ namespace DamageAssesment.Api.Questions.Providers
|
|||||||
return (false, null, ex.Message);
|
return (false, null, ex.Message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public async Task<(bool IsSuccess, IEnumerable<Models.MultiLanguage> Question, string ErrorMessage)> PutQuestionsAsync(int surveyId, List<Models.Question> Questions)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
questionDbContext.Questions.ToList().RemoveAll(s=> s.SurveyId == surveyId);
|
||||||
|
questionDbContext.SaveChanges();
|
||||||
|
var response = await PostQuestionsAsync(Questions);
|
||||||
|
return (response);
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
logger?.LogError(ex.ToString());
|
||||||
|
return (false, null, ex.Message);
|
||||||
|
}
|
||||||
|
}
|
||||||
public async Task<(bool IsSuccess, Models.MultiLanguage Question, string ErrorMessage)> UpdateQuestionAsync(Models.Question Question)
|
public async Task<(bool IsSuccess, Models.MultiLanguage Question, string ErrorMessage)> UpdateQuestionAsync(Models.Question Question)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
|
@ -52,6 +52,9 @@ builder.Services.AddDbContext<SurveyResponseDbContext>(option =>
|
|||||||
{
|
{
|
||||||
option.UseSqlServer("ResponsesConnection");
|
option.UseSqlServer("ResponsesConnection");
|
||||||
});
|
});
|
||||||
|
builder.Services.AddCors(p => p.AddPolicy("DamageAppCorsPolicy", build => {
|
||||||
|
build.WithOrigins("*").AllowAnyMethod().AllowAnyHeader().AllowAnyOrigin();
|
||||||
|
}));
|
||||||
var app = builder.Build();
|
var app = builder.Build();
|
||||||
|
|
||||||
// Configure the HTTP request pipeline.
|
// Configure the HTTP request pipeline.
|
||||||
@ -61,7 +64,6 @@ if (app.Environment.IsDevelopment())
|
|||||||
app.UseSwaggerUI();
|
app.UseSwaggerUI();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Enable CORS, authentication, and authorization middleware.
|
|
||||||
app.UseCors("DamageAppCorsPolicy");
|
app.UseCors("DamageAppCorsPolicy");
|
||||||
app.UseAuthorization();
|
app.UseAuthorization();
|
||||||
|
|
||||||
|
147
DamageAssesmentApi/DamageAssesment.Api.UsersAccess/Program.cs
Normal file
147
DamageAssesmentApi/DamageAssesment.Api.UsersAccess/Program.cs
Normal file
@ -0,0 +1,147 @@
|
|||||||
|
using DamageAssesment.Api.UsersAccess.Db;
|
||||||
|
using DamageAssesment.Api.UsersAccess.Interfaces;
|
||||||
|
using DamageAssesment.Api.UsersAccess.Providers;
|
||||||
|
using DamageAssesment.Api.UsersAccess.Models;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using Microsoft.IdentityModel.Tokens;
|
||||||
|
using System.Text;
|
||||||
|
using Polly;
|
||||||
|
using DamageAssesment.Api.UsersAccess.Services;
|
||||||
|
using Microsoft.OpenApi.Models;
|
||||||
|
using System.Reflection;
|
||||||
|
using Microsoft.AspNetCore.Authorization;
|
||||||
|
|
||||||
|
const int maxApiCallRetries = 3;
|
||||||
|
const int intervalToRetry = 2; //2 seconds
|
||||||
|
const int maxRetryForCircuitBraker = 5;
|
||||||
|
const int intervalForCircuitBraker = 5; //5 seconds
|
||||||
|
|
||||||
|
var builder = WebApplication.CreateBuilder(args);
|
||||||
|
|
||||||
|
// Add services to the container.
|
||||||
|
var authkey = builder.Configuration.GetValue<string>("JwtSettings:securitykey");
|
||||||
|
|
||||||
|
|
||||||
|
builder.Services.AddAuthentication().
|
||||||
|
AddJwtBearer("DamageApp", item =>
|
||||||
|
{
|
||||||
|
|
||||||
|
item.RequireHttpsMetadata = true;
|
||||||
|
item.SaveToken = true;
|
||||||
|
item.TokenValidationParameters = new TokenValidationParameters()
|
||||||
|
{
|
||||||
|
ValidateIssuerSigningKey = true,
|
||||||
|
IssuerSigningKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(authkey)),
|
||||||
|
ValidateIssuer = false,
|
||||||
|
ValidateAudience = false,
|
||||||
|
ClockSkew = TimeSpan.Zero
|
||||||
|
};
|
||||||
|
}).AddJwtBearer("Dadeschools", options =>
|
||||||
|
{
|
||||||
|
options.Authority = builder.Configuration["Dadeschools:Authority"];
|
||||||
|
options.TokenValidationParameters.ValidTypes = new[] { "at+jwt" };
|
||||||
|
options.TokenValidationParameters.ValidateAudience = false;
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
builder.Services.AddAuthorization(options =>
|
||||||
|
{
|
||||||
|
var DamageAppPolicy = new AuthorizationPolicyBuilder()
|
||||||
|
.RequireAuthenticatedUser()
|
||||||
|
.AddAuthenticationSchemes("DamageApp")
|
||||||
|
.Build();
|
||||||
|
var DadeschoolsPolicy = new AuthorizationPolicyBuilder()
|
||||||
|
.RequireAuthenticatedUser()
|
||||||
|
.AddAuthenticationSchemes("Dadeschools")
|
||||||
|
.Build();
|
||||||
|
|
||||||
|
var allPolicy = new AuthorizationPolicyBuilder()
|
||||||
|
.RequireAuthenticatedUser()
|
||||||
|
.AddAuthenticationSchemes("DamageApp", "Dadeschools")
|
||||||
|
.Build();
|
||||||
|
options.AddPolicy("DamageApp", DamageAppPolicy);
|
||||||
|
options.AddPolicy("Dadeschools", DadeschoolsPolicy);
|
||||||
|
options.AddPolicy("AllPolicies", allPolicy);
|
||||||
|
options.DefaultPolicy = options.GetPolicy("DamageApp")!;
|
||||||
|
});
|
||||||
|
|
||||||
|
var _jwtsettings = builder.Configuration.GetSection("JwtSettings");
|
||||||
|
builder.Services.Configure<JwtSettings>(_jwtsettings);
|
||||||
|
|
||||||
|
builder.Services.AddControllers();
|
||||||
|
// Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
|
||||||
|
builder.Services.AddScoped<IUsersAccessProvider, UsersAccessProvider>();
|
||||||
|
builder.Services.AddScoped<ITokenServiceProvider, TokenServiceProvider>();
|
||||||
|
builder.Services.AddScoped<IEmployeeServiceProvider, EmployeeServiceProvider>();
|
||||||
|
|
||||||
|
builder.Services.AddHttpClient<IHttpUtil, HttpUtil>().
|
||||||
|
AddTransientHttpErrorPolicy(policy => policy.WaitAndRetryAsync(maxApiCallRetries, _ => TimeSpan.FromSeconds(intervalToRetry))).
|
||||||
|
AddTransientHttpErrorPolicy(policy => policy.CircuitBreakerAsync(maxRetryForCircuitBraker, TimeSpan.FromSeconds(intervalForCircuitBraker)));
|
||||||
|
|
||||||
|
builder.Services.AddAutoMapper(AppDomain.CurrentDomain.GetAssemblies());
|
||||||
|
builder.Services.AddEndpointsApiExplorer();
|
||||||
|
//builder.Services.AddSwaggerGen();
|
||||||
|
|
||||||
|
builder.Services.AddSwaggerGen(options =>
|
||||||
|
{
|
||||||
|
|
||||||
|
// Include XML comments from your assembly
|
||||||
|
var xmlFile = $"{Assembly.GetExecutingAssembly().GetName().Name}.xml";
|
||||||
|
var xmlPath = Path.Combine(AppContext.BaseDirectory, xmlFile);
|
||||||
|
//options.IncludeXmlComments(xmlPath);
|
||||||
|
|
||||||
|
OpenApiSecurityScheme securityDefinition = new OpenApiSecurityScheme()
|
||||||
|
{
|
||||||
|
Name = "Bearer",
|
||||||
|
BearerFormat = "JWT",
|
||||||
|
Scheme = "bearer",
|
||||||
|
Description = "Specify the authorization token.",
|
||||||
|
In = ParameterLocation.Header,
|
||||||
|
Type = SecuritySchemeType.Http,
|
||||||
|
};
|
||||||
|
|
||||||
|
options.AddSecurityDefinition("jwt_auth", securityDefinition);
|
||||||
|
|
||||||
|
// Make sure swagger UI requires a Bearer token specified
|
||||||
|
OpenApiSecurityScheme securityScheme = new OpenApiSecurityScheme()
|
||||||
|
{
|
||||||
|
Reference = new OpenApiReference()
|
||||||
|
{
|
||||||
|
Id = "jwt_auth",
|
||||||
|
Type = ReferenceType.SecurityScheme
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
OpenApiSecurityRequirement securityRequirements = new OpenApiSecurityRequirement()
|
||||||
|
{
|
||||||
|
{securityScheme, new string[] { }},
|
||||||
|
};
|
||||||
|
|
||||||
|
options.AddSecurityRequirement(securityRequirements);
|
||||||
|
});
|
||||||
|
|
||||||
|
builder.Services.AddDbContext<UsersAccessDbContext>(option =>
|
||||||
|
{
|
||||||
|
option.UseInMemoryDatabase("UsersAccess");
|
||||||
|
});
|
||||||
|
var app = builder.Build();
|
||||||
|
|
||||||
|
// Configure the HTTP request pipeline.
|
||||||
|
if (app.Environment.IsDevelopment())
|
||||||
|
{
|
||||||
|
app.UseSwagger();
|
||||||
|
app.UseSwaggerUI();
|
||||||
|
|
||||||
|
using (var serviceScope = app.Services.CreateScope())
|
||||||
|
{
|
||||||
|
var services = serviceScope.ServiceProvider;
|
||||||
|
var usersAccessProvider = services.GetRequiredService<IUsersAccessProvider>();
|
||||||
|
usersAccessProvider.seedData();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
app.UseAuthentication();
|
||||||
|
app.UseAuthorization();
|
||||||
|
|
||||||
|
app.MapControllers();
|
||||||
|
app.Run();
|
Loading…
Reference in New Issue
Block a user