2012-09-07 00:23:11 +04:00
/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
2012-10-03 01:07:00 +04:00
# pragma once
2012-09-07 00:23:11 +04:00
/***
This file is part of systemd .
Copyright 2012 Dan Walsh
systemd is free software ; you can redistribute it and / or modify it
2013-08-15 00:34:41 +04:00
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
2012-09-07 00:23:11 +04:00
( 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
2013-08-15 00:34:41 +04:00
Lesser General Public License for more details .
2012-09-07 00:23:11 +04:00
2013-08-15 00:34:41 +04:00
You should have received a copy of the GNU Lesser General Public License
2012-09-07 00:23:11 +04:00
along with systemd ; If not , see < http : //www.gnu.org/licenses/>.
* * */
2013-11-20 00:12:59 +04:00
# include "sd-bus.h"
# include "bus-error.h"
# include "bus-util.h"
2012-10-03 01:56:54 +04:00
void selinux_access_free ( void ) ;
2013-11-20 00:12:59 +04:00
int selinux_access_check ( sd_bus * bus , sd_bus_message * message , const char * path , const char * permission , sd_bus_error * error ) ;
2012-10-03 01:07:00 +04:00
# ifdef HAVE_SELINUX
2013-11-20 00:12:59 +04:00
# define SELINUX_ACCESS_CHECK(bus, message, permission) \
2012-10-03 01:07:00 +04:00
do { \
2013-11-20 00:12:59 +04:00
_cleanup_bus_error_free_ sd_bus_error _error = SD_BUS_ERROR_NULL ; \
sd_bus_message * _m = ( message ) ; \
sd_bus * _b = ( bus ) ; \
2012-10-03 01:07:00 +04:00
int _r ; \
2013-11-20 00:12:59 +04:00
_r = selinux_access_check ( _b , _m , NULL , ( permission ) , & _error ) ; \
2012-10-03 01:07:00 +04:00
if ( _r < 0 ) \
2013-11-21 04:51:16 +04:00
return sd_bus_reply_method_errno ( _m , _r , & _error ) ; \
2012-10-03 01:07:00 +04:00
} while ( false )
2013-11-20 00:12:59 +04:00
# define SELINUX_UNIT_ACCESS_CHECK(unit, bus, message, permission) \
2012-10-03 01:07:00 +04:00
do { \
2013-11-20 00:12:59 +04:00
_cleanup_bus_error_free_ sd_bus_error _error = SD_BUS_ERROR_NULL ; \
sd_bus_message * _m = ( message ) ; \
sd_bus * _b = ( bus ) ; \
2012-10-03 01:56:54 +04:00
Unit * _u = ( unit ) ; \
2013-11-20 00:12:59 +04:00
int _r ; \
_r = selinux_access_check ( _b , _m , _u - > source_path ? : _u - > fragment_path , ( permission ) , & _error ) ; \
2012-10-03 01:07:00 +04:00
if ( _r < 0 ) \
2013-11-21 04:51:16 +04:00
return sd_bus_reply_method_errno ( _m , _r , & _error ) ; \
2012-10-03 01:07:00 +04:00
} while ( false )
# else
2013-11-20 00:12:59 +04:00
# define SELINUX_ACCESS_CHECK(bus, message, permission) do { } while (false)
# define SELINUX_UNIT_ACCESS_CHECK(unit, bus, message, permission) do { } while (false)
2012-10-03 01:07:00 +04:00
2012-09-07 00:23:11 +04:00
# endif