OpenVAS Scanner  22.7.9
nasl_snmp.c
Go to the documentation of this file.
1 /* SPDX-FileCopyrightText: 2023 Greenbone AG
2  *
3  * SPDX-License-Identifier: GPL-2.0-or-later
4  */
5 
11 #include "nasl_snmp.h"
12 
13 #include "../misc/plugutils.h"
14 #include "nasl_lex_ctxt.h"
15 
16 #include <assert.h>
17 #include <errno.h>
18 #include <gvm/base/logging.h>
19 #include <stdio.h>
20 #include <stdlib.h>
21 #include <string.h>
22 #include <unistd.h>
23 
24 #undef G_LOG_DOMAIN
25 
28 #define G_LOG_DOMAIN "lib nasl"
29 
33 #define SNMP_VERSION_1 0
34 
38 #define SNMP_VERSION_2c 1
39 
40 #define FD_STDERR_FLAG 1
41 #define FD_STDOUT_FLAG 0
42 
47 {
48  char *peername;
49  char *community;
50  char *oid_str;
51  int version;
52  u_char action;
53 };
54 
56 
61 {
62  char *peername;
63  char *username;
64  char *authpass;
65  char *privpass;
66  char *oid_str;
67  int authproto;
68  int privproto;
69  u_char action;
70 };
71 
73 
75 {
76  char *oid_str;
77  char *name;
78 };
79 
80 typedef struct snmp_result *snmp_result_t;
81 
82 static void
84 {
85  if (result == NULL)
86  return;
87  g_free (result->name);
88  g_free (result->oid_str);
89  g_free (result);
90 }
91 
92 /*
93  * @brief Check that protocol value is valid.
94  *
95  * param[in] proto Protocol string.
96  *
97  * @return 1 if proto is udp, udp6, tcp or tcp6. 0 otherwise.
98  */
99 static int
100 proto_is_valid (const char *proto)
101 {
102  if (strcmp (proto, "tcp") && strcmp (proto, "udp") && strcmp (proto, "tcp6")
103  && strcmp (proto, "udp6"))
104  return 0;
105  return 1;
106 }
107 
108 /*
109  * @brief Create a NASL array from a snmp result.
110  *
111  * param[in] ret Return value.
112  * param[in] result Result string.
113  *
114  * @return NASL array.
115  */
116 static tree_cell *
117 array_from_snmp_result (int ret, const snmp_result_t result)
118 {
119  anon_nasl_var v;
120 
121  assert (result);
122  assert (result->name);
124  retc->x.ref_val = g_malloc0 (sizeof (nasl_array));
125  /* Return code */
126  memset (&v, 0, sizeof (v));
127  v.var_type = VAR2_INT;
128  v.v.v_int = ret;
129  add_var_to_list (retc->x.ref_val, 0, &v);
130  /* Name */
131  memset (&v, 0, sizeof v);
132  v.var_type = VAR2_STRING;
133  v.v.v_str.s_val = (unsigned char *) g_strdup (result->name);
134  v.v.v_str.s_siz = strlen (result->name);
135  add_var_to_list (retc->x.ref_val, 1, &v);
136  /* OID */
137  if (result->oid_str != NULL)
138  {
139  memset (&v, 0, sizeof v);
140  v.var_type = VAR2_STRING;
141  v.v.v_str.s_val = (unsigned char *) g_strdup (result->oid_str);
142  v.v.v_str.s_siz = strlen (result->oid_str);
143  add_var_to_list (retc->x.ref_val, 2, &v);
144  }
145 
146  return retc;
147 }
148 
149 static tree_cell *
150 array_from_snmp_error (int ret, const char *err)
151 {
152  anon_nasl_var v;
153 
154  assert (err);
156  retc->x.ref_val = g_malloc0 (sizeof (nasl_array));
157  /* Return code */
158  memset (&v, 0, sizeof (v));
159  v.var_type = VAR2_INT;
160  v.v.v_int = ret;
161  add_var_to_list (retc->x.ref_val, 0, &v);
162  /* Return error */
163  memset (&v, 0, sizeof v);
164  v.var_type = VAR2_STRING;
165  v.v.v_str.s_val = (unsigned char *) err;
166  v.v.v_str.s_siz = strlen (err);
167  add_var_to_list (retc->x.ref_val, 1, &v);
168 
169  return retc;
170 }
171 
172 #ifdef HAVE_NETSNMP
173 
174 #include <net-snmp/net-snmp-config.h>
175 #include <net-snmp/net-snmp-includes.h>
176 
177 #define NASL_SNMP_GET SNMP_MSG_GET
178 #define NASL_SNMP_GETNEXT SNMP_MSG_GETNEXT
179 
180 /*
181  * @brief SNMP Get query value.
182  *
183  * param[in] session SNMP session.
184  * param[in] oid_str OID string.
185  * param[in] action Action to perform to get entry
186  * param[out] result Result of query.
187  *
188  * @return 0 if success and result value, -1 otherwise.
189  */
190 static int
191 snmp_get (struct snmp_session *session, const char *oid_str,
192  const u_char action, snmp_result_t result)
193 {
194  struct snmp_session *ss;
195  struct snmp_pdu *query, *response;
196  oid oid_buf[MAX_OID_LEN];
197  size_t oid_size = MAX_OID_LEN;
198  int status;
199 
200  ss = snmp_open (session);
201  if (!ss)
202  {
203  snmp_error (session, &status, &status, &(result->name));
204  return -1;
205  }
206 
207  query = snmp_pdu_create (action);
208  read_objid (oid_str, oid_buf, &oid_size);
209  snmp_add_null_var (query, oid_buf, oid_size);
210  status = snmp_synch_response (ss, query, &response);
211  if (status != STAT_SUCCESS)
212  {
213  snmp_error (ss, &status, &status, &(result->name));
214  snmp_close (ss);
215  return -1;
216  }
217  snmp_close (ss);
218 
219  if (response->errstat == SNMP_ERR_NOERROR)
220  {
221  struct variable_list *vars = response->variables;
222  size_t res_len = 0, buf_len = 0, res_len1 = 0, buf_len1 = 0;
223 
224  netsnmp_ds_set_boolean (NETSNMP_DS_LIBRARY_ID, NETSNMP_DS_LIB_QUICK_PRINT,
225  1);
226  sprint_realloc_value ((u_char **) &(result->name), &buf_len, &res_len, 1,
227  vars->name, vars->name_length, vars);
228  sprint_realloc_objid ((u_char **) &(result->oid_str), &buf_len1,
229  &res_len1, 1, vars->name, vars->name_length);
230 
231  snmp_free_pdu (response);
232  return 0;
233  }
234 
235  result->name = g_strdup (snmp_errstring (response->errstat));
236  snmp_free_pdu (response);
237  return -1;
238 }
239 
240 /*
241  * @brief SNMPv3 Get query value.
242  *
243  * param[in] request Contains all necessary information for SNMPv3 query.
244  * param[out] result Result of query.
245  *
246  * @return 0 if success and result value, -1 otherwise.
247  */
248 static int
249 snmpv3_get (const snmpv3_request_t request, snmp_result_t result)
250 {
251  struct snmp_session session;
252 
253  assert (request);
254  assert (request->peername);
255  assert (request->username);
256  assert (request->authpass);
257  assert (request->authproto == 0 || request->authproto == 1);
258  assert (request->oid_str);
259  assert (request->action);
260 
261  setenv ("MIBS", "", 1);
262  init_snmp ("openvas");
263  snmp_sess_init (&session);
264  session.version = SNMP_VERSION_3;
265  session.peername = (char *) request->peername;
266  session.securityName = (char *) request->username;
267  session.securityNameLen = strlen (session.securityName);
268 
269  if (request->privpass)
270  session.securityLevel = SNMP_SEC_LEVEL_AUTHPRIV;
271  else
272  session.securityLevel = SNMP_SEC_LEVEL_AUTHNOPRIV;
273  if (request->authproto == 0)
274  {
275  session.securityAuthProto = usmHMACMD5AuthProtocol;
276  session.securityAuthProtoLen = USM_AUTH_PROTO_MD5_LEN;
277  }
278  else
279  {
280  session.securityAuthProto = usmHMACSHA1AuthProtocol;
281  session.securityAuthProtoLen = USM_AUTH_PROTO_SHA_LEN;
282  }
283  session.securityAuthKeyLen = USM_AUTH_KU_LEN;
284  if (generate_Ku (session.securityAuthProto, session.securityAuthProtoLen,
285  (u_char *) request->authpass, strlen (request->authpass),
286  session.securityAuthKey, &session.securityAuthKeyLen)
287  != SNMPERR_SUCCESS)
288  {
289  result->name = g_strdup ("generate_Ku: Error");
290  return -1;
291  }
292  if (request->privpass)
293  {
294  if (request->privproto)
295  {
296  session.securityPrivProto = usmAESPrivProtocol;
297  session.securityPrivProtoLen = USM_PRIV_PROTO_AES_LEN;
298  }
299  else
300  {
301 #ifdef NETSNMP_DISABLE_DES
302  result->name =
303  g_strdup ("DES not supported in this net-snmp version.");
304  return -1;
305 #else
306  session.securityPrivProto = usmDESPrivProtocol;
307  session.securityPrivProtoLen = USM_PRIV_PROTO_DES_LEN;
308 #endif
309  }
310  session.securityPrivKeyLen = USM_PRIV_KU_LEN;
311  if (generate_Ku (session.securityAuthProto, session.securityAuthProtoLen,
312  (unsigned char *) request->privpass,
313  strlen (request->privpass), session.securityPrivKey,
314  &session.securityPrivKeyLen)
315  != SNMPERR_SUCCESS)
316  {
317  result->name = g_strdup ("generate_Ku: Error");
318  return -1;
319  }
320  }
321 
322  return snmp_get (&session, request->oid_str, request->action, result);
323 }
324 
325 /*
326  * @brief SNMP v1 or v2c Get query value.
327  *
328  * param[in] request Contains all necessary information for SNMPv1 or
329  * SNMPv2 query.
330  * param[out] result Result of query.
331  *
332  * @return 0 if success and result value, -1 otherwise.
333  */
334 static int
335 snmpv1v2c_get (const snmpv1v2_request_t request, snmp_result_t result)
336 {
337  struct snmp_session session;
338 
339  assert (request);
340  assert (request->peername);
341  assert (request->community);
342  assert (request->oid_str);
343  assert (request->version == SNMP_VERSION_1
344  || request->version == SNMP_VERSION_2c);
345 
346  setenv ("MIBS", "", 1);
347  snmp_sess_init (&session);
348  session.version = request->version;
349  session.peername = (char *) request->peername;
350  session.community = (u_char *) request->community;
351  session.community_len = strlen (request->community);
352 
353  return snmp_get (&session, request->oid_str, request->action, result);
354 }
355 
356 #else // no libnet. snmpget cmd wrap-up
357 
358 #define NASL_SNMP_GET 0
359 #define NASL_SNMP_GETNEXT 1
360 
366 static void
368 {
369  gchar **res_split, **res_aux;
370 
371  res_aux = res_split = g_strsplit (result->name, "\n", 0);
372 
373  if (!res_split)
374  return;
375 
376  while (res_aux)
377  {
378  /* There is no special reason, we return the whole error message
379  but removing the new line char at the end.
380  */
381  if (*res_aux == NULL)
382  {
383  char *pos;
384 
385  if ((pos = strchr (result->name, '\n')) != NULL)
386  *pos = '\0';
387  break;
388  }
389 
390  /* Search for the reason */
391  *res_aux = g_strrstr (*res_aux, "Reason: ");
392  if (*res_aux)
393  {
394  g_free (result->name);
395  result->name = g_strdup (*res_aux + 8);
396  break;
397  }
398  res_aux += 1;
399  }
400 
401  g_strfreev (res_split);
402  return;
403 }
404 
413 static int
414 check_spwan_output (int fd, snmp_result_t result, int fd_flag)
415 {
416  GString *string = NULL;
417 
418  string = g_string_new ("");
419  while (1)
420  {
421  char buf[4096];
422  size_t bytes;
423 
424  bytes = read (fd, buf, sizeof (buf));
425  if (!bytes)
426  break;
427  else if (bytes > 0)
428  g_string_append_len (string, buf, bytes);
429  else
430  {
431  g_warning ("snmpget: %s", strerror (errno));
432  g_string_free (string, TRUE);
433  return -1;
434  }
435  }
436 
437  // Split the result and store the oid and name
438  // in the result struct if there is a result
439  if (fd_flag == FD_STDOUT_FLAG)
440  {
441  gchar **oid_and_name;
442 
443  oid_and_name = g_strsplit (string->str, " ", 2);
444  result->oid_str = g_strdup (oid_and_name[0]);
445  result->name = g_strdup (oid_and_name[1]);
446  g_strfreev (oid_and_name);
447  }
448  else // STDERR, no oid
449  result->name = g_strdup (string->str);
450 
451  g_string_free (string, TRUE);
452 
453  return 0;
454 }
455 
465 static int
467 {
468  char *argv[8], *pos = NULL;
469  GError *err = NULL;
470  int sout = 0, serr = 0, ret;
471 
472  assert (request);
473  assert (request->peername);
474  assert (request->community);
475  assert (request->oid_str);
476  assert (request->version == SNMP_VERSION_1
477  || request->version == SNMP_VERSION_2c);
478  assert (request->action == NASL_SNMP_GET
479  || request->action == NASL_SNMP_GETNEXT);
480 
481  setenv ("MIBS", "", 1);
482 
483  argv[0] = (request->action == NASL_SNMP_GET) ? "snmpget" : "snmpgetnext";
484  argv[1] = (request->version == SNMP_VERSION_1) ? "-v1" : "-v2c";
485  argv[2] = "-Oqn";
486  argv[3] = "-c";
487  argv[4] = g_strdup (request->community);
488  argv[5] = g_strdup (request->peername);
489  argv[6] = g_strdup (request->oid_str);
490  argv[7] = NULL;
491  ret = g_spawn_async_with_pipes (NULL, argv, NULL, G_SPAWN_SEARCH_PATH, NULL,
492  NULL, NULL, NULL, &sout, &serr, &err);
493  g_free (argv[4]);
494  g_free (argv[5]);
495  g_free (argv[6]);
496 
497  if (ret == FALSE)
498  {
499  g_warning ("snmpget: %s", err ? err->message : "Error");
500  if (err)
501  g_error_free (err);
502  return -1;
503  }
504 
505  /* As we spawn the process asynchronously, we don't know the exit
506  status of the process. Therefore we need to check for errors in
507  the output.
508  We assume a valid output if there is no errors.
509  */
510  check_spwan_output (serr, result, FD_STDERR_FLAG);
511  if (result->name && result->name[0] != '\0')
512  {
513  parse_snmp_error (result);
514  close (sout);
515  close (serr);
516  return -1;
517  }
518  close (serr);
519  g_free (result->name);
520 
521  check_spwan_output (sout, result, FD_STDOUT_FLAG);
522  close (sout);
523 
524  /* Remove the last new line char from the result */
525  if ((pos = strchr (result->name, '\0')) != NULL)
526  {
527  pos--;
528  if (pos[0] == '\n')
529  *pos = '\0';
530  }
531 
532  return 0;
533 }
534 
543 static int
545 {
546  char *argv[18], *pos = NULL;
547  GError *err = NULL;
548  int sout = 0, serr = 0, ret;
549 
550  assert (request);
551  assert (request->peername);
552  assert (request->username);
553  assert (request->authpass);
554  assert (request->authproto == 0 || request->authproto == 1);
555  assert (request->oid_str);
556  assert (result);
557 
558  setenv ("MIBS", "", 1);
559 
560  argv[0] = (request->action == NASL_SNMP_GET) ? "snmpget" : "snmpgetnext";
561  argv[1] = "-v3";
562  argv[2] = "-Oqn";
563  argv[3] = "-u";
564  argv[4] = g_strdup (request->username);
565  argv[5] = "-A";
566  argv[6] = g_strdup (request->authpass);
567  argv[7] = "-l";
568  argv[8] = request->privpass ? "authPriv" : "authNoPriv";
569  argv[9] = "-a";
570  argv[10] = request->authproto ? "SHA" : "MD5";
571  if (request->privpass)
572  {
573  argv[11] = g_strdup (request->peername);
574  argv[12] = g_strdup (request->oid_str);
575  argv[13] = "-x";
576  argv[14] = request->privproto ? "AES" : "DES";
577  argv[15] = "-X";
578  argv[16] = g_strdup (request->privpass);
579  argv[17] = NULL;
580  }
581  else
582  {
583  argv[11] = g_strdup (request->peername);
584  argv[12] = g_strdup (request->oid_str);
585  argv[13] = NULL;
586  }
587 
588  ret = g_spawn_async_with_pipes (NULL, argv, NULL, G_SPAWN_SEARCH_PATH, NULL,
589  NULL, NULL, NULL, &sout, &serr, &err);
590  g_free (argv[4]);
591  g_free (argv[6]);
592  g_free (argv[11]);
593  g_free (argv[12]);
594  if (request->privpass)
595  g_free (argv[16]);
596 
597  if (ret == FALSE)
598  {
599  g_warning ("%s: %s", argv[0], err ? err->message : "Error");
600  if (err)
601  g_error_free (err);
602  return -1;
603  }
604 
605  check_spwan_output (serr, result, FD_STDERR_FLAG);
606  if (result->name && result->name[0] != '\0')
607  {
608  parse_snmp_error (result);
609  close (sout);
610  close (serr);
611  return -1;
612  }
613  close (serr);
614  g_free (result->name);
615 
616  check_spwan_output (sout, result, FD_STDOUT_FLAG);
617  close (sout);
618 
619  /* Remove the last new line char from the result */
620  if ((pos = strchr (result->name, '\0')) != NULL)
621  {
622  pos--;
623  if (pos[0] == '\n')
624  *pos = '\0';
625  }
626 
627  return 0;
628 }
629 
630 #endif /* HAVE_NETSNMP */
631 
632 static tree_cell *
633 nasl_snmpv1v2c_get (lex_ctxt *lexic, int version, u_char action)
634 {
635  tree_cell *retc = NULL;
636  const char *proto;
637  char peername[2048];
638  int port, ret;
639  snmpv1v2_request_t request;
640  snmp_result_t result;
641  char *oid_str;
642  static char *next_oid_str;
643 
644  request = g_malloc0 (sizeof (struct snmpv1v2_request));
645 
646  request->version = version;
647  request->action = action;
648  port = get_int_var_by_name (lexic, "port", -1);
649  proto = get_str_var_by_name (lexic, "protocol");
650  request->community = get_str_var_by_name (lexic, "community");
651 
652  oid_str = get_str_var_by_name (lexic, "oid");
653  if (action == NASL_SNMP_GETNEXT && oid_str == NULL && next_oid_str != NULL)
654  request->oid_str = next_oid_str;
655  else
656  request->oid_str = oid_str;
657 
658  if (!proto || !request->community || !request->oid_str)
659  {
660  g_free (request);
661  return array_from_snmp_error (-2, "Missing function argument");
662  }
663  if (port < 0 || port > 65535)
664  {
665  g_free (request);
666  return array_from_snmp_error (-2, "Invalid port value");
667  }
668  if (!proto_is_valid (proto))
669  {
670  g_free (request);
671  return array_from_snmp_error (-2, "Invalid protocol value");
672  }
673 
674  g_snprintf (peername, sizeof (peername), "%s:%s:%d", proto,
675  plug_get_host_ip_str (lexic->script_infos), port);
676  request->peername = peername;
677 
678  result = g_malloc0 (sizeof (struct snmp_result));
679  ret = snmpv1v2c_get (request, result);
680 
681  // Hack the OID string to adjust format. Replace 'iso.' with '.1.'
682  // This Allows to call getnext without an oid, since the last oid
683  // is stored.
684  if (result->oid_str != NULL && g_strstr_len (result->oid_str, 3, "iso"))
685  {
686  next_oid_str = result->oid_str + 2;
687  next_oid_str[0] = '1';
688  result->oid_str = g_strdup (next_oid_str);
689  }
690  else if (result->oid_str != NULL)
691  next_oid_str = result->oid_str;
692 
693  /* Free request only, since members are pointers to the nasl lexic context
694  which will be free()'d later */
695  g_free (request);
696 
697  retc = array_from_snmp_result (ret, result);
698  destroy_snmp_result (result);
699  return retc;
700 }
701 
702 tree_cell *
704 {
706 }
707 
708 tree_cell *
710 {
712 }
713 
714 tree_cell *
716 {
718 }
719 
720 tree_cell *
722 {
724 }
725 
726 static tree_cell *
727 nasl_snmpv3_get_action (lex_ctxt *lexic, u_char action)
728 {
729  tree_cell *retc = NULL;
730  const char *proto, *authproto, *privproto;
731  char peername[2048];
732  int port, ret;
733  snmpv3_request_t request;
734  snmp_result_t result;
735  char *oid_str;
736  static char *next_oid_str;
737 
738  request = g_malloc0 (sizeof (struct snmpv3_request));
739 
740  request->action = action;
741  port = get_int_var_by_name (lexic, "port", -1);
742  proto = get_str_var_by_name (lexic, "protocol");
743  request->username = get_str_var_by_name (lexic, "username");
744  request->authpass = get_str_var_by_name (lexic, "authpass");
745 
746  oid_str = get_str_var_by_name (lexic, "oid");
747 
748  if (action == NASL_SNMP_GETNEXT && oid_str == NULL && next_oid_str != NULL)
749  request->oid_str = next_oid_str;
750  else
751  request->oid_str = oid_str;
752 
753  authproto = get_str_var_by_name (lexic, "authproto");
754  request->privpass = get_str_var_by_name (lexic, "privpass");
755  privproto = get_str_var_by_name (lexic, "privproto");
756 
757  if (!proto || !request->username || !request->authpass || !request->oid_str
758  || !authproto)
759  {
760  g_free (request);
761  return array_from_snmp_error (-2, "Missing function argument");
762  }
763  if (port < 0 || port > 65535)
764  {
765  g_free (request);
766  return array_from_snmp_error (-2, "Invalid port value");
767  }
768  if (!proto_is_valid (proto))
769  {
770  g_free (request);
771  return array_from_snmp_error (-2, "Invalid protocol value");
772  }
773 
774  if (!privproto || !request->privpass)
775  {
776  g_free (request);
777  return array_from_snmp_error (-2, "Missing privproto or privpass");
778  }
779 
780  if (!strcasecmp (authproto, "md5"))
781  request->authproto = 0;
782  else if (!strcasecmp (authproto, "sha1"))
783  request->authproto = 1;
784  else
785  {
786  g_free (request);
787  return array_from_snmp_error (-2, "authproto should be md5 or sha1");
788  }
789 
790  if (privproto)
791  {
792  if (!strcasecmp (privproto, "des"))
793  request->privproto = 0;
794  else if (!strcasecmp (privproto, "aes"))
795  request->privproto = 1;
796  else
797  {
798  g_free (request);
799  return array_from_snmp_error (-2, "privproto should be des or aes");
800  }
801  }
802 
803  g_snprintf (peername, sizeof (peername), "%s:%s:%d", proto,
804  plug_get_host_ip_str (lexic->script_infos), port);
805  request->peername = peername;
806 
807  result = g_malloc0 (sizeof (struct snmp_result));
808  ret = snmpv3_get (request, result);
809 
810  // Hack the OID string to adjust format. Replace 'iso.' with '.1.'
811  // This Allows to call getnext without an oid, since the last oid
812  // is stored.
813  if (result->oid_str != NULL && g_strstr_len (result->oid_str, 3, "iso"))
814  {
815  next_oid_str = result->oid_str + 2;
816  next_oid_str[0] = '1';
817  result->oid_str = g_strdup (next_oid_str);
818  }
819  else if (result->oid_str != NULL)
820  next_oid_str = result->oid_str;
821 
822  /* Free request only, since members are pointers to the nasl lexic context
823  which will be free()'d later */
824  g_free (request);
825 
826  retc = array_from_snmp_result (ret, result);
827  destroy_snmp_result (result);
828  return retc;
829 }
830 
831 tree_cell *
833 {
834  return nasl_snmpv3_get_action (lexic, NASL_SNMP_GET);
835 }
836 
837 tree_cell *
839 {
841 }
nasl_snmp.h
Headers of an API for SNMP used by NASL scripts.
st_a_nasl_var
Definition: nasl_var.h:40
FD_STDOUT_FLAG
#define FD_STDOUT_FLAG
Definition: nasl_snmp.c:41
snmpv1v2_request::community
char * community
Definition: nasl_snmp.c:49
snmpv3_request::peername
char * peername
Definition: nasl_snmp.c:62
snmp_result::oid_str
char * oid_str
Definition: nasl_snmp.c:76
TC::x
union TC::@5 x
NASL_SNMP_GET
#define NASL_SNMP_GET
Definition: nasl_snmp.c:358
SNMP_VERSION_1
#define SNMP_VERSION_1
SNMP V1.
Definition: nasl_snmp.c:33
DYN_ARRAY
@ DYN_ARRAY
Definition: nasl_tree.h:90
snmpv3_request::action
u_char action
Definition: nasl_snmp.c:69
check_spwan_output
static int check_spwan_output(int fd, snmp_result_t result, int fd_flag)
Read data from a file descriptor.
Definition: nasl_snmp.c:414
st_a_nasl_var::v
union st_a_nasl_var::@7 v
get_str_var_by_name
char * get_str_var_by_name(lex_ctxt *, const char *)
Definition: nasl_var.c:1118
st_a_nasl_var::v_str
nasl_string_t v_str
Definition: nasl_var.h:47
VAR2_STRING
@ VAR2_STRING
Definition: nasl_var.h:17
st_nasl_string::s_siz
int s_siz
Definition: nasl_var.h:27
st_nasl_array
Definition: nasl_var.h:33
snmpv3_request::authproto
int authproto
Definition: nasl_snmp.c:67
snmpv1v2_request::peername
char * peername
Definition: nasl_snmp.c:48
FD_STDERR_FLAG
#define FD_STDERR_FLAG
Definition: nasl_snmp.c:40
destroy_snmp_result
static void destroy_snmp_result(snmp_result_t result)
Definition: nasl_snmp.c:83
VAR2_INT
@ VAR2_INT
Definition: nasl_var.h:16
oid
const char * oid
Definition: nasl_builtin_find_service.c:51
nasl_snmpv3_get_action
static tree_cell * nasl_snmpv3_get_action(lex_ctxt *lexic, u_char action)
Definition: nasl_snmp.c:727
snmpv1v2_request::oid_str
char * oid_str
Definition: nasl_snmp.c:50
nasl_snmpv1_getnext
tree_cell * nasl_snmpv1_getnext(lex_ctxt *lexic)
Definition: nasl_snmp.c:709
nasl_snmpv1v2c_get
static tree_cell * nasl_snmpv1v2c_get(lex_ctxt *lexic, int version, u_char action)
Definition: nasl_snmp.c:633
snmpv1v2_request::version
int version
Definition: nasl_snmp.c:51
snmpv3_request::username
char * username
Definition: nasl_snmp.c:63
nasl_lex_ctxt.h
snmp_result_t
struct snmp_result * snmp_result_t
Definition: nasl_snmp.c:80
get_int_var_by_name
long int get_int_var_by_name(lex_ctxt *, const char *, int)
Definition: nasl_var.c:1104
snmpv1v2_request::action
u_char action
Definition: nasl_snmp.c:52
TC::ref_val
void * ref_val
Definition: nasl_tree.h:105
st_a_nasl_var::var_type
int var_type
Definition: nasl_var.h:41
nasl_snmpv1_get
tree_cell * nasl_snmpv1_get(lex_ctxt *lexic)
Definition: nasl_snmp.c:703
struct_lex_ctxt::script_infos
struct script_infos * script_infos
Definition: nasl_lex_ctxt.h:30
snmpv3_request::authpass
char * authpass
Definition: nasl_snmp.c:64
TC
Definition: nasl_tree.h:94
struct_lex_ctxt
Definition: nasl_lex_ctxt.h:23
nasl_snmpv2c_get
tree_cell * nasl_snmpv2c_get(lex_ctxt *lexic)
Definition: nasl_snmp.c:715
array_from_snmp_error
static tree_cell * array_from_snmp_error(int ret, const char *err)
Definition: nasl_snmp.c:150
snmp_result
Definition: nasl_snmp.c:75
snmp_result::name
char * name
Definition: nasl_snmp.c:77
snmpv3_request::privpass
char * privpass
Definition: nasl_snmp.c:65
snmpv3_request
SNMP Request struct for snmp v3.
Definition: nasl_snmp.c:61
nasl_snmpv3_get
tree_cell * nasl_snmpv3_get(lex_ctxt *lexic)
Definition: nasl_snmp.c:832
array_from_snmp_result
static tree_cell * array_from_snmp_result(int ret, const snmp_result_t result)
Definition: nasl_snmp.c:117
snmpv1v2_request
SNMP Request struct for snmp v1 and v2c.
Definition: nasl_snmp.c:47
add_var_to_list
int add_var_to_list(nasl_array *a, int i, const anon_nasl_var *v)
Definition: nasl_var.c:1245
nasl_snmpv2c_getnext
tree_cell * nasl_snmpv2c_getnext(lex_ctxt *lexic)
Definition: nasl_snmp.c:721
NASL_SNMP_GETNEXT
#define NASL_SNMP_GETNEXT
Definition: nasl_snmp.c:359
st_a_nasl_var::v_int
long int v_int
Definition: nasl_var.h:48
snmpv1v2c_get
static int snmpv1v2c_get(const snmpv1v2_request_t request, snmp_result_t result)
SNMP v1 or v2c Get query value. snmpget cmd wrapper.
Definition: nasl_snmp.c:466
snmpv1v2_request_t
struct snmpv1v2_request * snmpv1v2_request_t
Definition: nasl_snmp.c:55
snmpv3_request_t
struct snmpv3_request * snmpv3_request_t
Definition: nasl_snmp.c:72
alloc_typed_cell
tree_cell * alloc_typed_cell(int typ)
Definition: nasl_tree.c:28
nasl_snmpv3_getnext
tree_cell * nasl_snmpv3_getnext(lex_ctxt *lexic)
Definition: nasl_snmp.c:838
SNMP_VERSION_2c
#define SNMP_VERSION_2c
SNMP V2c.
Definition: nasl_snmp.c:38
plug_get_host_ip_str
char * plug_get_host_ip_str(struct script_infos *desc)
Definition: plugutils.c:322
snmpv3_request::privproto
int privproto
Definition: nasl_snmp.c:68
snmpv3_get
static int snmpv3_get(const snmpv3_request_t request, snmp_result_t result)
SNMPv3 Get query value. snmpget cmd wrapper.
Definition: nasl_snmp.c:544
parse_snmp_error
static void parse_snmp_error(snmp_result_t result)
Parse the snmp error.
Definition: nasl_snmp.c:367
st_nasl_string::s_val
unsigned char * s_val
Definition: nasl_var.h:26
snmpv3_request::oid_str
char * oid_str
Definition: nasl_snmp.c:66
proto_is_valid
static int proto_is_valid(const char *proto)
Definition: nasl_snmp.c:100