~drizzle-trunk/drizzle/development

1637.3.1 by Mark Atwood
new syslog module, with plugins for query log, error message, and SYSLOG() function
1
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3
 *
4
 *  Copyright (C) 2010 Mark Atwood
5
 *
6
 *  This program is free software; you can redistribute it and/or modify
7
 *  it under the terms of the GNU General Public License as published by
8
 *  the Free Software Foundation; version 2 of the License.
9
 *
10
 *  This program is distributed in the hope that it will be useful,
11
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
 *  GNU General Public License for more details.
14
 *
15
 *  You should have received a copy of the GNU General Public License
16
 *  along with this program; if not, write to the Free Software
17
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
18
 */
19
2173.2.1 by Monty Taylor
Fixes incorrect usage of include
20
#include <config.h>
1637.3.1 by Mark Atwood
new syslog module, with plugins for query log, error message, and SYSLOG() function
21
22
#include <drizzled/gettext.h>
23
#include <drizzled/session.h>
24
2440.4.2 by Brian Aker
Fix level_t to be more inline with syslog
25
#include <plugin/syslog/function.h>
26
#include <plugin/syslog/wrap.h>
1637.3.1 by Mark Atwood
new syslog module, with plugins for query log, error message, and SYSLOG() function
27
1964.2.7 by Monty Taylor
Refactored syslog module and changed it to use sys_var directly.
28
namespace drizzle_plugin
29
{
1637.3.1 by Mark Atwood
new syslog module, with plugins for query log, error message, and SYSLOG() function
30
1964.2.7 by Monty Taylor
Refactored syslog module and changed it to use sys_var directly.
31
udf::Syslog::Syslog()
1637.3.1 by Mark Atwood
new syslog module, with plugins for query log, error message, and SYSLOG() function
32
  : Item_str_func()
1964.2.7 by Monty Taylor
Refactored syslog module and changed it to use sys_var directly.
33
{ }
1637.3.1 by Mark Atwood
new syslog module, with plugins for query log, error message, and SYSLOG() function
34
1964.2.7 by Monty Taylor
Refactored syslog module and changed it to use sys_var directly.
35
drizzled::String *udf::Syslog::val_str(drizzled::String *s)
1637.3.1 by Mark Atwood
new syslog module, with plugins for query log, error message, and SYSLOG() function
36
{
37
38
  if (args[0]->null_value || args[1]->null_value || args[2]->null_value)
39
  {
40
    null_value= 1;
41
    return 0;
42
  }
43
44
  int syslog_facility= WrapSyslog::getFacilityByName(args[0]->val_str(s)->c_ptr());
45
  int syslog_priority= WrapSyslog::getPriorityByName(args[1]->val_str(s)->c_ptr());
46
47
  if ((syslog_facility == -1) || (syslog_priority == -1))
48
  {
49
    null_value= 1;
50
    return 0;
51
  }
52
53
  char *syslog_string= args[2]->val_str(s)->c_ptr();
54
  if ((syslog_string == 0) || (syslog_string[0] == 0))
55
  {
56
    null_value= 1;
57
    return 0;
58
  }
59
2440.4.3 by Brian Aker
Update naming convention for priority.
60
  WrapSyslog::singleton().log(syslog_facility, drizzled::error::priority_t(syslog_priority), "%s", syslog_string);
1637.3.1 by Mark Atwood
new syslog module, with plugins for query log, error message, and SYSLOG() function
61
62
  null_value= 0;
63
  return args[2]->val_str(s);
64
}
65
1964.2.7 by Monty Taylor
Refactored syslog module and changed it to use sys_var directly.
66
void udf::Syslog::fix_length_and_dec()
1637.3.1 by Mark Atwood
new syslog module, with plugins for query log, error message, and SYSLOG() function
67
{
68
  max_length= args[0]->max_length;
69
}
70
1964.2.7 by Monty Taylor
Refactored syslog module and changed it to use sys_var directly.
71
bool udf::Syslog::check_argument_count(int n)
1637.3.1 by Mark Atwood
new syslog module, with plugins for query log, error message, and SYSLOG() function
72
{
73
  return (n == 3);
74
}
75
1964.2.7 by Monty Taylor
Refactored syslog module and changed it to use sys_var directly.
76
} /* namespace drizzle_plugin */