Dolda2000 GitWeb
/
doldaconnect.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Add trytransferbypeer.
[doldaconnect.git]
/
daemon
/
fnet-dc.c
diff --git
a/daemon/fnet-dc.c
b/daemon/fnet-dc.c
index
ed01d06
..
d295148
100644
(file)
--- a/
daemon/fnet-dc.c
+++ b/
daemon/fnet-dc.c
@@
-729,23
+729,30
@@
static void sendmyinfo(struct socket *sk, struct fnetnode *fn)
struct dchub *hub;
char *buf;
struct fnetnode *cfn;
struct dchub *hub;
char *buf;
struct fnetnode *cfn;
- int
numhubs
;
+ int
hn1, hn2, hn3
;
hub = fn->data;
qstrf(sk, "$MyINFO $ALL %s ", hub->nativenick);
buf = tr(icswcstombs(confgetstr("dc", "desc"), DCCHARSET, "Charset_conv_failure"), "$_|_");
qstrf(sk, "%s", buf);
hub = fn->data;
qstrf(sk, "$MyINFO $ALL %s ", hub->nativenick);
buf = tr(icswcstombs(confgetstr("dc", "desc"), DCCHARSET, "Charset_conv_failure"), "$_|_");
qstrf(sk, "%s", buf);
-
numhubs
= 0;
+
hn1 = hn2 = hn3
= 0;
for(cfn = fnetnodes; cfn != NULL; cfn = cfn->next)
{
if((cfn->state == FNN_EST) || (cfn->state == FNN_HS))
for(cfn = fnetnodes; cfn != NULL; cfn = cfn->next)
{
if((cfn->state == FNN_EST) || (cfn->state == FNN_HS))
- numhubs++;
+ {
+ if(cfn->regstatus == FNNS_OP)
+ hn3++;
+ else if(cfn->regstatus == FNNS_REG)
+ hn2++;
+ else
+ hn1++;
+ }
}
}
- qstrf(sk, "<%s V:%s,M:%c,H:%i/
0/0
,S:%i>",
+ qstrf(sk, "<%s V:%s,M:%c,H:%i/
%i/%i
,S:%i>",
DCIDTAG,
DCIDTAGV,
(tcpsock == NULL)?'P':'A',
DCIDTAG,
DCIDTAGV,
(tcpsock == NULL)?'P':'A',
-
numhubs
,
+
hn1, hn2, hn3
,
confgetint("transfer", "slots")
);
qstrf(sk, "$ $");
confgetint("transfer", "slots")
);
qstrf(sk, "$ $");
@@
-1445,6
+1452,16
@@
static void cmd_getpass(struct socket *sk, struct fnetnode *fn, char *cmd, char
}
qstrf(sk, "$MyPass %s|", mbspw);
free(mbspw);
}
qstrf(sk, "$MyPass %s|", mbspw);
free(mbspw);
+ fn->regstatus = FNNS_REG;
+ hubhandleaction(sk, fn, cmd, args);
+}
+
+static void cmd_logedin(struct socket *sk, struct fnetnode *fn, char *cmd, char *args)
+{
+ struct dchub *hub;
+
+ hub = fn->data;
+ fn->regstatus = FNNS_OP;
hubhandleaction(sk, fn, cmd, args);
}
hubhandleaction(sk, fn, cmd, args);
}
@@
-2494,6
+2511,7
@@
struct command hubcmds[] =
{"$SR", cc(cmd_sr)},
{"$UserCommand", cc(cmd_usercommand)},
{"$GetPass", cc(cmd_getpass)},
{"$SR", cc(cmd_sr)},
{"$UserCommand", cc(cmd_usercommand)},
{"$GetPass", cc(cmd_getpass)},
+ {"$LogedIn", cc(cmd_logedin)}, /* sic */
{NULL, NULL}
};
{NULL, NULL}
};