time: Also check for EPERM while trying to clock_settime
[glibc.git] / nis / nis_print.c
blob5569777a922d5eded6c270cc933ee954d0e56c38
1 /* Copyright (c) 1997-2023 Free Software Foundation, Inc.
2 This file is part of the GNU C Library.
4 The GNU C Library is free software; you can redistribute it and/or
5 modify it under the terms of the GNU Lesser General Public
6 License as published by the Free Software Foundation; either
7 version 2.1 of the License, or (at your option) any later version.
9 The GNU C Library is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 Lesser General Public License for more details.
14 You should have received a copy of the GNU Lesser General Public
15 License along with the GNU C Library; if not, see
16 <https://www.gnu.org/licenses/>. */
18 #include <time.h>
19 #include <string.h>
20 #include <libintl.h>
21 #include <stdint.h>
23 #include <rpcsvc/nis.h>
24 #include <shlib-compat.h>
26 static const char *
27 nis_nstype2str (const nstype type)
30 /* Name service names mustn't be translated, only UNKNOWN needs it */
32 switch (type)
34 case NIS:
35 return "NIS";
36 case SUNYP:
37 return "SUNYP";
38 case IVY:
39 return "IVY";
40 case DNS:
41 return "DNS";
42 case X500:
43 return "X500";
44 case DNANS:
45 return "DNANS";
46 case XCHS:
47 return "XCHS";
48 case CDS:
49 return "CDS";
50 default:
51 return N_("UNKNOWN");
55 static const char *
56 nis_objtype (const zotypes type)
58 switch (type)
60 case NIS_BOGUS_OBJ:
61 return _("BOGUS OBJECT");
62 case NIS_NO_OBJ:
63 return _("NO OBJECT");
64 case NIS_DIRECTORY_OBJ:
65 return _("DIRECTORY");
66 case NIS_GROUP_OBJ:
67 return _("GROUP");
68 case NIS_TABLE_OBJ:
69 return _("TABLE");
70 case NIS_ENTRY_OBJ:
71 return _("ENTRY");
72 case NIS_LINK_OBJ:
73 return _("LINK");
74 case NIS_PRIVATE_OBJ:
75 return _("PRIVATE\n");
76 default:
77 return _("(Unknown object");
81 static void
82 print_ttl (const uint32_t ttl)
84 uint32_t time, s, m, h;
86 time = ttl;
88 h = time / (60 * 60);
89 time %= (60 * 60);
90 m = time / 60;
91 time %= 60;
92 s = time;
93 printf ("%u:%u:%u\n", h, m, s);
96 static void
97 print_flags (const unsigned int flags)
99 fputs ("(", stdout);
101 if (flags & TA_SEARCHABLE)
102 fputs ("SEARCHABLE, ", stdout);
104 if (flags & TA_BINARY)
106 fputs ("BINARY DATA", stdout);
107 if (flags & TA_XDR)
108 fputs (", XDR ENCODED", stdout);
109 if (flags & TA_ASN1)
110 fputs (", ASN.1 ENCODED", stdout);
111 if (flags & TA_CRYPT)
112 fputs (", ENCRYPTED", stdout);
114 else
116 fputs ("TEXTUAL DATA", stdout);
117 if (flags & TA_SEARCHABLE)
119 if (flags & TA_CASE)
120 fputs (", CASE INSENSITIVE", stdout);
121 else
122 fputs (", CASE SENSITIVE", stdout);
126 fputs (")\n", stdout);
129 static void
130 nis_print_objtype (enum zotypes type)
132 printf ("%s\n", nis_objtype (type));
135 void
136 nis_print_rights (const unsigned int access)
138 char result[17];
139 unsigned int acc;
140 int i;
142 acc = access; /* Parameter is const ! */
143 result[i = 16] = '\0';
144 while (i > 0)
146 i -= 4;
147 result[i + 0] = (acc & NIS_READ_ACC) ? 'r' : '-';
148 result[i + 1] = (acc & NIS_MODIFY_ACC) ? 'm' : '-';
149 result[i + 2] = (acc & NIS_CREATE_ACC) ? 'c' : '-';
150 result[i + 3] = (acc & NIS_DESTROY_ACC) ? 'd' : '-';
152 acc >>= 8;
154 fputs (result, stdout);
156 libnsl_hidden_nolink_def (nis_print_rights, GLIBC_2_1)
158 void
159 nis_print_directory (const directory_obj *dir)
161 nis_server *sptr;
162 unsigned int i;
164 printf (_("Name : `%s'\n"), dir->do_name);
165 printf (_("Type : %s\n"), nis_nstype2str (dir->do_type));
166 sptr = dir->do_servers.do_servers_val;
167 for (i = 0; i < dir->do_servers.do_servers_len; i++)
169 if (i == 0)
170 fputs (_("Master Server :\n"), stdout);
171 else
172 fputs (_("Replicate :\n"), stdout);
173 printf (_("\tName : %s\n"), sptr->name);
174 fputs (_("\tPublic Key : "), stdout);
175 switch (sptr->key_type)
177 case NIS_PK_NONE:
178 fputs (_("None.\n"), stdout);
179 break;
180 case NIS_PK_DH:
181 printf (_("Diffie-Hellmann (%d bits)\n"),
182 (sptr->pkey.n_len - 1) * 4);
183 /* sptr->pkey.n_len counts the last 0, too */
184 break;
185 case NIS_PK_RSA:
186 printf (_("RSA (%d bits)\n"), (sptr->pkey.n_len - 1) * 4);
187 break;
188 case NIS_PK_KERB:
189 fputs (_("Kerberos.\n"), stdout);
190 break;
191 default:
192 printf (_("Unknown (type = %d, bits = %d)\n"), sptr->key_type,
193 (sptr->pkey.n_len - 1) * 4);
194 break;
197 if (sptr->ep.ep_len != 0)
199 unsigned int j;
201 endpoint *ptr;
202 ptr = sptr->ep.ep_val;
203 printf (_("\tUniversal addresses (%u)\n"), sptr->ep.ep_len);
204 for (j = 0; j < sptr->ep.ep_len; j++)
206 printf ("\t[%d] - ", j + 1);
207 if (ptr->proto != NULL && ptr->proto[0] != '\0')
208 printf ("%s, ", ptr->proto);
209 else
210 printf ("-, ");
211 if (ptr->family != NULL && ptr->family[0] != '\0')
212 printf ("%s, ", ptr->family);
213 else
214 printf ("-, ");
215 if (ptr->uaddr != NULL && ptr->uaddr[0] != '\0')
216 printf ("%s\n", ptr->uaddr);
217 else
218 fputs ("-\n", stdout);
219 ptr++;
222 sptr++;
225 fputs (_("Time to live : "), stdout);
226 print_ttl (dir->do_ttl);
227 fputs (_("Default Access rights :\n"), stdout);
228 if (dir->do_armask.do_armask_len != 0)
230 oar_mask *ptr;
232 ptr = dir->do_armask.do_armask_val;
233 for (i = 0; i < dir->do_armask.do_armask_len; i++)
235 nis_print_rights (ptr->oa_rights);
236 printf (_("\tType : %s\n"), nis_objtype (ptr->oa_otype));
237 fputs (_("\tAccess rights: "), stdout);
238 nis_print_rights (ptr->oa_rights);
239 fputs ("\n", stdout);
240 ptr++;
244 libnsl_hidden_nolink_def (nis_print_directory, GLIBC_2_1)
246 void
247 nis_print_group (const group_obj *obj)
249 unsigned int i;
251 fputs (_("Group Flags :"), stdout);
252 if (obj->gr_flags)
253 printf ("0x%08X", obj->gr_flags);
254 fputs (_("\nGroup Members :\n"), stdout);
256 for (i = 0; i < obj->gr_members.gr_members_len; i++)
257 printf ("\t%s\n", obj->gr_members.gr_members_val[i]);
259 libnsl_hidden_nolink_def (nis_print_group, GLIBC_2_1)
261 void
262 nis_print_table (const table_obj *obj)
264 unsigned int i;
266 printf (_("Table Type : %s\n"), obj->ta_type);
267 printf (_("Number of Columns : %d\n"), obj->ta_maxcol);
268 printf (_("Character Separator : %c\n"), obj->ta_sep);
269 printf (_("Search Path : %s\n"), obj->ta_path);
270 fputs (_("Columns :\n"), stdout);
271 for (i = 0; i < obj->ta_cols.ta_cols_len; i++)
273 printf (_("\t[%d]\tName : %s\n"), i,
274 obj->ta_cols.ta_cols_val[i].tc_name);
275 fputs (_("\t\tAttributes : "), stdout);
276 print_flags (obj->ta_cols.ta_cols_val[i].tc_flags);
277 fputs (_("\t\tAccess Rights : "), stdout);
278 nis_print_rights (obj->ta_cols.ta_cols_val[i].tc_rights);
279 fputc ('\n', stdout);
282 libnsl_hidden_nolink_def (nis_print_table, GLIBC_2_1)
284 void
285 nis_print_link (const link_obj *obj)
287 fputs (_("Linked Object Type : "), stdout);
288 nis_print_objtype (obj->li_rtype);
289 printf (_("Linked to : %s\n"), obj->li_name);
290 /* XXX Print the attributes here, if they exists */
292 libnsl_hidden_nolink_def (nis_print_link, GLIBC_2_1)
294 void
295 nis_print_entry (const entry_obj *obj)
297 unsigned int i;
299 printf (_("\tEntry data of type %s\n"), obj->en_type);
300 for (i = 0; i < obj->en_cols.en_cols_len; i++)
302 printf (_("\t[%u] - [%u bytes] "), i,
303 obj->en_cols.en_cols_val[i].ec_value.ec_value_len);
304 if ((obj->en_cols.en_cols_val[i].ec_flags & EN_CRYPT) == EN_CRYPT)
305 fputs (_("Encrypted data\n"), stdout);
306 else if ((obj->en_cols.en_cols_val[i].ec_flags & EN_BINARY) == EN_BINARY)
307 fputs (_("Binary data\n"), stdout);
308 else if (obj->en_cols.en_cols_val[i].ec_value.ec_value_len == 0)
309 fputs ("'(nil)'\n", stdout);
310 else
311 printf ("'%.*s'\n",
312 (int)obj->en_cols.en_cols_val[i].ec_value.ec_value_len,
313 obj->en_cols.en_cols_val[i].ec_value.ec_value_val);
316 libnsl_hidden_nolink_def (nis_print_entry, GLIBC_2_1)
318 void
319 nis_print_object (const nis_object * obj)
321 time_t buf;
323 printf (_("Object Name : %s\n"), obj->zo_name);
324 printf (_("Directory : %s\n"), obj->zo_domain);
325 printf (_("Owner : %s\n"), obj->zo_owner);
326 printf (_("Group : %s\n"), obj->zo_group);
327 fputs (_("Access Rights : "), stdout);
328 nis_print_rights (obj->zo_access);
329 printf (_("\nTime to Live : "));
330 print_ttl (obj->zo_ttl);
331 buf = obj->zo_oid.ctime;
332 printf (_("Creation Time : %s"), ctime (&buf));
333 buf = obj->zo_oid.mtime;
334 printf (_("Mod. Time : %s"), ctime (&buf));
335 fputs (_("Object Type : "), stdout);
336 nis_print_objtype (obj->zo_data.zo_type);
337 switch (obj->zo_data.zo_type)
339 case NIS_DIRECTORY_OBJ:
340 nis_print_directory (&obj->zo_data.objdata_u.di_data);
341 break;
342 case NIS_GROUP_OBJ:
343 nis_print_group (&obj->zo_data.objdata_u.gr_data);
344 break;
345 case NIS_TABLE_OBJ:
346 nis_print_table (&obj->zo_data.objdata_u.ta_data);
347 break;
348 case NIS_ENTRY_OBJ:
349 nis_print_entry (&obj->zo_data.objdata_u.en_data);
350 break;
351 case NIS_LINK_OBJ:
352 nis_print_link (&obj->zo_data.objdata_u.li_data);
353 break;
354 case NIS_PRIVATE_OBJ:
355 printf (_(" Data Length = %u\n"),
356 obj->zo_data.objdata_u.po_data.po_data_len);
357 break;
358 default:
359 break;
362 libnsl_hidden_nolink_def (nis_print_object, GLIBC_2_1)
364 void
365 nis_print_result (const nis_result *res)
367 unsigned int i;
369 printf (_("Status : %s\n"), nis_sperrno (NIS_RES_STATUS (res)));
370 printf (_("Number of objects : %u\n"), res->objects.objects_len);
372 for (i = 0; i < res->objects.objects_len; i++)
374 printf (_("Object #%d:\n"), i);
375 nis_print_object (&res->objects.objects_val[i]);
378 libnsl_hidden_nolink_def (nis_print_result, GLIBC_2_1)