3 Commits

Author SHA1 Message Date
Abdullah Atta
014c4e3b32 data: configure mongodb using connection string 2026-02-02 22:33:32 +05:00
Abdullah Atta
bf70a32b95 identity: temporarily disable password recovery & changing 2026-01-19 09:12:39 +05:00
Abdullah Atta
d047bd052e cors: add headers to allow the YouTube embed wrapper to be displayed in an iframe 2026-01-19 08:57:50 +05:00
4 changed files with 51 additions and 48 deletions

View File

@@ -33,9 +33,6 @@ namespace Streetwriters.Data.DbContexts
public static IMongoClient CreateMongoDbClient(IDbSettings dbSettings) public static IMongoClient CreateMongoDbClient(IDbSettings dbSettings)
{ {
var settings = MongoClientSettings.FromConnectionString(dbSettings.ConnectionString); var settings = MongoClientSettings.FromConnectionString(dbSettings.ConnectionString);
settings.MaxConnectionPoolSize = 500;
settings.MinConnectionPoolSize = 0;
settings.HeartbeatInterval = TimeSpan.FromSeconds(60);
return new MongoClient(settings); return new MongoClient(settings);
} }

View File

@@ -97,12 +97,12 @@ namespace Streetwriters.Identity.Controllers
} }
case TokenType.RESET_PASSWORD: case TokenType.RESET_PASSWORD:
{ {
if (!await UserManager.VerifyUserTokenAsync(user, TokenOptions.DefaultProvider, "ResetPassword", code)) // if (!await UserManager.VerifyUserTokenAsync(user, TokenOptions.DefaultProvider, "ResetPassword", code))
return BadRequest("Invalid token."); return BadRequest("Password reset is temporarily disabled due to some issues. It should be back soon. We apologize for the inconvenience.");
var authorizationCode = await UserManager.GenerateUserTokenAsync(user, TokenOptions.DefaultProvider, "PasswordResetAuthorizationCode"); // var authorizationCode = await UserManager.GenerateUserTokenAsync(user, TokenOptions.DefaultProvider, "PasswordResetAuthorizationCode");
var redirectUrl = $"{client.AccountRecoveryRedirectURL}?userId={userId}&code={authorizationCode}"; // var redirectUrl = $"{client.AccountRecoveryRedirectURL}?userId={userId}&code={authorizationCode}";
return RedirectPermanent(redirectUrl); // return RedirectPermanent(redirectUrl);
} }
default: default:
return BadRequest("Invalid type."); return BadRequest("Invalid type.");
@@ -149,21 +149,22 @@ namespace Streetwriters.Identity.Controllers
[EnableRateLimiting("strict")] [EnableRateLimiting("strict")]
public async Task<IActionResult> ResetUserPassword([FromForm] ResetPasswordForm form) public async Task<IActionResult> ResetUserPassword([FromForm] ResetPasswordForm form)
{ {
var client = Clients.FindClientById(form.ClientId); return BadRequest(new { error = "Password reset is temporarily disabled due to some issues. It should be back soon. We apologize for the inconvenience." });
if (client == null) return BadRequest("Invalid client_id."); // var client = Clients.FindClientById(form.ClientId);
// if (client == null) return BadRequest("Invalid client_id.");
var user = await UserManager.FindByEmailAsync(form.Email) ?? throw new Exception("User not found."); // var user = await UserManager.FindByEmailAsync(form.Email) ?? throw new Exception("User not found.");
if (!await UserService.IsUserValidAsync(UserManager, user, form.ClientId)) return Ok(); // if (!await UserService.IsUserValidAsync(UserManager, user, form.ClientId)) return Ok();
var code = await UserManager.GenerateUserTokenAsync(user, TokenOptions.DefaultProvider, "ResetPassword"); // var code = await UserManager.GenerateUserTokenAsync(user, TokenOptions.DefaultProvider, "ResetPassword");
var callbackUrl = Url.TokenLink(user.Id.ToString(), code, client.Id, TokenType.RESET_PASSWORD); // var callbackUrl = Url.TokenLink(user.Id.ToString(), code, client.Id, TokenType.RESET_PASSWORD);
#if (DEBUG || STAGING) // #if (DEBUG || STAGING)
return Ok(callbackUrl); // return Ok(callbackUrl);
#else // #else
logger.LogInformation("Password reset email sent to: {Email}, callback URL: {CallbackUrl}", user.Email, callbackUrl); // logger.LogInformation("Password reset email sent to: {Email}, callback URL: {CallbackUrl}", user.Email, callbackUrl);
await EmailSender.SendPasswordResetEmailAsync(user.Email, callbackUrl, client); // await EmailSender.SendPasswordResetEmailAsync(user.Email, callbackUrl, client);
return Ok(); // return Ok();
#endif // #endif
} }
[HttpPost("logout")] [HttpPost("logout")]
@@ -250,31 +251,33 @@ namespace Streetwriters.Identity.Controllers
} }
case "change_password": case "change_password":
{ {
ArgumentNullException.ThrowIfNull(form.OldPassword); return BadRequest(new { error = "Password change is temporarily disabled due to some issues. It should be back soon. We apologize for the inconvenience." });
ArgumentNullException.ThrowIfNull(form.NewPassword); // ArgumentNullException.ThrowIfNull(form.OldPassword);
var result = await UserManager.ChangePasswordAsync(user, form.OldPassword, form.NewPassword); // ArgumentNullException.ThrowIfNull(form.NewPassword);
if (result.Succeeded) // var result = await UserManager.ChangePasswordAsync(user, form.OldPassword, form.NewPassword);
{ // if (result.Succeeded)
await SendLogoutMessageAsync(user.Id.ToString(), "Password changed."); // {
return Ok(); // await SendLogoutMessageAsync(user.Id.ToString(), "Password changed.");
} // return Ok();
return BadRequest(result.Errors.ToErrors()); // }
// return BadRequest(result.Errors.ToErrors());
} }
case "reset_password": case "reset_password":
{ {
ArgumentNullException.ThrowIfNull(form.NewPassword); return BadRequest(new { error = "Password reset is temporarily disabled due to some issues. It should be back soon. We apologize for the inconvenience." });
var result = await UserManager.RemovePasswordAsync(user); // ArgumentNullException.ThrowIfNull(form.NewPassword);
if (result.Succeeded) // var result = await UserManager.RemovePasswordAsync(user);
{ // if (result.Succeeded)
await MFAService.ResetMFAAsync(user); // {
result = await UserManager.AddPasswordAsync(user, form.NewPassword); // await MFAService.ResetMFAAsync(user);
if (result.Succeeded) // result = await UserManager.AddPasswordAsync(user, form.NewPassword);
{ // if (result.Succeeded)
await SendLogoutMessageAsync(user.Id.ToString(), "Password reset."); // {
return Ok(); // await SendLogoutMessageAsync(user.Id.ToString(), "Password reset.");
} // return Ok();
} // }
return BadRequest(result.Errors.ToErrors()); // }
// return BadRequest(result.Errors.ToErrors());
} }
case "change_marketing_consent": case "change_marketing_consent":
{ {

View File

@@ -53,6 +53,7 @@ using Streetwriters.Identity.Interfaces;
using Streetwriters.Identity.Jobs; using Streetwriters.Identity.Jobs;
using Streetwriters.Identity.Services; using Streetwriters.Identity.Services;
using Streetwriters.Identity.Validation; using Streetwriters.Identity.Validation;
using IdentityServer4.MongoDB.Configuration;
namespace Streetwriters.Identity namespace Streetwriters.Identity
{ {
@@ -107,11 +108,6 @@ namespace Streetwriters.Identity
options.UsersCollection = "users"; options.UsersCollection = "users";
// options.MigrationCollection = "migration"; // options.MigrationCollection = "migration";
options.ConnectionString = connectionString; options.ConnectionString = connectionString;
options.ClusterConfigurator = builder =>
{
builder.ConfigureConnectionPool((c) => c.With(maxConnections: 500, minConnections: 0));
builder.ConfigureServer(s => s.With(heartbeatInterval: TimeSpan.FromSeconds(60)));
};
}).AddDefaultTokenProviders(); }).AddDefaultTokenProviders();
services.AddIdentityServer( services.AddIdentityServer(
@@ -137,6 +133,11 @@ namespace Streetwriters.Identity
.AddKeyManagement() .AddKeyManagement()
.AddFileSystemPersistence(Path.Combine(WebHostEnvironment.ContentRootPath, @"keystore")); .AddFileSystemPersistence(Path.Combine(WebHostEnvironment.ContentRootPath, @"keystore"));
services.Configure<MongoDBConfiguration>(options =>
{
options.ConnectionString = connectionString;
});
services.Configure<DataProtectionTokenProviderOptions>(options => services.Configure<DataProtectionTokenProviderOptions>(options =>
{ {
options.TokenLifespan = TimeSpan.FromHours(2); options.TokenLifespan = TimeSpan.FromHours(2);

View File

@@ -218,6 +218,8 @@ const server = Bun.serve({
status: 200, status: 200,
headers: { headers: {
"Content-Type": "text/html; charset=utf-8", "Content-Type": "text/html; charset=utf-8",
"Content-Security-Policy": "frame-ancestors *",
"X-Frame-Options": "ALLOWALL",
}, },
}); });
} }