
Authenticators now have a similar mechanism to the `router_options` parameter which enables configurable authentication. The authenticators also have a new initialize entry point which is similar to the createInstance entry point of the filters and routers. The value of `authenticator_options` is passed as a parameter to this function. The return vaulue of the `initialize` entry point is passed to the `create` entry point.
52 lines
1.3 KiB
C
52 lines
1.3 KiB
C
/*
|
|
* Copyright (c) 2016 MariaDB Corporation Ab
|
|
*
|
|
* Use of this software is governed by the Business Source License included
|
|
* in the LICENSE.TXT file and at www.mariadb.com/bsl.
|
|
*
|
|
* Change Date: 2019-07-01
|
|
*
|
|
* On the date above, in accordance with the Business Source License, use
|
|
* of this software will be governed by version 2 or later of the General
|
|
* Public License.
|
|
*/
|
|
|
|
#ifndef _GSSAPI_AUTH_H
|
|
#define _GSSAPI_AUTH_H
|
|
|
|
#include <stdint.h>
|
|
#include <stddef.h>
|
|
#include <gssapi.h>
|
|
|
|
/** Client auth plugin name */
|
|
static const char auth_plugin_name[] = "auth_gssapi_client";
|
|
|
|
/** This is mainly for testing purposes */
|
|
static const char default_princ_name[] = "mariadb/localhost.localdomain";
|
|
|
|
/** GSSAPI authentication states */
|
|
enum gssapi_auth_state
|
|
{
|
|
GSSAPI_AUTH_INIT = 0,
|
|
GSSAPI_AUTH_DATA_SENT,
|
|
GSSAPI_AUTH_OK,
|
|
GSSAPI_AUTH_FAILED
|
|
};
|
|
|
|
/** Common state tracking structure */
|
|
typedef struct gssapi_auth
|
|
{
|
|
enum gssapi_auth_state state;
|
|
uint8_t *principal_name;
|
|
size_t principal_name_len;
|
|
} gssapi_auth_t;
|
|
|
|
/** These functions can used for the `create` and `destroy` entry points */
|
|
void* gssapi_auth_alloc(void *instance);
|
|
void gssapi_auth_free(void *data);
|
|
|
|
/** Report GSSAPI errors */
|
|
void report_error(OM_uint32 major, OM_uint32 minor);
|
|
|
|
#endif
|