/*
SSSD - auth utils helpers
Copyright (C) Sumit Bose <simo@redhat.com> 2015
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef __AUTHTOK_UTILS_H__
#define __AUTHTOK_UTILS_H__
#include <talloc.h>
#include "sss_client/sss_cli.h"
/**
* @brief Fill memory buffer with Smartcard authentication blob
*
* @param[in] pin PIN, null terminated
* @param[in] pin_len Length of the PIN, if 0
* strlen() will be called internally
* @param[in] token_name Token name, null terminated
* @param[in] token_name_len Length of the token name, if 0
* strlen() will be called internally
* @param[in] module_name Name of PKCS#11 module, null terminated
* @param[in] module_name_len Length of the module name, if 0
* strlen() will be called internally
* @param[in] key_id Key ID of the certificate
* @param[in] key_id_len Length of the key id of the certificate, if 0
* strlen() will be called internally
* @param[in] buf memory buffer of size buf_len, may be NULL
* @param[in] buf_len size of memory buffer buf
*
* @param[out] _sc_blob len size of the Smartcard authentication blob
*
* @return EOK on success
* EINVAL if input data is not consistent
* EAGAIN if provided buffer is too small, _sc_blob_len
* contains the size needed to store the SC blob
*/
/**
* @brief Fill memory buffer with 2FA blob
*
* @param[in] fa1 First authentication factor, null terminated
* @param[in] fa1_len Length of the first authentication factor, if 0
* strlen() will be called internally
* @param[in] fa2 Second authentication factor, null terminated
* @param[in] fa2_len Length of the second authentication factor, if 0
* strlen() will be called internally
* @param[in] buf memory buffer of size buf_len
* @param[in] buf_len size of memory buffer buf
*
* @param[out] _2fa_blob_len size of the 2FA blob
*
* @return EOK on success
* EINVAL if input data is not consistent
* EAGAIN if provided buffer is too small, _2fa_blob_len
* contains the size needed to store the 2FA blob
*/
/**
* @brief Extract 2FA data from memory buffer
*
* @param[in] mem_ctx Talloc memory context to allocate the 2FA data on
* @param[in] blob Memory buffer containing the 2FA data
* @param[in] blob_len Size of the memory buffer
* @param[out] _fa1 First authentication factor, null terminated
* @param[out] _fa1_len Length of the first authentication factor
* @param[out] _fa2 Second authentication factor, null terminated
* @param[out] _fa2_len Length of the second authentication factor
*
* @return EOK on success
* EINVAL if input data is not consistent
* EINVAL if no memory can be allocated
*/
/**
* @brief Extract SC data from memory buffer
*
* @param[in] mem_ctx Talloc memory context to allocate the 2FA
* data on
* @param[in] blob Memory buffer containing the 2FA data
* @param[in] blob_len Size of the memory buffer
* @param[out] _pin PIN, null terminated
* @param[out] _pin_len Length of the PIN
* @param[out] _token_name Token name, null terminated
* @param[out] _token_name_len Length of the token name
* @param[out] _module_name Name of PKCS#11 module, null terminated
* @param[out] _module_name_len Length of the module name
*
* @return EOK on success
* EINVAL if input data is not consistent
* EINVAL if no memory can be allocated
*/
#endif /* __AUTHTOK_UTILS_H__ */