created libpts
[strongswan.git] / src / libpts / pts / pts_database.h
1 /*
2 * Copyright (C) 2011 Andreas Steffen
3 * HSR Hochschule fuer Technik Rapperswil
4 *
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License as published by the
7 * Free Software Foundation; either version 2 of the License, or (at your
8 * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
9 *
10 * This program is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
12 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
13 * for more details.
14 */
15
16 /**
17 * @defgroup pts_database pts_database
18 * @{ @ingroup pts
19 */
20
21 #ifndef PTS_DATABASE_H_
22 #define PTS_DATABASE_H_
23
24 typedef struct pts_database_t pts_database_t;
25
26 #include "pts_meas_algo.h"
27 #include <library.h>
28
29 /**
30 * Class implementing the PTS File Measurement database
31 *
32 */
33 struct pts_database_t {
34
35 /**
36 * Get files to be measured by PTS
37 *
38 * @param product software product (os, vpn client, etc.)
39 * @return enumerator over all matching files
40 */
41 enumerator_t* (*create_file_enumerator)(pts_database_t *this, char *product);
42
43 /**
44 * Get stored measurement hash for single file or directory entries
45 *
46 * @param product software product (os, vpn client, etc.)
47 * @param algo hash algorithm used for measurement
48 * @param id primary key of measured file/directory
49 * @param is_dir TRUE if directory was measured
50 * @return enumerator over all matching measurement hashes
51 */
52 enumerator_t* (*create_hash_enumerator)(pts_database_t *this, char *product,
53 pts_meas_algorithms_t algo,
54 int id, bool is_dir);
55
56 /**
57 * Destroys a pts_database_t object.
58 */
59 void (*destroy)(pts_database_t *this);
60
61 };
62
63 /**
64 * Creates an pts_database_t object
65 *
66 * @param uri database uri
67 */
68 pts_database_t* pts_database_create(char *uri);
69
70 #endif /** PTS_DATABASE_H_ @}*/