aboutsummaryrefslogtreecommitdiffstats
path: root/cynara.initial
blob: f2a88f8e3ab0d2a2f1acc989885bfc878f62a32a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#--------------------------------------------------------------------
# initial database for cynara
# format: space/tab separated fields
# fields: CLIENT SESSION USER PERMISSION ACTION EXPIRATION
#--------------------------------------------------------------------
* * *      * no  forever   # explicit default rule: NO
* * @ADMIN * yes forever   # users of group @ADMIN can do anything
* * @NONE  * no  forever   # users of group @NONE can do nothing

#--------------------------------------------------------------------
# User "0" and clients "System" is in the group "@ADMIN"
#--------------------------------------------------------------------
*      * 0 * @:%c:%s:@ADMIN:%p forever
System * * * @:%c:%s:@ADMIN:%p forever
ral.String.Other */ .highlight .sr { color: #008800; background-color: #fff0ff } /* Literal.String.Regex */ .highlight .s1 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Single */ .highlight .ss { color: #aa6600; background-color: #fff0f0 } /* Literal.String.Symbol */ .highlight .bp { color: #003388 } /* Name.Builtin.Pseudo */ .highlight .fm { color: #0066bb; font-weight: bold } /* Name.Function.Magic */ .highlight .vc { color: #336699 } /* Name.Variable.Class */ .highlight .vg { color: #dd7700 } /* Name.Variable.Global */ .highlight .vi { color: #3333bb } /* Name.Variable.Instance */ .highlight .vm { color: #336699 } /* Name.Variable.Magic */ .highlight .il { color: #0000DD; font-weight: bold } /* Literal.Number.Integer.Long */
###########################################################################
# Copyright (C) 2018 "IoT.bzh"
#
# author: José Bollo <jose.bollo@iot.bzh>
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
###########################################################################

CMAKE_MINIMUM_REQUIRED(VERSION 3.0)

PROJECT(cynara C)

SET(PROJECT_NAME "Cynara")
SET(PROJECT_PRETTY_NAME "Permission database")
SET(PROJECT_DESCRIPTION "Secured permission database for applications")
SET(PROJECT_VERSION "1.99.99")
set(PROJECT_URL "https://gerrit.automotivelinux.org/gerrit/gitweb?p=src/cynara.git;a=summary")

INCLUDE(FindPkgConfig)
INCLUDE(CheckIncludeFiles)
INCLUDE(CheckLibraryExists)
INCLUDE(GNUInstallDirs)
if(NOT CMAKE_INSTALL_FULL_RUNSTATEDIR)
  set(CMAKE_INSTALL_FULL_RUNSTATEDIR "${CMAKE_INSTALL_FULL_LOCALSTATEDIR}/run")
endif()
INCLUDE(CTest)

###########################################################################
# possible settings

set(CYNARA_VERSION ${PROJECT_VERSION})
set(CYNARA_SOVERSION 1.99)

add_definitions(-DCYNARA_VERSION="${CYNARA_VERSION}")

set(SYSTEMD ON CACHE BOOL "should use systemd")
set(DEFAULT_DB_DIR "${CMAKE_INSTALL_FULL_LOCALSTATEDIR}/lib/cynara"
	CACHE PATH "directory path of the database")
set(DEFAULT_SOCKET_DIR "${CMAKE_INSTALL_FULL_RUNSTATEDIR}"
	CACHE PATH "directory path of the sockets")
set(DEFAULT_CONFIG_DIR "${CMAKE_INSTALL_FULL_SYSCONFDIR}/security"
	CACHE PATH "directory of configuration")
set(DEFAULT_INIT_FILE "${DEFAULT_CONFIG_DIR}/cynara.initial")

###########################################################################

include_directories(include)
link_libraries(-Wl,--as-needed -Wl,--gc-sections -Wl,--no-undefined)

add_compile_options(-Wall -Wextra -Wconversion)
add_compile_options(-Wno-unused-parameter) # frankly not using a parameter does it care?
add_compile_options(-Wno-sign-compare -Wno-sign-conversion)
add_compile_options(-Werror=maybe-uninitialized)
add_compile_options(-Werror=implicit-function-declaration)
add_compile_options(-ffunction-sections -fdata-sections)
add_compile_options(-fPIC)
add_compile_options(-g)
add_compile_options(-fstack-protector -D_FORTIFY_SOURCE=2 -O2)

set(CMAKE_C_FLAGS_PROFILING    "-g -O2 -pg")
set(CMAKE_C_FLAGS_DEBUG        "-g -ggdb --fstack-protector -D_FORTIFY_SOURCE=2")
set(CMAKE_C_FLAGS_RELEASE      "-g -O2")
set(CMAKE_C_FLAGS_CCOV         "-g -O2 --coverage")

###########################################################################

if(SYSTEMD)
   PKG_CHECK_MODULES(libsystemd REQUIRED libsystemd>=222)
   add_subdirectory(systemd)
endif()

add_subdirectory(include)
add_subdirectory(src)
add_subdirectory(pkgconfig)

install(FILES
	${CMAKE_CURRENT_SOURCE_DIR}/cynara.initial
	DESTINATION
	${DEFAULT_CONFIG_DIR}
)