2 #Copyright (C) 2009-2010 :
3 # Gabes Jean, naparuba@gmail.com
4 # Gerhard Lausser, Gerhard.Lausser@consol.de
5 # Gregory Starck, g.starck@gmail.com
6 # Hartmut Goebel, h.goebel@goebel-consult.de
8 #This file is part of Shinken.
10 #Shinken is free software: you can redistribute it and/or modify
11 #it under the terms of the GNU Affero General Public License as published by
12 #the Free Software Foundation, either version 3 of the License, or
13 #(at your option) any later version.
15 #Shinken is distributed in the hope that it will be useful,
16 #but WITHOUT ANY WARRANTY; without even the implied warranty of
17 #MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 #GNU Affero General Public License for more details.
20 #You should have received a copy of the GNU Affero General Public License
21 #along with Shinken. If not, see <http://www.gnu.org/licenses/>.
32 # We load the object where we will put log broks
33 # with the 'add' method
34 def load_obj(self
, object, name_
= None):
40 # We enter a log message, we format it, and we add the log brok
41 def log(self
, message
, format
= None):
49 # We format the log in UTF-8
50 s
= u
'[%d] %s\n' % (int(time
.time()), message
.decode('UTF-8', 'replace'))
52 s
= u
'[%d] [%s] %s\n' % (int(time
.time()), name
, message
.decode('UTF-8', 'replace'))
56 # We create and add the brok
57 b
= Brok('log', {'log' : s
})
60 # If we want a local log write, do it
61 if local_log
is not None:
66 # The log can also write to a local file if need
67 def register_local_log(self
, path
):
69 local_log
= open(path
, 'a')
72 # Clsoe the local log file at program exit