summaryrefslogtreecommitdiff
path: root/ychat-0.7.5/src/mods/commands/yc_md5.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'ychat-0.7.5/src/mods/commands/yc_md5.cpp')
-rwxr-xr-xychat-0.7.5/src/mods/commands/yc_md5.cpp54
1 files changed, 54 insertions, 0 deletions
diff --git a/ychat-0.7.5/src/mods/commands/yc_md5.cpp b/ychat-0.7.5/src/mods/commands/yc_md5.cpp
new file mode 100755
index 0000000..d79d952
--- /dev/null
+++ b/ychat-0.7.5/src/mods/commands/yc_md5.cpp
@@ -0,0 +1,54 @@
+#include "../../incl.h"
+#include "../../chat/user.h"
+#include "../../contrib/crypt/md5.h"
+
+/*
+ gcc -shared -o yc_name.so yc_name.cpp
+*/
+
+using namespace std;
+
+extern "C" {
+ int extern_function(void *v_arg)
+ {
+ container *c=(container *)v_arg;
+
+ user *p_user = (user*) c->elem[1]; // the corresponding user
+ vector<string> *params = (vector<string>*) c->elem[2]; // param array
+ conf* p_conf = (conf*) ((dynamic_wrap*)c->elem[3])->CONF;
+
+ if (params->size() >= 2)
+ {
+ vector<string>::iterator iter;
+ string s_string = "";
+ string s_salt = "";
+
+ for (iter = params->begin(); iter+1 != params->end(); ++iter)
+ {
+ s_string.append(*iter);
+ }
+
+ s_salt = *iter;
+
+ string s_msg = "Crypt: <b>" + s_string + "</b>, Salt: <b>"
+ + s_salt + "</b> = <b>" +
+ + md5::MD5Crypt(s_string.c_str(), s_salt.c_str())
+ + "</b><br>\n";
+ p_user->msg_post( &s_msg );
+ }
+
+ else
+ {
+ string s_msg = "<font color=\"#"
+ + p_conf->get_elem("chat.html.errorcolor")
+ + "\"> "
+ + p_conf->get_elem("ERR_WRONG_COMMAND_USAGE")
+ + "</font><br>\n";
+ p_user->msg_post( &s_msg );
+
+ }
+
+ return 0;
+ }
+}
+