本文整理汇总了C#中RestClient.ExecuteWithPolicyAsync方法的典型用法代码示例。如果您正苦于以下问题:C# RestClient.ExecuteWithPolicyAsync方法的具体用法?C# RestClient.ExecuteWithPolicyAsync怎么用?C# RestClient.ExecuteWithPolicyAsync使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类RestClient
的用法示例。
在下文中一共展示了RestClient.ExecuteWithPolicyAsync方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: LoginAsync
/// <summary>
/// Authenticate this client with the Zipato API REST service.
/// </summary>
/// <param name="userNameEmail">User name (typically the email address you use on my.zipato.com)</param>
/// <param name="password">Password</param>
public async Task LoginAsync(string userNameEmail, string password)
{
// First call user/init which returns us a nonce
_httpClient = new RestClient();
_httpClient.BaseUrl = ApiUrl;
var jsonSerializerSettings = new JsonSerializerSettings { ContractResolver = new CamelCasePropertyNamesContractResolver() };
_httpClient.JsonSerializerSettings = jsonSerializerSettings;
var initRequest = new RestRequest("user/init", HttpMethod.Get);
var initResult = await _httpClient.ExecuteWithPolicyAsync<InitResponse>(this, initRequest, byPassCheckInitialized:true);
if (!initResult.Success)
throw new CannotInitializeSessionException();
// Save the JSessionId, because we pass this as Cookie value to all future requests
Jessionid = initResult.JSessionId;
// SHA1-hash the password with the nonce (protects against cross-site forgery)
string token = Utils.GetToken(password, initResult.Nonce);
// Sign in with user name and token
var loginRequest = new RestRequest("user/login", HttpMethod.Get);
loginRequest.AddQueryString("username", userNameEmail);
loginRequest.AddQueryString("token", token);
var loginResult = await _httpClient.ExecuteWithPolicyAsync<UserSession>(this, loginRequest, byPassCheckInitialized: true);
if (!loginResult.Success)
throw new AuthenticationFailureException(loginResult.Error);
if (_requireZipaboxOnline)
{
_initialized = await CheckConnection();
}
else
_initialized = true;
}