Shows how to manage cookies on a Ecore_Con_Url object. See the complete example description at Ecore_Con_Url - Managing cookies.
#include <stdio.h>
#include <Ecore.h>
#include <Ecore_Con.h>
#define COOKIEJAR "cookies.jar"
{
int i;
printf("\nData received from server:\n>>>>>\n");
for (i = 0; i < url_data->
size; i++)
printf(
"%c", url_data->
data[i]);
printf("\n>>>>>>\n\n");
}
{
char *str;
printf("\n");
printf(
"download completed with status code: %d\n", url_complete->
status);
printf("response headers:\n");
printf("header: %s", str);
}
int
main(int argc, const char *argv[])
{
char cmd = '\0';
if (argc < 2)
{
printf("need at least one parameter: <url> [command]\n");
return -1;
}
if (argc > 2)
cmd = argv[2][0];
if (!ec_url)
{
printf("error when creating ecore con url object.\n");
goto end;
}
if (cmd != 'c' && cmd != 's')
switch (cmd)
{
case 'c':
printf("Cleaning previously set cookies.\n");
break;
case 's':
printf("Cleaning previously set session cookies.\n");
break;
case 'i':
printf("Ignoring old session cookies.\n");
}
if (!r)
{
printf("could not realize request.\n");
goto free_ec_url;
}
free_ec_url:
end:
return 0;
}
unsigned char data[1]
the data received on this event
Definition: Ecore_Con.h:601
EAPI int ECORE_CON_EVENT_URL_COMPLETE
A URL object has completed its transfer to and from the server and can be reused.
Definition: ecore_con_url.c:30
Ecore_Con_Url * url_con
a pointer to the connection object
Definition: Ecore_Con.h:611
void ecore_main_loop_quit(void)
Quits the main loop once all the events currently on the queue have been processed.
Definition: ecore_main.c:1300
EAPI int ecore_con_shutdown(void)
Shuts down the Ecore_Con library.
Definition: ecore_con.c:133
#define EINA_LIST_FOREACH(list, l, _data)
Definition for the macro to iterate over a list.
Definition: eina_list.h:1415
EAPI void ecore_con_url_cookies_session_clear(Ecore_Con_Url *url_con)
Clears currently loaded session cookies.
Definition: ecore_con_url.c:1073
Definition: Ecore_Con.h:610
#define EINA_UNUSED
Definition: eina_types.h:339
struct _Ecore_Con_Url Ecore_Con_Url
Definition: Ecore_Con.h:347
EAPI Eina_Bool ecore_con_url_cookies_jar_file_set(Ecore_Con_Url *url_con, const char *const cookiejar_file)
Sets the name of the file to which all current cookies will be written when either cookies are flushe...
Definition: ecore_con_url.c:1102
EAPI void ecore_con_url_cookies_clear(Ecore_Con_Url *url_con)
Clears currently loaded cookies.
Definition: ecore_con_url.c:1052
Ecore_Event_Handler * ecore_event_handler_add(int type, Ecore_Event_Handler_Cb func, const void *data)
Adds an event handler.
Definition: ecore_events.c:13
EAPI void ecore_con_url_free(Ecore_Con_Url *url_con)
Destroys an Ecore_Con_Url connection object.
Definition: ecore_con_url.c:821
EAPI const Eina_List * ecore_con_url_response_headers_get(Ecore_Con_Url *url_con)
Retrieves headers from last request sent.
Definition: ecore_con_url.c:1296
EAPI int ECORE_CON_EVENT_URL_DATA
A URL object has data.
Definition: ecore_con_url.c:29
int size
the size of the current received data (in bytes)
Definition: Ecore_Con.h:600
EAPI void ecore_con_url_cookies_init(Ecore_Con_Url *url_con)
Enables the cookie engine for subsequent HTTP requests.
Definition: ecore_con_url.c:1014
void ecore_main_loop_begin(void)
Runs the application main loop.
Definition: ecore_main.c:1290
EAPI int ecore_con_url_shutdown(void)
Shuts down the Ecore_Con_Url library.
Definition: ecore_con_url.c:69
EAPI Ecore_Con_Url * ecore_con_url_new(const char *url)
Creates and initializes a new Ecore_Con_Url connection object.
Definition: ecore_con_url.c:784
#define EINA_TRUE
Definition: eina_types.h:539
EAPI void ecore_con_url_cookies_ignore_old_session_set(Ecore_Con_Url *url_con, Eina_Bool ignore)
Controls whether session cookies from previous sessions shall be loaded.
Definition: ecore_con_url.c:1094
unsigned char Eina_Bool
Definition: eina_types.h:527
EAPI int ecore_con_url_init(void)
Initializes the Ecore_Con_Url library.
Definition: ecore_con_url.c:45
EAPI int ecore_con_init(void)
Initializes the Ecore_Con library.
Definition: ecore_con.c:72
EAPI Eina_Bool ecore_con_url_get(Ecore_Con_Url *url_con)
Sends a get request.
Definition: ecore_con_url.c:864
Definition: eina_list.h:318
EAPI void ecore_con_url_additional_header_add(Ecore_Con_Url *url_con, const char *key, const char *value)
Adds an additional header to the request connection object.
Definition: ecore_con_url.c:969
EAPI int ecore_shutdown(void)
Shuts down connections, signal handlers sockets etc.
Definition: ecore.c:373
EAPI void ecore_con_url_cookies_jar_write(Ecore_Con_Url *url_con)
Writes all current cookies to the cookie jar immediately.
Definition: ecore_con_url.c:1123
Definition: Ecore_Con.h:598
EAPI int ecore_init(void)
Sets up connections, signal handlers, sockets etc.
Definition: ecore.c:229
EAPI void ecore_con_url_cookies_file_add(Ecore_Con_Url *url_con, const char *const file_name)
Adds a file to the list of files from which to load cookies.
Definition: ecore_con_url.c:1032
int status
HTTP status code of the operation (200, 404, 401, etc.)
Definition: Ecore_Con.h:612