5 /* Ecore_Con client example
6 * 2010 Mike Blumenkrantz
9 /* comment if not using gnutls */
11 tls_log_func(int level, const char *str)
13 fprintf(stderr, "|<%d>| %s", level, str);
17 _add(void *data, int type, Ecore_Con_Event_Server_Add *ev)
19 printf("Server with ip %s connected!\n", ecore_con_server_ip_get(ev->server));
20 ecore_con_server_send(ev->server, "hello!", 6);
21 ecore_con_server_flush(ev->server);
23 return ECORE_CALLBACK_RENEW;
28 _del(void *data, int type, Ecore_Con_Event_Server_Del *ev)
30 printf("Lost server with ip %s!\n", ecore_con_server_ip_get(ev->server));
31 ecore_main_loop_quit();
32 return ECORE_CALLBACK_RENEW;
36 _data(void *data, int type, Ecore_Con_Event_Server_Data *ev)
40 snprintf(fmt, sizeof(fmt),
41 "Received %i bytes from server:\n"
47 printf(fmt, ev->data);
48 return ECORE_CALLBACK_RENEW;
52 Ecore_Con_Server *svr;
60 /* comment if not using gnutls */
61 gnutls_global_set_log_level(9);
62 gnutls_global_set_log_function(tls_log_func);
64 if (!(it = eina_file_ls("/etc/ssl/certs")))
67 if (!(svr = ecore_con_server_connect(ECORE_CON_REMOTE_TCP | ECORE_CON_USE_MIXED, "www.verisign.com", 443, NULL)))
71 EINA_ITERATOR_FOREACH(it, ca)
73 if (!ecore_con_ssl_server_cafile_add(svr, ca))
74 printf("Could not load CA: %s!\n", ca);
75 eina_stringshare_del(ca);
78 eina_iterator_free(it);
79 ecore_con_ssl_server_verify(svr);
81 /* set event handler for server connect */
82 ecore_event_handler_add(ECORE_CON_EVENT_SERVER_ADD, (Ecore_Event_Handler_Cb)_add, NULL);
83 /* set event handler for server disconnect */
84 ecore_event_handler_add(ECORE_CON_EVENT_SERVER_DEL, (Ecore_Event_Handler_Cb)_del, NULL);
85 /* set event handler for receiving server data */
86 ecore_event_handler_add(ECORE_CON_EVENT_SERVER_DATA, (Ecore_Event_Handler_Cb)_data, NULL);
89 ecore_main_loop_begin();