1 /* $Id: ip_cloaking.c 3526 2007-07-06 07:56:14Z nenolod $ */
14 /* if you're modifying this module, you'll probably to change this */
15 #define KEY 0x13748cfa
20 /* add the usermode to the available slot */
21 user_modes
['h'] = find_umode_slot();
30 /* disable the umode and remove it from the available list */
35 static void check_umode_change(void *data
);
36 static void check_new_user(void *data
);
37 mapi_hfn_list_av1 ip_cloaking_hfnlist
[] = {
38 { "umode_changed", (hookfn
) check_umode_change
},
39 { "new_local_user", (hookfn
) check_new_user
},
43 DECLARE_MODULE_AV1(ip_cloaking
, _modinit
, _moddeinit
, NULL
, NULL
,
44 ip_cloaking_hfnlist
, "$Revision: 3526 $");
47 distribute_hostchange(struct Client
*client
)
49 if (irccmp(client
->host
, client
->orighost
))
50 sendto_one_numeric(client
, RPL_HOSTHIDDEN
, "%s :is now your hidden host",
53 sendto_one_numeric(client
, RPL_HOSTHIDDEN
, "%s :hostname reset",
56 sendto_server(NULL
, NULL
,
57 CAP_EUID
| CAP_TS6
, NOCAPS
, ":%s CHGHOST %s :%s",
58 use_id(&me
), use_id(client
), client
->host
);
59 sendto_server(NULL
, NULL
,
60 CAP_TS6
, CAP_EUID
, ":%s ENCAP * CHGHOST %s :%s",
61 use_id(&me
), use_id(client
), client
->host
);
62 if (irccmp(client
->host
, client
->orighost
))
65 ClearDynSpoof(client
);
68 #define Nval 0x8c3a48ac
70 #define INITDATA "98fwqefnoiqefv03f423t34gbv3vb89tg432t3b8" /* change this */
72 static inline unsigned int
73 get_string_entropy(const char *inbuf
)
75 unsigned int accum
= 1;
83 /* calls get_string_entropy() and toasts it against INITDATA */
84 static inline unsigned int
85 get_string_weighted_entropy(const char *inbuf
)
87 static int base_entropy
= 0;
88 unsigned int accum
= get_string_entropy(inbuf
);
90 /* initialize the algorithm if it is not yet ready */
91 if (base_entropy
== 0)
92 base_entropy
= get_string_entropy(INITDATA
);
94 return (Nval
* accum
) ^ base_entropy
;
98 do_host_cloak_ip(const char *inbuf
, char *outbuf
)
101 unsigned int accum
= get_string_weighted_entropy(inbuf
);
105 strncpy(buf
, inbuf
, HOSTLEN
);
106 tptr
= strrchr(buf
, '.');
110 tptr
= strrchr(buf
, ':');
116 strncpy(outbuf
, inbuf
, HOSTLEN
);
124 rb_snprintf(outbuf
, HOSTLEN
, "%s:%x", buf
, accum
);
128 rb_snprintf(outbuf
, HOSTLEN
, "%s.%x", buf
, accum
);
133 do_host_cloak_host(const char *inbuf
, char *outbuf
)
135 char b26_alphabet
[] = "abcdefghijklmnopqrstuvwxyz";
137 unsigned int accum
= get_string_weighted_entropy(inbuf
);
139 strncpy(outbuf
, inbuf
, HOSTLEN
);
141 /* pass 1: scramble first section of hostname using base26
142 * alphabet toasted against the weighted entropy of the string.
144 * numbers are not changed at this time, only letters.
146 for (tptr
= outbuf
; *tptr
!= '\0'; tptr
++)
151 if (isdigit(*tptr
) || *tptr
== '-')
154 *tptr
= b26_alphabet
[(*tptr
* accum
) % 26];
157 /* pass 2: scramble each number in the address */
158 for (tptr
= outbuf
; *tptr
!= '\0'; tptr
++)
162 *tptr
= 48 + ((*tptr
* accum
) % 10);
168 check_umode_change(void *vdata
)
170 hook_data_umode_changed
*data
= (hook_data_umode_changed
*)vdata
;
171 struct Client
*source_p
= data
->client
;
173 if (!MyClient(source_p
))
176 /* didn't change +h umode, we don't need to do anything */
177 if (!((data
->oldumodes
^ source_p
->umodes
) & user_modes
['h']))
180 if (source_p
->umodes
& user_modes
['h'])
182 if (IsIPSpoof(source_p
) || source_p
->localClient
->mangledhost
== NULL
|| (IsDynSpoof(source_p
) && strcmp(source_p
->host
, source_p
->localClient
->mangledhost
)))
184 source_p
->umodes
&= ~user_modes
['h'];
187 if (strcmp(source_p
->host
, source_p
->localClient
->mangledhost
))
189 rb_strlcpy(source_p
->host
, source_p
->localClient
->mangledhost
, HOSTLEN
);
190 distribute_hostchange(source_p
);
192 else /* not really nice, but we need to send this numeric here */
193 sendto_one_numeric(source_p
, RPL_HOSTHIDDEN
, "%s :is now your hidden host",
196 else if (!(source_p
->umodes
& user_modes
['h']))
198 if (source_p
->localClient
->mangledhost
!= NULL
&&
199 !strcmp(source_p
->host
, source_p
->localClient
->mangledhost
))
201 rb_strlcpy(source_p
->host
, source_p
->orighost
, HOSTLEN
);
202 distribute_hostchange(source_p
);
208 check_new_user(void *vdata
)
210 struct Client
*source_p
= (void *)vdata
;
212 if (IsIPSpoof(source_p
))
214 source_p
->umodes
&= ~user_modes
['h'];
217 source_p
->localClient
->mangledhost
= rb_malloc(HOSTLEN
);
218 if (!irccmp(source_p
->orighost
, source_p
->sockhost
))
219 do_host_cloak_ip(source_p
->orighost
, source_p
->localClient
->mangledhost
);
221 do_host_cloak_host(source_p
->orighost
, source_p
->localClient
->mangledhost
);
222 if (IsDynSpoof(source_p
))
223 source_p
->umodes
&= ~user_modes
['h'];
224 if (source_p
->umodes
& user_modes
['h'])
226 rb_strlcpy(source_p
->host
, source_p
->localClient
->mangledhost
, sizeof(source_p
->host
));
227 if (irccmp(source_p
->host
, source_p
->orighost
))
228 SetDynSpoof(source_p
);