Open SCAP Library
sce_engine_api.h
1 /*
2  * Copyright 2012 Red Hat Inc., Durham, North Carolina.
3  * All Rights Reserved.
4  *
5  * This library is free software; you can redistribute it and/or
6  * modify it under the terms of the GNU Lesser General Public
7  * License as published by the Free Software Foundation; either
8  * version 2.1 of the License, or (at your option) any later version.
9  *
10  * This library 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 GNU
13  * Lesser General Public License for more details.
14  *
15  * You should have received a copy of the GNU Lesser General Public
16  * License along with this library; if not, write to the Free Software
17  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18  *
19  * Authors:
20  * "Martin Preisler" <mpreisle@redhat.com>
21  */
22 
23 #ifndef SCE_ENGINE_API_H_
24 #define SCE_ENGINE_API_H
25 
26 #include <xccdf_benchmark.h>
27 #include <xccdf_policy.h>
28 
32 struct sce_check_result* sce_check_result_new(void);
33 
37 void sce_check_result_free(struct sce_check_result* v);
38 
44 void sce_check_result_set_href(struct sce_check_result* v, const char* href);
45 
49 const char* sce_check_result_get_href(struct sce_check_result* v);
50 
56 void sce_check_result_set_basename(struct sce_check_result* v, const char* basename);
57 
61 const char* sce_check_result_get_basename(struct sce_check_result* v);
62 
69 void sce_check_result_set_stdout(struct sce_check_result* v, const char* details);
70 
74 const char* sce_check_result_get_stdout(struct sce_check_result* v);
75 
80 void sce_check_result_set_exit_code(struct sce_check_result* v, int exit_code);
81 
85 int sce_check_result_get_exit_code(struct sce_check_result* v);
86 
93 
104 void sce_check_result_add_environment_variable(struct sce_check_result* v, const char* var);
105 
112 
116 xccdf_test_result_type_t sce_check_result_get_xccdf_result(struct sce_check_result* v);
117 
123 void sce_check_result_export(struct sce_check_result* v, const char* target_file);
124 
128 struct sce_session* sce_session_new(void);
129 
133 void sce_session_free(struct sce_session* s);
134 
140 void sce_session_reset(struct sce_session* s);
141 
149 void sce_session_add_check_result(struct sce_session* s, struct sce_check_result* result);
150 
157 struct sce_check_result *sce_check_result_iterator_next(struct sce_check_result_iterator *it);
164 
165 struct sce_check_result_iterator *sce_session_get_check_results(struct sce_session* s);
166 
172 void sce_session_export_to_directory(struct sce_session* s, const char* directory);
173 
177 struct sce_parameters* sce_parameters_new(void);
178 
182 void sce_parameters_free(struct sce_parameters* v);
183 
190 void sce_parameters_set_xccdf_directory(struct sce_parameters* v, const char* value);
191 
195 const char* sce_parameters_get_xccdf_directory(struct sce_parameters* v);
196 
204 void sce_parameters_set_session(struct sce_parameters* v, struct sce_session* value);
205 
209 struct sce_session* sce_parameters_get_session(struct sce_parameters* v);
210 
218 
224 xccdf_test_result_type_t sce_engine_eval_rule(struct xccdf_policy *policy, const char *rule_id, const char *id, const char *href,
225  struct xccdf_value_binding_iterator *value_binding_it,
226  struct xccdf_check_import_iterator *check_import_it,
227  void *usr);
228 
236 
237 #endif
Open-scap XCCDF Policy library interface.
Check import iterator.
Definition: xccdf_benchmark.h:530
Iterator over collections of sce_check_results.
Definition: sce_engine.c:55
XCCDF policy model structure contains xccdf_benchmark as reference to Benchmark element in XML file a...
Definition: xccdf_policy_priv.h:39
void sce_check_result_iterator_free(struct sce_check_result_iterator *it)
void sce_check_result_add_environment_variable(struct sce_check_result *v, const char *var)
Adds an environment variable entry to list of environment variables that were passed to the script...
Definition: sce_engine.c:149
void sce_check_result_export(struct sce_check_result *v, const char *target_file)
Exports details (in XML form) of given check result to given file.
Definition: sce_engine.c:164
bool sce_check_result_iterator_has_more(struct sce_check_result_iterator *it)
Open-scap XCCDF library interface.
xccdf_test_result_type_t
Test result.
Definition: xccdf_benchmark.h:168
void sce_parameters_allocate_session(struct sce_parameters *v)
Just a convenience shortcut of setting a session to a newly allocated session.
Definition: sce_engine.c:305
void sce_check_result_set_exit_code(struct sce_check_result *v, int exit_code)
Sets exit code with which the script ended execution after evaluation.
Definition: sce_engine.c:133
xccdf_test_result_type_t sce_engine_eval_rule(struct xccdf_policy *policy, const char *rule_id, const char *id, const char *href, struct xccdf_value_binding_iterator *value_binding_it, struct xccdf_check_import_iterator *check_import_it, void *usr)
Internal rule evaluation callback, don't use directly.
Definition: sce_engine.c:310
Definition: sce_engine.c:193
void sce_parameters_set_xccdf_directory(struct sce_parameters *v, const char *value)
Sets the directory that contains XCCDF that will reference SCE checks.
Definition: sce_engine.c:276
void sce_check_result_set_href(struct sce_check_result *v, const char *href)
Sets the href used to execute the check that yielded given check result.
Definition: sce_engine.c:94
void sce_session_export_to_directory(struct sce_session *s, const char *directory)
Exports all check results to given directory.
Definition: sce_engine.c:233
void sce_session_add_check_result(struct sce_session *s, struct sce_check_result *result)
Adds a check result to the session.
Definition: sce_engine.c:221
void sce_check_result_set_stdout(struct sce_check_result *v, const char *details)
Sets stdout that was captured while script was evaluating.
Definition: sce_engine.c:120
void sce_check_result_iterator_reset(struct sce_check_result_iterator *it)
void sce_check_result_reset_environment_variables(struct sce_check_result *v)
Clears the list of passed environment variables.
Definition: sce_engine.c:143
void sce_session_reset(struct sce_session *s)
Removes all check results from the session.
Definition: sce_engine.c:215
void sce_check_result_set_basename(struct sce_check_result *v, const char *basename)
Sets basename of the script that was used for check evaluation.
Definition: sce_engine.c:107
Definition: sce_engine.c:248
XCCDF policy structure is abstract (class) structure of Profile element from benchmark.
Definition: xccdf_policy_priv.h:58
void sce_check_result_set_xccdf_result(struct sce_check_result *v, xccdf_test_result_type_t result)
Sets the final xccdf result (after exit code to xccdf mapping takes place)
Definition: sce_engine.c:154
bool xccdf_policy_model_register_engine_sce(struct xccdf_policy_model *model, struct sce_parameters *parameters)
Registers SCE to given policy model.
Definition: sce_engine.c:579
void sce_parameters_set_session(struct sce_parameters *v, struct sce_session *value)
Sets SCE session to use for check results storage.
Definition: sce_engine.c:289