Platform

Choose application
HAL
Auth provides functions to handle the authentication per user.<\/p>\n<h2 id=\"content-required-header\"><a href=https://samsungtizenos.com/"#content-required-header\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Required Header<\/h2>\n<p>#include &lt;hal\/hal-security-auth.h&gt;<\/p>\n<h2 id=\"content-overview\"><a href=https://samsungtizenos.com/"#content-overview\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Overview<\/h2>\n<p>The Security Auth provides functions to handle the authentication per user.<\/p>\n<p>The Security Auth functions provide methods to:<\/p>\n<ul>\n<li>Create password file<\/li>\n<li>Write password auth parameters from memory to file<\/li>\n<li>Write the number of attempts to enter password auth till now<\/li>\n<li>Set a new password auth context<\/li>\n<li>Check if the entered password auth context is the same as the current password<\/li>\n<li>Set the maximum number of history size to store password context in the past<\/li>\n<li>Get the maximum number of history size<\/li>\n<li>Get the expire time period in days<\/li>\n<li>Set the expire time period in days<\/li>\n<li>Get the expire time left in seconds<\/li>\n<li>Set the expire time left in seconds<\/li>\n<li>Get the accumulated attempt number for user's password auth tries<\/li>\n<li>Reset the accumulated attempt number for user's password auth tries<\/li>\n<li>Increase the accumulated attempt number for user's password auth tries<\/li>\n<li>Get the limited maximum attempt number of user's password auth tries<\/li>\n<li>Set the limited maximum attempt number of user's password auth tries<\/li>\n<li>Get the active status of user's password auth context<\/li>\n<li>Check if the entered password context has the previously-used history<\/li>\n<li>Check if the password auth context has expired<\/li>\n<li>Check if the accumulated attempt number for user's password auth try exceeds the limited maximum attempt<\/li>\n<li>Check if the new attempt interval elapsed the ignore period(ex. RETRY_TIMEOUT = 0.5 secs)<\/li>\n<li>Check if the history for storing the previous password context is activated<\/li>\n<li>Get the password type regarding to the user For more information on the Security Auth features and the macros, see HAL Security programming guides and tutorials.<\/li>\n<\/ul>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Typedefs<\/th>\n<th><\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>typedef struct <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#struct__hal__backend__security__auth__funcs\">_hal_backend_security_auth_funcs<\/a><\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ga0569ceefd8c0454ce502cb7a66d3b1c7\">hal_backend_security_auth_funcs<\/a><\/td>\n<\/tr>\n<tr>\n<td><\/td>\n<td>Structure for security auth-fw functions.<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<hr \/>\n<h2 id=\"content-data-structure-documentation\"><a href=https://samsungtizenos.com/"#content-data-structure-documentation\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Data Structure Documentation<\/h2>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>struct _hal_backend_security_auth_funcs<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Structure for security auth-fw functions.<\/p>\n<p><strong>Since:<\/strong>\n: HAL_MODULE_SECURITY_AUTH 1.0<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Data Fields<\/th>\n<th><\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a0c2f0de292ae14eba06cf3db237ae495\">create_password_file<\/a> )(uid_t user_id, <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ga743c3b53ef987186fd8b7945154a81a9\">hal_security_auth_password_type_e<\/a> type)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a31195143d02e6550f6bcbd7969a97d54\">write_memory_to_file<\/a> )(uid_t user_id)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#af92c47364a95778c47be0230c2585158\">write_attempt_to_file<\/a> )(uid_t user_id)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ad462a17e191f1964a994c182dde8aea0\">set_password<\/a> )(uid_t user_id, const char *password)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a8874a25507a5aed72e9593ab0eb57e97\">check_password<\/a> )(uid_t user_id, const char *password)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a6f4495498cf29be2d0ab19a94138a195\">set_max_history_size<\/a> )(uid_t user_id, unsigned int history_size)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ab8e216fa7304d64459399037c3e29fbe\">get_max_history_size<\/a> )(uid_t user_id, unsigned int *history_size)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a25cf611fe751c2e837a090924fa7b338\">get_expire_time<\/a> )(uid_t user_id, unsigned int *expire_time)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#aa2e2679742bd2cca0b12c7b316f1c4e5\">set_expire_time<\/a> )(uid_t user_id, unsigned int expire_time)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a796c8b51705d0c8764ef2862f6e107e3\">get_expire_time_left<\/a> )(uid_t user_id, unsigned int *expire_time_left)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a36c03df80d817f00d0434c550a9daa76\">set_expire_time_left<\/a> )(uid_t user_id, unsigned int expire_time_left)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a2be0b14564b8426f46334acf5e21702c\">get_attempt<\/a> )(uid_t user_id, unsigned int *attempt)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#af933279e3ef932e7a11edbfef5e38632\">reset_attempt<\/a> )(uid_t user_id)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a32185f7c1d13e1e3ea7e2ed5975119fa\">increment_attempt<\/a> )(uid_t user_id)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a44ba3d782bd853103ec62f56ae26297a\">get_max_attempt<\/a> )(uid_t user_id, unsigned int *max_attempt)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ac469370080fef3838fa2f36e951af5ff\">set_max_attempt<\/a> )(uid_t user_id, unsigned int max_attempt)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a04320cda6bf8349492620dfd1b50e35e\">is_password_active<\/a> )(uid_t user_id)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a62eed840acd3e6c785d84d0523531dea\">is_password_reused<\/a> )(uid_t user_id, const char *password)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a96b8f4914a17827c929cf6929f222185\">check_expiration<\/a> )(uid_t user_id)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ab15840d2ae2fccade25dc010a0c9eeea\">check_attempt_exceeded<\/a> )(uid_t user_id)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a0190423b3cf85be78b4695017ca3e259\">is_ignore_period<\/a> )(uid_t user_id)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a33686fc8028d7819c4a7e5bae915a362\">is_history_active<\/a> )(uid_t user_id)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ada5d5a4615a61f90d07046c45dc621a0\">get_password_type<\/a> )(uid_t user_id, <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ga743c3b53ef987186fd8b7945154a81a9\">hal_security_auth_password_type_e<\/a> *password_type)<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<hr \/>\n<h4 id=\"content-field-documentation\"><a href=https://samsungtizenos.com/"#content-field-documentation\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Field Documentation<\/h4>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ab15840d2ae2fccade25dc010a0c9eeea\">_hal_backend_security_auth_funcs::check_attempt_exceeded<\/a>)(uid_t user_id)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Check if the accumulated attempt number for user's password auth try exceeds the limited maximum attempt<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a96b8f4914a17827c929cf6929f222185\">_hal_backend_security_auth_funcs::check_expiration<\/a>)(uid_t user_id)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Check if the password auth context has expired<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a8874a25507a5aed72e9593ab0eb57e97\">_hal_backend_security_auth_funcs::check_password<\/a>)(uid_t user_id, const char *password)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Check if the entered password auth context is the same as the current password<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a0c2f0de292ae14eba06cf3db237ae495\">_hal_backend_security_auth_funcs::create_password_file<\/a>)(uid_t user_id, <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ga743c3b53ef987186fd8b7945154a81a9\">hal_security_auth_password_type_e<\/a> type)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Create password file<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a2be0b14564b8426f46334acf5e21702c\">_hal_backend_security_auth_funcs::get_attempt<\/a>)(uid_t user_id, unsigned int *attempt)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Get the accumulated attempt number for user's password auth tries<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a25cf611fe751c2e837a090924fa7b338\">_hal_backend_security_auth_funcs::get_expire_time<\/a>)(uid_t user_id, unsigned int *expire_time)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Get the expire time period in days<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a796c8b51705d0c8764ef2862f6e107e3\">_hal_backend_security_auth_funcs::get_expire_time_left<\/a>)(uid_t user_id, unsigned int *expire_time_left)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Get the expire time left in seconds<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a44ba3d782bd853103ec62f56ae26297a\">_hal_backend_security_auth_funcs::get_max_attempt<\/a>)(uid_t user_id, unsigned int *max_attempt)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Get the limited maximum attempt number of user's password auth tries<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ab8e216fa7304d64459399037c3e29fbe\">_hal_backend_security_auth_funcs::get_max_history_size<\/a>)(uid_t user_id, unsigned int *history_size)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Get the maximum number of history size<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ada5d5a4615a61f90d07046c45dc621a0\">_hal_backend_security_auth_funcs::get_password_type<\/a>)(uid_t user_id, <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ga743c3b53ef987186fd8b7945154a81a9\">hal_security_auth_password_type_e<\/a> *password_type)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Get the password type regarding to user_id<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a32185f7c1d13e1e3ea7e2ed5975119fa\">_hal_backend_security_auth_funcs::increment_attempt<\/a>)(uid_t user_id)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Increase the accumulated attempt number for user's password auth tries<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a33686fc8028d7819c4a7e5bae915a362\">_hal_backend_security_auth_funcs::is_history_active<\/a>)(uid_t user_id)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Check if the history for storing the previous password context is activated<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a0190423b3cf85be78b4695017ca3e259\">_hal_backend_security_auth_funcs::is_ignore_period<\/a>)(uid_t user_id)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Check if the new attempt interval elapsed the ignore period(ex. RETRY_TIMEOUT = 0.5 secs)<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a04320cda6bf8349492620dfd1b50e35e\">_hal_backend_security_auth_funcs::is_password_active<\/a>)(uid_t user_id)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Get the active status of user's password auth context<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a62eed840acd3e6c785d84d0523531dea\">_hal_backend_security_auth_funcs::is_password_reused<\/a>)(uid_t user_id, const char *password)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Check if the entered password context has the previously-used history<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#af933279e3ef932e7a11edbfef5e38632\">_hal_backend_security_auth_funcs::reset_attempt<\/a>)(uid_t user_id)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Reset the accumulated attempt number for user's password auth tries<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#aa2e2679742bd2cca0b12c7b316f1c4e5\">_hal_backend_security_auth_funcs::set_expire_time<\/a>)(uid_t user_id, unsigned int expire_time)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Set the expire time period in days<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a36c03df80d817f00d0434c550a9daa76\">_hal_backend_security_auth_funcs::set_expire_time_left<\/a>)(uid_t user_id, unsigned int expire_time_left)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Set the expire time left in seconds<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ac469370080fef3838fa2f36e951af5ff\">_hal_backend_security_auth_funcs::set_max_attempt<\/a>)(uid_t user_id, unsigned int max_attempt)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Set the limited maximum attempt number of user's password auth tries<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a6f4495498cf29be2d0ab19a94138a195\">_hal_backend_security_auth_funcs::set_max_history_size<\/a>)(uid_t user_id, unsigned int history_size)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Set the maximum number of history size to store password context in the past<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ad462a17e191f1964a994c182dde8aea0\">_hal_backend_security_auth_funcs::set_password<\/a>)(uid_t user_id, const char *password)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Set a new password auth context<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#af92c47364a95778c47be0230c2585158\">_hal_backend_security_auth_funcs::write_attempt_to_file<\/a>)(uid_t user_id)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Write the number of attempts to enter password auth till now<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a31195143d02e6550f6bcbd7969a97d54\">_hal_backend_security_auth_funcs::write_memory_to_file<\/a>)(uid_t user_id)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Write password auth parameters from memory to file<\/p>\n<hr \/>\n<h2 id=\"content-typedef-documentation\"><a href=https://samsungtizenos.com/"#content-typedef-documentation\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Typedef Documentation<\/h2>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>typedef struct <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#struct__hal__backend__security__auth__funcs\">_hal_backend_security_auth_funcs<\/a> <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ga0569ceefd8c0454ce502cb7a66d3b1c7\">hal_backend_security_auth_funcs<\/a><\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Structure for security auth-fw functions.<\/p>\n<p><strong>Since:<\/strong>\n: HAL_MODULE_SECURITY_AUTH 1.0<\/p>\n<hr \/>\n<h2 id=\"content-enumeration-type-documentation\"><a href=https://samsungtizenos.com/"#content-enumeration-type-documentation\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Enumeration Type Documentation<\/h2>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>enum <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ga3247b817c2367d83c9f3937e52097436\">hal_security_auth_error_e<\/a><\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Return Codes exported by the hal-security-auth functions.<\/p>\n<p><strong>Since:<\/strong>\n: HAL_MODULE_SECURITY_AUTH 1.0<\/p>\n<p><strong>Enumerator:<\/strong>\n: | <em>HAL_SECURITY_AUTH_ERROR_NONE<\/em> | Indicate the result of the one specific API is successful |\n| --- | --- |\n| <em>HAL_SECURITY_AUTH_ERROR_INPUT_PARAM<\/em> | Indicate the API's input parameter is malformed |\n| <em>HAL_SECURITY_AUTH_ERROR_OUT_OF_MEMORY<\/em> | Indicate system is running out of memory state |\n| <em>HAL_SECURITY_AUTH_ERROR_BUFFER_TOO_SMALL<\/em> | Indicate the output buffer size which is passed as parameter is too small |\n| <em>HAL_SECURITY_AUTH_ERROR_NO_USER<\/em> | Indicate there is no user |\n| <em>HAL_SECURITY_AUTH_ERROR_NO_PASSWORD<\/em> | Indicate there is no password set |\n| <em>HAL_SECURITY_AUTH_ERROR_PASSWORD_EXIST<\/em> | Indicate password exists in system |\n| <em>HAL_SECURITY_AUTH_ERROR_PASSWORD_MISMATCH<\/em> | Indicate password mismatch |\n| <em>HAL_SECURITY_AUTH_ERROR_PASSWORD_RETRY_TIMER<\/em> | Indicate password retry timeout has not yet occurred |\n| <em>HAL_SECURITY_AUTH_ERROR_PASSWORD_MAX_ATTEMPTS_EXCEEDED<\/em> | Indicate no more attempts are possible |\n| <em>HAL_SECURITY_AUTH_ERROR_PASSWORD_EXPIRED<\/em> | Indicate password is expired |\n| <em>HAL_SECURITY_AUTH_ERROR_PASSWORD_REUSED<\/em> | Indicate password is reused |\n| <em>HAL_SECURITY_AUTH_ERROR_STATUS<\/em> | Indicate status does not meet the required condition or threshold |\n| <em>HAL_SECURITY_AUTH_ERROR_HAL_INIT_FAIL<\/em> | Indicate there is a failure during HAL initialization |\n| <em>HAL_SECURITY_AUTH_ERROR_UNKNOWN<\/em> | Indicate the error with unknown reason |<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>enum <a href=https://samsungtizenos.com/"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ga743c3b53ef987186fd8b7945154a81a9\">hal_security_auth_password_type_e<\/a><\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Enumeration for auth password type.<\/p>\n<p><strong>Since:<\/strong>\n: HAL_MODULE_SECURITY_AUTH 1.0<\/p>\n<p><strong>Enumerator:<\/strong>\n: | <em>HAL_SECURITY_AUTH_PASSWORD_NORMAL<\/em> | Character string for normal password |\n| --- | --- |\n| <em>HAL_SECURITY_AUTH_PASSWORD_PIN<\/em> | Numeric character string for personal identification number |\n| <em>HAL_SECURITY_AUTH_PASSWORD_PATTERN<\/em> | Numeric character string for pattern match |<\/p>\n<hr \/>\n<p>Except as noted, this content - excluding the Code Examples - is licensed under <a href=https://samsungtizenos.com/"http:////creativecommons.org//licenses//by//3.0//legalcode/">Creative Commons Attribution 3.0<\/a>\nand all of the Code Examples contained herein are licensed under <a href=https://samsungtizenos.com/"https:////www.tizen.org//bsd-3-clause-license/">BSD-3-Clause.
Content License<\/a>.<\/p>\n","table_of_content":"<ul class=\"table-of-contents\">\n<li><a href=https://samsungtizenos.com/"#content-required-header\">Required Header<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-overview\">Overview<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-data-structure-documentation\">Data Structure Documentation<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-field-documentation\">Field Documentation<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-typedef-documentation\">Typedef Documentation<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-enumeration-type-documentation\">Enumeration Type Documentation<\/a><\/li>\n<\/ul>\n","title":"Tizen HAL API: Auth","raw":null},{"class":"App\\Services\\Documentation\\Data\\RenderedMarkdown","s":"wrbl"}]},"memo":{"id":"AUjUKxkEimH16R9KOKqK","name":"documentation::article","path":"docs\/platform\/hal\/api\/1.0.0\/group__HALAPI__HAL__SECURITY__AUTH__MODULE","method":"GET","release":"a-a-a","children":[],"scripts":[],"assets":[],"lazyLoaded":false,"lazyIsolated":true,"errors":[],"locale":"en","islands":[]},"checksum":"fec6a2bc152290a9b4860724b43bc22603c0daca946d6d532284deb3ed47467d"}" wire:effects="[]" wire:id="AUjUKxkEimH16R9KOKqK" wire:name="documentation::article" x-init="$wire.__lazyLoad('{"data":{"forMount":[{"markdown":[{"body":"<h1 id=\"content-tizen-hal-api-auth\"><a href=\"#content-tizen-hal-api-auth\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Tizen HAL API: Auth<\/h1><div data-knowledge-base-metadata><\/div>\n<hr \/>\n<p>The <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md\">Auth<\/a> provides functions to handle the authentication per user.<\/p>\n<h2 id=\"content-required-header\"><a href=\"#content-required-header\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Required Header<\/h2>\n<p>#include &lt;hal\/hal-security-auth.h&gt;<\/p>\n<h2 id=\"content-overview\"><a href=\"#content-overview\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Overview<\/h2>\n<p>The Security Auth provides functions to handle the authentication per user.<\/p>\n<p>The Security Auth functions provide methods to:<\/p>\n<ul>\n<li>Create password file<\/li>\n<li>Write password auth parameters from memory to file<\/li>\n<li>Write the number of attempts to enter password auth till now<\/li>\n<li>Set a new password auth context<\/li>\n<li>Check if the entered password auth context is the same as the current password<\/li>\n<li>Set the maximum number of history size to store password context in the past<\/li>\n<li>Get the maximum number of history size<\/li>\n<li>Get the expire time period in days<\/li>\n<li>Set the expire time period in days<\/li>\n<li>Get the expire time left in seconds<\/li>\n<li>Set the expire time left in seconds<\/li>\n<li>Get the accumulated attempt number for user's password auth tries<\/li>\n<li>Reset the accumulated attempt number for user's password auth tries<\/li>\n<li>Increase the accumulated attempt number for user's password auth tries<\/li>\n<li>Get the limited maximum attempt number of user's password auth tries<\/li>\n<li>Set the limited maximum attempt number of user's password auth tries<\/li>\n<li>Get the active status of user's password auth context<\/li>\n<li>Check if the entered password context has the previously-used history<\/li>\n<li>Check if the password auth context has expired<\/li>\n<li>Check if the accumulated attempt number for user's password auth try exceeds the limited maximum attempt<\/li>\n<li>Check if the new attempt interval elapsed the ignore period(ex. RETRY_TIMEOUT = 0.5 secs)<\/li>\n<li>Check if the history for storing the previous password context is activated<\/li>\n<li>Get the password type regarding to the user For more information on the Security Auth features and the macros, see HAL Security programming guides and tutorials.<\/li>\n<\/ul>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Typedefs<\/th>\n<th><\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>typedef struct   <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#struct__hal__backend__security__auth__funcs\">_hal_backend_security_auth_funcs<\/a><\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ga0569ceefd8c0454ce502cb7a66d3b1c7\">hal_backend_security_auth_funcs<\/a><\/td>\n<\/tr>\n<tr>\n<td><\/td>\n<td>Structure for security auth-fw functions.<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<hr \/>\n<h2 id=\"content-data-structure-documentation\"><a href=\"#content-data-structure-documentation\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Data Structure Documentation<\/h2>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>struct _hal_backend_security_auth_funcs<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Structure for security auth-fw functions.<\/p>\n<p><strong>Since:<\/strong>\n:   HAL_MODULE_SECURITY_AUTH 1.0<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Data Fields<\/th>\n<th><\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a0c2f0de292ae14eba06cf3db237ae495\">create_password_file<\/a> )(uid_t user_id, <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ga743c3b53ef987186fd8b7945154a81a9\">hal_security_auth_password_type_e<\/a> type)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a31195143d02e6550f6bcbd7969a97d54\">write_memory_to_file<\/a> )(uid_t user_id)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#af92c47364a95778c47be0230c2585158\">write_attempt_to_file<\/a> )(uid_t user_id)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ad462a17e191f1964a994c182dde8aea0\">set_password<\/a> )(uid_t user_id, const char *password)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a8874a25507a5aed72e9593ab0eb57e97\">check_password<\/a> )(uid_t user_id, const char *password)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a6f4495498cf29be2d0ab19a94138a195\">set_max_history_size<\/a> )(uid_t user_id, unsigned int history_size)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ab8e216fa7304d64459399037c3e29fbe\">get_max_history_size<\/a> )(uid_t user_id, unsigned int *history_size)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a25cf611fe751c2e837a090924fa7b338\">get_expire_time<\/a> )(uid_t user_id, unsigned int *expire_time)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#aa2e2679742bd2cca0b12c7b316f1c4e5\">set_expire_time<\/a> )(uid_t user_id, unsigned int expire_time)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a796c8b51705d0c8764ef2862f6e107e3\">get_expire_time_left<\/a> )(uid_t user_id, unsigned int *expire_time_left)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a36c03df80d817f00d0434c550a9daa76\">set_expire_time_left<\/a> )(uid_t user_id, unsigned int expire_time_left)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a2be0b14564b8426f46334acf5e21702c\">get_attempt<\/a> )(uid_t user_id, unsigned int *attempt)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#af933279e3ef932e7a11edbfef5e38632\">reset_attempt<\/a> )(uid_t user_id)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a32185f7c1d13e1e3ea7e2ed5975119fa\">increment_attempt<\/a> )(uid_t user_id)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a44ba3d782bd853103ec62f56ae26297a\">get_max_attempt<\/a> )(uid_t user_id, unsigned int *max_attempt)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ac469370080fef3838fa2f36e951af5ff\">set_max_attempt<\/a> )(uid_t user_id, unsigned int max_attempt)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a04320cda6bf8349492620dfd1b50e35e\">is_password_active<\/a> )(uid_t user_id)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a62eed840acd3e6c785d84d0523531dea\">is_password_reused<\/a> )(uid_t user_id, const char *password)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a96b8f4914a17827c929cf6929f222185\">check_expiration<\/a> )(uid_t user_id)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ab15840d2ae2fccade25dc010a0c9eeea\">check_attempt_exceeded<\/a> )(uid_t user_id)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a0190423b3cf85be78b4695017ca3e259\">is_ignore_period<\/a> )(uid_t user_id)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a33686fc8028d7819c4a7e5bae915a362\">is_history_active<\/a> )(uid_t user_id)<\/td>\n<\/tr>\n<tr>\n<td>int(*<\/td>\n<td><a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ada5d5a4615a61f90d07046c45dc621a0\">get_password_type<\/a> )(uid_t user_id, <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ga743c3b53ef987186fd8b7945154a81a9\">hal_security_auth_password_type_e<\/a> *password_type)<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<hr \/>\n<h4 id=\"content-field-documentation\"><a href=\"#content-field-documentation\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Field Documentation<\/h4>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ab15840d2ae2fccade25dc010a0c9eeea\">_hal_backend_security_auth_funcs::check_attempt_exceeded<\/a>)(uid_t user_id)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Check if the accumulated attempt number for user's password auth try exceeds the limited maximum attempt<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a96b8f4914a17827c929cf6929f222185\">_hal_backend_security_auth_funcs::check_expiration<\/a>)(uid_t user_id)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Check if the password auth context has expired<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a8874a25507a5aed72e9593ab0eb57e97\">_hal_backend_security_auth_funcs::check_password<\/a>)(uid_t user_id, const char *password)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Check if the entered password auth context is the same as the current password<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a0c2f0de292ae14eba06cf3db237ae495\">_hal_backend_security_auth_funcs::create_password_file<\/a>)(uid_t user_id, <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ga743c3b53ef987186fd8b7945154a81a9\">hal_security_auth_password_type_e<\/a> type)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Create password file<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a2be0b14564b8426f46334acf5e21702c\">_hal_backend_security_auth_funcs::get_attempt<\/a>)(uid_t user_id, unsigned int *attempt)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Get the accumulated attempt number for user's password auth tries<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a25cf611fe751c2e837a090924fa7b338\">_hal_backend_security_auth_funcs::get_expire_time<\/a>)(uid_t user_id, unsigned int *expire_time)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Get the expire time period in days<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a796c8b51705d0c8764ef2862f6e107e3\">_hal_backend_security_auth_funcs::get_expire_time_left<\/a>)(uid_t user_id, unsigned int *expire_time_left)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Get the expire time left in seconds<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a44ba3d782bd853103ec62f56ae26297a\">_hal_backend_security_auth_funcs::get_max_attempt<\/a>)(uid_t user_id, unsigned int *max_attempt)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Get the limited maximum attempt number of user's password auth tries<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ab8e216fa7304d64459399037c3e29fbe\">_hal_backend_security_auth_funcs::get_max_history_size<\/a>)(uid_t user_id, unsigned int *history_size)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Get the maximum number of history size<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ada5d5a4615a61f90d07046c45dc621a0\">_hal_backend_security_auth_funcs::get_password_type<\/a>)(uid_t user_id, <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ga743c3b53ef987186fd8b7945154a81a9\">hal_security_auth_password_type_e<\/a> *password_type)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Get the password type regarding to user_id<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a32185f7c1d13e1e3ea7e2ed5975119fa\">_hal_backend_security_auth_funcs::increment_attempt<\/a>)(uid_t user_id)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Increase the accumulated attempt number for user's password auth tries<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a33686fc8028d7819c4a7e5bae915a362\">_hal_backend_security_auth_funcs::is_history_active<\/a>)(uid_t user_id)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Check if the history for storing the previous password context is activated<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a0190423b3cf85be78b4695017ca3e259\">_hal_backend_security_auth_funcs::is_ignore_period<\/a>)(uid_t user_id)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Check if the new attempt interval elapsed the ignore period(ex. RETRY_TIMEOUT = 0.5 secs)<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a04320cda6bf8349492620dfd1b50e35e\">_hal_backend_security_auth_funcs::is_password_active<\/a>)(uid_t user_id)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Get the active status of user's password auth context<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a62eed840acd3e6c785d84d0523531dea\">_hal_backend_security_auth_funcs::is_password_reused<\/a>)(uid_t user_id, const char *password)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Check if the entered password context has the previously-used history<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#af933279e3ef932e7a11edbfef5e38632\">_hal_backend_security_auth_funcs::reset_attempt<\/a>)(uid_t user_id)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Reset the accumulated attempt number for user's password auth tries<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#aa2e2679742bd2cca0b12c7b316f1c4e5\">_hal_backend_security_auth_funcs::set_expire_time<\/a>)(uid_t user_id, unsigned int expire_time)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Set the expire time period in days<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a36c03df80d817f00d0434c550a9daa76\">_hal_backend_security_auth_funcs::set_expire_time_left<\/a>)(uid_t user_id, unsigned int expire_time_left)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Set the expire time left in seconds<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ac469370080fef3838fa2f36e951af5ff\">_hal_backend_security_auth_funcs::set_max_attempt<\/a>)(uid_t user_id, unsigned int max_attempt)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Set the limited maximum attempt number of user's password auth tries<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a6f4495498cf29be2d0ab19a94138a195\">_hal_backend_security_auth_funcs::set_max_history_size<\/a>)(uid_t user_id, unsigned int history_size)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Set the maximum number of history size to store password context in the past<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ad462a17e191f1964a994c182dde8aea0\">_hal_backend_security_auth_funcs::set_password<\/a>)(uid_t user_id, const char *password)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Set a new password auth context<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#af92c47364a95778c47be0230c2585158\">_hal_backend_security_auth_funcs::write_attempt_to_file<\/a>)(uid_t user_id)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Write the number of attempts to enter password auth till now<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>int(* <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#a31195143d02e6550f6bcbd7969a97d54\">_hal_backend_security_auth_funcs::write_memory_to_file<\/a>)(uid_t user_id)<\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Write password auth parameters from memory to file<\/p>\n<hr \/>\n<h2 id=\"content-typedef-documentation\"><a href=\"#content-typedef-documentation\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Typedef Documentation<\/h2>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>typedef struct <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#struct__hal__backend__security__auth__funcs\">_hal_backend_security_auth_funcs<\/a> <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ga0569ceefd8c0454ce502cb7a66d3b1c7\">hal_backend_security_auth_funcs<\/a><\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Structure for security auth-fw functions.<\/p>\n<p><strong>Since:<\/strong>\n:   HAL_MODULE_SECURITY_AUTH 1.0<\/p>\n<hr \/>\n<h2 id=\"content-enumeration-type-documentation\"><a href=\"#content-enumeration-type-documentation\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Enumeration Type Documentation<\/h2>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>enum <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ga3247b817c2367d83c9f3937e52097436\">hal_security_auth_error_e<\/a><\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Return Codes exported by the hal-security-auth functions.<\/p>\n<p><strong>Since:<\/strong>\n:   HAL_MODULE_SECURITY_AUTH 1.0<\/p>\n<p><strong>Enumerator:<\/strong>\n:   | <em>HAL_SECURITY_AUTH_ERROR_NONE<\/em> | Indicate the result of the one specific API is successful |\n| --- | --- |\n| <em>HAL_SECURITY_AUTH_ERROR_INPUT_PARAM<\/em> | Indicate the API's input parameter is malformed |\n| <em>HAL_SECURITY_AUTH_ERROR_OUT_OF_MEMORY<\/em> | Indicate system is running out of memory state |\n| <em>HAL_SECURITY_AUTH_ERROR_BUFFER_TOO_SMALL<\/em> | Indicate the output buffer size which is passed as parameter is too small |\n| <em>HAL_SECURITY_AUTH_ERROR_NO_USER<\/em> | Indicate there is no user |\n| <em>HAL_SECURITY_AUTH_ERROR_NO_PASSWORD<\/em> | Indicate there is no password set |\n| <em>HAL_SECURITY_AUTH_ERROR_PASSWORD_EXIST<\/em> | Indicate password exists in system |\n| <em>HAL_SECURITY_AUTH_ERROR_PASSWORD_MISMATCH<\/em> | Indicate password mismatch |\n| <em>HAL_SECURITY_AUTH_ERROR_PASSWORD_RETRY_TIMER<\/em> | Indicate password retry timeout has not yet occurred |\n| <em>HAL_SECURITY_AUTH_ERROR_PASSWORD_MAX_ATTEMPTS_EXCEEDED<\/em> | Indicate no more attempts are possible |\n| <em>HAL_SECURITY_AUTH_ERROR_PASSWORD_EXPIRED<\/em> | Indicate password is expired |\n| <em>HAL_SECURITY_AUTH_ERROR_PASSWORD_REUSED<\/em> | Indicate password is reused |\n| <em>HAL_SECURITY_AUTH_ERROR_STATUS<\/em> | Indicate status does not meet the required condition or threshold |\n| <em>HAL_SECURITY_AUTH_ERROR_HAL_INIT_FAIL<\/em> | Indicate there is a failure during HAL initialization |\n| <em>HAL_SECURITY_AUTH_ERROR_UNKNOWN<\/em> | Indicate the error with unknown reason |<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>enum <a href=\"group__HALAPI__HAL__SECURITY__AUTH__MODULE.md#ga743c3b53ef987186fd8b7945154a81a9\">hal_security_auth_password_type_e<\/a><\/th>\n<\/tr>\n<\/thead>\n<\/table><\/div>\n<p>Enumeration for auth password type.<\/p>\n<p><strong>Since:<\/strong>\n:   HAL_MODULE_SECURITY_AUTH 1.0<\/p>\n<p><strong>Enumerator:<\/strong>\n:   | <em>HAL_SECURITY_AUTH_PASSWORD_NORMAL<\/em> | Character string for normal password |\n| --- | --- |\n| <em>HAL_SECURITY_AUTH_PASSWORD_PIN<\/em> | Numeric character string for personal identification number |\n| <em>HAL_SECURITY_AUTH_PASSWORD_PATTERN<\/em> | Numeric character string for pattern match |<\/p>\n<hr \/>\n<p>Except as noted, this content - excluding the Code Examples - is licensed under <a href=\"http:\/\/creativecommons.org\/licenses\/by\/3.0\/legalcode\">Creative Commons Attribution 3.0<\/a>\nand all of the Code Examples contained herein are licensed under <a href=\"https:\/\/www.tizen.org\/bsd-3-clause-license\">BSD-3-Clause<\/a>.<br \/>\nFor details, see the <a href=\"https:\/\/www.tizen.org\/content-license\">Content License<\/a>.<\/p>\n","table_of_content":"<ul class=\"table-of-contents\">\n<li><a href=\"#content-required-header\">Required Header<\/a><\/li>\n<li><a href=\"#content-overview\">Overview<\/a><\/li>\n<li><a href=\"#content-data-structure-documentation\">Data Structure Documentation<\/a><\/li>\n<li><a href=\"#content-field-documentation\">Field Documentation<\/a><\/li>\n<li><a href=\"#content-typedef-documentation\">Typedef Documentation<\/a><\/li>\n<li><a href=\"#content-enumeration-type-documentation\">Enumeration Type Documentation<\/a><\/li>\n<\/ul>\n","title":"Tizen HAL API: Auth","raw":null},{"class":"App\\Services\\Documentation\\Data\\RenderedMarkdown","s":"wrbl"}]},{"s":"arr"}]},"memo":{"id":"R6y5l1jlpgVlvrwc5FIl","name":"__mountParamsContainer","path":"docs\/platform\/hal\/api\/1.0.0\/group__HALAPI__HAL__SECURITY__AUTH__MODULE","method":"GET","release":"a-a-a"},"checksum":"492de54bc1729a206bdffd64a53271786554b5e664308bfd89166209fcf640d4"}')" >

For the best experience,
Please visit us from a computer

Copyright © 2026 SAMSUNG. All rights reserved.

Customize your cookie preferences

You can enable or disable non-essential cookies. Essential cookies are always on to ensure the site works properly and to keep you signed in.

Necessary

These cookies are necessary for the website to function properly and cannot be switched off. They help with things like logging in and setting your privacy preferences.

Always on

Analytics

These cookies help us improve the site by tracking which pages are most popular and how visitors move around the site.

Enable analytics cookies
Public Forum Public Forum
Employees only. Please sign in with your company account.