private async Task <HttpResponseMessage> SendAsyncSemaphore(HttpRequestMessage requestMessage, int @try = 1, CancellationToken cancellationToken = default)
        {
            if (@try > config.MaxRefreshAttempts)
            {
                throw new TokenRefreshException();
            }

            var token = await GetTokenForRequest(requestMessage, cancellationToken);

            requestMessage.Headers.Authorization = new AuthenticationHeaderValue("Bearer", token);

            var response = await base.SendAsync(requestMessage, cancellationToken).ConfigureAwait(false);

            if (response.StatusCode == HttpStatusCode.Unauthorized)
            {
                tokenStore.InvalidateToken();
                return(await SendAsyncSemaphore(requestMessage, @try + 1, cancellationToken));
            }

            return(response);
        }