/* * Asterisk -- An open source telephony toolkit. * * Copyright (C) 2020, Sangoma Technologies Corporation * * Kevin Harwell * * See http://www.asterisk.org for more information about * the Asterisk project. Please do not directly contact * any of the maintainers of this project for assistance; * the project provides a web site, mailing lists and IRC * channels for your use. * * This program is free software, distributed under the terms of * the GNU General Public License Version 2. See the LICENSE file * at the top of the source tree. */ #ifndef _STIR_SHAKEN_CERTIFICATE_H #define _STIR_SHAKEN_CERTIFICATE_H #include struct ast_sorcery; struct stir_shaken_certificate; /*! * \brief Get a STIR/SHAKEN certificate by caller ID number * * \param caller_id_number The caller ID number * * \retval NULL if not found * \return The certificate on success */ struct stir_shaken_certificate *stir_shaken_certificate_get_by_caller_id_number(const char *caller_id_number); /*! * \brief Get the public key URL associated with a certificate * * \param cert The certificate to get the public key URL from * * \retval NULL on failure * \return The public key URL on success */ const char *stir_shaken_certificate_get_public_cert_url(struct stir_shaken_certificate *cert); /*! * \brief Get the attestation level associated with a certificate * * \param cert The certificate * * \retval NULL on failure * \retval The attestation on success */ const char *stir_shaken_certificate_get_attestation(struct stir_shaken_certificate *cert); /*! * \brief Get the private key associated with a certificate * * \param cert The certificate to get the private key from * * \retval NULL on failure * \return The private key on success */ EVP_PKEY *stir_shaken_certificate_get_private_key(struct stir_shaken_certificate *cert); #ifdef TEST_FRAMEWORK /*! * \brief Clean up the certificate and mappings set up in test_stir_shaken_init * * \param caller_id_number The caller ID of the certificate to clean up * * \retval non-zero on failure * \retval 0 on success */ int test_stir_shaken_cleanup_cert(const char *caller_id_number); /*! * \brief Initialize a test certificate through wizard mappings * * \note test_stir_shaken_cleanup should be called when done with this certificate * * \param caller_id_number The caller ID of the certificate to create * \param file_path The path to the private key for this certificate * * \retval non-zero on failure * \retval 0 on success */ int test_stir_shaken_create_cert(const char *caller_id_number, const char *file_path); #endif /* TEST_FRAMEWORK */ /*! * \brief Load time initialization for the stir/shaken 'certificate' configuration * * \retval 0 on success * \retval -1 on error */ int stir_shaken_certificate_load(void); /*! * \brief Unload time cleanup for the stir/shaken 'certificate' configuration * * \retval 0 on success * \retval -1 on error */ int stir_shaken_certificate_unload(void); #endif /* _STIR_SHAKEN_CERTIFICATE_H */