File: bolt-sysfs.h

package info (click to toggle)
bolt 0.7-2
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 1,396 kB
  • sloc: ansic: 21,784; python: 1,574; xml: 426; sh: 25; makefile: 13
file content (82 lines) | stat: -rw-r--r-- 2,757 bytes parent folder | download
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/*
 * Copyright © 2017 Red Hat, Inc
 *
 * This program is free software; you can redistribute it and/or
 * modify it 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 (at your option) any later version.
 *
 * This library 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
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library. If not, see <http://www.gnu.org/licenses/>.
 *
 * Authors:
 *       Christian J. Kellner <christian@kellner.me>
 */

#pragma once

#include "bolt-enums.h"

#include <glib.h>

struct udev;
struct udev_device;

G_BEGIN_DECLS

typedef enum BoltStatTime {
  BOLT_ST_ATIME,
  BOLT_ST_CTIME,
  BOLT_ST_MTIME
} BoltStatTime;

gint64               bolt_sysfs_device_get_time (struct udev_device *udev,
                                                 BoltStatTime        st);

gboolean             bolt_sysfs_device_is_domain (struct udev_device *udev,
                                                  GError            **error);

struct udev_device * bolt_sysfs_domain_for_device (struct udev_device  *udev,
                                                   struct udev_device **host);

BoltSecurity         bolt_sysfs_security_for_device (struct udev_device *udev,
                                                     GError            **error);

int                  bolt_sysfs_count_domains (struct udev *udev,
                                               GError     **error);
typedef struct _BoltDevInfo
{

  /* always included  */
  gint   authorized;
  gssize keysize;
  gint   boot;

  /* if 'full' is true the rest is valid */
  gboolean    full;
  gint64      ctim;
  const char *syspath;
  const char *parent;       /* the uid */

} BoltDevInfo;

gboolean             bolt_sysfs_info_for_device (struct udev_device *udev,
                                                 gboolean            full,
                                                 BoltDevInfo        *info,
                                                 GError            **error);

gboolean             bolt_sysfs_read_boot_acl (struct udev_device *udev,
                                               GStrv              *out,
                                               GError            **error);

gboolean             bolt_sysfs_write_boot_acl (const char *device,
                                                GStrv       acl,
                                                GError    **error);


G_END_DECLS