blob: e8284517a83a83ecaf125a80e7bc0f2e2212af78 [file] [log] [blame]
/*
* ra_svn_sasl.h : SASL-related declarations shared between the
* ra_svn and svnserve module
*
* ====================================================================
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
* ====================================================================
*/
#ifndef RA_SVN_SASL_H
#define RA_SVN_SASL_H
/* Keep this include statement at the top of this file. */
#include "private/ra_svn_wrapped_sasl.h"
#include <apr_errno.h>
#include <apr_pools.h>
#include "svn_error.h"
#include "svn_ra_svn.h"
#include "private/svn_atomic.h"
#ifdef __cplusplus
extern "C" {
#endif /* __cplusplus */
/** The application and service name used for sasl_client_new,
* sasl_server_init, and sasl_server_new. */
#define SVN_RA_SVN_SASL_NAME "svn"
extern volatile svn_atomic_t svn_ra_svn__sasl_status;
/* Initialize secprops with default values. */
void
svn_ra_svn__default_secprops(sasl_security_properties_t *secprops);
/* This function is called by the client and the server before
calling sasl_{client, server}_init, pool is used for allocations. */
svn_error_t *
svn_ra_svn__sasl_common_init(apr_pool_t *pool);
/* Sets local_addrport and remote_addrport to a string containing the
remote and local IP address and port, formatted like this: a.b.c.d;port. */
svn_error_t *
svn_ra_svn__get_addresses(const char **local_addrport,
const char **remote_addrport,
svn_ra_svn_conn_t *conn,
apr_pool_t *pool);
/* If a security layer was negotiated during the authentication exchange,
create an encrypted stream for conn. */
svn_error_t *
svn_ra_svn__enable_sasl_encryption(svn_ra_svn_conn_t *conn,
sasl_conn_t *sasl_ctx,
apr_pool_t *pool);
#ifdef __cplusplus
}
#endif /* __cplusplus */
#endif /* RA_SVN_SASL_H */