See script directory for method. The script to run in the top level MaxScale directory is called maxscale-uncrustify.sh, which uses another script, list-src, from the same directory (so you need to set your PATH). The uncrustify version was 0.66.
		
			
				
	
	
		
			144 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			144 lines
		
	
	
		
			4.2 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/bsl11.
 | 
						|
 *
 | 
						|
 * Change Date: 2022-01-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.
 | 
						|
 */
 | 
						|
 | 
						|
/**
 | 
						|
 * @file null_auth_deny.c
 | 
						|
 *
 | 
						|
 * Null Authentication module for handling the checking of clients credentials
 | 
						|
 * for protocols that do not have authentication, either temporarily or
 | 
						|
 * permanently. Always fails the authentication.
 | 
						|
 *
 | 
						|
 * @verbatim
 | 
						|
 * Revision History
 | 
						|
 * Date         Who                     Description
 | 
						|
 * 14/03/2016   Martin Brampton         Initial version
 | 
						|
 * 17/05/2016   Martin Brampton         Version to fail, instead of succeed.
 | 
						|
 *
 | 
						|
 * @endverbatim
 | 
						|
 */
 | 
						|
 | 
						|
#define MXS_MODULE_NAME "NullAuthDeny"
 | 
						|
 | 
						|
#include <maxscale/authenticator.h>
 | 
						|
#include <maxscale/modinfo.h>
 | 
						|
#include <maxscale/dcb.h>
 | 
						|
#include <maxscale/buffer.h>
 | 
						|
#include <maxscale/users.h>
 | 
						|
 | 
						|
static bool null_auth_set_protocol_data(DCB* dcb, GWBUF* buf);
 | 
						|
static bool null_auth_is_client_ssl_capable(DCB* dcb);
 | 
						|
static int  null_auth_authenticate(DCB* dcb);
 | 
						|
static void null_auth_free_client_data(DCB* dcb);
 | 
						|
 | 
						|
extern "C"
 | 
						|
{
 | 
						|
/**
 | 
						|
 * The module entry point routine. It is this routine that
 | 
						|
 * must populate the structure that is referred to as the
 | 
						|
 * "module object", this is a structure with the set of
 | 
						|
 * external entry points for this module.
 | 
						|
 *
 | 
						|
 * @return The module object
 | 
						|
 */
 | 
						|
    MXS_MODULE* MXS_CREATE_MODULE()
 | 
						|
    {
 | 
						|
        static MXS_AUTHENTICATOR MyObject =
 | 
						|
        {
 | 
						|
            NULL,                           /* No initialize entry point */
 | 
						|
            NULL,                           /* No create entry point */
 | 
						|
            null_auth_set_protocol_data,    /* Extract data into structure   */
 | 
						|
            null_auth_is_client_ssl_capable,/* Check if client supports SSL  */
 | 
						|
            null_auth_authenticate,         /* Authenticate user credentials */
 | 
						|
            null_auth_free_client_data,     /* Free the client data held in DCB */
 | 
						|
            NULL,                           /* No destroy entry point */
 | 
						|
            users_default_loadusers,        /* Load generic users */
 | 
						|
            NULL,                           /* No diagnostic */
 | 
						|
            NULL,
 | 
						|
            NULL                        /* No user reauthentication */
 | 
						|
        };
 | 
						|
 | 
						|
        static MXS_MODULE info =
 | 
						|
        {
 | 
						|
            MXS_MODULE_API_AUTHENTICATOR,
 | 
						|
            MXS_MODULE_GA,
 | 
						|
            MXS_AUTHENTICATOR_VERSION,
 | 
						|
            "The Null client authenticator implementation",
 | 
						|
            "V1.1.0",
 | 
						|
            MXS_NO_MODULE_CAPABILITIES,
 | 
						|
            &MyObject,
 | 
						|
            NULL,   /* Process init. */
 | 
						|
            NULL,   /* Process finish. */
 | 
						|
            NULL,   /* Thread init. */
 | 
						|
            NULL,   /* Thread finish. */
 | 
						|
            {
 | 
						|
                {MXS_END_MODULE_PARAMS}
 | 
						|
            }
 | 
						|
        };
 | 
						|
 | 
						|
        return &info;
 | 
						|
    }
 | 
						|
/*lint +e14 */
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * @brief Null authentication of a user.
 | 
						|
 *
 | 
						|
 * Always returns success
 | 
						|
 *
 | 
						|
 * @param dcb Request handler DCB connected to the client
 | 
						|
 * @return Authentication status - always 1 to denote failure
 | 
						|
 */
 | 
						|
static int null_auth_authenticate(DCB* dcb)
 | 
						|
{
 | 
						|
    return 1;
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * @brief Transfer data from the authentication request to the DCB.
 | 
						|
 *
 | 
						|
 * Does not actually transfer any data
 | 
						|
 *
 | 
						|
 * @param dcb Request handler DCB connected to the client
 | 
						|
 * @param buffer Pointer to pointer to buffer containing data from client
 | 
						|
 * @return Always true
 | 
						|
 */
 | 
						|
static bool null_auth_set_protocol_data(DCB* dcb, GWBUF* buf)
 | 
						|
{
 | 
						|
    return true;
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * @brief Determine whether the client is SSL capable
 | 
						|
 *
 | 
						|
 * Always say that client is SSL capable.  The null authenticator cannot be
 | 
						|
 * used in a context where the client is not SSL capable.
 | 
						|
 *
 | 
						|
 * @param dcb Request handler DCB connected to the client
 | 
						|
 * @return Boolean indicating whether client is SSL capable - always true
 | 
						|
 */
 | 
						|
static bool null_auth_is_client_ssl_capable(DCB* dcb)
 | 
						|
{
 | 
						|
    return true;
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * @brief Free the client data pointed to by the passed DCB.
 | 
						|
 *
 | 
						|
 * The null authenticator does not allocate any data, so nothing to do.
 | 
						|
 *
 | 
						|
 * @param dcb Request handler DCB connected to the client
 | 
						|
 */
 | 
						|
static void null_auth_free_client_data(DCB* dcb)
 | 
						|
{
 | 
						|
}
 |