1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
|
/** BEGIN COPYRIGHT BLOCK
* Copyright (C) 2001 Sun Microsystems, Inc. Used by permission.
* Copyright (C) 2005 Red Hat, Inc.
* All rights reserved.
* END COPYRIGHT BLOCK **/
/********************************************************************
*
* agtmmap.h: Memory Map interface for SNMP sub-agent for
* Brandx Directory Server stats (for UNIX environment).
*
* Revision History:
* 07/22/97 Created Steve Ross
*
*
*
**********************************************************************/
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <errno.h>
#include "nspr.h"
#ifdef _WIN32
#include <windows.h>
#define caddr_t PCHAR
#endif
#ifdef __cplusplus
extern "C" {
#endif
#define NUM_SNMP_INT_TBL_ROWS 5
#ifndef _WIN32
extern int errno;
#endif
#if !defined(_MAX_PATH)
#define _MAX_PATH 256
#endif
#define AGT_STATS_FILE "slapd.stats"
#define AGT_MJR_VERSION 1
#define AGT_MNR_VERSION 0
typedef enum { AGT_MAP_UNINIT = 0, AGT_MAP_READ, AGT_MAP_RDWR } agt_mmap_type;
#ifndef _WIN32
typedef struct
{
agt_mmap_type maptype;
int fd;
caddr_t fp;
} agt_mmap_context_t;
#else
typedef struct
{
agt_mmap_type maptype;
HANDLE fd;
caddr_t fp;
HANDLE mfh;
} agt_mmap_context_t;
#endif /* ! _WIN32 */
struct hdr_stats_t{
/*
* Header
*/
int restarted; /* 1/0 = Yes/No */
time_t startTime;
time_t updateTime;
char dsVersion[100];
};
struct ops_stats_t{
/*
* Ops Table attributes
*/
PRUint32 dsAnonymousBinds;
PRUint32 dsUnAuthBinds;
PRUint32 dsSimpleAuthBinds;
PRUint32 dsStrongAuthBinds;
PRUint32 dsBindSecurityErrors;
PRUint32 dsInOps;
PRUint32 dsReadOps;
PRUint32 dsCompareOps;
PRUint32 dsAddEntryOps;
PRUint32 dsRemoveEntryOps;
PRUint32 dsModifyEntryOps;
PRUint32 dsModifyRDNOps;
PRUint32 dsListOps;
PRUint32 dsSearchOps;
PRUint32 dsOneLevelSearchOps;
PRUint32 dsWholeSubtreeSearchOps;
PRUint32 dsReferrals;
PRUint32 dsChainings;
PRUint32 dsSecurityErrors;
PRUint32 dsErrors;
PRUint32 dsConnections; /* Number of currently connected clients */
PRUint32 dsConnectionSeq; /* Monotonically increasing number bumped on each new conn est */
PRUint32 dsBytesRecv; /* Count of bytes read from clients */
PRUint32 dsBytesSent; /* Count of bytes sent to clients */
PRUint32 dsEntriesReturned; /* Number of entries returned by the server */
PRUint32 dsReferralsReturned; /* Number of entries returned by the server */
};
struct entries_stats_t
{
/*
* Entries Table Attributes
*/
PRUint32 dsMasterEntries;
PRUint32 dsCopyEntries;
PRUint32 dsCacheEntries;
PRUint32 dsCacheHits;
PRUint32 dsSlaveHits;
};
struct int_stats_t
{
/*
* Interaction Table Attributes
*/
PRUint32 dsIntIndex;
char dsName[100];
time_t dsTimeOfCreation;
time_t dsTimeOfLastAttempt;
time_t dsTimeOfLastSuccess;
PRUint32 dsFailuresSinceLastSuccess;
PRUint32 dsFailures;
PRUint32 dsSuccesses;
char dsURL[100];
};
struct agt_stats_t
{
struct hdr_stats_t hdr_stats;
struct ops_stats_t ops_stats;
struct entries_stats_t entries_stats;
struct int_stats_t int_stats[NUM_SNMP_INT_TBL_ROWS];
} ;
extern agt_mmap_context_t mmap_tbl[];
/****************************************************************************
*
* agt_mopen_stats () - open and Memory Map the stats file. agt_mclose_stats()
* must be called prior to invoking agt_mopen_stats() again.
* Inputs:
* statsfile -> Name of stats file including full path or NULL.
* If NULL, default ($NETSITE_ROOT/daemonstats.ldap) is assumed.
* mode -> Must be one of O_RDONLY / O_RDWR.
* O_RDWR creates the file if it does not exist.
* Outputs:
* hdl -> Opaque handle to the mapped file. Should be
* passed to a subsequent agt_mupdate_stats() or
* agt_mread_stats() or agt_mclose_stats() call.
* Return Values:
* Returns 0 on successfully doing the memmap or error
* codes as defined in <errno.h>, otherwise.
*
****************************************************************************/
int agt_mopen_stats (char * statsfile, int mode, int *hdl);
/****************************************************************************
*
* agt_mclose_stats () - Close the Memory Map'ed stats file.
*
*
* Inputs:
* hdl -> Opaque handle to the mapped file. Should have been
* returned by an earlier call to agt_mopen_stats().
*
* Outputs: <NONE>
*
* Return Values: Returns 0 on normal completion or error codes
* as defined in <errno.h>, otherwise.
*
****************************************************************************/
int agt_mclose_stats (int hdl);
int agt_mread_stats(int hdl, struct hdr_stats_t *, struct ops_stats_t *,
struct entries_stats_t *);
#ifdef __cplusplus
}
#endif
|