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
|