~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
20
#include "config.h"
21
22
#include <drizzled/gettext.h>
23
#include <drizzled/session.h>
24
25
#include "function.h"
26
#include "wrap.h"
27
28
using namespace drizzled;
29
30
Function_syslog::Function_syslog()
31
  : Item_str_func()
32
{
33
  WrapSyslog::singleton().openlog(syslog_module::sysvar_ident);
34
}
35
36
String *Function_syslog::val_str(String *s)
37
{
38
39
  if (args[0]->null_value || args[1]->null_value || args[2]->null_value)
40
  {
41
    null_value= 1;
42
    return 0;
43
  }
44
45
  int syslog_facility= WrapSyslog::getFacilityByName(args[0]->val_str(s)->c_ptr());
46
  int syslog_priority= WrapSyslog::getPriorityByName(args[1]->val_str(s)->c_ptr());
47
48
  if ((syslog_facility == -1) || (syslog_priority == -1))
49
  {
50
    null_value= 1;
51
    return 0;
52
  }
53
54
  char *syslog_string= args[2]->val_str(s)->c_ptr();
55
  if ((syslog_string == 0) || (syslog_string[0] == 0))
56
  {
57
    null_value= 1;
58
    return 0;
59
  }
60
61
  WrapSyslog::singleton().log(syslog_facility, syslog_priority, "%s", syslog_string);
62
63
  null_value= 0;
64
  return args[2]->val_str(s);
65
}
66
67
void Function_syslog::fix_length_and_dec()
68
{
69
  max_length= args[0]->max_length;
70
}
71
72
bool Function_syslog::check_argument_count(int n)
73
{
74
  return (n == 3);
75
}
76