#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
 
#include <stdio.h>
#include <Ecore.h>
#include <Ecore_Con.h>
#include <Ecore_Getopt.h>
 
 
static int retval = EXIT_SUCCESS;
 
{
 
 
   if (!echo)
     {
        else if (do_ssl_upgrade)
          {
             const char upgrade_msg[] = "\nSend \"Upgrade: SSL\" followed by newline (\\n) to do it.\n";
          }
     }
 
}
 
{
 
}
 
{
   const char upgrade_ssl[] = "Upgrade: SSL\n";
 
   printf("INFO: client data %p: %s\n"
          "INFO:  - size: %d\n"
          "-- BEGIN DATA --\n",
 
   puts("-- END DATA --");
 
   if (do_ssl_upgrade && ((
size_t)ev->
size == strlen(upgrade_ssl)) &&
 
       (memcmp(ev->
data, upgrade_ssl, ev->
size) == 0))
     {
          {
          }
        else
 
     }
 
   if (echo)
     {
     }
 
}
 
 
{
}
 
{
}
 
{
}
 
static const char *types_strs[] = {
  "tcp",
  "udp",
  "ssl",
  "tcp+ssl",
  "mcast",
  "local-user",
  "local-system",
  NULL
};
 
  "ecore_con_server_example", 
  NULL, 
  "1", 
  "(C) 2016 Enlightenment Project; 2010 Mike Blumenkrantz", 
  "BSD 2-Clause", 
  
  "Example of ecore_con_server_add() usage.\n",
  {
                            "Try to use $LISTEN_FDS from systemd, if not do a regular serve"),
 
                            "If set will limit number of clients to accept"),
                            "Immediately reject excess clients (over limit)"),
 
                            "Behave as 'echo' server, send back to client all the data receive"),
 
 
 
  }
};
 
