-
Notifications
You must be signed in to change notification settings - Fork 97
Expand file tree
/
Copy pathPreparedRequest.cs
More file actions
242 lines (216 loc) · 8.23 KB
/
PreparedRequest.cs
File metadata and controls
242 lines (216 loc) · 8.23 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
using System;
using System.Collections;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using Flurl.Http.Configuration;
using Flurl.Http.Content;
using net.openstack.Core;
using OpenStack.ObjectStorage.v1.Metadata;
using OpenStack.ObjectStorage.v1.Serialization;
using OpenStack.Serialization;
// ReSharper disable once CheckNamespace
namespace Flurl.Http
{
/// <summary>
/// Represents a prepared Flurl request which can be executed at a later time.
/// </summary>
/// <exclude />
public class PreparedRequest : FlurlClient
{
/// <summary>
/// Initializes a new instance of the <see cref="PreparedRequest"/> class.
/// </summary>
public PreparedRequest()
{
}
/// <summary>
/// Initializes a new instance of the <see cref="PreparedRequest"/> class.
/// </summary>
/// <param name="url">The URL.</param>
public PreparedRequest(string url) : base(url)
{
}
/// <summary>
/// Initializes a new instance of the <see cref="PreparedRequest"/> class.
/// </summary>
/// <param name="url">The URL.</param>
public PreparedRequest(Url url) : base(url)
{
}
/// <summary>
/// Initializes a new instance of the <see cref="PreparedRequest"/> class.
/// </summary>
/// <param name="url">The URL.</param>
/// <param name="autoDispose">Specifies if the request should be automatically disposed.</param>
public PreparedRequest(string url, bool autoDispose) : base(url, autoDispose)
{
}
/// <summary>
/// Initializes a new instance of the <see cref="PreparedRequest"/> class.
/// </summary>
/// <param name="url">The URL.</param>
/// <param name="autoDispose">Specifies if the request should be automatically disposed.</param>
public PreparedRequest(Url url, bool autoDispose) : base(url, autoDispose)
{
}
/// <summary>
/// The HTTP verb which will be used in the request.
/// </summary>
public HttpMethod Verb { get; protected set; }
/// <summary>
/// The HTTP content which will be used in the request.
/// </summary>
public HttpContent Content { get; protected set; }
/// <summary>
/// The optional canellation token which will be used in the request, defaults to None.
/// </summary>
public CancellationToken CancellationToken { get; protected set; }
/// <summary>
/// Apply default timeout to current Request
/// </summary>
/// <param name="defaultTimeout">The timeout to apply.</param>
/// <returns></returns>
public PreparedRequest SettingTimeout(TimeSpan defaultTimeout)
{
Settings.DefaultTimeout = defaultTimeout;
return this;
}
/// <summary>
/// Prepares the client to send a DELETE request
/// </summary>
public PreparedRequest PrepareDelete(CancellationToken cancellationToken = default(CancellationToken))
{
Verb = HttpMethod.Delete;
CancellationToken = cancellationToken;
return this;
}
/// <summary>
/// Prepares the client to send a DELETE request
/// </summary>
public PreparedRequest PrepareHead(CancellationToken cancellationToken = default(CancellationToken))
{
Verb = HttpMethod.Head;
CancellationToken = cancellationToken;
return this;
}
/// <summary>
/// Prepares the client to send a GET request
/// </summary>
public PreparedRequest PrepareGet(CancellationToken cancellationToken = default(CancellationToken))
{
Verb = HttpMethod.Get;
CancellationToken = cancellationToken;
return this;
}
/// <summary>
/// Prepares the client to send a PATCH request containing json
/// </summary>
public PreparedRequest PreparePatchJson(object data, CancellationToken cancellationToken = default(CancellationToken))
{
Verb = new HttpMethod("PATCH");
Content = new CapturedJsonContent(Settings.JsonSerializer.Serialize(data));
CancellationToken = cancellationToken;
return this;
}
/// <summary>
/// Prepares the client to send a POST request containing json
/// </summary>
public PreparedRequest PreparePostJson(object data, CancellationToken cancellationToken = default(CancellationToken))
{
Verb = HttpMethod.Post;
Content = new CapturedJsonContent(Settings.JsonSerializer.Serialize(data));
CancellationToken = cancellationToken;
return this;
}
/// <summary>
/// Prepares the client to send a POST request containing data in content Header
/// </summary>
/// <param name="formData"></param>
/// <param name="cancellationToken"></param>
/// <returns></returns>
public PreparedRequest PreparePostContentHeader(IEnumerable<KeyValuePair<string, IEnumerable<string>>> formData, CancellationToken cancellationToken = default(CancellationToken))
{
Verb = HttpMethod.Post;
Content = new System.Net.Http.StringContent("");
Content.Headers.Remove("Content-Type");
foreach (var pair in formData)
{
System.Net.Http.Headers.HttpHeaders headerColl;
switch (pair.Key.ToLowerInvariant())
{
case "cache-control":
headerColl = this.HttpClient.DefaultRequestHeaders;
break;
default:
headerColl = this.Content.Headers;
break;
}
headerColl.Add(pair.Key, pair.Value);
}
CancellationToken = cancellationToken;
return this;
}
/// <summary>
/// Prepares the client to send a POST request containing data in content Header
/// </summary>
/// <param name="data"></param>
/// <param name="cancellationToken"></param>
/// <returns></returns>
public PreparedRequest PreparePostContentTextPlain(string data, CancellationToken cancellationToken = default(CancellationToken))
{
Verb = HttpMethod.Post;
Content = new System.Net.Http.StringContent(data);
CancellationToken = cancellationToken;
return this;
}
/// <summary>
/// Prepares the client to send a PUT request containing json
/// </summary>
public PreparedRequest PreparePutJson(object data, CancellationToken cancellationToken = default(CancellationToken))
{
Verb = HttpMethod.Put;
Content = new CapturedJsonContent(Settings.JsonSerializer.Serialize(data));
CancellationToken = cancellationToken;
return this;
}
/// <summary>
/// Prepares the client to send a PUT request containing data in stream
/// </summary>
public PreparedRequest PreparePutStream(System.IO.Stream dataStream, CancellationToken cancellationToken = default(CancellationToken))
{
Verb = HttpMethod.Put;
Content = new CapturedStreamContent(dataStream);
CancellationToken = cancellationToken;
return this;
}
/// <summary>
/// Executes the built request
/// </summary>
public Task<HttpResponseMessage> SendAsync()
{
if(Verb == null)
throw new InvalidOperationException("Unable to execute request as nothing has been built yet.");
return SendAsync(Verb, Content, CancellationToken);
}
}
/// <summary />
public static class PreparedRequestExtensions
{
/// <summary>
/// Allow a specific set of HTTP status codes.
/// </summary>
/// <param name="request">The prepared request.</param>
/// <param name="statusCodes">The allowed status codes.</param>
/// <returns></returns>
public static PreparedRequest AllowHttpStatus(this PreparedRequest request, params HttpStatusCode[] statusCodes)
{
return (PreparedRequest)((FlurlClient)request).AllowHttpStatus(statusCodes);
}
}
}