summaryrefslogtreecommitdiff
path: root/client.c
diff options
context:
space:
mode:
authorꦌꦫꦶꦏ꧀ꦦꦿꦧꦮꦑꦩꦭ꧀ <erik@darapsa.co.id>2021-06-18 02:25:02 +0800
committerꦌꦫꦶꦏ꧀ꦦꦿꦧꦮꦑꦩꦭ꧀ <erik@darapsa.co.id>2021-06-18 02:25:02 +0800
commit1df77942aee0dbd6e79e5aa019d2bcb95c59e6ec (patch)
treed2c97d2fbd89c2a8999425899c984d7c43702323 /client.c
parentd8844d9038e99e2d6175c4a2d99f36bde28deae9 (diff)
Leave request as the minimum of what needs to be shared
Diffstat (limited to 'client.c')
-rw-r--r--client.c44
1 files changed, 42 insertions, 2 deletions
diff --git a/client.c b/client.c
index fd34d3b..b43d1c5 100644
--- a/client.c
+++ b/client.c
@@ -3,7 +3,22 @@
char *sampleurl;
char *image_dir;
+#ifdef __EMSCRIPTEN__
+emscripten_fetch_attr_t attr;
+#else
+CURL *curl;
+size_t append(char *data, size_t size, size_t nmemb, icclient_response *response)
+{
+ size_t realsize = size * nmemb;
+ response->data = realloc(response->data, response->numBytes + realsize + 1);
+ memcpy(&(response->data[response->numBytes]), data, realsize);
+ response->numBytes += realsize;
+ response->data[response->numBytes] = '\0';
+ return realsize;
+}
+#endif
+extern inline void request(void (*)(icclient_response *), void (*)(void *), struct body *, char *, ...);
extern void handle_results(icclient_response *);
void icclient_init(const char *url, const char *dir, const char *certificate)
@@ -16,7 +31,20 @@ void icclient_init(const char *url, const char *dir, const char *certificate)
strcat(sampleurl, "/");
image_dir = malloc(strlen(dir) + 1);
strcpy(image_dir, dir);
- init(certificate);
+#ifdef __EMSCRIPTEN__
+ emscripten_fetch_attr_init(&attr);
+ attr.attributes = EMSCRIPTEN_FETCH_LOAD_TO_MEMORY;
+#else
+ curl_global_init(CURL_GLOBAL_SSL);
+ curl = curl_easy_init();
+ curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1L);
+ curl_easy_setopt(curl, CURLOPT_COOKIEFILE, "");
+ if (certificate)
+ curl_easy_setopt(curl, CURLOPT_CAINFO, certificate);
+#ifdef DEBUG
+ curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L);
+#endif
+#endif
}
void icclient_results(const char *prod_group, void (*handler)(icclient_response *), void (*callback)(struct icclient_catalog *))
@@ -67,9 +95,21 @@ void icclient_free_catalog(struct icclient_catalog *catalog)
free(catalog);
}
+void icclient_free_response(icclient_response *response)
+{
+#ifdef __EMSCRIPTEN__
+ emscripten_fetch_close(response);
+#else
+ if (response->userData)
+ free(response->userData);
+#endif
+}
+
void icclient_cleanup()
{
#ifndef __EMSCRIPTEN__
- cleanup();
+ free(sampleurl);
+ curl_easy_cleanup(curl);
+ curl_global_cleanup();
#endif
}