1
0
mirror of https://github.com/samba-team/samba.git synced 2025-02-03 13:47:25 +03:00

patch from michael glauche to add session enum code into smbd.

This commit is contained in:
Luke Leighton -
parent e0713cf933
commit e90e38c66d
2 changed files with 111 additions and 14 deletions

View File

@ -47,7 +47,7 @@ BOOL get_connection_status(struct connect_record **crec,
trim_string(fname,"","/");
pstrcat(fname,"/STATUS..LCK");
fd = sys_open(fname,O_RDONLY, 0);
fd = sys_open(fname,O_RDONLY, 0);
if (fd == -1)
{
@ -69,6 +69,7 @@ fd = sys_open(fname,O_RDONLY, 0);
DEBUG(0,("Realloc failed in get_connection_status\n"));
return False;
}
c = &((*crec)[conn]);
if (sys_lseek(fd,i*sizeof(*c),SEEK_SET) != i*sizeof(*c) ||
read(fd,c,sizeof(*c)) != sizeof(*c))
@ -84,10 +85,76 @@ fd = sys_open(fname,O_RDONLY, 0);
{
conn++;
}
}
}
close(fd);
(*connection_count)=conn;
return True;
}
/*******************************************************************
Get the number of open Sessions. Not optimal yet. Has at least O(n*log(n)).
********************************************************************/
BOOL get_session_count(struct connect_record **srec,uint32 *session_count)
{
struct connect_record *crec = NULL;
struct connect_record *c;
uint32 connection_count;
uint32 conn;
int *pid;
int i;
int MaxPid;
BOOL found;
(*srec) = NULL;
pid = NULL;
if (get_connection_status(&crec, &connection_count))
{
MaxPid = 0;
for (conn = 0; conn < connection_count; conn++)
{
DEBUG(10,("Connection nr : %u\n",conn));
found=False;
for (i = 0; i < MaxPid; i++)
{
if (crec[conn].pid == pid[i])
{
found = True;
i=MaxPid;
}
}
if (!found) {
(*srec) = Realloc((*srec), (MaxPid+1) * sizeof((*srec)[MaxPid]));
if ((*srec) == NULL)
{
DEBUG(0,("Realloc failed in get_connection_status\n"));
return False;
}
pid = Realloc(pid, (MaxPid+1) * sizeof(int));
if (pid == NULL)
{
DEBUG(0,("Realloc failed in get_session_count\n"));
free(crec);
return False;
}
c = &((*srec)[MaxPid]);
pid[MaxPid]=crec[conn].pid;
pstrcpy(c->machine,crec[conn].machine);
c->uid = crec[conn].uid;
c->pid = crec[conn].pid;
c->cnum = crec[conn].cnum;
pstrcpy(c->name,crec[conn].name);
MaxPid++;
}
}
} else {
/* crec is not valid, so no need to free it here */
return False;
}
free(crec);
(*session_count) = MaxPid;
return True;
}

View File

@ -300,23 +300,36 @@ static void make_srv_sess_0_info(SESS_INFO_0 *se0, SESS_INFO_0_STR *str0,
static void make_srv_sess_info_0(SRV_SESS_INFO_0 *ss0, uint32 *snum, uint32 *stot)
{
uint32 num_entries = 0;
(*stot) = 1;
struct connect_record *crec;
uint32 session_count;
if (!get_session_count(&crec, &session_count))
{
(*snum) = 0;
(*stot) = 0;
return;
}
(*stot) = session_count;
DEBUG(0,("Session Count : %u\n",session_count));
if (ss0 == NULL)
{
(*snum) = 0;
free(crec);
return;
}
DEBUG(5,("make_srv_sess_0_ss0\n"));
if (snum)
{
DEBUG(0,("snum ok\n"));
for (; (*snum) < (*stot) && num_entries < MAX_SESS_ENTRIES; (*snum)++)
{
make_srv_sess_0_info(&(ss0->info_0 [num_entries]),
&(ss0->info_0_str[num_entries]), "MACHINE");
&(ss0->info_0_str[num_entries]), crec[num_entries].machine);
DEBUG(0,("make_srv_sess_0_info\n"));
/* move on to creating next session */
/* move on to creating next sess */
num_entries++;
@ -337,6 +350,7 @@ static void make_srv_sess_info_0(SRV_SESS_INFO_0 *ss0, uint32 *snum, uint32 *sto
ss0->ptr_sess_info = 0;
ss0->num_entries_read2 = 0;
}
free(crec);
}
/*******************************************************************
@ -368,11 +382,23 @@ static void make_srv_sess_1_info(SESS_INFO_1 *se1, SESS_INFO_1_STR *str1,
static void make_srv_sess_info_1(SRV_SESS_INFO_1 *ss1, uint32 *snum, uint32 *stot)
{
uint32 num_entries = 0;
(*stot) = 1;
struct connect_record *crec;
uint32 session_count;
if (!get_session_count(&crec, &session_count))
{
(*snum) = 0;
(*stot) = 0;
return;
}
(*stot) = session_count;
DEBUG(0,("Session Count (info1) : %u\n",session_count));
if (ss1 == NULL)
{
(*snum) = 0;
free(crec);
return;
}
@ -382,9 +408,12 @@ static void make_srv_sess_info_1(SRV_SESS_INFO_1 *ss1, uint32 *snum, uint32 *sto
{
for (; (*snum) < (*stot) && num_entries < MAX_SESS_ENTRIES; (*snum)++)
{
DEBUG(0,("sess1 machine: %s, uid : %u\n",crec[num_entries].machine,crec[num_entries].uid));
make_srv_sess_1_info(&(ss1->info_1 [num_entries]),
&(ss1->info_1_str[num_entries]),
"MACHINE", "dummy_user", 1, 10, 5, 0);
crec[num_entries].machine,
uidtoname(crec[num_entries].uid), 1, 10, 5, 0);
/* What are these on the End ??? */
/* move on to creating next session */
/* move on to creating next sess */
@ -408,6 +437,7 @@ static void make_srv_sess_info_1(SRV_SESS_INFO_1 *ss1, uint32 *snum, uint32 *sto
(*stot) = 0;
}
free(crec);
}
/*******************************************************************