2014-03-14 03:38:15 +04:00
/***
This file is part of systemd .
Copyright 2014 Sebastian Thorarensen
systemd is free software ; you can redistribute it and / or modify it
under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation ; either version 2.1 of the License , or
( at your option ) any later version .
systemd 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
Lesser General Public License for more details .
You should have received a copy of the GNU Lesser General Public License
along with systemd ; If not , see < http : //www.gnu.org/licenses/>.
* * */
2015-10-27 05:01:06 +03:00
# include "alloc-util.h"
2016-11-07 18:14:59 +03:00
# include "format-util.h"
2015-10-24 23:58:24 +03:00
# include "journald-server.h"
2015-11-17 00:09:36 +03:00
# include "journald-wall.h"
2015-04-10 20:10:00 +03:00
# include "process-util.h"
2015-10-24 23:58:24 +03:00
# include "string-util.h"
# include "utmp-wtmp.h"
2014-03-14 03:38:15 +04:00
void server_forward_wall (
Server * s ,
int priority ,
const char * identifier ,
const char * message ,
2014-11-02 23:46:42 +03:00
const struct ucred * ucred ) {
2014-03-14 03:38:15 +04:00
_cleanup_free_ char * ident_buf = NULL , * l_buf = NULL ;
const char * l ;
int r ;
assert ( s ) ;
assert ( message ) ;
if ( LOG_PRI ( priority ) > s - > max_level_wall )
return ;
if ( ucred ) {
if ( ! identifier ) {
get_process_comm ( ucred - > pid , & ident_buf ) ;
identifier = ident_buf ;
}
if ( asprintf ( & l_buf , " %s[ " PID_FMT " ]: %s " , strempty ( identifier ) , ucred - > pid , message ) < 0 ) {
log_oom ( ) ;
return ;
}
l = l_buf ;
} else if ( identifier ) {
2016-10-23 18:43:27 +03:00
l = l_buf = strjoin ( identifier , " : " , message ) ;
2014-03-14 03:38:15 +04:00
if ( ! l_buf ) {
log_oom ( ) ;
return ;
}
} else
l = message ;
2015-04-24 16:31:29 +03:00
r = utmp_wall ( l , " systemd-journald " , NULL , NULL , NULL ) ;
2014-03-14 03:38:15 +04:00
if ( r < 0 )
2014-11-28 15:19:16 +03:00
log_debug_errno ( r , " Failed to send wall message: %m " ) ;
2014-03-14 03:38:15 +04:00
}