nis_getservlist.c 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. /* Copyright (c) 1997-2026 Free Software Foundation, Inc.
  2. This file is part of the GNU C Library.
  3. The GNU C Library is free software; you can redistribute it and/or
  4. modify it under the terms of the GNU Lesser General Public
  5. License as published by the Free Software Foundation; either
  6. version 2.1 of the License, or (at your option) any later version.
  7. The GNU C Library is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  10. Lesser General Public License for more details.
  11. You should have received a copy of the GNU Lesser General Public
  12. License along with the GNU C Library; if not, see
  13. <https://www.gnu.org/licenses/>. */
  14. #include <string.h>
  15. #include <rpcsvc/nis.h>
  16. #include <shlib-compat.h>
  17. #include "nis_xdr.h"
  18. #include "nis_intern.h"
  19. nis_server **
  20. nis_getservlist (const_nis_name dir)
  21. {
  22. nis_result *res;
  23. nis_server **serv;
  24. res = nis_lookup (dir, FOLLOW_LINKS);
  25. if (res != NULL && NIS_RES_STATUS (res) == NIS_SUCCESS)
  26. {
  27. unsigned long i;
  28. nis_server *server;
  29. serv =
  30. malloc (sizeof (nis_server *) *
  31. (NIS_RES_OBJECT (res)->DI_data.do_servers.do_servers_len + 1));
  32. if (__glibc_unlikely (serv == NULL))
  33. {
  34. nis_freeresult (res);
  35. return NULL;
  36. }
  37. for (i = 0; i < NIS_RES_OBJECT (res)->DI_data.do_servers.do_servers_len;
  38. ++i)
  39. {
  40. server =
  41. &NIS_RES_OBJECT (res)->DI_data.do_servers.do_servers_val[i];
  42. serv[i] = calloc (1, sizeof (nis_server));
  43. if (__glibc_unlikely (serv[i] == NULL))
  44. {
  45. free_all:
  46. while (i-- > 0)
  47. {
  48. free (serv[i]->pkey.n_bytes);
  49. if (serv[i]->ep.ep_val != NULL)
  50. {
  51. unsigned long int j;
  52. for (j = 0; j < serv[i]->ep.ep_len; ++j)
  53. {
  54. free (serv[i]->ep.ep_val[j].proto);
  55. free (serv[i]->ep.ep_val[j].family);
  56. free (serv[i]->ep.ep_val[j].uaddr);
  57. }
  58. free (serv[i]->ep.ep_val);
  59. }
  60. free (serv[i]->name);
  61. free (serv[i]);
  62. }
  63. free (serv);
  64. nis_freeresult (res);
  65. return NULL;
  66. }
  67. if (server->name != NULL)
  68. {
  69. serv[i]->name = strdup (server->name);
  70. if (__glibc_unlikely (serv[i]->name == NULL))
  71. {
  72. ++i;
  73. goto free_all;
  74. }
  75. }
  76. serv[i]->ep.ep_len = server->ep.ep_len;
  77. if (serv[i]->ep.ep_len > 0)
  78. {
  79. unsigned long int j;
  80. serv[i]->ep.ep_val =
  81. malloc (server->ep.ep_len * sizeof (endpoint));
  82. if (__glibc_unlikely (serv[i]->ep.ep_val == NULL))
  83. {
  84. ++i;
  85. goto free_all;
  86. }
  87. for (j = 0; j < serv[i]->ep.ep_len; ++j)
  88. {
  89. if (server->ep.ep_val[j].uaddr)
  90. serv[i]->ep.ep_val[j].uaddr =
  91. strdup (server->ep.ep_val[j].uaddr);
  92. else
  93. serv[i]->ep.ep_val[j].uaddr = NULL;
  94. if (server->ep.ep_val[j].family)
  95. serv[i]->ep.ep_val[j].family =
  96. strdup (server->ep.ep_val[j].family);
  97. else
  98. serv[i]->ep.ep_val[j].family = NULL;
  99. if (server->ep.ep_val[j].proto)
  100. serv[i]->ep.ep_val[j].proto =
  101. strdup (server->ep.ep_val[j].proto);
  102. else
  103. serv[i]->ep.ep_val[j].proto = NULL;
  104. }
  105. }
  106. serv[i]->key_type = server->key_type;
  107. serv[i]->pkey.n_len = server->pkey.n_len;
  108. if (server->pkey.n_len > 0)
  109. {
  110. serv[i]->pkey.n_bytes = malloc (server->pkey.n_len);
  111. if (__glibc_unlikely (serv[i]->pkey.n_bytes == NULL))
  112. {
  113. ++i;
  114. goto free_all;
  115. }
  116. memcpy (serv[i]->pkey.n_bytes, server->pkey.n_bytes,
  117. server->pkey.n_len);
  118. }
  119. }
  120. serv[i] = NULL;
  121. }
  122. else
  123. {
  124. serv = malloc (sizeof (nis_server *));
  125. if (__glibc_unlikely (serv != NULL))
  126. serv[0] = NULL;
  127. }
  128. nis_freeresult (res);
  129. return serv;
  130. }
  131. libnsl_hidden_nolink_def (nis_getservlist, GLIBC_2_1)
  132. void
  133. nis_freeservlist (nis_server **serv)
  134. {
  135. int i;
  136. if (serv == NULL)
  137. return;
  138. i = 0;
  139. while (serv[i] != NULL)
  140. {
  141. xdr_free ((xdrproc_t)_xdr_nis_server, (char *)serv[i]);
  142. free (serv[i]);
  143. ++i;
  144. }
  145. free (serv);
  146. }
  147. libnsl_hidden_nolink_def (nis_freeservlist, GLIBC_2_1)