X-Git-Url: https://jfr.im/git/irc/rqf/shadowircd.git/blobdiff_plain/13ae2f4b6904ebf7b8160902f9ffeb80f7585ed2..cb9345dcd1f3a48fe488cfb9b91eb16d87e45cc4:/modules/m_oper.c diff --git a/modules/m_oper.c b/modules/m_oper.c index ca5c212..061a9b7 100644 --- a/modules/m_oper.c +++ b/modules/m_oper.c @@ -52,11 +52,9 @@ mapi_clist_av1 oper_clist[] = { &oper_msgtab, NULL }; DECLARE_MODULE_AV1(oper, NULL, NULL, oper_clist, NULL, NULL, "$Revision: 1483 $"); static int match_oper_password(const char *password, struct oper_conf *oper_p); -extern char *crypt(); /* * m_oper - * parv[0] = sender prefix * parv[1] = oper name * parv[2] = oper password */ @@ -101,6 +99,22 @@ m_oper(struct Client *client_p, struct Client *source_p, int parc, const char *p return 0; } + if(IsOperConfNeedSSL(oper_p) && !IsSSLClient(source_p)) + { + sendto_one(source_p, form_str(ERR_NOOPERHOST), me.name, source_p->name); + ilog(L_FOPER, "FAILED OPER (%s) by (%s!%s@%s) (%s) -- requires SSL/TLS", + name, source_p->name, + source_p->username, source_p->host, source_p->sockhost); + + if(ConfigFileEntry.failed_oper_notice) + { + sendto_realops_snomask(SNO_GENERAL, L_ALL, + "Failed OPER attempt - missing SSL/TLS by %s (%s@%s)", + source_p->name, source_p->username, source_p->host); + } + return 0; + } + if(match_oper_password(password, oper_p)) { oper_up(source_p, oper_p); @@ -156,7 +170,7 @@ match_oper_password(const char *password, struct oper_conf *oper_p) * the proper encrypted hash for comparison. */ if(!EmptyString(password)) - encr = crypt(password, oper_p->passwd); + encr = rb_crypt(password, oper_p->passwd); else encr = ""; }