#region Copyright notice and license
// Copyright 2019 The gRPC Authors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#endregion
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net.Http;
using System.Threading;
using System.Threading.Tasks;
namespace HotelPms.Client.Blazor.Util
{
///
/// A delegating handler that will add a subdirectory to the URI of gRPC requests.
///
public class GrpcSubDirHandler : DelegatingHandler
{
private readonly string _subdirectory;
private readonly IGlobalLoadingSpinner _loadingSpinnerService;
public GrpcSubDirHandler(HttpMessageHandler innerHandler, IGlobalLoadingSpinner loadingSpinnerService, string subdirectory) : base(innerHandler)
{
_subdirectory = subdirectory;
_loadingSpinnerService = loadingSpinnerService;
}
protected async override Task SendAsync(HttpRequestMessage request, CancellationToken cancellationToken)
{
//发送请求之前显示加载指示器
//EnvironmentSetting.Debug($"ShowAsync begin:{DateTime.Now.ToString("HH:mm:ss fff")}");
//await _loadingSpinnerService.ShowAsync(); //0.5秒
EnvironmentSetting.Debug($"SendAsync begin:{DateTime.Now.ToString("HH:mm:ss fff")}");
//发送请求
if (request.RequestUri != null && _subdirectory.Length > 0)
{
var url = $"{request.RequestUri.Scheme}://{request.RequestUri.Host}{_subdirectory}{request.RequestUri.AbsolutePath}";
EnvironmentSetting.Debug($"SendAsync Url⇒{url}");
request.RequestUri = new Uri(url, UriKind.Absolute);
}
else
{
EnvironmentSetting.Debug($"SendAsync Url⇒{request.RequestUri.AbsolutePath}");
}
var response = await base.SendAsync(request, cancellationToken);
EnvironmentSetting.Debug($"SendAsync End:{DateTime.Now.ToString("HH:mm:ss fff")}");
//收到结果之后隐藏加载指示器
//await _loadingSpinnerService.HideAsync();
//EnvironmentSetting.Debug($"HideAsync End:{DateTime.Now.ToString("HH:mm:ss fff")}");
return response;
}
}
}