ruby-curl 0.0.0 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/Gemfile +3 -0
- data/LICENSE.txt +21 -0
- data/README.md +48 -0
- data/ext/curl.c +402 -0
- data/ext/curl.h +37 -0
- data/ext/easy.c +554 -0
- data/ext/easy.h +30 -0
- data/ext/extconf.rb +26 -0
- data/ext/multi.c +133 -0
- data/ext/multi.h +18 -0
- data/lib/ruby-curl/version.rb +3 -0
- data/lib/ruby-curl.rb +4 -1
- data/ruby-curl.gemspec +40 -0
- metadata +83 -18
data/ext/easy.c
ADDED
@@ -0,0 +1,554 @@
|
|
1
|
+
#include "easy.h"
|
2
|
+
|
3
|
+
extern VALUE rb_mCurl;
|
4
|
+
|
5
|
+
VALUE rb_cEasy;
|
6
|
+
|
7
|
+
static VALUE rb_curl_easy_strerror(VALUE self, VALUE errornum) {
|
8
|
+
const char *error_str;
|
9
|
+
|
10
|
+
error_str = curl_easy_strerror(NUM2LONG(errornum));
|
11
|
+
|
12
|
+
return rb_str_new2(error_str);
|
13
|
+
}
|
14
|
+
|
15
|
+
static inline struct curl_slist *rb_array_to_curl_slist(VALUE arr, struct curl_slist *slist) {
|
16
|
+
long arr_len;
|
17
|
+
VALUE arr_ele;
|
18
|
+
|
19
|
+
if(TYPE(arr) == T_ARRAY) {
|
20
|
+
arr_len = RARRAY_LEN(arr);
|
21
|
+
curl_slist_free_all(slist);
|
22
|
+
|
23
|
+
for (long i = 0; i < arr_len; i++) {
|
24
|
+
arr_ele = RARRAY_AREF(arr, i);
|
25
|
+
slist = curl_slist_append(slist, StringValueCStr(arr_ele));
|
26
|
+
if (!slist) {
|
27
|
+
//Handle Error here.
|
28
|
+
}
|
29
|
+
}
|
30
|
+
}
|
31
|
+
else {
|
32
|
+
rb_raise(rb_eTypeError, "Array is required.");
|
33
|
+
}
|
34
|
+
|
35
|
+
return slist;
|
36
|
+
}
|
37
|
+
|
38
|
+
static inline VALUE curl_slist_to_rb_array(struct curl_slist *slist) {
|
39
|
+
VALUE arr = rb_ary_new();
|
40
|
+
|
41
|
+
while (slist) {
|
42
|
+
rb_ary_push(arr, rb_str_new_cstr(slist->data));
|
43
|
+
slist = slist->next;
|
44
|
+
}
|
45
|
+
|
46
|
+
return arr;
|
47
|
+
}
|
48
|
+
|
49
|
+
void rb_curl_mark(rb_curl_easy *rb_ch) {
|
50
|
+
rb_gc_mark(rb_ch->self);
|
51
|
+
rb_gc_mark(rb_ch->write_data);
|
52
|
+
rb_gc_mark(rb_ch->write_header_data);
|
53
|
+
rb_gc_mark(rb_ch->read_data);
|
54
|
+
}
|
55
|
+
|
56
|
+
void rb_curl_free(rb_curl_easy *rb_ch) {
|
57
|
+
curl_slist_free_all(rb_ch->curl_httpheader_slist);
|
58
|
+
curl_slist_free_all(rb_ch->curl_http200aliases_slist);
|
59
|
+
curl_slist_free_all(rb_ch->curl_hosts_slist);
|
60
|
+
curl_slist_free_all(rb_ch->curl_headers_slist);
|
61
|
+
free(rb_ch->write_function);
|
62
|
+
free(rb_ch->write_header_function);
|
63
|
+
free(rb_ch->read_function);
|
64
|
+
free(rb_ch);
|
65
|
+
}
|
66
|
+
|
67
|
+
static void rb_curl_zero_state(rb_curl_easy *rb_ch) {
|
68
|
+
rb_ch->ch = NULL;
|
69
|
+
rb_ch->write_function = NULL;
|
70
|
+
rb_ch->write_header_function = NULL;
|
71
|
+
rb_ch->read_function = NULL;
|
72
|
+
rb_ch->write_data = Qnil;
|
73
|
+
rb_ch->write_header_data = Qnil;
|
74
|
+
rb_ch->read_data = Qnil;
|
75
|
+
rb_ch->curl_httpheader_slist = NULL;
|
76
|
+
rb_ch->curl_http200aliases_slist = NULL;
|
77
|
+
rb_ch->curl_hosts_slist = NULL;
|
78
|
+
rb_ch->curl_headers_slist = NULL;
|
79
|
+
}
|
80
|
+
|
81
|
+
static VALUE rb_curl_easy_allocate(VALUE klass) {
|
82
|
+
rb_curl_easy *rb_ch;
|
83
|
+
|
84
|
+
rb_ch = ALLOC(rb_curl_easy);
|
85
|
+
rb_curl_zero_state(rb_ch);
|
86
|
+
|
87
|
+
return Data_Wrap_Struct(klass, rb_curl_mark, rb_curl_free, rb_ch);
|
88
|
+
}
|
89
|
+
|
90
|
+
static char* rb_normalized_str(VALUE str) {
|
91
|
+
|
92
|
+
if (rb_type(str) == T_SYMBOL)
|
93
|
+
str = rb_sym_to_s(str);
|
94
|
+
|
95
|
+
return StringValueCStr(str);
|
96
|
+
}
|
97
|
+
|
98
|
+
static size_t rb_curl_write(char *buffer, size_t size, size_t nmemb, rb_curl_easy *rb_ch) {
|
99
|
+
VALUE ret_val, buf, buf_io;
|
100
|
+
|
101
|
+
buf = rb_str_new(buffer, size * nmemb);
|
102
|
+
buf_io = rb_funcall(rb_const_get(rb_cObject, rb_intern("StringIO")), rb_intern("new"), 2, buf, rb_str_new2("rb"));
|
103
|
+
ret_val = rb_funcall(rb_ch->self, rb_intern(rb_ch->write_function), 4, buf_io, INT2NUM(size), INT2NUM(nmemb), rb_ch->write_data);
|
104
|
+
rb_funcall(buf_io, rb_intern("close"), 0);
|
105
|
+
|
106
|
+
return FIX2LONG(ret_val);
|
107
|
+
}
|
108
|
+
|
109
|
+
static size_t rb_curl_write_header(char *buffer, size_t size, size_t nmemb, rb_curl_easy *rb_ch) {
|
110
|
+
VALUE ret_val, buf, buf_io;
|
111
|
+
|
112
|
+
buf = rb_str_new(buffer, size * nmemb);
|
113
|
+
buf_io = rb_funcall(rb_const_get(rb_cObject, rb_intern("StringIO")), rb_intern("new"), 2, buf, rb_str_new2("rb"));
|
114
|
+
ret_val = rb_funcall(rb_ch->self, rb_intern(rb_ch->write_header_function), 4, buf_io, INT2NUM(size), INT2NUM(nmemb), rb_ch->write_header_data);
|
115
|
+
rb_funcall(buf_io, rb_intern("close"), 0);
|
116
|
+
|
117
|
+
return FIX2LONG(ret_val);
|
118
|
+
}
|
119
|
+
|
120
|
+
static size_t rb_curl_read(char *buffer, size_t size, size_t nmemb, rb_curl_easy *rb_ch) {
|
121
|
+
VALUE ret_val, buf, buf_io;
|
122
|
+
long ret_val_l;
|
123
|
+
|
124
|
+
buf = rb_str_new2("");
|
125
|
+
buf_io = rb_funcall(rb_const_get(rb_cObject, rb_intern("StringIO")), rb_intern("new"), 2, buf, rb_str_new2("wb"));
|
126
|
+
ret_val = rb_funcall(rb_ch->self, rb_intern(rb_ch->read_function), 4, buf_io, INT2NUM(size), INT2NUM(nmemb), rb_ch->read_data);
|
127
|
+
rb_funcall(buf_io, rb_intern("close"), 0);
|
128
|
+
|
129
|
+
ret_val_l = FIX2LONG(ret_val);
|
130
|
+
|
131
|
+
if (ret_val_l > 0) {
|
132
|
+
memcpy(buffer, RSTRING_PTR(buf), RSTRING_LEN(buf));
|
133
|
+
}
|
134
|
+
|
135
|
+
return ret_val_l;
|
136
|
+
}
|
137
|
+
|
138
|
+
static VALUE rb_curl_create_certinfo(struct curl_certinfo *curl_certinfo_chain) {
|
139
|
+
int i;
|
140
|
+
VALUE listcode = rb_ary_new();
|
141
|
+
|
142
|
+
if (curl_certinfo_chain) {
|
143
|
+
for (i=0; i < curl_certinfo_chain->num_of_certs; i++) {
|
144
|
+
struct curl_slist *slist;
|
145
|
+
|
146
|
+
for (slist = curl_certinfo_chain->certinfo[i]; slist; slist = slist->next) {
|
147
|
+
rb_ary_push(listcode, rb_str_new2(slist->data));
|
148
|
+
}
|
149
|
+
}
|
150
|
+
}
|
151
|
+
|
152
|
+
return listcode;
|
153
|
+
}
|
154
|
+
|
155
|
+
static VALUE rb_curl_easy_initialize(int argc, VALUE *argv, VALUE self) {
|
156
|
+
VALUE url;
|
157
|
+
rb_curl_easy *rb_ch;
|
158
|
+
|
159
|
+
rb_scan_args(argc, argv, "01", &url);
|
160
|
+
|
161
|
+
Data_Get_Struct(self, rb_curl_easy, rb_ch);
|
162
|
+
|
163
|
+
rb_ch->ch = curl_easy_init();
|
164
|
+
if (!rb_ch->ch) {
|
165
|
+
rb_raise(rb_eRuntimeError, "Failed to initialize easy handle");
|
166
|
+
}
|
167
|
+
|
168
|
+
rb_ch->self = self;
|
169
|
+
|
170
|
+
if (url != Qnil)
|
171
|
+
curl_easy_setopt(rb_ch->ch, CURLOPT_URL, StringValueCStr(url));
|
172
|
+
|
173
|
+
return self;
|
174
|
+
}
|
175
|
+
|
176
|
+
static VALUE rb_curl_easy_getinfo(VALUE self, VALUE info) {
|
177
|
+
CURLcode c_err_code;
|
178
|
+
rb_curl_easy *rb_ch;
|
179
|
+
VALUE info_val = Qnil, ret_val = rb_ary_new();
|
180
|
+
long information = NUM2LONG(info);
|
181
|
+
|
182
|
+
char *s_var;
|
183
|
+
long l_var;
|
184
|
+
double d_var;
|
185
|
+
struct curl_slist *curl_list_var = NULL;
|
186
|
+
struct curl_certinfo *curl_certinfo_chain = NULL;
|
187
|
+
|
188
|
+
Data_Get_Struct(self, rb_curl_easy, rb_ch);
|
189
|
+
|
190
|
+
switch (information) {
|
191
|
+
/* pointer to a char pointer */
|
192
|
+
#if LIBCURL_VERSION_NUM >= 0x071202 /* Curl::Info constants (Available since 7.18.2) */
|
193
|
+
case CURLINFO_REDIRECT_URL:
|
194
|
+
#endif
|
195
|
+
#if LIBCURL_VERSION_NUM >= 0x071300 /* Curl::Info constants (Available since 7.19.0) */
|
196
|
+
case CURLINFO_PRIMARY_IP:
|
197
|
+
#endif
|
198
|
+
case CURLINFO_CONTENT_TYPE:
|
199
|
+
#if LIBCURL_VERSION_NUM >= 0x071500 /* Curl::Info constants (Available since 7.21.0) */
|
200
|
+
case CURLINFO_LOCAL_IP:
|
201
|
+
#endif
|
202
|
+
#if LIBCURL_VERSION_NUM >= 0x073400 /* Curl::Info constants (Available since 7.52.0) */
|
203
|
+
case CURLINFO_SCHEME:
|
204
|
+
#endif
|
205
|
+
case CURLINFO_EFFECTIVE_URL:
|
206
|
+
c_err_code = curl_easy_getinfo(rb_ch->ch, information, &s_var);
|
207
|
+
if (c_err_code == CURLE_OK)
|
208
|
+
info_val = rb_str_new2(s_var);
|
209
|
+
break;
|
210
|
+
/* pointer to a long */
|
211
|
+
#if LIBCURL_VERSION_NUM >= 0x071500 /* Curl::Info constants (Available since 7.21.0) */
|
212
|
+
case CURLINFO_LOCAL_PORT:
|
213
|
+
case CURLINFO_PRIMARY_PORT:
|
214
|
+
#endif
|
215
|
+
#if LIBCURL_VERSION_NUM >= 0x073200 /* Curl::Info constants (Available since 7.50.0) */
|
216
|
+
case CURLINFO_HTTP_VERSION:
|
217
|
+
#endif
|
218
|
+
#if LIBCURL_VERSION_NUM >= 0x073400 /* Curl::Info constants (Available since 7.52.0) */
|
219
|
+
case CURLINFO_PROTOCOL:
|
220
|
+
case CURLINFO_PROXY_SSL_VERIFYRESULT:
|
221
|
+
#endif
|
222
|
+
case CURLINFO_RESPONSE_CODE:
|
223
|
+
case CURLINFO_HTTP_CONNECTCODE:
|
224
|
+
case CURLINFO_FILETIME:
|
225
|
+
case CURLINFO_REDIRECT_COUNT:
|
226
|
+
case CURLINFO_HEADER_SIZE:
|
227
|
+
case CURLINFO_REQUEST_SIZE:
|
228
|
+
case CURLINFO_SSL_VERIFYRESULT:
|
229
|
+
case CURLINFO_HTTPAUTH_AVAIL:
|
230
|
+
case CURLINFO_PROXYAUTH_AVAIL:
|
231
|
+
case CURLINFO_OS_ERRNO:
|
232
|
+
case CURLINFO_NUM_CONNECTS:
|
233
|
+
case CURLINFO_LASTSOCKET:
|
234
|
+
c_err_code = curl_easy_getinfo(rb_ch->ch, information, &l_var);
|
235
|
+
if (c_err_code == CURLE_OK)
|
236
|
+
info_val = INT2FIX(l_var);
|
237
|
+
break;
|
238
|
+
/* pointer to a double */
|
239
|
+
case CURLINFO_TOTAL_TIME:
|
240
|
+
case CURLINFO_NAMELOOKUP_TIME:
|
241
|
+
case CURLINFO_CONNECT_TIME:
|
242
|
+
case CURLINFO_PRETRANSFER_TIME:
|
243
|
+
case CURLINFO_STARTTRANSFER_TIME:
|
244
|
+
case CURLINFO_REDIRECT_TIME:
|
245
|
+
case CURLINFO_SIZE_UPLOAD:
|
246
|
+
case CURLINFO_SIZE_DOWNLOAD:
|
247
|
+
case CURLINFO_SPEED_UPLOAD:
|
248
|
+
case CURLINFO_SPEED_DOWNLOAD:
|
249
|
+
case CURLINFO_CONTENT_LENGTH_DOWNLOAD:
|
250
|
+
case CURLINFO_CONTENT_LENGTH_UPLOAD:
|
251
|
+
c_err_code = curl_easy_getinfo(rb_ch->ch, information, &d_var);
|
252
|
+
if (c_err_code == CURLE_OK)
|
253
|
+
info_val = DBL2NUM(d_var);
|
254
|
+
break;
|
255
|
+
/* pointer to a 'struct curl_certinfo *' */
|
256
|
+
#if LIBCURL_VERSION_NUM >= 0x071301 /* Curl::Info constants (Available since 7.19.1) */
|
257
|
+
case CURLINFO_CERTINFO:
|
258
|
+
c_err_code = curl_easy_getinfo(rb_ch->ch, information, &curl_certinfo_chain);
|
259
|
+
if (c_err_code == CURLE_OK)
|
260
|
+
info_val = rb_curl_create_certinfo(curl_certinfo_chain);
|
261
|
+
break;
|
262
|
+
#endif
|
263
|
+
/* address of a 'struct curl_slist *' */
|
264
|
+
case CURLINFO_SSL_ENGINES:
|
265
|
+
case CURLINFO_COOKIELIST:
|
266
|
+
c_err_code = curl_easy_getinfo(rb_ch->ch, information, &curl_list_var);
|
267
|
+
if (c_err_code == CURLE_OK) {
|
268
|
+
info_val = curl_slist_to_rb_array(curl_list_var);
|
269
|
+
curl_slist_free_all(curl_list_var);
|
270
|
+
}
|
271
|
+
break;
|
272
|
+
default:
|
273
|
+
rb_raise(rb_eTypeError, "Unsupported information.");
|
274
|
+
}
|
275
|
+
rb_ary_push(ret_val, info_val);
|
276
|
+
rb_ary_push(ret_val, LONG2NUM(c_err_code));
|
277
|
+
|
278
|
+
return ret_val;
|
279
|
+
}
|
280
|
+
|
281
|
+
|
282
|
+
static VALUE rb_curl_easy_setopt(VALUE self, VALUE opt, VALUE val) {
|
283
|
+
CURLcode c_err_code;
|
284
|
+
rb_curl_easy *rb_ch;
|
285
|
+
long option = NUM2LONG(opt);
|
286
|
+
|
287
|
+
Data_Get_Struct(self, rb_curl_easy, rb_ch);
|
288
|
+
|
289
|
+
switch (option) {
|
290
|
+
case CURLOPT_TIMEOUT:
|
291
|
+
case CURLOPT_FOLLOWLOCATION:
|
292
|
+
case CURLOPT_MAXREDIRS:
|
293
|
+
case CURLOPT_POST:
|
294
|
+
case CURLOPT_PUT:
|
295
|
+
case CURLOPT_HTTPGET:
|
296
|
+
case CURLOPT_UPLOAD:
|
297
|
+
case CURLOPT_VERBOSE:
|
298
|
+
#if LIBCURL_VERSION_NUM >= 0x070b02 /* Available since 7.11.2 */
|
299
|
+
case CURLOPT_TCP_NODELAY:
|
300
|
+
#endif
|
301
|
+
#if LIBCURL_VERSION_NUM >= 0x070e01 /* Available since 7.14.1 */
|
302
|
+
case CURLOPT_IGNORE_CONTENT_LENGTH:
|
303
|
+
#endif
|
304
|
+
#if LIBCURL_VERSION_NUM >= 0x070f02 /* Available since 7.15.2 */
|
305
|
+
case CURLOPT_CONNECT_ONLY:
|
306
|
+
case CURLOPT_LOCALPORT:
|
307
|
+
#endif
|
308
|
+
#if LIBCURL_VERSION_NUM >= 0x071000 /* Available since 7.16.0 */
|
309
|
+
case CURLOPT_SSL_SESSIONID_CACHE:
|
310
|
+
#endif
|
311
|
+
#if LIBCURL_VERSION_NUM >= 0x071002 /* Available since 7.16.2 */
|
312
|
+
case CURLOPT_CONNECTTIMEOUT_MS:
|
313
|
+
case CURLOPT_HTTP_CONTENT_DECODING:
|
314
|
+
case CURLOPT_HTTP_TRANSFER_DECODING:
|
315
|
+
case CURLOPT_TIMEOUT_MS:
|
316
|
+
#endif
|
317
|
+
#if LIBCURL_VERSION_NUM >= 0x071300 /* Available since 7.19.0 */
|
318
|
+
case CURLOPT_ADDRESS_SCOPE:
|
319
|
+
#endif
|
320
|
+
#if LIBCURL_VERSION_NUM >= 0x071301 /* Available since 7.19.1 */
|
321
|
+
case CURLOPT_CERTINFO:
|
322
|
+
case CURLOPT_POSTREDIR:
|
323
|
+
#endif
|
324
|
+
#if LIBCURL_VERSION_NUM >= 0x071600 /* Available since 7.22.0 */
|
325
|
+
case CURLOPT_GSSAPI_DELEGATION:
|
326
|
+
#endif
|
327
|
+
#if LIBCURL_VERSION_NUM >= 0x072a00 /* Available since 7.42.0 */
|
328
|
+
case CURLOPT_PATH_AS_IS:
|
329
|
+
#endif
|
330
|
+
#if LIBCURL_VERSION_NUM >= 0x072b00 /* Available since 7.43.0 */
|
331
|
+
case CURLOPT_PIPEWAIT:
|
332
|
+
#endif
|
333
|
+
#if LIBCURL_VERSION_NUM >= 0x070a06 /* Available since 7.10.6 */
|
334
|
+
case CURLOPT_HTTPAUTH:
|
335
|
+
#endif
|
336
|
+
#if LIBCURL_VERSION_NUM >= 0x070a07 /* Available since 7.10.7 */
|
337
|
+
case CURLOPT_PROXYAUTH:
|
338
|
+
#endif
|
339
|
+
#if LIBCURL_VERSION_NUM >= 0x070a08 /* Available since 7.10.8 */
|
340
|
+
case CURLOPT_IPRESOLVE:
|
341
|
+
case CURLOPT_MAXFILESIZE:
|
342
|
+
#endif
|
343
|
+
case CURLOPT_AUTOREFERER:
|
344
|
+
case CURLOPT_BUFFERSIZE:
|
345
|
+
case CURLOPT_CONNECTTIMEOUT:
|
346
|
+
case CURLOPT_COOKIESESSION:
|
347
|
+
case CURLOPT_CRLF:
|
348
|
+
case CURLOPT_DNS_CACHE_TIMEOUT:
|
349
|
+
case CURLOPT_DNS_USE_GLOBAL_CACHE:
|
350
|
+
case CURLOPT_FAILONERROR:
|
351
|
+
case CURLOPT_FILETIME:
|
352
|
+
case CURLOPT_FORBID_REUSE:
|
353
|
+
case CURLOPT_FRESH_CONNECT:
|
354
|
+
case CURLOPT_HEADER:
|
355
|
+
case CURLOPT_HTTPPROXYTUNNEL:
|
356
|
+
case CURLOPT_HTTP_VERSION:
|
357
|
+
case CURLOPT_INFILESIZE:
|
358
|
+
case CURLOPT_LOW_SPEED_LIMIT:
|
359
|
+
case CURLOPT_LOW_SPEED_TIME:
|
360
|
+
case CURLOPT_MAXCONNECTS:
|
361
|
+
case CURLOPT_NETRC:
|
362
|
+
case CURLOPT_NOBODY:
|
363
|
+
case CURLOPT_NOPROGRESS:
|
364
|
+
case CURLOPT_NOSIGNAL:
|
365
|
+
case CURLOPT_PORT:
|
366
|
+
case CURLOPT_PROXYPORT:
|
367
|
+
case CURLOPT_PROXYTYPE:
|
368
|
+
case CURLOPT_RESUME_FROM:
|
369
|
+
case CURLOPT_SSLENGINE_DEFAULT:
|
370
|
+
case CURLOPT_SSLVERSION:
|
371
|
+
case CURLOPT_SSL_VERIFYHOST:
|
372
|
+
case CURLOPT_SSL_VERIFYPEER:
|
373
|
+
case CURLOPT_TIMECONDITION:
|
374
|
+
case CURLOPT_TIMEVALUE:
|
375
|
+
case CURLOPT_UNRESTRICTED_AUTH:
|
376
|
+
#if LIBCURL_VERSION_NUM >= 0x071304 /* Available since 7.19.4 */
|
377
|
+
case CURLOPT_PROTOCOLS:
|
378
|
+
case CURLOPT_REDIR_PROTOCOLS:
|
379
|
+
case CURLOPT_SOCKS5_GSSAPI_NEC:
|
380
|
+
#endif
|
381
|
+
c_err_code = curl_easy_setopt(rb_ch->ch, option, NUM2LONG(val));
|
382
|
+
break;
|
383
|
+
case CURLOPT_URL:
|
384
|
+
#if LIBCURL_VERSION_NUM >= 0x071301 /* Available since 7.19.1 */
|
385
|
+
case CURLOPT_PASSWORD:
|
386
|
+
case CURLOPT_USERNAME:
|
387
|
+
#endif
|
388
|
+
#if LIBCURL_VERSION_NUM >= 0x071304 /* Available since 7.19.4 */
|
389
|
+
case CURLOPT_SOCKS5_GSSAPI_SERVICE:
|
390
|
+
#endif
|
391
|
+
case CURLOPT_CAINFO:
|
392
|
+
case CURLOPT_SSLCERTTYPE:
|
393
|
+
case CURLOPT_SSLKEYTYPE:
|
394
|
+
c_err_code = curl_easy_setopt(rb_ch->ch, option, StringValueCStr(val));
|
395
|
+
break;
|
396
|
+
case CURLOPT_POSTFIELDS:
|
397
|
+
case CURLOPT_USERAGENT:
|
398
|
+
case CURLOPT_USERPWD:
|
399
|
+
#if LIBCURL_VERSION_NUM >= 0x070b00 /* Available since 7.11.0 */
|
400
|
+
case CURLOPT_NETRC_FILE:
|
401
|
+
#endif
|
402
|
+
#if LIBCURL_VERSION_NUM >= 0x070e01 /* Available since 7.14.1 */
|
403
|
+
case CURLOPT_COOKIELIST:
|
404
|
+
#endif
|
405
|
+
#if LIBCURL_VERSION_NUM >= 0x071004 /* Available since 7.16.4 */
|
406
|
+
case CURLOPT_KRBLEVEL:
|
407
|
+
#endif
|
408
|
+
#if LIBCURL_VERSION_NUM >= 0x071300 /* Available since 7.19.0 */
|
409
|
+
case CURLOPT_CRLFILE:
|
410
|
+
case CURLOPT_ISSUERCERT:
|
411
|
+
case CURLOPT_KEYPASSWD:
|
412
|
+
#endif
|
413
|
+
#if LIBCURL_VERSION_NUM >= 0x071304 /* Available since 7.19.4 */
|
414
|
+
case CURLOPT_NOPROXY:
|
415
|
+
#endif
|
416
|
+
#if LIBCURL_VERSION_NUM >= 0x071504 /* Available since 7.21.4 */
|
417
|
+
case CURLOPT_TLSAUTH_PASSWORD:
|
418
|
+
case CURLOPT_TLSAUTH_TYPE:
|
419
|
+
#endif
|
420
|
+
case CURLOPT_TLSAUTH_USERNAME:
|
421
|
+
#if LIBCURL_VERSION_NUM >= 0x072800 /* Available since 7.40.0 */
|
422
|
+
case CURLOPT_UNIX_SOCKET_PATH:
|
423
|
+
#endif
|
424
|
+
case CURLOPT_CAPATH:
|
425
|
+
case CURLOPT_COOKIE:
|
426
|
+
case CURLOPT_COOKIEFILE:
|
427
|
+
case CURLOPT_COOKIEJAR:
|
428
|
+
case CURLOPT_CUSTOMREQUEST:
|
429
|
+
case CURLOPT_EGDSOCKET:
|
430
|
+
case CURLOPT_ENCODING:
|
431
|
+
case CURLOPT_INTERFACE:
|
432
|
+
case CURLOPT_PROXY:
|
433
|
+
case CURLOPT_PROXYUSERPWD:
|
434
|
+
case CURLOPT_RANDOM_FILE:
|
435
|
+
case CURLOPT_RANGE:
|
436
|
+
case CURLOPT_REFERER:
|
437
|
+
case CURLOPT_SSLCERT:
|
438
|
+
case CURLOPT_SSLENGINE:
|
439
|
+
case CURLOPT_SSLKEY:
|
440
|
+
case CURLOPT_SSL_CIPHER_LIST:
|
441
|
+
c_err_code = curl_easy_setopt(rb_ch->ch, option, NIL_P(val) ? NULL : StringValueCStr(val));
|
442
|
+
break;
|
443
|
+
case CURLOPT_WRITEFUNCTION:
|
444
|
+
if (NIL_P(val)) {
|
445
|
+
c_err_code = curl_easy_setopt(rb_ch->ch, CURLOPT_WRITEFUNCTION, NULL);
|
446
|
+
} else {
|
447
|
+
rb_ch->write_function = strdup(rb_normalized_str(val));
|
448
|
+
curl_easy_setopt(rb_ch->ch, CURLOPT_WRITEDATA, rb_ch);
|
449
|
+
c_err_code = curl_easy_setopt(rb_ch->ch, CURLOPT_WRITEFUNCTION, rb_curl_write);
|
450
|
+
}
|
451
|
+
break;
|
452
|
+
case CURLOPT_WRITEDATA:
|
453
|
+
rb_ch->write_data = val;
|
454
|
+
c_err_code = curl_easy_setopt(rb_ch->ch, CURLOPT_WRITEDATA, rb_ch);
|
455
|
+
break;
|
456
|
+
case CURLOPT_HEADERFUNCTION:
|
457
|
+
if (NIL_P(val)) {
|
458
|
+
c_err_code = curl_easy_setopt(rb_ch->ch, CURLOPT_HEADERFUNCTION, NULL);
|
459
|
+
} else {
|
460
|
+
rb_ch->write_header_function = strdup(rb_normalized_str(val));
|
461
|
+
curl_easy_setopt(rb_ch->ch, CURLOPT_HEADERDATA, rb_ch);
|
462
|
+
c_err_code = curl_easy_setopt(rb_ch->ch, CURLOPT_HEADERFUNCTION, rb_curl_write_header);
|
463
|
+
}
|
464
|
+
break;
|
465
|
+
case CURLOPT_HEADERDATA:
|
466
|
+
rb_ch->write_header_data = val;
|
467
|
+
c_err_code = curl_easy_setopt(rb_ch->ch, CURLOPT_HEADERDATA, rb_ch);
|
468
|
+
break;
|
469
|
+
case CURLOPT_READFUNCTION:
|
470
|
+
if (NIL_P(val)) {
|
471
|
+
c_err_code = curl_easy_setopt(rb_ch->ch, CURLOPT_READFUNCTION, NULL);
|
472
|
+
} else {
|
473
|
+
rb_ch->read_function = strdup(rb_normalized_str(val));
|
474
|
+
curl_easy_setopt(rb_ch->ch, CURLOPT_READDATA, rb_ch);
|
475
|
+
c_err_code = curl_easy_setopt(rb_ch->ch, CURLOPT_READFUNCTION, rb_curl_read);
|
476
|
+
}
|
477
|
+
break;
|
478
|
+
case CURLOPT_READDATA:
|
479
|
+
rb_ch->read_data = val;
|
480
|
+
c_err_code = curl_easy_setopt(rb_ch->ch, CURLOPT_READDATA, rb_ch);
|
481
|
+
break;
|
482
|
+
#if LIBCURL_VERSION_NUM >= 0x070f02 /* Available since 7.15.2 */
|
483
|
+
case CURLOPT_MAX_RECV_SPEED_LARGE:
|
484
|
+
case CURLOPT_MAX_SEND_SPEED_LARGE:
|
485
|
+
c_err_code = curl_easy_setopt(rb_ch->ch, option, (curl_off_t) NUM2LL(val));
|
486
|
+
break;
|
487
|
+
#endif
|
488
|
+
case CURLOPT_HTTP200ALIASES:
|
489
|
+
rb_ch->curl_http200aliases_slist = rb_array_to_curl_slist(val, rb_ch->curl_http200aliases_slist);
|
490
|
+
c_err_code = curl_easy_setopt(rb_ch->ch, CURLOPT_HTTP200ALIASES, rb_ch->curl_http200aliases_slist);
|
491
|
+
break;
|
492
|
+
case CURLOPT_HTTPHEADER:
|
493
|
+
rb_ch->curl_httpheader_slist = rb_array_to_curl_slist(val, rb_ch->curl_httpheader_slist);
|
494
|
+
c_err_code = curl_easy_setopt(rb_ch->ch, CURLOPT_HTTPHEADER, rb_ch->curl_httpheader_slist);
|
495
|
+
break;
|
496
|
+
#if LIBCURL_VERSION_NUM >= 0x071503 /* Available since 7.21.3 */
|
497
|
+
case CURLOPT_RESOLVE:
|
498
|
+
rb_ch->curl_hosts_slist = rb_array_to_curl_slist(val, rb_ch->curl_hosts_slist);
|
499
|
+
c_err_code = curl_easy_setopt(rb_ch->ch, CURLOPT_RESOLVE, rb_ch->curl_hosts_slist);
|
500
|
+
break;
|
501
|
+
#endif
|
502
|
+
#if LIBCURL_VERSION_NUM >= 0x072500 /* Available since 7.37.0 */
|
503
|
+
case CURLOPT_PROXYHEADER:
|
504
|
+
rb_ch->curl_headers_slist = rb_array_to_curl_slist(val, rb_ch->curl_headers_slist);
|
505
|
+
c_err_code = curl_easy_setopt(rb_ch->ch, CURLOPT_PROXYHEADER, rb_ch->curl_headers_slist);
|
506
|
+
break;
|
507
|
+
#endif
|
508
|
+
default:
|
509
|
+
rb_raise(rb_eTypeError, "Unsupported option.");
|
510
|
+
}
|
511
|
+
|
512
|
+
return LONG2NUM(c_err_code);
|
513
|
+
}
|
514
|
+
|
515
|
+
static VALUE rb_curl_easy_perform(VALUE self) {
|
516
|
+
CURLcode c_err_code;
|
517
|
+
rb_curl_easy *rb_ch;
|
518
|
+
|
519
|
+
Data_Get_Struct(self, rb_curl_easy, rb_ch);
|
520
|
+
c_err_code = curl_easy_perform(rb_ch->ch);
|
521
|
+
|
522
|
+
return LONG2NUM(c_err_code);
|
523
|
+
}
|
524
|
+
|
525
|
+
static VALUE rb_curl_easy_cleanup(VALUE self) {
|
526
|
+
rb_curl_easy *rb_ch;
|
527
|
+
|
528
|
+
Data_Get_Struct(self, rb_curl_easy, rb_ch);
|
529
|
+
curl_easy_cleanup(rb_ch->ch);
|
530
|
+
|
531
|
+
return Qnil;
|
532
|
+
}
|
533
|
+
|
534
|
+
static VALUE rb_curl_easy_reset(VALUE self) {
|
535
|
+
rb_curl_easy *rb_ch;
|
536
|
+
|
537
|
+
Data_Get_Struct(self, rb_curl_easy, rb_ch);
|
538
|
+
curl_easy_reset(rb_ch->ch);
|
539
|
+
rb_curl_zero_state(rb_ch);
|
540
|
+
|
541
|
+
return Qnil;
|
542
|
+
}
|
543
|
+
|
544
|
+
void Init_easy() {
|
545
|
+
rb_cEasy = rb_define_class_under(rb_mCurl, "Easy", rb_cObject);
|
546
|
+
rb_define_alloc_func(rb_cEasy, rb_curl_easy_allocate);
|
547
|
+
rb_define_singleton_method(rb_cEasy, "strerror", rb_curl_easy_strerror, 1);
|
548
|
+
rb_define_method(rb_cEasy, "initialize", rb_curl_easy_initialize, -1);
|
549
|
+
rb_define_method(rb_cEasy, "setopt", rb_curl_easy_setopt, 2);
|
550
|
+
rb_define_method(rb_cEasy, "getinfo", rb_curl_easy_getinfo, 1);
|
551
|
+
rb_define_method(rb_cEasy, "perform", rb_curl_easy_perform, 0);
|
552
|
+
rb_define_method(rb_cEasy, "cleanup", rb_curl_easy_cleanup, 0);
|
553
|
+
rb_define_method(rb_cEasy, "reset", rb_curl_easy_reset, 0);
|
554
|
+
}
|
data/ext/easy.h
ADDED
@@ -0,0 +1,30 @@
|
|
1
|
+
#ifndef RUBY_CURL_EASY_H
|
2
|
+
#define RUBY_CURL_EASY_H
|
3
|
+
|
4
|
+
#include <ruby.h>
|
5
|
+
#include <curl/curl.h>
|
6
|
+
#include <curl/easy.h>
|
7
|
+
|
8
|
+
typedef struct {
|
9
|
+
CURL *ch;
|
10
|
+
VALUE self;
|
11
|
+
|
12
|
+
char *write_function;
|
13
|
+
char *write_header_function;
|
14
|
+
char *read_function;
|
15
|
+
|
16
|
+
VALUE write_data;
|
17
|
+
VALUE write_header_data;
|
18
|
+
VALUE read_data;
|
19
|
+
|
20
|
+
struct curl_slist *curl_httpheader_slist;
|
21
|
+
struct curl_slist *curl_http200aliases_slist;
|
22
|
+
struct curl_slist *curl_hosts_slist;
|
23
|
+
struct curl_slist *curl_headers_slist;
|
24
|
+
} rb_curl_easy;
|
25
|
+
|
26
|
+
extern VALUE rb_cEasy;
|
27
|
+
|
28
|
+
extern void Init_easy();
|
29
|
+
|
30
|
+
#endif
|
data/ext/extconf.rb
ADDED
@@ -0,0 +1,26 @@
|
|
1
|
+
require 'mkmf'
|
2
|
+
|
3
|
+
dir_config('curl')
|
4
|
+
|
5
|
+
if find_executable('curl-config')
|
6
|
+
$CFLAGS << " #{`curl-config --cflags`.strip} -g"
|
7
|
+
if ENV['STATIC_BUILD']
|
8
|
+
$LIBS << " #{`curl-config --static-libs`.strip}"
|
9
|
+
else
|
10
|
+
$LIBS << " #{`curl-config --libs`.strip}"
|
11
|
+
end
|
12
|
+
ca_bundle_path=`curl-config --ca`.strip
|
13
|
+
if !ca_bundle_path.nil? and ca_bundle_path != ''
|
14
|
+
$defs.push( %{-D HAVE_CURL_CONFIG_CA} )
|
15
|
+
$defs.push( %{-D CURL_CONFIG_CA='#{ca_bundle_path.inspect}'} )
|
16
|
+
end
|
17
|
+
elsif !have_library('curl') or !have_header('curl/curl.h')
|
18
|
+
fail <<-EOM
|
19
|
+
Can't find libcurl or curl/curl.h
|
20
|
+
|
21
|
+
Try passing --with-curl-dir or --with-curl-lib and --with-curl-include
|
22
|
+
options to extconf.
|
23
|
+
EOM
|
24
|
+
end
|
25
|
+
|
26
|
+
create_makefile('curl')
|