Oops, forgot to actually add krb5-plugin.7
I use a shell alias that expands to git add -uv ..., and the -u means new files don't get added :(
This commit is contained in:
192
lib/krb5/krb5-plugin.7
Normal file
192
lib/krb5/krb5-plugin.7
Normal file
@@ -0,0 +1,192 @@
|
||||
.\" Copyright (c) 1999 - 2005 Kungliga Tekniska Högskolan
|
||||
.\" (Royal Institute of Technology, Stockholm, Sweden).
|
||||
.\" All rights reserved.
|
||||
.\"
|
||||
.\" Redistribution and use in source and binary forms, with or without
|
||||
.\" modification, are permitted provided that the following conditions
|
||||
.\" are met:
|
||||
.\"
|
||||
.\" 1. Redistributions of source code must retain the above copyright
|
||||
.\" notice, this list of conditions and the following disclaimer.
|
||||
.\"
|
||||
.\" 2. Redistributions in binary form must reproduce the above copyright
|
||||
.\" notice, this list of conditions and the following disclaimer in the
|
||||
.\" documentation and/or other materials provided with the distribution.
|
||||
.\"
|
||||
.\" 3. Neither the name of the Institute nor the names of its contributors
|
||||
.\" may be used to endorse or promote products derived from this software
|
||||
.\" without specific prior written permission.
|
||||
.\"
|
||||
.\" THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
|
||||
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
|
||||
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
.\" SUCH DAMAGE.
|
||||
.\"
|
||||
.\" $Id$
|
||||
.\"
|
||||
.Dd December 21, 2011
|
||||
.Dt KRB5-PLUGIN 7
|
||||
.Os HEIMDAL
|
||||
.Sh NAME
|
||||
.Nm krb5-plugin
|
||||
.Nd plugin interface for Heimdal
|
||||
.Sh SYNOPSIS
|
||||
.In krb5.h
|
||||
.In krb5/an2ln_plugin.h
|
||||
.In krb5/ccache_plugin.h
|
||||
.In krb5/kuserok_plugin.h
|
||||
.In krb5/locate_plugin.h
|
||||
.In krb5/send_to_kdc_plugin.h
|
||||
.Sh DESCRIPTION
|
||||
Heimdal has a plugin interface. Plugins may be statically linked into
|
||||
Heimdal and registered via the
|
||||
.Xr krb5_plugin_register 3
|
||||
function, or they may be loaded from shared objects present in the
|
||||
Heimdal plugins directories.
|
||||
.Pp
|
||||
Plugins consist of a C struct whose struct name is given in the
|
||||
associated header file, such as, for example,
|
||||
.Va krb5plugin_kuserok_ftable
|
||||
and a pointer to which is either registered via
|
||||
.Xr krb5_plugin_register 3
|
||||
or found in a shared object via a symbol lookup for the symbol name
|
||||
defined in the associated header file (e.g., "kuserok-plugin" for the
|
||||
plugin for
|
||||
.Xr krb5_kuserok 3
|
||||
).
|
||||
.Pp
|
||||
The plugin structs for all plugin types always begin with the same three
|
||||
common fields:
|
||||
.Bl -enum -compact
|
||||
.It
|
||||
.Va minor_version
|
||||
, an int. Plugin minor versions are defined in each plugin type's
|
||||
associated header file.
|
||||
.It
|
||||
.Va init
|
||||
, a pointer to a function with two arguments, a krb5_context and a
|
||||
void **, returning a krb5_error_code. This function will be called to
|
||||
initialize a plugin-specific context in the form of a void * that will
|
||||
be output through the init function's second argument.
|
||||
.It
|
||||
.Va fini
|
||||
, a pointer to a function of one argument, a void *, consisting of the
|
||||
plugin's context to be destroyed, and returning void.
|
||||
.El
|
||||
.Pp
|
||||
Each plugin type must add one or more fields to this struct following
|
||||
the above three. Plugins are typically invoked in no particular order until
|
||||
one succeeds or fails, or all return a special return value such as
|
||||
KRB5_PLUGIN_NO_HANDLE to indicate that the plugin was not applicable. Most
|
||||
plugin types obtain deterministic plugin behavior in spite of the
|
||||
non-deterministic invokation order by, for example, invoking all plugins for
|
||||
each "rule" and passing the rule to each plugin with the expectation that just
|
||||
one plugin will match any given rul.
|
||||
.Pp
|
||||
The krb5-kuserok plugin adds a single field to its struct: a pointer to
|
||||
a function that implements kuserok functionality with the following
|
||||
form:
|
||||
.Bd -literal -offset indent
|
||||
static krb5_error_code
|
||||
kuserok(void *plug_ctx, krb5_context context, const char *rule,
|
||||
unsigned int flags, const char *k5login_dir,
|
||||
const char *luser, krb5_const_principal principal,
|
||||
krb5_boolean *result)
|
||||
.Ed
|
||||
.Pp
|
||||
The
|
||||
.Va luser
|
||||
,
|
||||
.Va principal
|
||||
and
|
||||
.Va result
|
||||
arguments are self-explanatory (see
|
||||
.Xr krb5_kuserok 3
|
||||
). The
|
||||
.Va plug_ctx
|
||||
argument is the context output by the plugin's init function. The
|
||||
.Va rule
|
||||
argument is a kuserok rule from the krb5.conf file; each plugin is invoked once
|
||||
for each rule until all plugins fail or one succeeds. The
|
||||
.Va k5login_dir
|
||||
argument provides an alternative k5login file location, if not NULL.
|
||||
The
|
||||
.Va flags
|
||||
argument indicates whether the plugin may call
|
||||
.Xr krb5_aname_to_lname 3
|
||||
(KUSEROK_ANAME_TO_LNAME_OK), and whether k5login databases are expected to be
|
||||
authoritative (KUSEROK_K5LOGIN_IS_AUTHORITATIVE).
|
||||
.Pp
|
||||
The plugin for
|
||||
.Xr krb5_aname_to_lname 3
|
||||
is named "an2ln" and has a single extra field for the plugin struct:
|
||||
.Bd -literal -offset indent
|
||||
typedef krb5_error_code (*set_result_f)(void *, const char *);
|
||||
|
||||
static krb5_error_code
|
||||
an2ln(void *plug_ctx, krb5_context context, const char *rule,
|
||||
krb5_const_principal aname, set_result_f set_res_f, void *set_res_ctx)
|
||||
.Ed
|
||||
.Pp
|
||||
The arguments for the
|
||||
.Va an2ln
|
||||
plugin are similar to those of the kuserok plugin, but the result, being
|
||||
a string, is set by calling the
|
||||
.Va set_res_f
|
||||
function argument with the
|
||||
.Va set_res_ctx
|
||||
and result string as arguments. The
|
||||
.Va set_res_f
|
||||
function will make a copy of the string.
|
||||
.Sh FILES
|
||||
.Bl -tag -compact
|
||||
.It Pa libdir/plugin/krb5/*
|
||||
Shared objects containing plugins for Heimdal.
|
||||
.El
|
||||
.Sh EXAMPLES
|
||||
.Pp
|
||||
An example an2ln plugin that maps principals to a constant "nouser"
|
||||
follows:
|
||||
.Pp
|
||||
.Bd -literal -offset indent
|
||||
static krb5_error_code
|
||||
nouser_plug_init(krb5_context context, void **ctx)
|
||||
{
|
||||
*ctx = NULL;
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void nouser_plug_fini(void *ctx) { }
|
||||
|
||||
static krb5_error_code
|
||||
nouser_plug_an2ln(void *plug_ctx, krb5_context context,
|
||||
const char *rule,
|
||||
krb5_const_principal aname,
|
||||
set_result_f set_res_f, void *set_res_ctx)
|
||||
{
|
||||
krb5_error_code ret;
|
||||
|
||||
if (strcmp(rule, "NOUSER") != 0)
|
||||
return KRB5_PLUGIN_NO_HANDLE;
|
||||
|
||||
ret = set_res_f(set_res_ctx, "nouser");
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
krb5plugin_an2ln_ftable an2ln = {
|
||||
KRB5_PLUGIN_AN2LN_VERSION_0,
|
||||
nouser_plug_init,
|
||||
nouser_plug_fini,
|
||||
nouser_plug_an2ln,
|
||||
};
|
||||
.Ed
|
||||
.Sh SEE ALSO
|
||||
.Xr krb5_plugin_register 3
|
Reference in New Issue
Block a user