From 9fda99f2d08077862879e7df37eacb2c39b3414e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Patrick=20K=C3=BChnel?= Date: Sun, 5 Jan 2025 13:39:12 +0100 Subject: [PATCH] feat(BackendApiService): use separateEndpoint for no token installation info posts --- TeslaSolarCharger/Server/Services/BackendApiService.cs | 7 ++++--- TeslaSolarCharger/Shared/Wrappers/ConfigurationWrapper.cs | 1 - 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/TeslaSolarCharger/Server/Services/BackendApiService.cs b/TeslaSolarCharger/Server/Services/BackendApiService.cs index 0e0667b2f..9596b8927 100644 --- a/TeslaSolarCharger/Server/Services/BackendApiService.cs +++ b/TeslaSolarCharger/Server/Services/BackendApiService.cs @@ -159,11 +159,12 @@ public async Task PostInstallationInformation(string reason) var tokenState = await tokenHelper.GetBackendTokenState(true); var installationId = await tscConfigurationService.GetInstallationId().ConfigureAwait(false); var currentVersion = await GetCurrentVersion().ConfigureAwait(false); - var url = configurationWrapper.BackendApiBaseUrl() + $"Client/NotifyInstallation?version={Uri.EscapeDataString(currentVersion ?? string.Empty)}&infoReason{Uri.EscapeDataString(reason)}"; + using var httpClient = new HttpClient(); httpClient.Timeout = TimeSpan.FromSeconds(10); if (tokenState == TokenState.UpToDate) { + var url = configurationWrapper.BackendApiBaseUrl() + $"Client/NotifyInstallation?version={Uri.EscapeDataString(currentVersion ?? string.Empty)}&infoReason{Uri.EscapeDataString(reason)}"; var token = await teslaSolarChargerContext.BackendTokens.SingleAsync(); var request = new HttpRequestMessage(HttpMethod.Post, url); request.Headers.Authorization = new("Bearer", token.AccessToken); @@ -176,8 +177,8 @@ public async Task PostInstallationInformation(string reason) logger.LogWarning("Error while sending installation information to backend. StatusCode: {statusCode}. Trying again without token", response.StatusCode); } - url += $"&installationId={Uri.EscapeDataString(installationId.ToString())}"; - var nonTokenRequest = new HttpRequestMessage(HttpMethod.Post, url); + var noTokenUrl = configurationWrapper.BackendApiBaseUrl() + $"Client/NotifyInstallationAnonymous?version={Uri.EscapeDataString(currentVersion ?? string.Empty)}&infoReason{Uri.EscapeDataString(reason)}&installationId={Uri.EscapeDataString(installationId.ToString())}"; + var nonTokenRequest = new HttpRequestMessage(HttpMethod.Post, noTokenUrl); var nonTokenResponse = await httpClient.SendAsync(nonTokenRequest).ConfigureAwait(false); if (nonTokenResponse.IsSuccessStatusCode) { diff --git a/TeslaSolarCharger/Shared/Wrappers/ConfigurationWrapper.cs b/TeslaSolarCharger/Shared/Wrappers/ConfigurationWrapper.cs index aafb1e0df..33d5ffbc8 100644 --- a/TeslaSolarCharger/Shared/Wrappers/ConfigurationWrapper.cs +++ b/TeslaSolarCharger/Shared/Wrappers/ConfigurationWrapper.cs @@ -4,7 +4,6 @@ using Microsoft.Extensions.Configuration; using Microsoft.Extensions.Logging; using Newtonsoft.Json; -using System.Configuration; using TeslaSolarCharger.Shared.Contracts; using TeslaSolarCharger.Shared.Dtos.BaseConfiguration; using TeslaSolarCharger.Shared.Dtos.Contracts;