Diff for /libaitrpc/src/builtin.c between versions 1.7 and 1.7.2.4

version 1.7, 2012/05/14 08:39:05 version 1.7.2.4, 2012/05/16 13:52:59
Line 48  SUCH DAMAGE. Line 48  SUCH DAMAGE.
   
 /* builtin RPC server functions */  /* builtin RPC server functions */
   
intstatic int
 rpcServerClients(rpc_func_t *call, int ic, array_t *iv)  rpcServerClients(rpc_func_t *call, int ic, array_t *iv)
 {  {
         rpc_srv_t *srv;          rpc_srv_t *srv;
         array_t *vals;  
         rpc_cli_t *cli;          rpc_cli_t *cli;
         register int i;          register int i;
         int len;          int len;
         const char *str = NULL;          const char *str = NULL;
        char *val, wrk[INET6_ADDRSTRLEN];        char *val;
         ait_val_t v;
   
         RPC_CALLBACK_CHECK_INPUT(call);          RPC_CALLBACK_CHECK_INPUT(call);
         if (!call->func_parent)          if (!call->func_parent)
Line 65  rpcServerClients(rpc_func_t *call, int ic, array_t *iv Line 65  rpcServerClients(rpc_func_t *call, int ic, array_t *iv
         else          else
                 srv = call->func_parent;                  srv = call->func_parent;
   
        rpc_srv_getVars(call, &vals);        len = io_arraySize(srv->srv_clients) * STRSIZ;
 
        len = srv->srv_numcli * STRSIZ; 
         if (!(val = malloc(len))) {          if (!(val = malloc(len))) {
                 LOGERR;                  LOGERR;
                 return -1;                  return -1;
         } else          } else
                 memset(val, 0, len);                  memset(val, 0, len);
   
        for (i = 0, cli = srv->srv_clients; i < srv->srv_numcli; i++, cli++) {        for (i = 0; i < io_arraySize(srv->srv_clients); i++) {
                if (!cli->cli_sa.sa.sa_family)                cli = io_array(srv->srv_clients, i, rpc_cli_t*);
                 if (!cli)
                         continue;                          continue;
   
                switch (cli->cli_sa.sa.sa_family) {                str = io_n2addr(&cli->cli_sa, &v);
                        case AF_INET: 
                                str = inet_ntop(cli->cli_sa.sa.sa_family, &cli->cli_sa.sin.sin_addr, wrk, sizeof wrk); 
                                break; 
                        case AF_INET6: 
                                str = inet_ntop(cli->cli_sa.sa.sa_family, &cli->cli_sa.sin6.sin6_addr, wrk, sizeof wrk); 
                                break; 
                        case AF_LOCAL: 
                                str = cli->cli_sa.sun.sun_path; 
                                break; 
                } 
                 if (str)                  if (str)
                         strlcat(val, (char*) str, len);                          strlcat(val, (char*) str, len);
                 else                  else
                         strlcat(val, "0.0.0.0", len);                          strlcat(val, "0.0.0.0", len);
                 strlcat(val, " ", len);                  strlcat(val, " ", len);
                   AIT_FREE_VAL(&v);
         }          }
   
        AIT_SET_STR(io_array(vals, 0, ait_val_t*), val);        AIT_SET_STR(io_array(call->func_vars, 0, ait_val_t*), val);
         free(val);          free(val);
         return 0;          return 0;
 }  }
   
intstatic int
 rpcServerCalls(rpc_func_t *call, int ic, array_t *iv)  rpcServerCalls(rpc_func_t *call, int ic, array_t *iv)
 {  {
         rpc_srv_t *srv;          rpc_srv_t *srv;
         array_t *vals;  
         rpc_func_t *f;          rpc_func_t *f;
        register int i;        register int i = 0;
         int len;          int len;
         char *val, str[MAXPATHLEN];          char *val, str[MAXPATHLEN];
   
Line 117  rpcServerCalls(rpc_func_t *call, int ic, array_t *iv) Line 106  rpcServerCalls(rpc_func_t *call, int ic, array_t *iv)
         else          else
                 srv = call->func_parent;                  srv = call->func_parent;
   
        for (i = 0, f = srv->srv_funcs; f; i++, f = f->func_next);        TAILQ_FOREACH(f, &srv->srv_funcs, func_node)
                 i++;
         len = i * STRSIZ;          len = i * STRSIZ;
   
         rpc_srv_getVars(call, &vals);  
   
         if (!(val = malloc(len))) {          if (!(val = malloc(len))) {
                 LOGERR;                  LOGERR;
                 return -1;                  return -1;
         } else          } else
                 memset(val, 0, len);                  memset(val, 0, len);
   
        for (f = srv->srv_funcs, i = 0; f; f = f->func_next) {        TAILQ_FOREACH(f, &srv->srv_funcs, func_node)
                if (*AIT_GET_STR(&f->func_name)) {                if (AIT_ADDR(&f->func_name)) {
                         memset(str, 0, sizeof str);                          memset(str, 0, sizeof str);
                        if (AIT_ISEMPTY(&f->func_file))                        snprintf(str, sizeof str, "/%hu/0x%p(%d); ", AIT_KEY(&f->func_name), 
                                snprintf(str, sizeof str, "/*/%s(%d); ",                                         AIT_ADDR(&f->func_name), io_arraySize(f->func_vars));
                                                AIT_GET_STR(&f->func_name), io_arraySize(f->func_vars)); 
                        else 
                                snprintf(str, sizeof str, "/%s/%s(%d); ", AIT_GET_STR(&f->func_file),  
                                                AIT_GET_STR(&f->func_name), io_arraySize(f->func_vars)); 
                         strlcat(val, str, len);                          strlcat(val, str, len);
                 }                  }
         }  
   
        AIT_SET_STR(io_array(vals, 0, ait_val_t*), val);        AIT_SET_STR(io_array(f->func_vars, 0, ait_val_t*), val);
         free(val);          free(val);
         return 0;          return 0;
 }  }
   
intstatic int
 rpcServerSessions(rpc_func_t *call, int ic, array_t *iv)  rpcServerSessions(rpc_func_t *call, int ic, array_t *iv)
 {  {
         rpc_srv_t *srv;          rpc_srv_t *srv;
         array_t *vals;  
         ait_val_t *v;          ait_val_t *v;
   
         RPC_CALLBACK_CHECK_INPUT(call);          RPC_CALLBACK_CHECK_INPUT(call);
Line 159  rpcServerSessions(rpc_func_t *call, int ic, array_t *i Line 141  rpcServerSessions(rpc_func_t *call, int ic, array_t *i
         else          else
                 srv = call->func_parent;                  srv = call->func_parent;
   
        rpc_srv_getVars(call, &vals);        v = io_array(call->func_vars, 0, ait_val_t*);
 
        v = io_array(vals, 0, ait_val_t*); 
         AIT_SET_U8(v, srv->srv_session.sess_version);          AIT_SET_U8(v, srv->srv_session.sess_version);
        v = io_array(vals, 1, ait_val_t*);        v = io_array(call->func_vars, 1, ait_val_t*);
         AIT_SET_U32(v, srv->srv_session.sess_program);          AIT_SET_U32(v, srv->srv_session.sess_program);
        v = io_array(vals, 2, ait_val_t*);        v = io_array(call->func_vars, 2, ait_val_t*);
        AIT_SET_U32(v, srv->srv_session.sess_process);        AIT_SET_U8(v, srv->srv_session.sess_process);
        v = io_array(vals, 3, ait_val_t*);        v = io_array(call->func_vars, 3, ait_val_t*);
        AIT_SET_I32(v, srv->srv_numcli);        AIT_SET_I32(v, io_arraySize(srv->srv_clients));
   
         return 0;          return 0;
 }  }
   
intstatic int
 rpcServerShutdown(rpc_func_t *call, int ic, array_t *iv)  rpcServerShutdown(rpc_func_t *call, int ic, array_t *iv)
 {  {
         rpc_srv_t *srv;          rpc_srv_t *srv;
Line 184  rpcServerShutdown(rpc_func_t *call, int ic, array_t *i Line 164  rpcServerShutdown(rpc_func_t *call, int ic, array_t *i
         else          else
                 srv = call->func_parent;                  srv = call->func_parent;
   
        srv->srv_kill = kill;        srv->srv_kill = 1;
   
         return 0;          return 0;
 }  }
   
// ----------------------------------------------------/* ---------------------------------------------------- */
   
intstatic int
 rpcBLOBServerShutdown(rpc_func_t *call, int ic, array_t *iv)  rpcBLOBServerShutdown(rpc_func_t *call, int ic, array_t *iv)
 {  {
         rpc_srv_t *srv;          rpc_srv_t *srv;
Line 202  rpcBLOBServerShutdown(rpc_func_t *call, int ic, array_ Line 182  rpcBLOBServerShutdown(rpc_func_t *call, int ic, array_
         else          else
                 srv = call->func_parent;                  srv = call->func_parent;
   
        srv->srv_blob.state = kill;        srv->srv_blob.kill = 1;
   
         return 0;          return 0;
 }  }
   
intstatic int
 rpcBLOBServerVars(rpc_func_t *call, int ic, array_t *iv)  rpcBLOBServerVars(rpc_func_t *call, int ic, array_t *iv)
 {  {
         rpc_srv_t *srv;          rpc_srv_t *srv;
         array_t *vals;  
         rpc_blob_t *b;          rpc_blob_t *b;
        register int i;        register int i = 0;
         char *val, str[64];          char *val, str[64];
         int len;          int len;
   
Line 223  rpcBLOBServerVars(rpc_func_t *call, int ic, array_t *i Line 202  rpcBLOBServerVars(rpc_func_t *call, int ic, array_t *i
         else          else
                 srv = call->func_parent;                  srv = call->func_parent;
   
        rpc_srv_getVars(call, &vals);        if (srv->srv_blob.kill) {
                AIT_SET_STR(io_array(call->func_vars, 0, ait_val_t*), "BLOB Server is killed");
        if (srv->srv_blob.state == kill) { 
                AIT_SET_STR(io_array(vals, 0, ait_val_t*), "BLOB Server is killed"); 
                 return 1;                  return 1;
         }          }
         if (srv->srv_blob.state == disable) {  
                 AIT_SET_STR(io_array(vals, 0, ait_val_t*), "BLOB Server is disabled");  
                 return 1;  
         }  
   
        for (i = 0, b = srv->srv_blob.blobs; b; i++, b = b->blob_next);        TAILQ_FOREACH(b, &srv->srv_blob.blobs, blob_node)
                 i++;
         len = i * sizeof str;          len = i * sizeof str;
   
         if (!len) {          if (!len) {
                AIT_SET_STR(io_array(vals, 0, ait_val_t*), "");                AIT_SET_STR(io_array(call->func_vars, 0, ait_val_t*), "");
                 return 0;                  return 0;
         }          }
   
Line 248  rpcBLOBServerVars(rpc_func_t *call, int ic, array_t *i Line 222  rpcBLOBServerVars(rpc_func_t *call, int ic, array_t *i
         } else          } else
                 memset(val, 0, len);                  memset(val, 0, len);
   
        for (b = srv->srv_blob.blobs, i = 0; b; i++, b = b->blob_next) {        TAILQ_FOREACH(b, &srv->srv_blob.blobs, blob_node) {
                 memset(str, 0, sizeof str);                  memset(str, 0, sizeof str);
                 snprintf(str, sizeof str, "0x%0X(%lu)=%p ", b->blob_var, (u_long) b->blob_len, b->blob_data);                  snprintf(str, sizeof str, "0x%0X(%lu)=%p ", b->blob_var, (u_long) b->blob_len, b->blob_data);
                 strlcat(val, str, len);                  strlcat(val, str, len);
         }          }
   
        AIT_SET_STR(io_array(vals, 0, ait_val_t*), val);        AIT_SET_STR(io_array(call->func_vars, 0, ait_val_t*), val);
         free(val);          free(val);
         return 0;          return 0;
 }  }
   
intstatic int
rpcBLOBServerState(rpc_func_t *call, int ic, array_t *iv) 
{ 
        rpc_srv_t *srv; 
 
        RPC_CALLBACK_CHK_ARGS(call, ic); 
        if (!call->func_parent) 
                return -1; 
        else 
                srv = call->func_parent; 
 
        if (AIT_TYPE(io_array(iv, 0, ait_val_t*)) != i32) 
                return -1; 
 
        srv->srv_blob.state = AIT_GET_I32(io_array(iv, 0, ait_val_t*)); 
        return 0; 
} 
 
int 
 rpcBLOBServerClients(rpc_func_t *call, int ic, array_t *iv)  rpcBLOBServerClients(rpc_func_t *call, int ic, array_t *iv)
 {  {
         rpc_srv_t *srv;          rpc_srv_t *srv;
         array_t *vals;  
         rpc_cli_t *cli;          rpc_cli_t *cli;
         register int i;          register int i;
         int len;          int len;
         const char *str = NULL;          const char *str = NULL;
        char *val, wrk[INET6_ADDRSTRLEN];        char *val;
         ait_val_t v;
   
         RPC_CALLBACK_CHECK_INPUT(call);          RPC_CALLBACK_CHECK_INPUT(call);
         if (!call->func_parent)          if (!call->func_parent)
Line 294  rpcBLOBServerClients(rpc_func_t *call, int ic, array_t Line 250  rpcBLOBServerClients(rpc_func_t *call, int ic, array_t
         else          else
                 srv = call->func_parent;                  srv = call->func_parent;
   
        rpc_srv_getVars(call, &vals);        if (srv->srv_blob.kill) {
                AIT_SET_STR(io_array(call->func_vars, 0, ait_val_t*), "BLOB Server is killed");
        if (srv->srv_blob.state == kill) { 
                AIT_SET_STR(io_array(vals, 0, ait_val_t*), "BLOB Server is killed"); 
                 return 1;                  return 1;
         }          }
         if (srv->srv_blob.state == disable) {  
                 AIT_SET_STR(io_array(vals, 0, ait_val_t*), "BLOB Server is disabled");  
                 return 1;  
         }  
   
        len = srv->srv_numcli * STRSIZ;        len = io_arraySize(srv->srv_blob.clients) * STRSIZ;
         if (!(val = malloc(len))) {          if (!(val = malloc(len))) {
                 LOGERR;                  LOGERR;
                 return -1;                  return -1;
         } else          } else
                 memset(val, 0, len);                  memset(val, 0, len);
   
        for (i = 0, cli = srv->srv_blob.clients; i < srv->srv_numcli; i++, cli++) {        for (i = 0; i < io_arraySize(srv->srv_clients); i++) {
                if (!cli->cli_sa.sa.sa_family)                cli = io_array(srv->srv_blob.clients, i, rpc_cli_t*);
                 if (!cli)
                         continue;                          continue;
   
                switch (cli->cli_sa.sa.sa_family) {                str = io_n2addr(&cli->cli_sa, &v);
                        case AF_INET: 
                                str = inet_ntop(cli->cli_sa.sa.sa_family, &cli->cli_sa.sin.sin_addr, wrk, sizeof wrk); 
                                break; 
                        case AF_INET6: 
                                str = inet_ntop(cli->cli_sa.sa.sa_family, &cli->cli_sa.sin6.sin6_addr, wrk, sizeof wrk); 
                                break; 
                        case AF_LOCAL: 
                                str = cli->cli_sa.sun.sun_path; 
                                break; 
                } 
                 if (str)                  if (str)
                         strlcat(val, (char*) str, len);                          strlcat(val, (char*) str, len);
                 else                  else
                         strlcat(val, "0.0.0.0", len);                          strlcat(val, "0.0.0.0", len);
                 strlcat(val, " ", len);                  strlcat(val, " ", len);
                   AIT_FREE_VAL(&v);
         }          }
   
        AIT_SET_STR(io_array(vals, 0, ait_val_t*), val);        AIT_SET_STR(io_array(call->func_vars, 0, ait_val_t*), val);
         free(val);          free(val);
           return 0;
   }
   
   /* ----------------------------------------------------------------- */
   
   /*
    * rpc_register_srvServices() - Register internal service functions
    *
    * @srv = RPC server instance
    * return: -1 error or 0 ok
    */
   int
   rpc_register_srvServices(rpc_srv_t * __restrict srv)
   {
           if (!srv)
                   return -1;
   
           if (rpc_srv_registerCall(srv, CALL_SRVSHUTDOWN, rpcServerShutdown, 0) < 1)
                   return -1;
           if (rpc_srv_registerCall(srv, CALL_SRVCLIENTS, rpcServerClients, 1) < 1)
                   return -1;
           if (rpc_srv_registerCall(srv, CALL_SRVSESSIONS, rpcServerSessions, 4) < 1)
                   return -1;
           if (rpc_srv_registerCall(srv, CALL_SRVCALLS, rpcServerCalls, 1) < 1)
                   return -1;
   
           return 0;
   }
   
   /*
    * rpc_register_blobServices() - Register internal service functions
    *
    * @srv = RPC server instance
    * return: -1 error or 0 ok
    */
   int
   rpc_register_blobServices(rpc_srv_t * __restrict srv)
   {
           if (!srv)
                   return -1;
   
           if (rpc_srv_registerCall(srv, CALL_BLOBSHUTDOWN, rpcBLOBServerShutdown, 0) < 1)
                   return -1;
           if (rpc_srv_registerCall(srv, CALL_BLOBCLIENTS, rpcBLOBServerClients, 1) < 1)
                   return -1;
           if (rpc_srv_registerCall(srv, CALL_BLOBVARS, rpcBLOBServerVars, 1) < 1)
                   return -1;
   
         return 0;          return 0;
 }  }

Removed from v.1.7  
changed lines
  Added in v.1.7.2.4


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>