2007-10-17 10:29:46 +04:00
|
|
|
/* Definitions for key type implementations
|
|
|
|
*
|
|
|
|
* Copyright (C) 2007 Red Hat, Inc. All Rights Reserved.
|
|
|
|
* Written by David Howells (dhowells@redhat.com)
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public Licence
|
|
|
|
* as published by the Free Software Foundation; either version
|
|
|
|
* 2 of the Licence, or (at your option) any later version.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _LINUX_KEY_TYPE_H
|
|
|
|
#define _LINUX_KEY_TYPE_H
|
|
|
|
|
|
|
|
#include <linux/key.h>
|
2012-07-23 18:37:31 +04:00
|
|
|
#include <linux/errno.h>
|
2007-10-17 10:29:46 +04:00
|
|
|
|
|
|
|
#ifdef CONFIG_KEYS
|
|
|
|
|
|
|
|
/*
|
|
|
|
* key under-construction record
|
|
|
|
* - passed to the request_key actor if supplied
|
|
|
|
*/
|
|
|
|
struct key_construction {
|
|
|
|
struct key *key; /* key being constructed */
|
|
|
|
struct key *authkey;/* authorisation for key being constructed */
|
|
|
|
};
|
|
|
|
|
2012-09-13 16:06:29 +04:00
|
|
|
/*
|
|
|
|
* Pre-parsed payload, used by key add, update and instantiate.
|
|
|
|
*
|
|
|
|
* This struct will be cleared and data and datalen will be set with the data
|
|
|
|
* and length parameters from the caller and quotalen will be set from
|
|
|
|
* def_datalen from the key type. Then if the preparse() op is provided by the
|
|
|
|
* key type, that will be called. Then the struct will be passed to the
|
|
|
|
* instantiate() or the update() op.
|
|
|
|
*
|
|
|
|
* If the preparse() op is given, the free_preparse() op will be called to
|
|
|
|
* clear the contents.
|
|
|
|
*/
|
|
|
|
struct key_preparsed_payload {
|
|
|
|
char *description; /* Proposed key description (or NULL) */
|
|
|
|
void *type_data[2]; /* Private key-type data */
|
|
|
|
void *payload; /* Proposed payload */
|
|
|
|
const void *data; /* Raw data */
|
|
|
|
size_t datalen; /* Raw datalen */
|
|
|
|
size_t quotalen; /* Quota length for proposed payload */
|
2013-08-30 19:07:37 +04:00
|
|
|
bool trusted; /* True if key is trusted */
|
2012-09-13 16:06:29 +04:00
|
|
|
};
|
|
|
|
|
2007-10-17 10:29:46 +04:00
|
|
|
typedef int (*request_key_actor_t)(struct key_construction *key,
|
|
|
|
const char *op, void *aux);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* kernel managed key type definition
|
|
|
|
*/
|
|
|
|
struct key_type {
|
|
|
|
/* name of the type */
|
|
|
|
const char *name;
|
|
|
|
|
|
|
|
/* default payload length for quota precalculation (optional)
|
|
|
|
* - this can be used instead of calling key_payload_reserve(), that
|
|
|
|
* function only needs to be called if the real datalen is different
|
|
|
|
*/
|
|
|
|
size_t def_datalen;
|
|
|
|
|
2013-09-24 13:35:15 +04:00
|
|
|
/* Default key search algorithm. */
|
|
|
|
unsigned def_lookup_type;
|
|
|
|
#define KEYRING_SEARCH_LOOKUP_DIRECT 0x0000 /* Direct lookup by description. */
|
|
|
|
#define KEYRING_SEARCH_LOOKUP_ITERATE 0x0001 /* Iterative search. */
|
|
|
|
|
2011-03-07 18:05:59 +03:00
|
|
|
/* vet a description */
|
|
|
|
int (*vet_description)(const char *description);
|
|
|
|
|
2012-09-13 16:06:29 +04:00
|
|
|
/* Preparse the data blob from userspace that is to be the payload,
|
|
|
|
* generating a proposed description and payload that will be handed to
|
|
|
|
* the instantiate() and update() ops.
|
|
|
|
*/
|
|
|
|
int (*preparse)(struct key_preparsed_payload *prep);
|
|
|
|
|
|
|
|
/* Free a preparse data structure.
|
|
|
|
*/
|
|
|
|
void (*free_preparse)(struct key_preparsed_payload *prep);
|
|
|
|
|
2007-10-17 10:29:46 +04:00
|
|
|
/* instantiate a key of this type
|
|
|
|
* - this method should call key_payload_reserve() to determine if the
|
|
|
|
* user's quota will hold the payload
|
|
|
|
*/
|
2012-09-13 16:06:29 +04:00
|
|
|
int (*instantiate)(struct key *key, struct key_preparsed_payload *prep);
|
2007-10-17 10:29:46 +04:00
|
|
|
|
|
|
|
/* update a key of this type (optional)
|
|
|
|
* - this method should call key_payload_reserve() to recalculate the
|
|
|
|
* quota consumption
|
|
|
|
* - the key must be locked against read when modifying
|
|
|
|
*/
|
2012-09-13 16:06:29 +04:00
|
|
|
int (*update)(struct key *key, struct key_preparsed_payload *prep);
|
2007-10-17 10:29:46 +04:00
|
|
|
|
|
|
|
/* match a key against a description */
|
|
|
|
int (*match)(const struct key *key, const void *desc);
|
|
|
|
|
|
|
|
/* clear some of the data from a key on revokation (optional)
|
|
|
|
* - the key's semaphore will be write-locked by the caller
|
|
|
|
*/
|
|
|
|
void (*revoke)(struct key *key);
|
|
|
|
|
|
|
|
/* clear the data from a key (optional) */
|
|
|
|
void (*destroy)(struct key *key);
|
|
|
|
|
|
|
|
/* describe a key */
|
|
|
|
void (*describe)(const struct key *key, struct seq_file *p);
|
|
|
|
|
|
|
|
/* read a key's data (optional)
|
|
|
|
* - permission checks will be done by the caller
|
|
|
|
* - the key's semaphore will be readlocked by the caller
|
|
|
|
* - should return the amount of data that could be read, no matter how
|
|
|
|
* much is copied into the buffer
|
|
|
|
* - shouldn't do the copy if the buffer is NULL
|
|
|
|
*/
|
|
|
|
long (*read)(const struct key *key, char __user *buffer, size_t buflen);
|
|
|
|
|
|
|
|
/* handle request_key() for this type instead of invoking
|
|
|
|
* /sbin/request-key (optional)
|
|
|
|
* - key is the key to instantiate
|
|
|
|
* - authkey is the authority to assume when instantiating this key
|
|
|
|
* - op is the operation to be done, usually "create"
|
|
|
|
* - the call must not return until the instantiation process has run
|
|
|
|
* its course
|
|
|
|
*/
|
|
|
|
request_key_actor_t request_key;
|
|
|
|
|
|
|
|
/* internal fields */
|
|
|
|
struct list_head link; /* link in types list */
|
2011-11-16 15:15:54 +04:00
|
|
|
struct lock_class_key lock_class; /* key->sem lock class */
|
2007-10-17 10:29:46 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
extern struct key_type key_type_keyring;
|
|
|
|
|
|
|
|
extern int register_key_type(struct key_type *ktype);
|
|
|
|
extern void unregister_key_type(struct key_type *ktype);
|
|
|
|
|
|
|
|
extern int key_payload_reserve(struct key *key, size_t datalen);
|
|
|
|
extern int key_instantiate_and_link(struct key *key,
|
|
|
|
const void *data,
|
|
|
|
size_t datalen,
|
|
|
|
struct key *keyring,
|
|
|
|
struct key *instkey);
|
2011-03-07 18:06:09 +03:00
|
|
|
extern int key_reject_and_link(struct key *key,
|
2007-10-17 10:29:46 +04:00
|
|
|
unsigned timeout,
|
2011-03-07 18:06:09 +03:00
|
|
|
unsigned error,
|
2007-10-17 10:29:46 +04:00
|
|
|
struct key *keyring,
|
|
|
|
struct key *instkey);
|
|
|
|
extern void complete_request_key(struct key_construction *cons, int error);
|
|
|
|
|
2011-03-07 18:06:09 +03:00
|
|
|
static inline int key_negate_and_link(struct key *key,
|
|
|
|
unsigned timeout,
|
|
|
|
struct key *keyring,
|
|
|
|
struct key *instkey)
|
|
|
|
{
|
|
|
|
return key_reject_and_link(key, timeout, ENOKEY, keyring, instkey);
|
|
|
|
}
|
|
|
|
|
2007-10-17 10:29:46 +04:00
|
|
|
#endif /* CONFIG_KEYS */
|
|
|
|
#endif /* _LINUX_KEY_TYPE_H */
|