int
main(int argc, char **argv)
{
   Ecore_Con_Type type;
   char *name = NULL;
   char *type_choice = NULL;
   int clients_limit = -1;
   int port = -1;
 
 
 
     
 
     
 
   };
   int args;
 
 
   if (args < 0)
     {
        fputs("ERROR: Could not parse command line options.\n", stderr);
        retval = EXIT_FAILURE;
        goto end;
     }
 
   if (quit_option) goto end;
 
   if (args < 0)
     {
        fputs("ERROR: Could not parse positional arguments.\n", stderr);
        retval = EXIT_FAILURE;
        goto end;
     }
 
   if (!type_choice) type_choice = "tcp";
 
   if (strcmp(type_choice, "tcp") == 0)
     type = ECORE_CON_REMOTE_TCP;
   else if (strcmp(type_choice, "udp") == 0)
     type = ECORE_CON_REMOTE_UDP;
   else if (strcmp(type_choice, "ssl") == 0)
     type = ECORE_CON_REMOTE_TCP | ECORE_CON_USE_MIXED | ECORE_CON_LOAD_CERT;
   else if (strcmp(type_choice, "tcp+ssl") == 0)
     {
        type = ECORE_CON_REMOTE_TCP;
     }
   else if (strcmp(type_choice, "local-user") == 0)
     type = ECORE_CON_LOCAL_USER;
   else if (strcmp(type_choice, "local-system") == 0)
     type = ECORE_CON_LOCAL_SYSTEM;
   else if (strcmp(type_choice, "mcast") == 0)
     type = ECORE_CON_REMOTE_MCAST;
   else
     {
        fprintf(stderr, "ERROR: unsupported --type/-t '%s'\n", type_choice);
        retval = EXIT_FAILURE;
        goto end;
     }
 
   if (socket_activated) type |= ECORE_CON_SOCKET_ACTIVATE;
 
   if (!svr) goto end;
 
   if ((strcmp(type_choice, "ssl") == 0)
#if 1
       
       || (strcmp(type_choice, "tcp+ssl") == 0)
#endif
       )
     {
          {
             fprintf(stderr, "ERROR: could not add cert: server.pem\n");
             goto no_mainloop;
          }
          {
             fprintf(stderr, "ERROR: could not add privkey: server.pem\n");
             goto no_mainloop;
          }
     }
 
 
 
 no_mainloop:
   svr = NULL;
 
 end:
 
   return retval;
}
ECORE_CON_API int ecore_con_client_send(Ecore_Con_Client *cl, const void *data, int size)
Sends the given data to the given client.
Definition ecore_con_legacy.c:668
ECORE_CON_API void ecore_con_client_flush(Ecore_Con_Client *cl)
Flushes all pending data to the given client.
Definition ecore_con_legacy.c:767
ECORE_CON_API const char * ecore_con_client_ip_get(const Ecore_Con_Client *cl)
Gets the IP address of a client that has connected.
Definition ecore_con_legacy.c:739
ECORE_CON_API void * ecore_con_client_del(Ecore_Con_Client *cl)
Closes the connection and free memory allocated to the given client.
Definition ecore_con_legacy.c:711
ECORE_CON_API int ECORE_CON_EVENT_CLIENT_ERROR
A client experienced an error.
Definition ecore_con_legacy.c:168
ECORE_CON_API int ECORE_CON_EVENT_CLIENT_ADD
A client has connected to the server.
Definition ecore_con_legacy.c:157
ECORE_CON_API int ECORE_CON_EVENT_CLIENT_WRITE
A server connection has sent data to its client.
Definition ecore_con_legacy.c:167
ECORE_CON_API int ECORE_CON_EVENT_CLIENT_DEL
A client has disconnected from the server.
Definition ecore_con_legacy.c:158
ECORE_CON_API int ECORE_CON_EVENT_CLIENT_UPGRADE
A client connection has been upgraded to SSL.
Definition ecore_con_legacy.c:169
ECORE_CON_API int ECORE_CON_EVENT_CLIENT_DATA
A client connected to the server has sent data.
Definition ecore_con_legacy.c:166
ECORE_CON_API int ecore_con_shutdown(void)
Shuts down the Ecore_Con library.
Definition ecore_con.c:133
ECORE_CON_API int ecore_con_init(void)
Initializes the Ecore_Con library.
Definition ecore_con.c:68
ECORE_CON_API Eina_Bool ecore_con_ssl_server_privkey_add(Ecore_Con_Server *svr, const char *key_file)
Adds an SSL private key for use in ecore_con functions.
Definition ecore_con_legacy.c:2483
ECORE_CON_API Eina_Bool ecore_con_ssl_client_upgrade(Ecore_Con_Client *cl, Ecore_Con_Type ssl_type)
Upgrades a connection to a specified level of encryption.
Definition ecore_con_legacy.c:900
ECORE_CON_API Eina_Bool ecore_con_ssl_server_cert_add(Ecore_Con_Server *svr, const char *cert)
Adds an SSL certificate for use in ecore_con functions.
Definition ecore_con_legacy.c:2468
ECORE_CON_API void * ecore_con_server_del(Ecore_Con_Server *svr)
Closes the connection and free the given server.
Definition ecore_con_legacy.c:2302
struct _Ecore_Con_Server Ecore_Con_Server
Used to provide legacy API/ABI compatibility with non-Eo applications.
Definition Ecore_Con.h:294
ECORE_CON_API Ecore_Con_Server * ecore_con_server_add(Ecore_Con_Type type, const char *name, int port, const void *data)
Creates a server to listen for connections.
Definition ecore_con_legacy.c:1696
Eina_Bool(* Ecore_Event_Handler_Cb)(void *data, int type, void *event)
A callback used by the main loop to handle events of a specified type.
Definition Ecore_Common.h:603
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
#define ECORE_GETOPT_VALUE_NONE
Definition for options that store a NULL value.
Definition Ecore_Getopt.h:1018
#define ECORE_GETOPT_VALUE_INT(val)
Definition for options that store a single value in a variable of type int.
Definition Ecore_Getopt.h:955
#define ECORE_GETOPT_CHOICE(shortname, longname, help, choices_array)
Definition for filling Ecore_Getopt_Desc table with a true boolean value.
Definition Ecore_Getopt.h:750
#define ECORE_GETOPT_VALUE_STR(val)
Definition for options that store a single value in a variable of type string.
Definition Ecore_Getopt.h:934
#define ECORE_GETOPT_STORE_METAVAR_INT(shortname, longname, help, metavar)
Definition for filling Ecore_Getopt_Desc table with an option of type int and metavar.
Definition Ecore_Getopt.h:381
#define ECORE_GETOPT_STORE_METAVAR_STR(shortname, longname, help, metavar)
Definition for filling Ecore_Getopt_Desc table with an option of type string and metavar.
Definition Ecore_Getopt.h:348
#define ECORE_GETOPT_LICENSE(shortname, longname)
Definition for filling Ecore_Getopt_Desc table with a license action.
Definition Ecore_Getopt.h:892
#define ECORE_GETOPT_VALUE_BOOL(val)
Definition for options that store a single value in a variable of type boolean.
Definition Ecore_Getopt.h:941
#define ECORE_GETOPT_VERSION(shortname, longname)
Definition for filling Ecore_Getopt_Desc table with a version action.
Definition Ecore_Getopt.h:870
EAPI int ecore_getopt_parse_positional(const Ecore_Getopt *parser, Ecore_Getopt_Value *values, int argc, char **argv, int start)
Parses command line positional parameters.
Definition ecore_getopt.c:2096
EAPI int ecore_getopt_parse(const Ecore_Getopt *parser, Ecore_Getopt_Value *values, int argc, char **argv)
Parses command line parameters.
Definition ecore_getopt.c:2032
#define ECORE_GETOPT_COPYRIGHT(shortname, longname)
Definition for filling Ecore_Getopt_Desc table with a copyright action.
Definition Ecore_Getopt.h:881
#define ECORE_GETOPT_STORE_TRUE(shortname, longname, help)
Definition for filling Ecore_Getopt_Desc table with a true boolean value.
Definition Ecore_Getopt.h:727
#define ECORE_GETOPT_HELP(shortname, longname)
Definition for filling Ecore_Getopt_Desc table with a help action.
Definition Ecore_Getopt.h:859
#define ECORE_GETOPT_STORE_INT(shortname, longname, help)
Definition for macro that fill Ecore_Getopt_Desc table with an option of type int.
Definition Ecore_Getopt.h:279
#define ECORE_GETOPT_SENTINEL
Definition for filling Ecore_Getopt_Desc table with a sentinel to indicate the end of descriptions.
Definition Ecore_Getopt.h:927
EAPI int ecore_shutdown(void)
Shuts down connections, signal handlers sockets etc.
Definition ecore.c:371
EAPI int ecore_init(void)
Sets up connections, signal handlers, sockets etc.
Definition ecore.c:230
#define ECORE_CALLBACK_RENEW
Return value to keep a callback.
Definition Ecore_Common.h:153
void ecore_main_loop_begin(void)
Runs the application main loop.
Definition ecore_main.c:1316
EINA_API int eina_shutdown(void)
Shuts down the Eina library.
Definition eina_main.c:379
EINA_API int eina_init(void)
Initializes the Eina library.
Definition eina_main.c:291
#define EINA_TRUE
boolean value TRUE (numerical value 1)
Definition eina_types.h:539
#define EINA_FALSE
boolean value FALSE (numerical value 0)
Definition eina_types.h:533
unsigned char Eina_Bool
Type to mimic a boolean.
Definition eina_types.h:527
#define EINA_UNUSED
Used to indicate that a function parameter is purposely unused.
Definition eina_types.h:339
Used as the data param for the ECORE_CON_EVENT_CLIENT_ADD event.
Definition Ecore_Con.h:442
Ecore_Con_Client * client
the client that connected
Definition Ecore_Con.h:443
Used as the data param for the ECORE_CON_EVENT_CLIENT_DATA event.
Definition Ecore_Con.h:518
void * data
the data that the client sent
Definition Ecore_Con.h:520
Ecore_Con_Client * client
the client that connected
Definition Ecore_Con.h:519
int size
the length of the data sent
Definition Ecore_Con.h:521
Used as the data param for the ECORE_CON_EVENT_CLIENT_DEL event.
Definition Ecore_Con.h:461
Ecore_Con_Client * client
the client that was lost
Definition Ecore_Con.h:462
Used as the data param for the ECORE_CON_EVENT_CLIENT_ERROR event.
Definition Ecore_Con.h:470
char * error
the error string describing what happened
Definition Ecore_Con.h:472
Ecore_Con_Client * client
the client for which an error occurred
Definition Ecore_Con.h:471
Used as the data param for the ECORE_CON_EVENT_CLIENT_UPGRADE event.
Definition Ecore_Con.h:452
Ecore_Con_Client * client
the client that completed handshake
Definition Ecore_Con.h:453
Used as the data param for the ECORE_CON_EVENT_CLIENT_WRITE event.
Definition Ecore_Con.h:540
Ecore_Con_Client * client
the client that connected
Definition Ecore_Con.h:541
int size
the length of the data sent
Definition Ecore_Con.h:542
Structure that contains information on all command line options.
Definition Ecore_Getopt.h:212
Union listing the types of parameters that can take Getopt values.
Definition Ecore_Getopt.h:130