summaryrefslogtreecommitdiffstats
path: root/contrib/android/perms.h
blob: 9ea3f95c07614dc58dc6bd4d5b8c6c77d2ae3728 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#ifndef ANDROID_PERMS_H
# define ANDROID_PERMS_H

# include <ext2fs/ext2fs.h>

typedef void (*fs_config_f)(const char *path, int dir,
			    const char *target_out_path,
			    unsigned *uid, unsigned *gid,
			    unsigned *mode, uint64_t *capabilities);

/*
 * Represents a range of UID/GID mapping.
 * This maps the id in [|parent_id|, |parent_id| + |length|) into
 * [|child_id|, |child_id| + |length|)
 */
struct ugid_map_entry {
	unsigned int child_id;
	unsigned int parent_id;
	unsigned int length;
};

struct ugid_map {
	/* The number of elements in |entries|. */
	size_t size;

	/* An array of entries. If |size| is 0, this is a null pointer. */
	struct ugid_map_entry* entries;
};

# ifdef _WIN32
struct selabel_handle;
static inline errcode_t android_configure_fs(ext2_filsys fs,
					     char *src_dir,
					     char *target_out,
					     char *mountpoint,
					     void *seopts,
					     unsigned int nopt,
					     char *fs_config_file,
					     time_t fixed_time,
					     const struct ugid_map* uid_map,
					     const struct ugdi_map* gid_map)
{
	return 0;
}
# else
#  include <selinux/selinux.h>
#  include <selinux/label.h>
#  if defined(__ANDROID__)
#   include <selinux/android.h>
#  endif
#  include <private/android_filesystem_config.h>
#  include <private/canned_fs_config.h>
#  include <private/fs_config.h>

errcode_t android_configure_fs(ext2_filsys fs, char *src_dir,
			       char *target_out,
			       char *mountpoint,
			       struct selinux_opt *seopts,
			       unsigned int nopt,
			       char *fs_config_file, time_t fixed_time,
			       const struct ugid_map* uid_map,
			       const struct ugid_map* gid_map);

# endif
#endif /* !ANDROID_PERMS_H */