536b656c6c79
536b656c6c79
Explore posts from servers
CC#
Created by 536b656c6c79 on 12/11/2024 in #help
App returning "Bad Request" before Controller method is called or ServiceFilter is triggered.
Hi I have an issue where I'm trying to send some user data to an endpoint from my frontend blazor server app to an api. Inspecting breakpoints tells me that the payload send is 100% correct. And the api call is made. But it only reaches somewhere before the whole controller. When I use a debugging Middleware I see that the request is made but it ends there. No more logs from inside the filter or controller method are logged and I just get the response bad request. Controller
[HttpPost]
[Route("auth0")]
[AllowAnonymous]
[ServiceFilter(typeof(AuthenticatedFrontendFilter))]
public async Task<IActionResult> CreateNewAuth0User([FromBody] UserDTO user)
{
if (!ModelState.IsValid)
{
return BadRequest(ModelState);
}
var result = await _mediator.Send(new CreateUserCommand() { _user = user });
return Created("", result);
}
[HttpPost]
[Route("auth0")]
[AllowAnonymous]
[ServiceFilter(typeof(AuthenticatedFrontendFilter))]
public async Task<IActionResult> CreateNewAuth0User([FromBody] UserDTO user)
{
if (!ModelState.IsValid)
{
return BadRequest(ModelState);
}
var result = await _mediator.Send(new CreateUserCommand() { _user = user });
return Created("", result);
}
Filter
public class AuthenticatedFrontendFilter : IActionFilter
{
private readonly EnvironmentWrapper _environmentWrapper;
private readonly ILogger<AuthenticatedFrontendFilter> _logger;

public AuthenticatedFrontendFilter(EnvironmentWrapper environmentWrapper, ILogger<AuthenticatedFrontendFilter> logger)
{
_environmentWrapper = environmentWrapper;
_logger = logger;
}
public void OnActionExecuting(ActionExecutingContext context)
{
if (!context.HttpContext.Request.Headers.TryGetValue("X-Api-Key", out var apiKey) || string.IsNullOrEmpty(apiKey))
{
_logger.LogWarning("Authentication failed: X-Api-Key header missing.");
context.Result = new UnauthorizedResult();
return;
}

if (apiKey != _environmentWrapper.APIKEY)
{
_logger.LogWarning("Authentication failed: Invalid X-Api-Key.");
context.Result = new UnauthorizedResult();
return;
}

_logger.LogInformation("Authentication successful.");
}
...
}
public class AuthenticatedFrontendFilter : IActionFilter
{
private readonly EnvironmentWrapper _environmentWrapper;
private readonly ILogger<AuthenticatedFrontendFilter> _logger;

public AuthenticatedFrontendFilter(EnvironmentWrapper environmentWrapper, ILogger<AuthenticatedFrontendFilter> logger)
{
_environmentWrapper = environmentWrapper;
_logger = logger;
}
public void OnActionExecuting(ActionExecutingContext context)
{
if (!context.HttpContext.Request.Headers.TryGetValue("X-Api-Key", out var apiKey) || string.IsNullOrEmpty(apiKey))
{
_logger.LogWarning("Authentication failed: X-Api-Key header missing.");
context.Result = new UnauthorizedResult();
return;
}

if (apiKey != _environmentWrapper.APIKEY)
{
_logger.LogWarning("Authentication failed: Invalid X-Api-Key.");
context.Result = new UnauthorizedResult();
return;
}

_logger.LogInformation("Authentication successful.");
}
...
}
6 replies
DIdiscord.js - Imagine ❄
Created by 536b656c6c79 on 1/23/2024 in #djs-questions
Recieved 1 instruction to send a webhook but it send twice with different contents.
We have a system in place that sends instructions to the bot with webhook id and token. Upon recieving the instructions the bot handles this perfectly but somehow send some webhooks twice with different contents. Does Discord.js do something behind the scenes to retry webhooks? We are using discordjs/rest v2.2.0 and discord.js v14.14.1 Node LTS 1.18
88 replies