
- All now include maxscale/cdefs.h as the very first file. - MXS_[BEGIN|END]_DECLS added to all C-headers. Strictly speaking not necessary for private headers, but does not hurt either. - Include guards moved to the very top of the file. - #pragma once added.
57 lines
1.3 KiB
C
57 lines
1.3 KiB
C
#pragma once
|
|
#ifndef _GSSAPI_AUTH_H
|
|
#define _GSSAPI_AUTH_H
|
|
/*
|
|
* 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.
|
|
*/
|
|
|
|
#include <maxscale/cdefs.h>
|
|
#include <stdint.h>
|
|
#include <stddef.h>
|
|
#include <gssapi.h>
|
|
|
|
MXS_BEGIN_DECLS
|
|
|
|
/** 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);
|
|
|
|
MXS_END_DECLS
|
|
|
|
#endif
|