mirror of
https://gitlab.com/cryptsetup/cryptsetup.git
synced 2025-12-11 10:50:01 +01:00
This patch switches code to SPDX one-line license identifiers according to https://spdx.dev/learn/handling-license-info/ and replacing long license text headers. I used C++ format on the first line in style // SPDX-License-Identifier: <id> except exported libcryptsetup.h, when only C comments are used. The only additional changes are: - switch backend utf8.c from LGPL2+ to LGPL2.1+ (as in systemd) - add some additional formatting lines.
139 lines
3.5 KiB
C
139 lines
3.5 KiB
C
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
/*
|
|
* LUKS - Linux Unified Key Setup, keyslot unlock helpers
|
|
*
|
|
* Copyright (C) 2022-2024 Red Hat, Inc. All rights reserved.
|
|
* Copyright (C) 2022-2024 Ondrej Kozina
|
|
*/
|
|
|
|
#ifndef KEYSLOT_CONTEXT_H
|
|
#define KEYSLOT_CONTEXT_H
|
|
|
|
#include <stdbool.h>
|
|
#include <stdint.h>
|
|
|
|
#include "internal.h"
|
|
|
|
typedef int (*keyslot_context_get_key) (
|
|
struct crypt_device *cd,
|
|
struct crypt_keyslot_context *kc,
|
|
int keyslot,
|
|
int segment,
|
|
struct volume_key **r_vk);
|
|
|
|
typedef int (*keyslot_context_get_volume_key) (
|
|
struct crypt_device *cd,
|
|
struct crypt_keyslot_context *kc,
|
|
int keyslot,
|
|
struct volume_key **r_vk);
|
|
|
|
typedef int (*keyslot_context_get_generic_volume_key) (
|
|
struct crypt_device *cd,
|
|
struct crypt_keyslot_context *kc,
|
|
struct volume_key **r_vk);
|
|
|
|
typedef int (*keyslot_context_get_generic_signed_key) (
|
|
struct crypt_device *cd,
|
|
struct crypt_keyslot_context *kc,
|
|
struct volume_key **r_vk,
|
|
struct volume_key **r_signature);
|
|
|
|
typedef int (*keyslot_context_get_passphrase) (
|
|
struct crypt_device *cd,
|
|
struct crypt_keyslot_context *kc,
|
|
const char **r_passphrase,
|
|
size_t *r_passphrase_size);
|
|
|
|
/* crypt_keyslot_context */
|
|
struct crypt_keyslot_context {
|
|
int type;
|
|
|
|
union {
|
|
struct {
|
|
const char *passphrase;
|
|
size_t passphrase_size;
|
|
} p;
|
|
struct {
|
|
const char *keyfile;
|
|
uint64_t keyfile_offset;
|
|
size_t keyfile_size;
|
|
} kf;
|
|
struct {
|
|
int id;
|
|
const char *type;
|
|
const char *pin;
|
|
size_t pin_size;
|
|
void *usrptr;
|
|
} t;
|
|
struct {
|
|
const char *volume_key;
|
|
size_t volume_key_size;
|
|
} k;
|
|
struct {
|
|
const char *volume_key;
|
|
size_t volume_key_size;
|
|
const char *signature;
|
|
size_t signature_size;
|
|
} ks;
|
|
struct {
|
|
const char *key_description;
|
|
} kr;
|
|
struct {
|
|
const char *key_description;
|
|
} vk_kr;
|
|
} u;
|
|
|
|
int error;
|
|
|
|
char *i_passphrase;
|
|
size_t i_passphrase_size;
|
|
|
|
keyslot_context_get_key get_luks2_key;
|
|
keyslot_context_get_volume_key get_luks1_volume_key;
|
|
keyslot_context_get_volume_key get_luks2_volume_key;
|
|
keyslot_context_get_generic_volume_key get_plain_volume_key;
|
|
keyslot_context_get_generic_volume_key get_bitlk_volume_key;
|
|
keyslot_context_get_generic_volume_key get_fvault2_volume_key;
|
|
keyslot_context_get_generic_signed_key get_verity_volume_key;
|
|
keyslot_context_get_generic_volume_key get_integrity_volume_key;
|
|
keyslot_context_get_passphrase get_passphrase;
|
|
};
|
|
|
|
void crypt_keyslot_context_destroy_internal(struct crypt_keyslot_context *method);
|
|
|
|
void crypt_keyslot_unlock_by_key_init_internal(struct crypt_keyslot_context *kc,
|
|
const char *volume_key,
|
|
size_t volume_key_size);
|
|
|
|
void crypt_keyslot_unlock_by_signed_key_init_internal(struct crypt_keyslot_context *kc,
|
|
const char *volume_key,
|
|
size_t volume_key_size,
|
|
const char *signature,
|
|
size_t signature_size);
|
|
|
|
void crypt_keyslot_unlock_by_passphrase_init_internal(struct crypt_keyslot_context *kc,
|
|
const char *passphrase,
|
|
size_t passphrase_size);
|
|
|
|
void crypt_keyslot_unlock_by_keyfile_init_internal(struct crypt_keyslot_context *kc,
|
|
const char *keyfile,
|
|
size_t keyfile_size,
|
|
uint64_t keyfile_offset);
|
|
|
|
void crypt_keyslot_unlock_by_token_init_internal(struct crypt_keyslot_context *kc,
|
|
int token,
|
|
const char *type,
|
|
const char *pin,
|
|
size_t pin_size,
|
|
void *usrptr);
|
|
|
|
void crypt_keyslot_unlock_by_keyring_internal(struct crypt_keyslot_context *kc,
|
|
const char *key_description);
|
|
|
|
void crypt_keyslot_unlock_by_vk_in_keyring_internal(struct crypt_keyslot_context *kc,
|
|
const char *key_description);
|
|
|
|
const char *keyslot_context_type_string(const struct crypt_keyslot_context *kc);
|
|
|
|
#endif /* KEYSLOT_CONTEXT_H */
|