1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
|
/* Copyright (C) 2006 MySQL AB
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; version 2 of the License.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
#include <drizzled/common_includes.h>
#include <drizzled/sql_udf.h>
#include <drizzled/item/func.h>
#include <drizzled/item/strfunc.h>
#include <openssl/md5.h>
#include <stdio.h>
using namespace std;
class Item_func_md5 : public Item_str_func
{
public:
const char *func_name() const { return "md5"; }
String *val_str(String*);
void fix_length_and_dec() {
max_length=32;
args[0]->collation.set(
get_charset_by_csname(args[0]->collation.collation->csname,
MY_CS_BINSORT,MYF(0)), DERIVATION_COERCIBLE);
}
};
String *Item_func_md5::val_str(String *str)
{
assert(fixed == 1);
String * sptr= args[0]->val_str(str);
str->set_charset(&my_charset_bin);
if (sptr)
{
MD5_CTX context;
unsigned char digest[16];
null_value=0;
MD5_Init (&context);
MD5_Update (&context,(unsigned char *) sptr->ptr(), sptr->length());
MD5_Final (digest, &context);
if (str->alloc(32)) // Ensure that memory is free
{
null_value=1;
return 0;
}
snprintf((char *) str->ptr(), 33,
"%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x",
digest[0], digest[1], digest[2], digest[3],
digest[4], digest[5], digest[6], digest[7],
digest[8], digest[9], digest[10], digest[11],
digest[12], digest[13], digest[14], digest[15]);
str->length((uint) 32);
return str;
}
null_value=1;
return 0;
}
Item_func* create_md5udf_item(MEM_ROOT* m)
{
return new (m) Item_func_md5();
}
struct udf_func md5udf = {
{ C_STRING_WITH_LEN("md5") },
create_md5udf_item
};
static int md5udf_plugin_init(void *p)
{
udf_func **f = (udf_func**) p;
*f= &md5udf;
return 0;
}
static int md5udf_plugin_deinit(void *p)
{
udf_func *udff = (udf_func *) p;
(void)udff;
return 0;
}
mysql_declare_plugin(md5)
{
DRIZZLE_UDF_PLUGIN,
"md5",
"1.0",
"Stewart Smith",
"UDF for computing md5sum",
PLUGIN_LICENSE_GPL,
md5udf_plugin_init, /* Plugin Init */
md5udf_plugin_deinit, /* Plugin Deinit */
NULL, /* status variables */
NULL, /* system variables */
NULL /* config options */
}
mysql_declare_plugin_end;
|