1*0Sstevel@tonic-gate /*
2*0Sstevel@tonic-gate  * CDDL HEADER START
3*0Sstevel@tonic-gate  *
4*0Sstevel@tonic-gate  * The contents of this file are subject to the terms of the
5*0Sstevel@tonic-gate  * Common Development and Distribution License, Version 1.0 only
6*0Sstevel@tonic-gate  * (the "License").  You may not use this file except in compliance
7*0Sstevel@tonic-gate  * with the License.
8*0Sstevel@tonic-gate  *
9*0Sstevel@tonic-gate  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10*0Sstevel@tonic-gate  * or http://www.opensolaris.org/os/licensing.
11*0Sstevel@tonic-gate  * See the License for the specific language governing permissions
12*0Sstevel@tonic-gate  * and limitations under the License.
13*0Sstevel@tonic-gate  *
14*0Sstevel@tonic-gate  * When distributing Covered Code, include this CDDL HEADER in each
15*0Sstevel@tonic-gate  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16*0Sstevel@tonic-gate  * If applicable, add the following below this CDDL HEADER, with the
17*0Sstevel@tonic-gate  * fields enclosed by brackets "[]" replaced with your own identifying
18*0Sstevel@tonic-gate  * information: Portions Copyright [yyyy] [name of copyright owner]
19*0Sstevel@tonic-gate  *
20*0Sstevel@tonic-gate  * CDDL HEADER END
21*0Sstevel@tonic-gate  */
22*0Sstevel@tonic-gate /*
23*0Sstevel@tonic-gate  * Copyright 1996 Sun Microsystems, Inc.  All rights reserved.
24*0Sstevel@tonic-gate  * Use is subject to license terms.
25*0Sstevel@tonic-gate  */
26*0Sstevel@tonic-gate #pragma ident	"%Z%%M%	%I%	%E% SMI"
27*0Sstevel@tonic-gate 
28*0Sstevel@tonic-gate 
29*0Sstevel@tonic-gate #include "stdio.h"
30*0Sstevel@tonic-gate #include "errno.h"
31*0Sstevel@tonic-gate #include "sys/types.h"
32*0Sstevel@tonic-gate #include "sys/socket.h"
33*0Sstevel@tonic-gate #include "netinet/in.h"
34*0Sstevel@tonic-gate 
35*0Sstevel@tonic-gate #include "snmp_msg.h"
36*0Sstevel@tonic-gate #include "error.h"
37*0Sstevel@tonic-gate #include "trace.h"
38*0Sstevel@tonic-gate #include "madman_api.h"
39*0Sstevel@tonic-gate 
40*0Sstevel@tonic-gate 
41*0Sstevel@tonic-gate /***** NEW CONSTANTS *****/
42*0Sstevel@tonic-gate 
43*0Sstevel@tonic-gate #define MSG_END_OF_TABLE	"end of table for request %s on %s\n\n"
44*0Sstevel@tonic-gate #define ERR_MSG_REQUEST_FAILED	"the request %s on %s failed: %s\n\n"
45*0Sstevel@tonic-gate 
46*0Sstevel@tonic-gate 
47*0Sstevel@tonic-gate /***** NEW TYPES *****/
48*0Sstevel@tonic-gate 
49*0Sstevel@tonic-gate typedef struct _Target {
50*0Sstevel@tonic-gate 	struct _Target *next_target;
51*0Sstevel@tonic-gate 	char name[100];
52*0Sstevel@tonic-gate } Target;
53*0Sstevel@tonic-gate 
54*0Sstevel@tonic-gate 
55*0Sstevel@tonic-gate /***** STATIC VARIABLES *****/
56*0Sstevel@tonic-gate 
57*0Sstevel@tonic-gate static int snmp_session_num = 0;
58*0Sstevel@tonic-gate 
59*0Sstevel@tonic-gate static Target *first_target = NULL;
60*0Sstevel@tonic-gate 
61*0Sstevel@tonic-gate 
62*0Sstevel@tonic-gate /****** STATIC FUNCTIONS *****/
63*0Sstevel@tonic-gate 
64*0Sstevel@tonic-gate static int target_add(char *name, char *error_label);
65*0Sstevel@tonic-gate 
66*0Sstevel@tonic-gate 
67*0Sstevel@tonic-gate /**************************************************************/
68*0Sstevel@tonic-gate 
target_add(char * name,char * error_label)69*0Sstevel@tonic-gate static int target_add(char *name, char *error_label)
70*0Sstevel@tonic-gate {
71*0Sstevel@tonic-gate 	Target *new;
72*0Sstevel@tonic-gate 
73*0Sstevel@tonic-gate 
74*0Sstevel@tonic-gate 	error_label[0] = '\0';
75*0Sstevel@tonic-gate 
76*0Sstevel@tonic-gate 	if(name == NULL)
77*0Sstevel@tonic-gate 	{
78*0Sstevel@tonic-gate 		sprintf(error_label, "BUG: name is NULL");
79*0Sstevel@tonic-gate 		return -1;
80*0Sstevel@tonic-gate 	}
81*0Sstevel@tonic-gate 
82*0Sstevel@tonic-gate 	new = (Target *) malloc(sizeof(Target));
83*0Sstevel@tonic-gate 	if(new == NULL)
84*0Sstevel@tonic-gate 	{
85*0Sstevel@tonic-gate 		sprintf(error_label, ERR_MSG_ALLOC);
86*0Sstevel@tonic-gate 		return -1;
87*0Sstevel@tonic-gate 	}
88*0Sstevel@tonic-gate 
89*0Sstevel@tonic-gate 	strcpy(new->name, name);
90*0Sstevel@tonic-gate 
91*0Sstevel@tonic-gate 	new->next_target = first_target;
92*0Sstevel@tonic-gate 	first_target = new;
93*0Sstevel@tonic-gate 
94*0Sstevel@tonic-gate 	return 0;
95*0Sstevel@tonic-gate }
96*0Sstevel@tonic-gate 
97*0Sstevel@tonic-gate 
98*0Sstevel@tonic-gate /**************************************************************/
99*0Sstevel@tonic-gate /*
100*0Sstevel@tonic-gate  *	do not free response!
101*0Sstevel@tonic-gate  */
102*0Sstevel@tonic-gate 
snmp_callback(int operation,SNMP_session * session,int request_id,int predefined_id,SNMP_pdu * response,void * snmp_callback_magic)103*0Sstevel@tonic-gate static void snmp_callback(int operation, SNMP_session *session, int request_id, int predefined_id, SNMP_pdu *response, void *snmp_callback_magic)
104*0Sstevel@tonic-gate {
105*0Sstevel@tonic-gate 	struct itimerval itimeout;
106*0Sstevel@tonic-gate 	ApplEntry *applEntry = NULL;
107*0Sstevel@tonic-gate 	AssocEntry *assocEntry = NULL;
108*0Sstevel@tonic-gate 	MtaEntry *mtaEntry = NULL;
109*0Sstevel@tonic-gate 	MtaGroupEntry *mtaGroupEntry = NULL;
110*0Sstevel@tonic-gate 	MtaGroupAssociationEntry *mtaGroupAssociationEntry = NULL;
111*0Sstevel@tonic-gate 	DsaOpsEntry *dsaOpsEntry = NULL;
112*0Sstevel@tonic-gate 	DsaEntriesEntry *dsaEntriesEntry = NULL;
113*0Sstevel@tonic-gate 	DsaIntEntry *dsaIntEntry = NULL;
114*0Sstevel@tonic-gate 	X4msMtaEntry *x4msMtaEntry = NULL;
115*0Sstevel@tonic-gate 	X4msUserEntryPart1 *x4msUserEntryPart1 = NULL;
116*0Sstevel@tonic-gate 	X4msUserEntryPart2 *x4msUserEntryPart2 = NULL;
117*0Sstevel@tonic-gate 	X4msUserAssociationEntry *x4msUserAssociationEntry = NULL;
118*0Sstevel@tonic-gate 	X4grpEntry *x4grpEntry = NULL;
119*0Sstevel@tonic-gate 	X4grpMappingEntry *x4grpMappingEntry = NULL;
120*0Sstevel@tonic-gate 	X5dsaReferenceEntry *x5dsaReferenceEntry = NULL;
121*0Sstevel@tonic-gate 	char *request_name = NULL;
122*0Sstevel@tonic-gate 
123*0Sstevel@tonic-gate 
124*0Sstevel@tonic-gate 	request_name = predefined_request_string(predefined_id);
125*0Sstevel@tonic-gate 
126*0Sstevel@tonic-gate 	switch(operation)
127*0Sstevel@tonic-gate 	{
128*0Sstevel@tonic-gate 		case RECEIVED_MESSAGE:
129*0Sstevel@tonic-gate 			switch(predefined_id)
130*0Sstevel@tonic-gate 			{
131*0Sstevel@tonic-gate 				case APPL_ENTRY_REQ:
132*0Sstevel@tonic-gate 					applEntry = applEntry_process_response(session, response, error_label);
133*0Sstevel@tonic-gate 					if(applEntry == NULL)
134*0Sstevel@tonic-gate 					{
135*0Sstevel@tonic-gate 						if(snmp_errno == SNMP_ERR_NOSUCHNAME)
136*0Sstevel@tonic-gate 						{
137*0Sstevel@tonic-gate 							fprintf(stderr, MSG_END_OF_TABLE,
138*0Sstevel@tonic-gate 								request_name, session->peername);
139*0Sstevel@tonic-gate 
140*0Sstevel@tonic-gate 							if(assocEntry_send_request(session, GETNEXT_REQ_MSG, -1, -1, error_label))
141*0Sstevel@tonic-gate 							{
142*0Sstevel@tonic-gate 								fprintf(stderr, "assocEntry_send_request(%s) failed: %s\n\n",
143*0Sstevel@tonic-gate 									session->peername, error_label);
144*0Sstevel@tonic-gate 								snmp_session_close(session, error_label);
145*0Sstevel@tonic-gate 								snmp_session_num--;
146*0Sstevel@tonic-gate 							}
147*0Sstevel@tonic-gate 						}
148*0Sstevel@tonic-gate 						else
149*0Sstevel@tonic-gate 						{
150*0Sstevel@tonic-gate 							fprintf(stderr, ERR_MSG_REQUEST_FAILED,
151*0Sstevel@tonic-gate 								request_name, session->peername, error_label);
152*0Sstevel@tonic-gate 							trace_snmp_pdu(response);
153*0Sstevel@tonic-gate 
154*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
155*0Sstevel@tonic-gate 							snmp_session_num--;
156*0Sstevel@tonic-gate 						}
157*0Sstevel@tonic-gate 					}
158*0Sstevel@tonic-gate 					else
159*0Sstevel@tonic-gate 					{
160*0Sstevel@tonic-gate 						applEntry_print(applEntry);
161*0Sstevel@tonic-gate 						if(applEntry_send_request(session, GETNEXT_REQ_MSG, applEntry->applIndex, error_label))
162*0Sstevel@tonic-gate 						{
163*0Sstevel@tonic-gate 							fprintf(stderr, "applEntry_send_request(%s) failed: %s\n\n",
164*0Sstevel@tonic-gate 								session->peername, error_label);
165*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
166*0Sstevel@tonic-gate 							snmp_session_num--;
167*0Sstevel@tonic-gate 						}
168*0Sstevel@tonic-gate 						applEntry_free(applEntry);
169*0Sstevel@tonic-gate 					}
170*0Sstevel@tonic-gate 
171*0Sstevel@tonic-gate 					break;
172*0Sstevel@tonic-gate 
173*0Sstevel@tonic-gate 
174*0Sstevel@tonic-gate 				case ASSOC_ENTRY_REQ:
175*0Sstevel@tonic-gate 					assocEntry = assocEntry_process_response(session, response, error_label);
176*0Sstevel@tonic-gate 					if(assocEntry == NULL)
177*0Sstevel@tonic-gate 					{
178*0Sstevel@tonic-gate 						if(snmp_errno == SNMP_ERR_NOSUCHNAME)
179*0Sstevel@tonic-gate 						{
180*0Sstevel@tonic-gate 							fprintf(stderr, MSG_END_OF_TABLE,
181*0Sstevel@tonic-gate 								request_name, session->peername);
182*0Sstevel@tonic-gate 
183*0Sstevel@tonic-gate 							if(mtaEntry_send_request(session, GETNEXT_REQ_MSG, -1, error_label))
184*0Sstevel@tonic-gate 							{
185*0Sstevel@tonic-gate 								fprintf(stderr, "mtaEntry_send_request(%s) failed: %s\n\n",
186*0Sstevel@tonic-gate 									session->peername, error_label);
187*0Sstevel@tonic-gate 								snmp_session_close(session, error_label);
188*0Sstevel@tonic-gate 								snmp_session_num--;
189*0Sstevel@tonic-gate 							}
190*0Sstevel@tonic-gate 						}
191*0Sstevel@tonic-gate 						else
192*0Sstevel@tonic-gate 						{
193*0Sstevel@tonic-gate 							fprintf(stderr, ERR_MSG_REQUEST_FAILED,
194*0Sstevel@tonic-gate 								request_name, session->peername, error_label);
195*0Sstevel@tonic-gate 							trace_snmp_pdu(response);
196*0Sstevel@tonic-gate 
197*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
198*0Sstevel@tonic-gate 							snmp_session_num--;
199*0Sstevel@tonic-gate 						}
200*0Sstevel@tonic-gate 					}
201*0Sstevel@tonic-gate 					else
202*0Sstevel@tonic-gate 					{
203*0Sstevel@tonic-gate 						assocEntry_print(assocEntry);
204*0Sstevel@tonic-gate 						if(assocEntry_send_request(session, GETNEXT_REQ_MSG, assocEntry->applIndex, assocEntry->assocIndex, error_label))
205*0Sstevel@tonic-gate 						{
206*0Sstevel@tonic-gate 							fprintf(stderr, "assocEntry_send_request(%s) failed: %s\n\n",
207*0Sstevel@tonic-gate 								session->peername, error_label);
208*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
209*0Sstevel@tonic-gate 							snmp_session_num--;
210*0Sstevel@tonic-gate 						}
211*0Sstevel@tonic-gate 						assocEntry_free(assocEntry);
212*0Sstevel@tonic-gate 					}
213*0Sstevel@tonic-gate 
214*0Sstevel@tonic-gate 					break;
215*0Sstevel@tonic-gate 
216*0Sstevel@tonic-gate 
217*0Sstevel@tonic-gate 				case MTA_ENTRY_REQ:
218*0Sstevel@tonic-gate 					mtaEntry = mtaEntry_process_response(session, response, error_label);
219*0Sstevel@tonic-gate 					if(mtaEntry == NULL)
220*0Sstevel@tonic-gate 					{
221*0Sstevel@tonic-gate 						if(snmp_errno == SNMP_ERR_NOSUCHNAME)
222*0Sstevel@tonic-gate 						{
223*0Sstevel@tonic-gate 							fprintf(stderr, MSG_END_OF_TABLE,
224*0Sstevel@tonic-gate 								request_name, session->peername);
225*0Sstevel@tonic-gate 
226*0Sstevel@tonic-gate 							if(mtaGroupEntry_send_request(session, GETNEXT_REQ_MSG, -1, -1, error_label))
227*0Sstevel@tonic-gate 							{
228*0Sstevel@tonic-gate 								fprintf(stderr, "mtaGroupEntry_send_request(%s) failed: %s\n\n",
229*0Sstevel@tonic-gate 									session->peername, error_label);
230*0Sstevel@tonic-gate 								snmp_session_close(session, error_label);
231*0Sstevel@tonic-gate 								snmp_session_num--;
232*0Sstevel@tonic-gate 							}
233*0Sstevel@tonic-gate 						}
234*0Sstevel@tonic-gate 						else
235*0Sstevel@tonic-gate 						{
236*0Sstevel@tonic-gate 							fprintf(stderr, ERR_MSG_REQUEST_FAILED,
237*0Sstevel@tonic-gate 								request_name, session->peername, error_label);
238*0Sstevel@tonic-gate 							trace_snmp_pdu(response);
239*0Sstevel@tonic-gate 
240*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
241*0Sstevel@tonic-gate 							snmp_session_num--;
242*0Sstevel@tonic-gate 						}
243*0Sstevel@tonic-gate 					}
244*0Sstevel@tonic-gate 					else
245*0Sstevel@tonic-gate 					{
246*0Sstevel@tonic-gate 						mtaEntry_print(mtaEntry);
247*0Sstevel@tonic-gate 						if(mtaEntry_send_request(session, GETNEXT_REQ_MSG, mtaEntry->applIndex, error_label))
248*0Sstevel@tonic-gate 						{
249*0Sstevel@tonic-gate 							fprintf(stderr, "mtaEntry_send_request(%s) failed: %s\n\n",
250*0Sstevel@tonic-gate 								session->peername, error_label);
251*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
252*0Sstevel@tonic-gate 							snmp_session_num--;
253*0Sstevel@tonic-gate 						}
254*0Sstevel@tonic-gate 						mtaEntry_free(mtaEntry);
255*0Sstevel@tonic-gate 					}
256*0Sstevel@tonic-gate 
257*0Sstevel@tonic-gate 					break;
258*0Sstevel@tonic-gate 
259*0Sstevel@tonic-gate 
260*0Sstevel@tonic-gate 				case MTA_GROUP_ENTRY_REQ:
261*0Sstevel@tonic-gate 					mtaGroupEntry = mtaGroupEntry_process_response(session, response, error_label);
262*0Sstevel@tonic-gate 					if(mtaGroupEntry == NULL)
263*0Sstevel@tonic-gate 					{
264*0Sstevel@tonic-gate 						if(snmp_errno == SNMP_ERR_NOSUCHNAME)
265*0Sstevel@tonic-gate 						{
266*0Sstevel@tonic-gate 							fprintf(stderr, MSG_END_OF_TABLE,
267*0Sstevel@tonic-gate 								request_name, session->peername);
268*0Sstevel@tonic-gate 
269*0Sstevel@tonic-gate 							if(mtaGroupAssociationEntry_send_request(session, GETNEXT_REQ_MSG, -1, -1, -1, error_label))
270*0Sstevel@tonic-gate 							{
271*0Sstevel@tonic-gate 								fprintf(stderr, "mtaGroupAssociationEntry_send_request(%s) failed: %s\n\n",
272*0Sstevel@tonic-gate 									session->peername, error_label);
273*0Sstevel@tonic-gate 								snmp_session_close(session, error_label);
274*0Sstevel@tonic-gate 								snmp_session_num--;
275*0Sstevel@tonic-gate 							}
276*0Sstevel@tonic-gate 						}
277*0Sstevel@tonic-gate 						else
278*0Sstevel@tonic-gate 						{
279*0Sstevel@tonic-gate 							fprintf(stderr, ERR_MSG_REQUEST_FAILED,
280*0Sstevel@tonic-gate 								request_name, session->peername, error_label);
281*0Sstevel@tonic-gate 							trace_snmp_pdu(response);
282*0Sstevel@tonic-gate 
283*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
284*0Sstevel@tonic-gate 							snmp_session_num--;
285*0Sstevel@tonic-gate 						}
286*0Sstevel@tonic-gate 					}
287*0Sstevel@tonic-gate 					else
288*0Sstevel@tonic-gate 					{
289*0Sstevel@tonic-gate 						mtaGroupEntry_print(mtaGroupEntry);
290*0Sstevel@tonic-gate 						if(mtaGroupEntry_send_request(session, GETNEXT_REQ_MSG, mtaGroupEntry->applIndex, mtaGroupEntry->mtaGroupIndex, error_label))
291*0Sstevel@tonic-gate 						{
292*0Sstevel@tonic-gate 							fprintf(stderr, "mtaGroupEntry_send_request(%s) failed: %s\n\n",
293*0Sstevel@tonic-gate 								session->peername, error_label);
294*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
295*0Sstevel@tonic-gate 							snmp_session_num--;
296*0Sstevel@tonic-gate 						}
297*0Sstevel@tonic-gate 						mtaGroupEntry_free(mtaGroupEntry);
298*0Sstevel@tonic-gate 					}
299*0Sstevel@tonic-gate 
300*0Sstevel@tonic-gate 					break;
301*0Sstevel@tonic-gate 
302*0Sstevel@tonic-gate 
303*0Sstevel@tonic-gate 				case MTA_GROUP_ASSOCIATION_ENTRY_REQ:
304*0Sstevel@tonic-gate 					mtaGroupAssociationEntry = mtaGroupAssociationEntry_process_response(session, response, error_label);
305*0Sstevel@tonic-gate 					if(mtaGroupAssociationEntry == NULL)
306*0Sstevel@tonic-gate 					{
307*0Sstevel@tonic-gate 						if(snmp_errno == SNMP_ERR_NOSUCHNAME)
308*0Sstevel@tonic-gate 						{
309*0Sstevel@tonic-gate 							fprintf(stderr, MSG_END_OF_TABLE,
310*0Sstevel@tonic-gate 								request_name, session->peername);
311*0Sstevel@tonic-gate 
312*0Sstevel@tonic-gate 							if(dsaOpsEntry_send_request(session, GETNEXT_REQ_MSG, -1, error_label))
313*0Sstevel@tonic-gate 							{
314*0Sstevel@tonic-gate 								fprintf(stderr, "dsaOpsEntry_send_request(%s) failed: %s\n\n",
315*0Sstevel@tonic-gate 									session->peername, error_label);
316*0Sstevel@tonic-gate 								snmp_session_close(session, error_label);
317*0Sstevel@tonic-gate 								snmp_session_num--;
318*0Sstevel@tonic-gate 							}
319*0Sstevel@tonic-gate 						}
320*0Sstevel@tonic-gate 						else
321*0Sstevel@tonic-gate 						{
322*0Sstevel@tonic-gate 							fprintf(stderr, ERR_MSG_REQUEST_FAILED,
323*0Sstevel@tonic-gate 								request_name, session->peername, error_label);
324*0Sstevel@tonic-gate 							trace_snmp_pdu(response);
325*0Sstevel@tonic-gate 
326*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
327*0Sstevel@tonic-gate 							snmp_session_num--;
328*0Sstevel@tonic-gate 						}
329*0Sstevel@tonic-gate 					}
330*0Sstevel@tonic-gate 					else
331*0Sstevel@tonic-gate 					{
332*0Sstevel@tonic-gate 						mtaGroupAssociationEntry_print(mtaGroupAssociationEntry);
333*0Sstevel@tonic-gate 						if(mtaGroupAssociationEntry_send_request(session, GETNEXT_REQ_MSG, mtaGroupAssociationEntry->applIndex, mtaGroupAssociationEntry->mtaGroupIndex, mtaGroupAssociationEntry->mtaGroupAssociationIndex, error_label))
334*0Sstevel@tonic-gate 						{
335*0Sstevel@tonic-gate 							fprintf(stderr, "mtaGroupAssociationEntry_send_request(%s) failed: %s\n\n",
336*0Sstevel@tonic-gate 								session->peername, error_label);
337*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
338*0Sstevel@tonic-gate 							snmp_session_num--;
339*0Sstevel@tonic-gate 						}
340*0Sstevel@tonic-gate 						mtaGroupAssociationEntry_free(mtaGroupAssociationEntry);
341*0Sstevel@tonic-gate 					}
342*0Sstevel@tonic-gate 
343*0Sstevel@tonic-gate 					break;
344*0Sstevel@tonic-gate 
345*0Sstevel@tonic-gate 
346*0Sstevel@tonic-gate 				case DSA_OPS_ENTRY_REQ:
347*0Sstevel@tonic-gate 					dsaOpsEntry = dsaOpsEntry_process_response(session, response, error_label);
348*0Sstevel@tonic-gate 					if(dsaOpsEntry == NULL)
349*0Sstevel@tonic-gate 					{
350*0Sstevel@tonic-gate 						if(snmp_errno == SNMP_ERR_NOSUCHNAME)
351*0Sstevel@tonic-gate 						{
352*0Sstevel@tonic-gate 							fprintf(stderr, MSG_END_OF_TABLE,
353*0Sstevel@tonic-gate 								request_name, session->peername);
354*0Sstevel@tonic-gate 
355*0Sstevel@tonic-gate 							if(dsaEntriesEntry_send_request(session, GETNEXT_REQ_MSG, -1, error_label))
356*0Sstevel@tonic-gate 							{
357*0Sstevel@tonic-gate 								fprintf(stderr, "dsaEntriesEntry_send_request(%s) failed: %s\n\n",
358*0Sstevel@tonic-gate 									session->peername, error_label);
359*0Sstevel@tonic-gate 								snmp_session_close(session, error_label);
360*0Sstevel@tonic-gate 								snmp_session_num--;
361*0Sstevel@tonic-gate 							}
362*0Sstevel@tonic-gate 						}
363*0Sstevel@tonic-gate 						else
364*0Sstevel@tonic-gate 						{
365*0Sstevel@tonic-gate 							fprintf(stderr, ERR_MSG_REQUEST_FAILED,
366*0Sstevel@tonic-gate 								request_name, session->peername, error_label);
367*0Sstevel@tonic-gate 							trace_snmp_pdu(response);
368*0Sstevel@tonic-gate 
369*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
370*0Sstevel@tonic-gate 							snmp_session_num--;
371*0Sstevel@tonic-gate 						}
372*0Sstevel@tonic-gate 					}
373*0Sstevel@tonic-gate 					else
374*0Sstevel@tonic-gate 					{
375*0Sstevel@tonic-gate 						dsaOpsEntry_print(dsaOpsEntry);
376*0Sstevel@tonic-gate 						if(dsaOpsEntry_send_request(session, GETNEXT_REQ_MSG, dsaOpsEntry->applIndex, error_label))
377*0Sstevel@tonic-gate 						{
378*0Sstevel@tonic-gate 							fprintf(stderr, "dsaOpsEntry_send_request(%s) failed: %s\n\n",
379*0Sstevel@tonic-gate 								session->peername, error_label);
380*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
381*0Sstevel@tonic-gate 							snmp_session_num--;
382*0Sstevel@tonic-gate 						}
383*0Sstevel@tonic-gate 						dsaOpsEntry_free(dsaOpsEntry);
384*0Sstevel@tonic-gate 					}
385*0Sstevel@tonic-gate 
386*0Sstevel@tonic-gate 					break;
387*0Sstevel@tonic-gate 
388*0Sstevel@tonic-gate 
389*0Sstevel@tonic-gate 				case DSA_ENTRIES_ENTRY_REQ:
390*0Sstevel@tonic-gate 					dsaEntriesEntry = dsaEntriesEntry_process_response(session, response, error_label);
391*0Sstevel@tonic-gate 					if(dsaEntriesEntry == NULL)
392*0Sstevel@tonic-gate 					{
393*0Sstevel@tonic-gate 						if(snmp_errno == SNMP_ERR_NOSUCHNAME)
394*0Sstevel@tonic-gate 						{
395*0Sstevel@tonic-gate 							fprintf(stderr, MSG_END_OF_TABLE,
396*0Sstevel@tonic-gate 								request_name, session->peername);
397*0Sstevel@tonic-gate 
398*0Sstevel@tonic-gate 							if(dsaIntEntry_send_request(session, GETNEXT_REQ_MSG, -1, -1, error_label))
399*0Sstevel@tonic-gate 							{
400*0Sstevel@tonic-gate 								fprintf(stderr, "dsaIntEntry_send_request(%s) failed: %s\n\n",
401*0Sstevel@tonic-gate 									session->peername, error_label);
402*0Sstevel@tonic-gate 								snmp_session_close(session, error_label);
403*0Sstevel@tonic-gate 								snmp_session_num--;
404*0Sstevel@tonic-gate 							}
405*0Sstevel@tonic-gate 						}
406*0Sstevel@tonic-gate 						else
407*0Sstevel@tonic-gate 						{
408*0Sstevel@tonic-gate 							fprintf(stderr, ERR_MSG_REQUEST_FAILED,
409*0Sstevel@tonic-gate 								request_name, session->peername, error_label);
410*0Sstevel@tonic-gate 							trace_snmp_pdu(response);
411*0Sstevel@tonic-gate 
412*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
413*0Sstevel@tonic-gate 							snmp_session_num--;
414*0Sstevel@tonic-gate 						}
415*0Sstevel@tonic-gate 					}
416*0Sstevel@tonic-gate 					else
417*0Sstevel@tonic-gate 					{
418*0Sstevel@tonic-gate 						dsaEntriesEntry_print(dsaEntriesEntry);
419*0Sstevel@tonic-gate 						if(dsaEntriesEntry_send_request(session, GETNEXT_REQ_MSG, dsaEntriesEntry->applIndex, error_label))
420*0Sstevel@tonic-gate 						{
421*0Sstevel@tonic-gate 							fprintf(stderr, "dsaEntriesEntry_send_request(%s) failed: %s\n\n",
422*0Sstevel@tonic-gate 								session->peername, error_label);
423*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
424*0Sstevel@tonic-gate 							snmp_session_num--;
425*0Sstevel@tonic-gate 						}
426*0Sstevel@tonic-gate 						dsaEntriesEntry_free(dsaEntriesEntry);
427*0Sstevel@tonic-gate 					}
428*0Sstevel@tonic-gate 
429*0Sstevel@tonic-gate 					break;
430*0Sstevel@tonic-gate 
431*0Sstevel@tonic-gate 
432*0Sstevel@tonic-gate 				case DSA_INT_ENTRY_REQ:
433*0Sstevel@tonic-gate 					dsaIntEntry = dsaIntEntry_process_response(session, response, error_label);
434*0Sstevel@tonic-gate 					if(dsaIntEntry == NULL)
435*0Sstevel@tonic-gate 					{
436*0Sstevel@tonic-gate 						if(snmp_errno == SNMP_ERR_NOSUCHNAME)
437*0Sstevel@tonic-gate 						{
438*0Sstevel@tonic-gate 							fprintf(stderr, MSG_END_OF_TABLE,
439*0Sstevel@tonic-gate 								request_name, session->peername);
440*0Sstevel@tonic-gate 
441*0Sstevel@tonic-gate 							if(x4msMtaEntry_send_request(session, GETNEXT_REQ_MSG, -1, error_label))
442*0Sstevel@tonic-gate 							{
443*0Sstevel@tonic-gate 								fprintf(stderr, "x4msMtaEntry_send_request(%s) failed: %s\n\n",
444*0Sstevel@tonic-gate 									session->peername, error_label);
445*0Sstevel@tonic-gate 								snmp_session_close(session, error_label);
446*0Sstevel@tonic-gate 								snmp_session_num--;
447*0Sstevel@tonic-gate 							}
448*0Sstevel@tonic-gate 						}
449*0Sstevel@tonic-gate 						else
450*0Sstevel@tonic-gate 						{
451*0Sstevel@tonic-gate 							fprintf(stderr, ERR_MSG_REQUEST_FAILED,
452*0Sstevel@tonic-gate 								request_name, session->peername, error_label);
453*0Sstevel@tonic-gate 							trace_snmp_pdu(response);
454*0Sstevel@tonic-gate 
455*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
456*0Sstevel@tonic-gate 							snmp_session_num--;
457*0Sstevel@tonic-gate 						}
458*0Sstevel@tonic-gate 					}
459*0Sstevel@tonic-gate 					else
460*0Sstevel@tonic-gate 					{
461*0Sstevel@tonic-gate 						dsaIntEntry_print(dsaIntEntry);
462*0Sstevel@tonic-gate 						if(dsaIntEntry_send_request(session, GETNEXT_REQ_MSG, dsaIntEntry->applIndex, dsaIntEntry->dsaIntIndex, error_label))
463*0Sstevel@tonic-gate 						{
464*0Sstevel@tonic-gate 							fprintf(stderr, "dsaIntEntry_send_request(%s) failed: %s\n\n",
465*0Sstevel@tonic-gate 								session->peername, error_label);
466*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
467*0Sstevel@tonic-gate 							snmp_session_num--;
468*0Sstevel@tonic-gate 						}
469*0Sstevel@tonic-gate 						dsaIntEntry_free(dsaIntEntry);
470*0Sstevel@tonic-gate 					}
471*0Sstevel@tonic-gate 
472*0Sstevel@tonic-gate 					break;
473*0Sstevel@tonic-gate 
474*0Sstevel@tonic-gate 
475*0Sstevel@tonic-gate 				case X4MS_MTA_ENTRY_REQ:
476*0Sstevel@tonic-gate 					x4msMtaEntry = x4msMtaEntry_process_response(session, response, error_label);
477*0Sstevel@tonic-gate 					if(x4msMtaEntry == NULL)
478*0Sstevel@tonic-gate 					{
479*0Sstevel@tonic-gate 						if(snmp_errno == SNMP_ERR_NOSUCHNAME)
480*0Sstevel@tonic-gate 						{
481*0Sstevel@tonic-gate 							fprintf(stderr, MSG_END_OF_TABLE,
482*0Sstevel@tonic-gate 								request_name, session->peername);
483*0Sstevel@tonic-gate 
484*0Sstevel@tonic-gate 							if(x4msUserEntryPart1_send_request(session, GETNEXT_REQ_MSG, -1, error_label))
485*0Sstevel@tonic-gate 							{
486*0Sstevel@tonic-gate 								fprintf(stderr, "x4msUserEntryPart1_send_request(%s) failed: %s\n\n",
487*0Sstevel@tonic-gate 									session->peername, error_label);
488*0Sstevel@tonic-gate 								snmp_session_close(session, error_label);
489*0Sstevel@tonic-gate 								snmp_session_num--;
490*0Sstevel@tonic-gate 							}
491*0Sstevel@tonic-gate 						}
492*0Sstevel@tonic-gate 						else
493*0Sstevel@tonic-gate 						{
494*0Sstevel@tonic-gate 							fprintf(stderr, ERR_MSG_REQUEST_FAILED,
495*0Sstevel@tonic-gate 								request_name, session->peername, error_label);
496*0Sstevel@tonic-gate 							trace_snmp_pdu(response);
497*0Sstevel@tonic-gate 
498*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
499*0Sstevel@tonic-gate 							snmp_session_num--;
500*0Sstevel@tonic-gate 						}
501*0Sstevel@tonic-gate 					}
502*0Sstevel@tonic-gate 					else
503*0Sstevel@tonic-gate 					{
504*0Sstevel@tonic-gate 						x4msMtaEntry_print(x4msMtaEntry);
505*0Sstevel@tonic-gate 						if(x4msMtaEntry_send_request(session, GETNEXT_REQ_MSG, x4msMtaEntry->x4msMtaIndex, error_label))
506*0Sstevel@tonic-gate 						{
507*0Sstevel@tonic-gate 							fprintf(stderr, "x4msMtaEntry_send_request(%s) failed: %s\n\n",
508*0Sstevel@tonic-gate 								session->peername, error_label);
509*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
510*0Sstevel@tonic-gate 							snmp_session_num--;
511*0Sstevel@tonic-gate 						}
512*0Sstevel@tonic-gate 						x4msMtaEntry_free(x4msMtaEntry);
513*0Sstevel@tonic-gate 					}
514*0Sstevel@tonic-gate 
515*0Sstevel@tonic-gate 					break;
516*0Sstevel@tonic-gate 
517*0Sstevel@tonic-gate 
518*0Sstevel@tonic-gate 				case X4MS_USER_ENTRY_PART1_REQ:
519*0Sstevel@tonic-gate 					x4msUserEntryPart1 = x4msUserEntryPart1_process_response(session, response, error_label);
520*0Sstevel@tonic-gate 					if(x4msUserEntryPart1 == NULL)
521*0Sstevel@tonic-gate 					{
522*0Sstevel@tonic-gate 						if(snmp_errno == SNMP_ERR_NOSUCHNAME)
523*0Sstevel@tonic-gate 						{
524*0Sstevel@tonic-gate 							fprintf(stderr, MSG_END_OF_TABLE,
525*0Sstevel@tonic-gate 								request_name, session->peername);
526*0Sstevel@tonic-gate 
527*0Sstevel@tonic-gate 							if(x4msUserAssociationEntry_send_request(session, GETNEXT_REQ_MSG, -1, -1, error_label))
528*0Sstevel@tonic-gate 							{
529*0Sstevel@tonic-gate 								fprintf(stderr, "x4msUserAssociationEntry_send_request(%s) failed: %s\n\n",
530*0Sstevel@tonic-gate 									session->peername, error_label);
531*0Sstevel@tonic-gate 								snmp_session_close(session, error_label);
532*0Sstevel@tonic-gate 								snmp_session_num--;
533*0Sstevel@tonic-gate 							}
534*0Sstevel@tonic-gate 						}
535*0Sstevel@tonic-gate 						else
536*0Sstevel@tonic-gate 						{
537*0Sstevel@tonic-gate 							fprintf(stderr, ERR_MSG_REQUEST_FAILED,
538*0Sstevel@tonic-gate 								request_name, session->peername, error_label);
539*0Sstevel@tonic-gate 							trace_snmp_pdu(response);
540*0Sstevel@tonic-gate 
541*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
542*0Sstevel@tonic-gate 							snmp_session_num--;
543*0Sstevel@tonic-gate 						}
544*0Sstevel@tonic-gate 					}
545*0Sstevel@tonic-gate 					else
546*0Sstevel@tonic-gate 					{
547*0Sstevel@tonic-gate 						x4msUserEntryPart1_print(x4msUserEntryPart1);
548*0Sstevel@tonic-gate 
549*0Sstevel@tonic-gate 						if(x4msUserEntryPart2_send_request(session, GET_REQ_MSG, x4msUserEntryPart1->x4msUserIndex, error_label))
550*0Sstevel@tonic-gate 						{
551*0Sstevel@tonic-gate 							fprintf(stderr, "x4msUserEntryPart2_send_request(%s) failed: %s\n\n",
552*0Sstevel@tonic-gate 								session->peername, error_label);
553*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
554*0Sstevel@tonic-gate 							snmp_session_num--;
555*0Sstevel@tonic-gate 						}
556*0Sstevel@tonic-gate 
557*0Sstevel@tonic-gate 						if(x4msUserEntryPart1_send_request(session, GETNEXT_REQ_MSG, x4msUserEntryPart1->x4msUserIndex, error_label))
558*0Sstevel@tonic-gate 						{
559*0Sstevel@tonic-gate 							fprintf(stderr, "x4msUserEntryPart1_send_request(%s) failed: %s\n\n",
560*0Sstevel@tonic-gate 								session->peername, error_label);
561*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
562*0Sstevel@tonic-gate 							snmp_session_num--;
563*0Sstevel@tonic-gate 						}
564*0Sstevel@tonic-gate 
565*0Sstevel@tonic-gate 						x4msUserEntryPart1_free(x4msUserEntryPart1);
566*0Sstevel@tonic-gate 					}
567*0Sstevel@tonic-gate 
568*0Sstevel@tonic-gate 					break;
569*0Sstevel@tonic-gate 
570*0Sstevel@tonic-gate 
571*0Sstevel@tonic-gate 				case X4MS_USER_ENTRY_PART2_REQ:
572*0Sstevel@tonic-gate 					x4msUserEntryPart2 = x4msUserEntryPart2_process_response(session, response, error_label);
573*0Sstevel@tonic-gate 					if(x4msUserEntryPart2 == NULL)
574*0Sstevel@tonic-gate 					{
575*0Sstevel@tonic-gate 						fprintf(stderr, ERR_MSG_REQUEST_FAILED,
576*0Sstevel@tonic-gate 							request_name, session->peername, error_label);
577*0Sstevel@tonic-gate 						trace_snmp_pdu(response);
578*0Sstevel@tonic-gate 
579*0Sstevel@tonic-gate 						snmp_session_close(session, error_label);
580*0Sstevel@tonic-gate 						snmp_session_num--;
581*0Sstevel@tonic-gate 					}
582*0Sstevel@tonic-gate 					else
583*0Sstevel@tonic-gate 					{
584*0Sstevel@tonic-gate 						x4msUserEntryPart2_print(x4msUserEntryPart2);
585*0Sstevel@tonic-gate 						x4msUserEntryPart2_free(x4msUserEntryPart2);
586*0Sstevel@tonic-gate 					}
587*0Sstevel@tonic-gate 
588*0Sstevel@tonic-gate 					break;
589*0Sstevel@tonic-gate 
590*0Sstevel@tonic-gate 
591*0Sstevel@tonic-gate 				case X4MS_USER_ASSOCIATION_ENTRY_REQ:
592*0Sstevel@tonic-gate 					x4msUserAssociationEntry = x4msUserAssociationEntry_process_response(session, response, error_label);
593*0Sstevel@tonic-gate 					if(x4msUserAssociationEntry == NULL)
594*0Sstevel@tonic-gate 					{
595*0Sstevel@tonic-gate 						if(snmp_errno == SNMP_ERR_NOSUCHNAME)
596*0Sstevel@tonic-gate 						{
597*0Sstevel@tonic-gate 							fprintf(stderr, MSG_END_OF_TABLE,
598*0Sstevel@tonic-gate 								request_name, session->peername);
599*0Sstevel@tonic-gate 
600*0Sstevel@tonic-gate 							if(x4grpEntry_send_request(session, GETNEXT_REQ_MSG, -1, error_label))
601*0Sstevel@tonic-gate 							{
602*0Sstevel@tonic-gate 								fprintf(stderr, "x4grpEntry_send_request(%s) failed: %s\n\n",
603*0Sstevel@tonic-gate 									session->peername, error_label);
604*0Sstevel@tonic-gate 								snmp_session_close(session, error_label);
605*0Sstevel@tonic-gate 								snmp_session_num--;
606*0Sstevel@tonic-gate 							}
607*0Sstevel@tonic-gate 						}
608*0Sstevel@tonic-gate 						else
609*0Sstevel@tonic-gate 						{
610*0Sstevel@tonic-gate 							fprintf(stderr, ERR_MSG_REQUEST_FAILED,
611*0Sstevel@tonic-gate 								request_name, session->peername, error_label);
612*0Sstevel@tonic-gate 							trace_snmp_pdu(response);
613*0Sstevel@tonic-gate 
614*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
615*0Sstevel@tonic-gate 							snmp_session_num--;
616*0Sstevel@tonic-gate 						}
617*0Sstevel@tonic-gate 					}
618*0Sstevel@tonic-gate 					else
619*0Sstevel@tonic-gate 					{
620*0Sstevel@tonic-gate 						x4msUserAssociationEntry_print(x4msUserAssociationEntry);
621*0Sstevel@tonic-gate 						if(x4msUserAssociationEntry_send_request(session, GETNEXT_REQ_MSG, x4msUserAssociationEntry->x4msUserIndex, x4msUserAssociationEntry->x4msUserAssociationIndex, error_label))
622*0Sstevel@tonic-gate 						{
623*0Sstevel@tonic-gate 							fprintf(stderr, "x4msUserAssociationEntry_send_request(%s) failed: %s\n\n",
624*0Sstevel@tonic-gate 								session->peername, error_label);
625*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
626*0Sstevel@tonic-gate 							snmp_session_num--;
627*0Sstevel@tonic-gate 						}
628*0Sstevel@tonic-gate 						x4msUserAssociationEntry_free(x4msUserAssociationEntry);
629*0Sstevel@tonic-gate 					}
630*0Sstevel@tonic-gate 
631*0Sstevel@tonic-gate 					break;
632*0Sstevel@tonic-gate 
633*0Sstevel@tonic-gate 				case X4GRP_ENTRY_REQ:
634*0Sstevel@tonic-gate 					x4grpEntry = x4grpEntry_process_response(session, response, error_label);
635*0Sstevel@tonic-gate 					if(x4grpEntry == NULL)
636*0Sstevel@tonic-gate 					{
637*0Sstevel@tonic-gate 						if(snmp_errno == SNMP_ERR_NOSUCHNAME)
638*0Sstevel@tonic-gate 						{
639*0Sstevel@tonic-gate 							fprintf(stderr, MSG_END_OF_TABLE,
640*0Sstevel@tonic-gate 								request_name, session->peername);
641*0Sstevel@tonic-gate 
642*0Sstevel@tonic-gate 							if(x4grpMappingEntry_send_request(session, GETNEXT_REQ_MSG, -1, -1, -1, error_label))
643*0Sstevel@tonic-gate 							{
644*0Sstevel@tonic-gate 								fprintf(stderr, "x4grpMappingEntry_send_request(%s) failed: %s\n\n",
645*0Sstevel@tonic-gate 									session->peername, error_label);
646*0Sstevel@tonic-gate 								snmp_session_close(session, error_label);
647*0Sstevel@tonic-gate 								snmp_session_num--;
648*0Sstevel@tonic-gate 							}
649*0Sstevel@tonic-gate 						}
650*0Sstevel@tonic-gate 						else
651*0Sstevel@tonic-gate 						{
652*0Sstevel@tonic-gate 							fprintf(stderr, ERR_MSG_REQUEST_FAILED,
653*0Sstevel@tonic-gate 								request_name, session->peername, error_label);
654*0Sstevel@tonic-gate 							trace_snmp_pdu(response);
655*0Sstevel@tonic-gate 
656*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
657*0Sstevel@tonic-gate 							snmp_session_num--;
658*0Sstevel@tonic-gate 						}
659*0Sstevel@tonic-gate 					}
660*0Sstevel@tonic-gate 					else
661*0Sstevel@tonic-gate 					{
662*0Sstevel@tonic-gate 						x4grpEntry_print(x4grpEntry);
663*0Sstevel@tonic-gate 						if(x4grpEntry_send_request(session, GETNEXT_REQ_MSG, x4grpEntry->x4grpIndex, error_label))
664*0Sstevel@tonic-gate 						{
665*0Sstevel@tonic-gate 							fprintf(stderr, "x4grpEntry_send_request(%s) failed: %s\n\n",
666*0Sstevel@tonic-gate 								session->peername, error_label);
667*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
668*0Sstevel@tonic-gate 							snmp_session_num--;
669*0Sstevel@tonic-gate 						}
670*0Sstevel@tonic-gate 						x4grpEntry_free(x4grpEntry);
671*0Sstevel@tonic-gate 					}
672*0Sstevel@tonic-gate 
673*0Sstevel@tonic-gate 					break;
674*0Sstevel@tonic-gate 
675*0Sstevel@tonic-gate 
676*0Sstevel@tonic-gate 				case X4GRP_MAPPING_ENTRY_REQ:
677*0Sstevel@tonic-gate 					x4grpMappingEntry = x4grpMappingEntry_process_response(session, response, error_label);
678*0Sstevel@tonic-gate 					if(x4grpMappingEntry == NULL)
679*0Sstevel@tonic-gate 					{
680*0Sstevel@tonic-gate 						if(snmp_errno == SNMP_ERR_NOSUCHNAME)
681*0Sstevel@tonic-gate 						{
682*0Sstevel@tonic-gate 							fprintf(stderr, MSG_END_OF_TABLE,
683*0Sstevel@tonic-gate 								request_name, session->peername);
684*0Sstevel@tonic-gate 
685*0Sstevel@tonic-gate 							if(x5dsaReferenceEntry_send_request(session, GETNEXT_REQ_MSG, -1, error_label))
686*0Sstevel@tonic-gate 							{
687*0Sstevel@tonic-gate 								fprintf(stderr, "x5dsaReferenceEntry_send_request(%s) failed: %s\n\n",
688*0Sstevel@tonic-gate 									session->peername, error_label);
689*0Sstevel@tonic-gate 								snmp_session_close(session, error_label);
690*0Sstevel@tonic-gate 								snmp_session_num--;
691*0Sstevel@tonic-gate 							}
692*0Sstevel@tonic-gate 						}
693*0Sstevel@tonic-gate 						else
694*0Sstevel@tonic-gate 						{
695*0Sstevel@tonic-gate 							fprintf(stderr, ERR_MSG_REQUEST_FAILED,
696*0Sstevel@tonic-gate 								request_name, session->peername, error_label);
697*0Sstevel@tonic-gate 							trace_snmp_pdu(response);
698*0Sstevel@tonic-gate 
699*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
700*0Sstevel@tonic-gate 							snmp_session_num--;
701*0Sstevel@tonic-gate 						}
702*0Sstevel@tonic-gate 					}
703*0Sstevel@tonic-gate 					else
704*0Sstevel@tonic-gate 					{
705*0Sstevel@tonic-gate 						x4grpMappingEntry_print(x4grpMappingEntry);
706*0Sstevel@tonic-gate 						if(x4grpMappingEntry_send_request(session, GETNEXT_REQ_MSG, x4grpMappingEntry->x4grpIndex, x4grpMappingEntry->x4grpMappingMSIndex, x4grpMappingEntry->x4grpMappingMTAIndex, error_label))
707*0Sstevel@tonic-gate 						{
708*0Sstevel@tonic-gate 							fprintf(stderr, "x4grpMappingEntry_send_request(%s) failed: %s\n\n",
709*0Sstevel@tonic-gate 								session->peername, error_label);
710*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
711*0Sstevel@tonic-gate 							snmp_session_num--;
712*0Sstevel@tonic-gate 						}
713*0Sstevel@tonic-gate 						x4grpMappingEntry_free(x4grpMappingEntry);
714*0Sstevel@tonic-gate 					}
715*0Sstevel@tonic-gate 
716*0Sstevel@tonic-gate 					break;
717*0Sstevel@tonic-gate 
718*0Sstevel@tonic-gate 
719*0Sstevel@tonic-gate 				case X5DSA_REFERENCE_ENTRY_REQ:
720*0Sstevel@tonic-gate 					x5dsaReferenceEntry = x5dsaReferenceEntry_process_response(session, response, error_label);
721*0Sstevel@tonic-gate 					if(x5dsaReferenceEntry == NULL)
722*0Sstevel@tonic-gate 					{
723*0Sstevel@tonic-gate 						if(snmp_errno == SNMP_ERR_NOSUCHNAME)
724*0Sstevel@tonic-gate 						{
725*0Sstevel@tonic-gate 							fprintf(stderr, MSG_END_OF_TABLE,
726*0Sstevel@tonic-gate 								request_name, session->peername);
727*0Sstevel@tonic-gate 
728*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
729*0Sstevel@tonic-gate 							snmp_session_num--;
730*0Sstevel@tonic-gate 						}
731*0Sstevel@tonic-gate 						else
732*0Sstevel@tonic-gate 						{
733*0Sstevel@tonic-gate 							fprintf(stderr, ERR_MSG_REQUEST_FAILED,
734*0Sstevel@tonic-gate 								request_name, session->peername, error_label);
735*0Sstevel@tonic-gate 							trace_snmp_pdu(response);
736*0Sstevel@tonic-gate 
737*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
738*0Sstevel@tonic-gate 							snmp_session_num--;
739*0Sstevel@tonic-gate 						}
740*0Sstevel@tonic-gate 					}
741*0Sstevel@tonic-gate 					else
742*0Sstevel@tonic-gate 					{
743*0Sstevel@tonic-gate 						x5dsaReferenceEntry_print(x5dsaReferenceEntry);
744*0Sstevel@tonic-gate 						if(x5dsaReferenceEntry_send_request(session, GETNEXT_REQ_MSG, x5dsaReferenceEntry->x5dsaReferenceIndex, error_label))
745*0Sstevel@tonic-gate 						{
746*0Sstevel@tonic-gate 							fprintf(stderr, "x5dsaReferenceEntry_send_request(%s) failed: %s\n\n",
747*0Sstevel@tonic-gate 								session->peername, error_label);
748*0Sstevel@tonic-gate 							snmp_session_close(session, error_label);
749*0Sstevel@tonic-gate 							snmp_session_num--;
750*0Sstevel@tonic-gate 						}
751*0Sstevel@tonic-gate 						x5dsaReferenceEntry_free(x5dsaReferenceEntry);
752*0Sstevel@tonic-gate 					}
753*0Sstevel@tonic-gate 
754*0Sstevel@tonic-gate 					break;
755*0Sstevel@tonic-gate 
756*0Sstevel@tonic-gate 
757*0Sstevel@tonic-gate 				default:
758*0Sstevel@tonic-gate 					fprintf(stderr, "unknown pdu received %d from %s\n\n",
759*0Sstevel@tonic-gate 						predefined_id, session->peername);
760*0Sstevel@tonic-gate 
761*0Sstevel@tonic-gate 					trace_snmp_pdu(response);
762*0Sstevel@tonic-gate 
763*0Sstevel@tonic-gate 					snmp_session_close(session, error_label);
764*0Sstevel@tonic-gate 					snmp_session_num--;
765*0Sstevel@tonic-gate 
766*0Sstevel@tonic-gate 					break;
767*0Sstevel@tonic-gate 			}
768*0Sstevel@tonic-gate 
769*0Sstevel@tonic-gate 			break;
770*0Sstevel@tonic-gate 
771*0Sstevel@tonic-gate 
772*0Sstevel@tonic-gate 		case TIMED_OUT:
773*0Sstevel@tonic-gate 			switch(predefined_id)
774*0Sstevel@tonic-gate 			{
775*0Sstevel@tonic-gate 				case APPL_ENTRY_REQ:
776*0Sstevel@tonic-gate 				case ASSOC_ENTRY_REQ:
777*0Sstevel@tonic-gate 				case MTA_ENTRY_REQ:
778*0Sstevel@tonic-gate 				case MTA_GROUP_ENTRY_REQ:
779*0Sstevel@tonic-gate 				case MTA_GROUP_ASSOCIATION_ENTRY_REQ:
780*0Sstevel@tonic-gate 				case X4MS_MTA_ENTRY_REQ:
781*0Sstevel@tonic-gate 				case X4MS_USER_ENTRY_PART1_REQ:
782*0Sstevel@tonic-gate 				case X4MS_USER_ENTRY_PART2_REQ:
783*0Sstevel@tonic-gate 				case X4MS_USER_ASSOCIATION_ENTRY_REQ:
784*0Sstevel@tonic-gate 				case X4GRP_ENTRY_REQ:
785*0Sstevel@tonic-gate 				case X4GRP_MAPPING_ENTRY_REQ:
786*0Sstevel@tonic-gate 				case X5DSA_REFERENCE_ENTRY_REQ:
787*0Sstevel@tonic-gate 					fprintf(stderr, "the request %s on %s TIMED OUT\n\n",
788*0Sstevel@tonic-gate 						request_name, session->peername);
789*0Sstevel@tonic-gate 					break;
790*0Sstevel@tonic-gate 
791*0Sstevel@tonic-gate 				default:
792*0Sstevel@tonic-gate 					fprintf(stderr, "an unknown request %d on %s TIMED OUT\n\n",
793*0Sstevel@tonic-gate 						predefined_id, session->peername);
794*0Sstevel@tonic-gate 					break;
795*0Sstevel@tonic-gate 			}
796*0Sstevel@tonic-gate 
797*0Sstevel@tonic-gate 			snmp_session_close(session, error_label);
798*0Sstevel@tonic-gate 			snmp_session_num--;
799*0Sstevel@tonic-gate 
800*0Sstevel@tonic-gate 			break;
801*0Sstevel@tonic-gate 	}
802*0Sstevel@tonic-gate 
803*0Sstevel@tonic-gate 	if(snmp_session_num == 0)
804*0Sstevel@tonic-gate 	{
805*0Sstevel@tonic-gate 		exit(0);
806*0Sstevel@tonic-gate 	}
807*0Sstevel@tonic-gate }
808*0Sstevel@tonic-gate 
809*0Sstevel@tonic-gate 
810*0Sstevel@tonic-gate /**************************************************************/
811*0Sstevel@tonic-gate 
main(int argc,char ** argv)812*0Sstevel@tonic-gate main(int argc, char **argv)
813*0Sstevel@tonic-gate {
814*0Sstevel@tonic-gate 	int numfds;
815*0Sstevel@tonic-gate 	fd_set fdset;
816*0Sstevel@tonic-gate 	int count;
817*0Sstevel@tonic-gate 	struct timeval timeout;
818*0Sstevel@tonic-gate 	char targets[1000];
819*0Sstevel@tonic-gate 	char target[1000];
820*0Sstevel@tonic-gate 	char c;
821*0Sstevel@tonic-gate 	char *ptr;
822*0Sstevel@tonic-gate 	int i = 0;
823*0Sstevel@tonic-gate 	Target *t;
824*0Sstevel@tonic-gate 
825*0Sstevel@tonic-gate 
826*0Sstevel@tonic-gate 	while((c = getopt(argc, argv, "t:v"))!= -1)
827*0Sstevel@tonic-gate 	{
828*0Sstevel@tonic-gate 		switch(c)
829*0Sstevel@tonic-gate 		{
830*0Sstevel@tonic-gate 			case 't':
831*0Sstevel@tonic-gate 				strcpy(targets, optarg);
832*0Sstevel@tonic-gate 				break;
833*0Sstevel@tonic-gate 			case 'v':
834*0Sstevel@tonic-gate 				trace_flags = 0xFFFF;
835*0Sstevel@tonic-gate 		}
836*0Sstevel@tonic-gate 	}
837*0Sstevel@tonic-gate 
838*0Sstevel@tonic-gate 
839*0Sstevel@tonic-gate 	i = 0;
840*0Sstevel@tonic-gate 	for(ptr = targets; *ptr; ptr++)
841*0Sstevel@tonic-gate 	{
842*0Sstevel@tonic-gate 		if(isspace(*ptr))
843*0Sstevel@tonic-gate 		{
844*0Sstevel@tonic-gate 			if(i == 0)
845*0Sstevel@tonic-gate 			{
846*0Sstevel@tonic-gate 				continue;
847*0Sstevel@tonic-gate 			}
848*0Sstevel@tonic-gate 		}
849*0Sstevel@tonic-gate 
850*0Sstevel@tonic-gate 		target[i++] = *ptr;
851*0Sstevel@tonic-gate 
852*0Sstevel@tonic-gate 		if( (*(ptr + 1) == '\0') || isspace(*(ptr + 1)) )
853*0Sstevel@tonic-gate 		{
854*0Sstevel@tonic-gate 			target[i] = '\0';
855*0Sstevel@tonic-gate 
856*0Sstevel@tonic-gate 			if(target_add(target, error_label))
857*0Sstevel@tonic-gate 			{
858*0Sstevel@tonic-gate 				fprintf(stderr, "target_add(%s) failed: %s\n\n",
859*0Sstevel@tonic-gate 					target, error_label);
860*0Sstevel@tonic-gate 			}
861*0Sstevel@tonic-gate 
862*0Sstevel@tonic-gate 			i = 0;
863*0Sstevel@tonic-gate 		}
864*0Sstevel@tonic-gate 	}
865*0Sstevel@tonic-gate 
866*0Sstevel@tonic-gate 
867*0Sstevel@tonic-gate 	for(t = first_target; t; t = t->next_target)
868*0Sstevel@tonic-gate 	{
869*0Sstevel@tonic-gate 		SNMP_session *session;
870*0Sstevel@tonic-gate 
871*0Sstevel@tonic-gate 
872*0Sstevel@tonic-gate 		session = snmp_session_open_default(t->name, snmp_callback, NULL, error_label);
873*0Sstevel@tonic-gate 		if(session == NULL)
874*0Sstevel@tonic-gate 		{
875*0Sstevel@tonic-gate 			fprintf(stderr, "snmp_session_open_default(%s) failed: %s\n\n",
876*0Sstevel@tonic-gate 				t->name, error_label);
877*0Sstevel@tonic-gate 			continue;
878*0Sstevel@tonic-gate 		}
879*0Sstevel@tonic-gate 		snmp_session_num++;
880*0Sstevel@tonic-gate 
881*0Sstevel@tonic-gate 		if(applEntry_send_request(session, GETNEXT_REQ_MSG, -1, error_label))
882*0Sstevel@tonic-gate 		{
883*0Sstevel@tonic-gate 			fprintf(stderr, "applEntry_send_request(%s) failed: %s\n\n",
884*0Sstevel@tonic-gate 				session->peername, error_label);
885*0Sstevel@tonic-gate 			snmp_session_close(session, error_label);
886*0Sstevel@tonic-gate 			snmp_session_num--;
887*0Sstevel@tonic-gate 		}
888*0Sstevel@tonic-gate 	}
889*0Sstevel@tonic-gate 
890*0Sstevel@tonic-gate 
891*0Sstevel@tonic-gate 	if(snmp_session_num == 0)
892*0Sstevel@tonic-gate 	{
893*0Sstevel@tonic-gate 		exit(0);
894*0Sstevel@tonic-gate 	}
895*0Sstevel@tonic-gate 
896*0Sstevel@tonic-gate 
897*0Sstevel@tonic-gate 	while(1)
898*0Sstevel@tonic-gate 	{
899*0Sstevel@tonic-gate 		numfds = 0;
900*0Sstevel@tonic-gate 		FD_ZERO(&fdset);
901*0Sstevel@tonic-gate 
902*0Sstevel@tonic-gate 		timeout.tv_sec = 10;
903*0Sstevel@tonic-gate 		timeout.tv_usec = 0;
904*0Sstevel@tonic-gate 
905*0Sstevel@tonic-gate 		snmp_session_select_info(&numfds, &fdset, &timeout);
906*0Sstevel@tonic-gate 
907*0Sstevel@tonic-gate 		count = select(numfds, &fdset, 0, 0, &timeout);
908*0Sstevel@tonic-gate 		if(count > 0)
909*0Sstevel@tonic-gate 		{
910*0Sstevel@tonic-gate 			snmp_session_read(&fdset);
911*0Sstevel@tonic-gate 		}
912*0Sstevel@tonic-gate 		else
913*0Sstevel@tonic-gate 		{
914*0Sstevel@tonic-gate 			switch(count)
915*0Sstevel@tonic-gate 			{
916*0Sstevel@tonic-gate 				case 0:
917*0Sstevel@tonic-gate 					snmp_session_timeout();
918*0Sstevel@tonic-gate 					break;
919*0Sstevel@tonic-gate 
920*0Sstevel@tonic-gate 				case -1:
921*0Sstevel@tonic-gate 					if(errno == EINTR)
922*0Sstevel@tonic-gate 					{
923*0Sstevel@tonic-gate 						continue;
924*0Sstevel@tonic-gate 					}
925*0Sstevel@tonic-gate 					else
926*0Sstevel@tonic-gate 					{
927*0Sstevel@tonic-gate 						fprintf(stderr, "select() failed %s\n",
928*0Sstevel@tonic-gate 							errno_string());
929*0Sstevel@tonic-gate 					}
930*0Sstevel@tonic-gate 			}
931*0Sstevel@tonic-gate 		}
932*0Sstevel@tonic-gate 	}
933*0Sstevel@tonic-gate }
934*0Sstevel@tonic-gate 
935*0Sstevel@tonic-gate 
936