source: trunk/zoo-project/zoo-kernel/ulinet.c @ 303

Last change on this file since 303 was 274, checked in by djay, 13 years ago

Solving bugs #43 and #42

File size: 13.0 KB
Line 
1/**
2 *  ulinet.c
3 *
4 * Author : Gérald FENOY
5 *
6 * Copyright (c) 2008-2010 GeoLabs SARL
7 *
8 * Permission is hereby granted, free of charge, to any person obtaining a copy
9 * of this software and associated documentation files (the "Software"), to deal
10 * in the Software without restriction, including without limitation the rights
11 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12 * copies of the Software, and to permit persons to whom the Software is
13 * furnished to do so, subject to the following conditions:
14 *
15 * The above copyright notice and this permission notice shall be included in
16 * all copies or substantial portions of the Software.
17 *
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24 * THE SOFTWARE.
25 *
26 */
27
28#define _ULINET
29#include "ulinet.h"
30#include <assert.h>
31
32size_t write_data_into(void *buffer, size_t size, size_t nmemb, void *data){
33  size_t realsize = size * nmemb;
34  HINTERNET *psInternet;
35  if(buffer==NULL){
36    buffer=NULL;
37    return -1;
38  }
39  psInternet=(HINTERNET *)data;
40  if(psInternet->pabyData){
41    psInternet->pabyData=(char*)realloc(psInternet->pabyData,psInternet->nDataLen+realsize+1);
42    psInternet->nDataAlloc+=psInternet->nDataLen+realsize+1;
43  }
44  else{
45    psInternet->pabyData=(char*)malloc(psInternet->nDataLen+realsize+1);
46    psInternet->nDataAlloc=realsize+1;
47  }
48
49  if (psInternet->pabyData) {
50    memcpy( psInternet->pabyData + psInternet->nDataLen, buffer, realsize);
51    psInternet->nDataLen += realsize;
52    psInternet->pabyData[psInternet->nDataLen] = 0;
53  }
54
55  buffer=NULL;
56  return realsize;
57}
58
59size_t header_write_data(void *buffer, size_t size, size_t nmemb, void *data){
60  if(strncmp("Set-Cookie: ",buffer,12)==0){
61    int i;
62    char env[1024];
63    char path[1024];
64    char domain[1024];
65        char* tmp;
66    for(i=0;i<12;i++)
67#ifndef WIN32
68      buffer++;
69#else
70        ;
71#endif
72    sscanf(buffer,"%s; path=%s; domain=%s",env,path,domain);
73    tmp=strcat(env,CCookie);
74#ifdef MSG_LAF_OUT
75    printf("\n**Cookie env : [%s] , path : [%s], domain : [%s]**\n",env,path,domain);
76    printf("buffer : %d (%s) (%s) (%s)\n",(buffer==NULL),buffer,tmp,CCookie);
77#endif
78    strcpy(CCookie,tmp);
79  }
80  return size * nmemb;//write_data_into(buffer,size,nmemb,data,HEADER);
81};
82
83
84void setProxy(CURL* handle,char* host,long port){
85}
86
87/**
88 * MACOSX
89 */
90#if defined(macintosh) || (defined(__MACH__) && defined(__APPLE__))
91
92
93char* CFStringToCString(CFStringRef dest,char *buffer){
94  CFStringEncoding encoding = kCFStringEncodingUTF8;
95  Boolean bool2 = CFStringGetCString(dest,buffer,1024,encoding);
96  if(bool2){
97    printf("Loaded into local_buffer");
98    return buffer;
99  }
100  return NULL;
101}
102
103OSStatus setProxiesForProtcol(CURL* handle,const char *proto){
104  OSStatus              err;
105  CFDictionaryRef proxyDict;
106  CFArrayRef            proxies;
107 
108  CFStringRef key_enabled;
109  CFStringRef key_host;
110  CFStringRef key_port;
111 
112  bool proxy_enabled;
113  char *proxy_host;
114  long proxy_port;
115 
116  proxyDict = NULL;
117  proxies = NULL;
118
119  err = noErr;
120  proxyDict = SCDynamicStoreCopyProxies(NULL);
121
122  if(proto=="http"){
123      key_enabled=kSCPropNetProxiesHTTPEnable;
124      key_host=kSCPropNetProxiesHTTPProxy;
125      key_port=kSCPropNetProxiesHTTPPort;
126  }
127  else
128    if(proto=="https"){
129      key_enabled=kSCPropNetProxiesHTTPSEnable;
130      key_host=kSCPropNetProxiesHTTPSProxy;
131      key_port=kSCPropNetProxiesHTTPSPort;
132    }
133
134  CFNumberGetValue(CFDictionaryGetValue(proxyDict,key_enabled),kCFNumberIntType,&proxy_enabled);
135  if(proxy_enabled){
136    CFNumberGetValue(CFDictionaryGetValue(proxyDict,key_port),CFNumberGetType(CFDictionaryGetValue(proxyDict,key_port)),&proxy_port);
137    char buffer[1024];
138    CFStringToCString(CFDictionaryGetValue(proxyDict,key_host),buffer);
139    proxy_host=buffer;
140
141#ifdef MSG_LAF_VERBOSE
142    printf("\n**[PROXY SETTINGS DETECTION %s (%d) %s:%li (%s)]**\n",proto,proxy_enabled,(char*)proxy_host,proxy_port,buffer);
143#endif
144
145    if (proxyDict == NULL) {
146      err = coreFoundationUnknownErr;
147    }
148
149    setProxy(handle,proxy_host,proxy_port);
150  }
151  return err;
152}
153#else
154/**
155 * Linux (Gnome)
156 */
157bool setProxiesForProtcol(CURL* handle,const char *proto){
158#ifdef MSG_LAF_VERBOSE
159  fprintf( stderr, "setProxiesForProtocol (do nothing) ...\n" );
160#endif
161}
162#endif
163
164HINTERNET InternetOpen(char* lpszAgent,int dwAccessType,char* lpszProxyName,char* lpszProxyBypass,int dwFlags){
165 
166  HINTERNET ret;
167  struct MemoryStruct header;
168  ret.hasCacheFile=0;
169  ret.nDataAlloc = 0;
170
171  ret.handle=curl_easy_init();
172
173  curl_easy_setopt(ret.handle, CURLOPT_COOKIEFILE, "ALL");
174#ifndef TIGER
175  curl_easy_setopt(ret.handle, CURLOPT_COOKIELIST, "ALL");
176#endif
177  curl_easy_setopt(ret.handle, CURLOPT_USERAGENT, lpszAgent);
178 
179  curl_easy_setopt(ret.handle,CURLOPT_FOLLOWLOCATION,1);
180  curl_easy_setopt(ret.handle,CURLOPT_MAXREDIRS,3);
181 
182  header.memory=NULL;
183  header.size = 0;
184
185  curl_easy_setopt(ret.handle, CURLOPT_HEADERFUNCTION, header_write_data);
186  curl_easy_setopt(ret.handle, CURLOPT_WRITEHEADER, (void *)&header);
187
188#ifdef MSG_LAF_VERBOSE
189  curl_easy_setopt(ret.handle, CURLOPT_VERBOSE, 1);
190#endif
191
192  return ret;
193}
194
195static size_t 
196CurlWriteCB(void *buffer, size_t size, size_t nmemb, void *reqInfo){
197  HINTERNET *psInternet = (HINTERNET *) reqInfo;
198
199  memcpy( psInternet->pabyData + psInternet->nDataLen, buffer,  nmemb * size );
200  psInternet->nDataLen += nmemb * size;
201  psInternet->pabyData[psInternet->nDataLen] = 0;
202
203  return nmemb *size;
204}
205
206void InternetCloseHandle(HINTERNET handle){
207  if(handle.hasCacheFile>0){
208    fclose(handle.file);
209    unlink(handle.filename);
210  }
211  else{
212    handle.pabyData = NULL;
213    handle.nDataAlloc = handle.nDataLen = 0;
214  }
215  if(handle.handle)
216    curl_easy_cleanup(handle.handle);
217  curl_global_cleanup();
218}
219
220HINTERNET InternetOpenUrl(HINTERNET hInternet,LPCTSTR lpszUrl,LPCTSTR lpszHeaders,size_t dwHeadersLength,size_t dwFlags,size_t dwContext){
221
222  char filename[255];
223  hInternet.nDataLen = 0;
224
225  hInternet.nDataAlloc = 0;
226  hInternet.pabyData= NULL;
227     
228  switch(dwFlags)
229    {
230    case INTERNET_FLAG_NO_CACHE_WRITE:   
231      hInternet.hasCacheFile=-1;
232      curl_easy_setopt(hInternet.handle, CURLOPT_WRITEFUNCTION, write_data_into);
233      curl_easy_setopt(hInternet.handle, CURLOPT_WRITEDATA, &hInternet);
234      break;
235    default:
236      sprintf(filename,"/tmp/ZOO_Cache%d",(int)time(NULL));
237      filename[24]=0;
238      fprintf(stderr,"file=%s",filename);
239#ifdef MSG_LAF_VERBOSE
240      fprintf(stderr,"file=%s",filename);
241#endif
242      hInternet.filename=filename;
243      hInternet.file=fopen(hInternet.filename,"w+");
244   
245      hInternet.hasCacheFile=1;
246      curl_easy_setopt(hInternet.handle, CURLOPT_WRITEFUNCTION, NULL);
247      curl_easy_setopt(hInternet.handle, CURLOPT_WRITEDATA, hInternet.file);
248      hInternet.nDataLen=0;
249      break;
250    }
251#ifdef ULINET_DEBUG
252  fprintf(stderr,"URL (%s)\nBODY (%s)\n",lpszUrl,lpszHeaders);
253#endif
254  if(lpszHeaders!=NULL && strlen(lpszHeaders)>0){
255#ifdef MSG_LAF_VERBOSE
256    fprintf(stderr,"FROM ULINET !!");
257    fprintf(stderr,"HEADER : %s\n",lpszHeaders);
258#endif
259    //curl_easy_setopt(hInternet.handle,CURLOPT_COOKIE,lpszHeaders);
260    curl_easy_setopt(hInternet.handle,CURLOPT_POST,1);
261#ifdef ULINET_DEBUG
262    fprintf(stderr,"** (%s) %d **\n",lpszHeaders,dwHeadersLength);
263#endif
264    curl_easy_setopt(hInternet.handle,CURLOPT_POSTFIELDS,lpszHeaders);
265    //curl_easy_setopt(hInternet.handle,CURLOPT_POSTFIELDSIZE,dwHeadersLength+1);
266    if(hInternet.header!=NULL)
267      curl_easy_setopt(hInternet.handle,CURLOPT_HTTPHEADER,hInternet.header);
268  }
269
270  curl_easy_setopt(hInternet.handle,CURLOPT_URL,lpszUrl);
271  curl_easy_perform(hInternet.handle);
272
273  return hInternet;
274};
275
276int freeCookieList(HINTERNET hInternet){
277  memset(&CCookie[0],0,1024);
278#ifndef TIGER
279  curl_easy_setopt(hInternet.handle, CURLOPT_COOKIELIST, "ALL");
280#endif
281  return 1;
282}
283
284int InternetReadFile(HINTERNET hInternet,LPVOID lpBuffer,int dwNumberOfBytesToRead, size_t *lpdwNumberOfBytesRead){
285  int dwDataSize;
286
287  if(hInternet.hasCacheFile>0){
288    fseek (hInternet.file , 0 , SEEK_END);
289    dwDataSize=ftell(hInternet.file); //taille du ficher
290    rewind (hInternet.file);
291  }
292  else{
293    memset(lpBuffer,0,hInternet.nDataLen+1);
294    memcpy( lpBuffer, hInternet.pabyData, hInternet.nDataLen );
295    dwDataSize=hInternet.nDataLen;
296    free( hInternet.pabyData );
297    hInternet.pabyData=NULL;
298  }
299
300  if( dwNumberOfBytesToRead /* buffer size */ < dwDataSize )
301    return 0;
302
303#ifdef MSG_LAF_VERBOSE
304  printf("\nfile size : %dko\n",dwDataSize/1024);
305#endif
306
307  if(hInternet.hasCacheFile>0){
308    *lpdwNumberOfBytesRead = fread(lpBuffer,1,dwDataSize,hInternet.file); 
309  }
310  else{
311    *lpdwNumberOfBytesRead = hInternet.nDataLen;
312    free( hInternet.pabyData );
313    hInternet.pabyData = NULL;
314    hInternet.nDataAlloc = hInternet.nDataLen = 0;
315  }
316
317  CCookie[0]=0;
318
319  if( *lpdwNumberOfBytesRead < dwDataSize )
320      return 0;
321  else
322      return 1; // TRUE
323}
324
325bool InternetGetCookie(LPCTSTR lpszUrl,LPCTSTR lpszCookieName,LPTSTR lpszCookieData,LPDWORD lpdwSize){
326
327  bool ret=1; 
328  int count=0;
329  int hasCookie=-1;
330  char TMP[1024];
331  int j;
332  int tmpC=0;
333  lpszUrl=NULL;
334
335  for(j=0;j<strlen(CCookie);j++){
336    if(lpszCookieName[count]==CCookie[j]){
337      hasCookie=1;
338      count++;
339      if(count==strlen(lpszCookieName))
340        break;
341      continue;
342    }
343  }
344
345  if(hasCookie>0){
346    if(CCookie[count]=='='){
347      int i=0;
348      count++;
349      for(i=count;i<strlen(CCookie);i++){
350        if(CCookie[i]!=';'){
351          TMP[tmpC]=CCookie[i];
352          tmpC++;
353        }
354        else{
355          break;
356        }
357      }
358    }
359  }
360  else
361    return -1;
362
363  TMP[tmpC]=0;
364  strncpy(lpszCookieData,TMP,strlen(TMP)+1);
365  lpdwSize=(size_t*) strlen(lpszCookieData);
366
367#ifdef MSG_LAF_VERBOSE
368  printf("Cookie returned : (%s)",(char*)lpszCookieData);
369#endif
370
371  return ret;
372
373}
374
375#ifdef USE_JS
376#include "jsapi.h"
377
378char* JSValToChar(JSContext* context, jsval* arg) {
379  if(!JSVAL_IS_STRING(*arg)) {
380    return NULL;
381  }
382  char *c, *tmp;
383  JSString *jsmsg;
384  size_t len;
385  jsmsg = JS_ValueToString(context,*arg);
386  len = JS_GetStringLength(jsmsg);
387  tmp = JS_EncodeString(context,jsmsg);
388  c = (char*)malloc((len+1)*sizeof(char));
389  c[len] = '\0';
390  int i;
391#ifdef ULINET_DEBUG
392  fprintf(stderr,"%d \n",len);
393#endif
394  for(i = 0;i < len;i++) {
395    c[i] = tmp[i];
396    c[i+1] = 0;
397  }
398#ifdef ULINET_DEBUG
399  fprintf(stderr,"%s \n",c);
400#endif
401  return c;
402}
403
404HINTERNET setHeader(HINTERNET handle,JSContext *cx,JSObject *header){
405  jsuint length=0;
406#ifdef ULINET_DEBUG
407  fprintf(stderr,"setHeader\n");
408#endif
409  if(JS_IsArrayObject(cx,header)){
410#ifdef ULINET_DEBUG
411    fprintf(stderr,"header is an array\n");
412#endif
413    JS_GetArrayLength(cx,header,&length);
414#ifdef ULINET_DEBUG
415    fprintf(stderr,"header is an array of %d elements\n",length);
416#endif
417    jsint i=0;
418    handle.header=NULL;
419    for(i=0;i<length;i++){
420      jsval tmp;
421      JS_GetElement(cx,header,i,&tmp);
422      char *tmp1=JSValToChar(cx,&tmp);
423#ifdef ULINET_DEBUG
424      fprintf(stderr,"Element of array n° %d, value : %s\n",i,tmp1);
425#endif
426      handle.header=curl_slist_append(handle.header, tmp1);
427      free(tmp1);
428    }
429  }
430  else{
431    fprintf(stderr,"not an array !!!!!!!\n");
432  }
433  return handle;
434}
435
436JSBool
437JSRequest(JSContext *cx, uintN argc, jsval *argv1)
438{
439  jsval *argv = JS_ARGV(cx,argv1);
440  HINTERNET hInternet;
441  char *url;
442  char *method;
443  JS_MaybeGC(cx);
444  hInternet=InternetOpen((LPCTSTR)"ZooWPSClient\0",
445                         INTERNET_OPEN_TYPE_PRECONFIG,
446                         NULL,NULL, 0);
447  if(!CHECK_INET_HANDLE(hInternet))
448    return JS_FALSE;
449  int i=0;
450  if(argc>=2){
451    method=JSValToChar(cx,&argv[0]);
452    url=JSValToChar(cx,&argv[1]);
453  }
454  else{
455    method=strdup("GET");
456    url=JSValToChar(cx,argv);
457  }
458  HINTERNET res;
459  if(argc==4){
460    char *body;
461    body=JSValToChar(cx,&argv[2]);
462    JSObject *header=JSVAL_TO_OBJECT(argv[3]);
463    HINTERNET res1;
464#ifdef ULINET_DEBUG
465    fprintf(stderr,"URL (%s) \nBODY (%s)\n",url,body);
466#endif
467    if(JS_IsArrayObject(cx,header))
468      res1=setHeader(hInternet,cx,header);
469#ifdef ULINET_DEBUG
470    fprintf(stderr,"BODY (%s)\n",body);
471#endif
472    res=InternetOpenUrl(res1,url,body,strlen(body),
473                        INTERNET_FLAG_NO_CACHE_WRITE,0);   
474    free(body);
475  }else{
476    if(argc==3){
477      char *body=JSValToChar(cx,&argv[2]);
478      res=InternetOpenUrl(hInternet,url,body,strlen(body),
479                          INTERNET_FLAG_NO_CACHE_WRITE,0);
480      free(body);
481    }
482    res=InternetOpenUrl(hInternet,url,NULL,0,
483                        INTERNET_FLAG_NO_CACHE_WRITE,0);
484  }
485  char* tmpValue=(char*)malloc((res.nDataLen+1)*sizeof(char));
486  size_t dwRead;
487  InternetReadFile(res,(LPVOID)tmpValue,res.nDataLen,&dwRead);
488#ifdef ULINET_DEBUG
489  fprintf(stderr,"content downloaded (%d) (%s) \n",dwRead,tmpValue);
490#endif
491  JS_SET_RVAL(cx, argv1,STRING_TO_JSVAL(JS_NewStringCopyN(cx,tmpValue,strlen(tmpValue))));
492  free(url);
493  if(argc>=2)
494    free(method);
495  if(argc==4 && res.header!=NULL){
496    curl_slist_free_all(res.header);
497  }
498  InternetCloseHandle(hInternet);
499  JS_MaybeGC(cx);
500  return JS_TRUE;
501}
502#endif
Note: See TracBrowser for help on using the repository browser.

Search

Context Navigation

ZOO Sponsors

http://www.zoo-project.org/trac/chrome/site/img/geolabs-logo.pnghttp://www.zoo-project.org/trac/chrome/site/img/neogeo-logo.png http://www.zoo-project.org/trac/chrome/site/img/apptech-logo.png http://www.zoo-project.org/trac/chrome/site/img/3liz-logo.png http://www.zoo-project.org/trac/chrome/site/img/gateway-logo.png

Become a sponsor !

Knowledge partners

http://www.zoo-project.org/trac/chrome/site/img/ocu-logo.png http://www.zoo-project.org/trac/chrome/site/img/gucas-logo.png http://www.zoo-project.org/trac/chrome/site/img/polimi-logo.png http://www.zoo-project.org/trac/chrome/site/img/fem-logo.png http://www.zoo-project.org/trac/chrome/site/img/supsi-logo.png http://www.zoo-project.org/trac/chrome/site/img/cumtb-logo.png

Become a knowledge partner

Related links

http://zoo-project.org/img/ogclogo.png http://zoo-project.org/img/osgeologo.png