Sophie

Sophie

distrib > Mageia > 7 > armv7hl > media > core-updates > by-pkgid > 2b8767642b0a927316af342b14b4b58e > files > 23

libipa_hbac-devel-1.16.3-3.3.mga7.armv7hl.rpm

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.15"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>ipa_hbac: Host-Based Access Control Resolver</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
 <tbody>
 <tr style="height: 56px;">
  <td id="projectalign" style="padding-left: 0.5em;">
   <div id="projectname">ipa_hbac
   &#160;<span id="projectnumber">1.16.3</span>
   </div>
  </td>
 </tr>
 </tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.15 -->
<script type="text/javascript" src="menudata.js"></script>
<script type="text/javascript" src="menu.js"></script>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
$(function() {
  initMenu('',false,false,'search.php','Search');
});
/* @license-end */</script>
<div id="main-nav"></div>
</div><!-- top -->
<div class="header">
  <div class="summary">
<a href="#nested-classes">Data Structures</a> &#124;
<a href="#define-members">Macros</a> &#124;
<a href="#typedef-members">Typedefs</a> &#124;
<a href="#enum-members">Enumerations</a> &#124;
<a href="#func-members">Functions</a>  </div>
  <div class="headertitle">
<div class="title">Host-Based Access Control Resolver</div>  </div>
</div><!--header-->
<div class="contents">

<p>Libipa_hbac provides a mechanism to validate FreeIPA HBAC rules as well as evaluate whether they apply to a particular user login attempt.  
<a href="#details">More...</a></p>
<table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="nested-classes"></a>
Data Structures</h2></td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structhbac__rule__element.html">hbac_rule_element</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Component of an HBAC rule.  <a href="structhbac__rule__element.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structhbac__rule.html">hbac_rule</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">HBAC rule object for evaluation.  <a href="structhbac__rule.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structhbac__request__element.html">hbac_request_element</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Component of an HBAC request.  <a href="structhbac__request__element.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structhbac__eval__req.html">hbac_eval_req</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Request object for an HBAC rule evaluation.  <a href="structhbac__eval__req.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structhbac__info.html">hbac_info</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Extended information.  <a href="structhbac__info.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="define-members"></a>
Macros</h2></td></tr>
<tr class="memitem:gaedbbc12bed44918a30d673720df85d03"><td class="memItemLeft" align="right" valign="top"><a id="gaedbbc12bed44918a30d673720df85d03"></a>
#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ipa__hbac.html#gaedbbc12bed44918a30d673720df85d03">HBAC_CATEGORY_NULL</a>&#160;&#160;&#160;0x0000</td></tr>
<tr class="memdesc:gaedbbc12bed44918a30d673720df85d03"><td class="mdescLeft">&#160;</td><td class="mdescRight">No service category specified. <br /></td></tr>
<tr class="separator:gaedbbc12bed44918a30d673720df85d03"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:gaff3d14567e8ca0ed671fc88287e7aaec"><td class="memItemLeft" align="right" valign="top"><a id="gaff3d14567e8ca0ed671fc88287e7aaec"></a>
#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ipa__hbac.html#gaff3d14567e8ca0ed671fc88287e7aaec">HBAC_CATEGORY_ALL</a>&#160;&#160;&#160;0x0001</td></tr>
<tr class="memdesc:gaff3d14567e8ca0ed671fc88287e7aaec"><td class="mdescLeft">&#160;</td><td class="mdescRight">Rule should apply to all. <br /></td></tr>
<tr class="separator:gaff3d14567e8ca0ed671fc88287e7aaec"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:gae31ab9dce5991045fb4d945f9f04e68d"><td class="memItemLeft" align="right" valign="top"><a id="gae31ab9dce5991045fb4d945f9f04e68d"></a>
#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ipa__hbac.html#gae31ab9dce5991045fb4d945f9f04e68d">HBAC_RULE_ELEMENT_USERS</a>&#160;&#160;&#160;0x01</td></tr>
<tr class="memdesc:gae31ab9dce5991045fb4d945f9f04e68d"><td class="mdescLeft">&#160;</td><td class="mdescRight">User element. <br /></td></tr>
<tr class="separator:gae31ab9dce5991045fb4d945f9f04e68d"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ga8fda15d21054d3c3754fe1d1948b37ff"><td class="memItemLeft" align="right" valign="top"><a id="ga8fda15d21054d3c3754fe1d1948b37ff"></a>
#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ipa__hbac.html#ga8fda15d21054d3c3754fe1d1948b37ff">HBAC_RULE_ELEMENT_SERVICES</a>&#160;&#160;&#160;0x02</td></tr>
<tr class="memdesc:ga8fda15d21054d3c3754fe1d1948b37ff"><td class="mdescLeft">&#160;</td><td class="mdescRight">Service element. <br /></td></tr>
<tr class="separator:ga8fda15d21054d3c3754fe1d1948b37ff"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ga57195713344d39e9ca73a2775ba371a5"><td class="memItemLeft" align="right" valign="top"><a id="ga57195713344d39e9ca73a2775ba371a5"></a>
#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ipa__hbac.html#ga57195713344d39e9ca73a2775ba371a5">HBAC_RULE_ELEMENT_TARGETHOSTS</a>&#160;&#160;&#160;0x04</td></tr>
<tr class="memdesc:ga57195713344d39e9ca73a2775ba371a5"><td class="mdescLeft">&#160;</td><td class="mdescRight">Target host element. <br /></td></tr>
<tr class="separator:ga57195713344d39e9ca73a2775ba371a5"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:gad39fb6b6afefa7ccbceab5d80eb35684"><td class="memItemLeft" align="right" valign="top"><a id="gad39fb6b6afefa7ccbceab5d80eb35684"></a>
#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ipa__hbac.html#gad39fb6b6afefa7ccbceab5d80eb35684">HBAC_RULE_ELEMENT_SOURCEHOSTS</a>&#160;&#160;&#160;0x08</td></tr>
<tr class="memdesc:gad39fb6b6afefa7ccbceab5d80eb35684"><td class="mdescLeft">&#160;</td><td class="mdescRight">Source host element. <br /></td></tr>
<tr class="separator:gad39fb6b6afefa7ccbceab5d80eb35684"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="typedef-members"></a>
Typedefs</h2></td></tr>
<tr class="memitem:gab8400b6ed76fb89701240b1114f464f8"><td class="memItemLeft" align="right" valign="top"><a id="gab8400b6ed76fb89701240b1114f464f8"></a>
typedef void(*&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ipa__hbac.html#gab8400b6ed76fb89701240b1114f464f8">hbac_debug_fn_t</a>) (const char *file, int line, const char *function, enum <a class="el" href="group__ipa__hbac.html#gad8db2e23cb9fe197ba3d2cd7cc9981eb">hbac_debug_level</a>, const char *format,...) HBAC_ATTRIBUTE_PRINTF(5</td></tr>
<tr class="memdesc:gab8400b6ed76fb89701240b1114f464f8"><td class="mdescLeft">&#160;</td><td class="mdescRight">Function pointer to HBAC external debugging function. <br /></td></tr>
<tr class="separator:gab8400b6ed76fb89701240b1114f464f8"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:gab627f9114335229990023954682ffdd6"><td class="memItemLeft" align="right" valign="top">typedef void(*) voi&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ipa__hbac.html#gab627f9114335229990023954682ffdd6">hbac_enable_debug</a>) (<a class="el" href="group__ipa__hbac.html#gab8400b6ed76fb89701240b1114f464f8">hbac_debug_fn_t</a> external_debug_fn)</td></tr>
<tr class="memdesc:gab627f9114335229990023954682ffdd6"><td class="mdescLeft">&#160;</td><td class="mdescRight">HBAC uses external_debug_fn for logging messages.  <a href="#gab627f9114335229990023954682ffdd6">More...</a><br /></td></tr>
<tr class="separator:gab627f9114335229990023954682ffdd6"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="enum-members"></a>
Enumerations</h2></td></tr>
<tr class="memitem:gad8db2e23cb9fe197ba3d2cd7cc9981eb"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ipa__hbac.html#gad8db2e23cb9fe197ba3d2cd7cc9981eb">hbac_debug_level</a> { , <a class="el" href="group__ipa__hbac.html#ggad8db2e23cb9fe197ba3d2cd7cc9981ebaa1c55f23449dd5bdd2fadbba54006850">HBAC_DBG_ERROR</a>, 
<a class="el" href="group__ipa__hbac.html#ggad8db2e23cb9fe197ba3d2cd7cc9981ebadd95bf7aed56c4571b46ed22be33e3df">HBAC_DBG_WARNING</a>, 
<a class="el" href="group__ipa__hbac.html#ggad8db2e23cb9fe197ba3d2cd7cc9981eba69c15053ae680c9e51d7d2d93bbbf99f">HBAC_DBG_INFO</a>, 
<a class="el" href="group__ipa__hbac.html#ggad8db2e23cb9fe197ba3d2cd7cc9981ebaa925d6f8deabf2417096b347cfcc56e4">HBAC_DBG_TRACE</a>
 }</td></tr>
<tr class="memdesc:gad8db2e23cb9fe197ba3d2cd7cc9981eb"><td class="mdescLeft">&#160;</td><td class="mdescRight">Debug levels for HBAC.  <a href="group__ipa__hbac.html#gad8db2e23cb9fe197ba3d2cd7cc9981eb">More...</a><br /></td></tr>
<tr class="separator:gad8db2e23cb9fe197ba3d2cd7cc9981eb"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:gad62bd2c7fb837272a3cf80d176410cd6"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ipa__hbac.html#gad62bd2c7fb837272a3cf80d176410cd6">hbac_eval_result</a> { <a class="el" href="group__ipa__hbac.html#ggad62bd2c7fb837272a3cf80d176410cd6ae037f769a8a5b21d518733cdef7bb1c1">HBAC_EVAL_ERROR</a> = -1, 
<a class="el" href="group__ipa__hbac.html#ggad62bd2c7fb837272a3cf80d176410cd6a7990610222cac06bb359bbef96ec5710">HBAC_EVAL_ALLOW</a>, 
<a class="el" href="group__ipa__hbac.html#ggad62bd2c7fb837272a3cf80d176410cd6ad2fde36248cdaa69d07c69ced9ecfd59">HBAC_EVAL_DENY</a>, 
<a class="el" href="group__ipa__hbac.html#ggad62bd2c7fb837272a3cf80d176410cd6a771aaa647d402b3796c8bd9e9bc6e915">HBAC_EVAL_OOM</a>
 }</td></tr>
<tr class="memdesc:gad62bd2c7fb837272a3cf80d176410cd6"><td class="mdescLeft">&#160;</td><td class="mdescRight">Result of HBAC evaluation.  <a href="group__ipa__hbac.html#gad62bd2c7fb837272a3cf80d176410cd6">More...</a><br /></td></tr>
<tr class="separator:gad62bd2c7fb837272a3cf80d176410cd6"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:gac4bf6648ee5fb44693543581ad8956fd"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ipa__hbac.html#gac4bf6648ee5fb44693543581ad8956fd">hbac_error_code</a> { <br />
&#160;&#160;<a class="el" href="group__ipa__hbac.html#ggac4bf6648ee5fb44693543581ad8956fdab458a5182a5fa817b9170f733e6e2a68">HBAC_ERROR_UNKNOWN</a> = -1, 
<a class="el" href="group__ipa__hbac.html#ggac4bf6648ee5fb44693543581ad8956fdad2a456bafa5157c4948c4731f98bd934">HBAC_SUCCESS</a>, 
<a class="el" href="group__ipa__hbac.html#ggac4bf6648ee5fb44693543581ad8956fda714c7f58d25e404aa489f7f552a328aa">HBAC_ERROR_NOT_IMPLEMENTED</a>, 
<a class="el" href="group__ipa__hbac.html#ggac4bf6648ee5fb44693543581ad8956fda7ab6bd70d35aca7230973453f3996f94">HBAC_ERROR_OUT_OF_MEMORY</a>, 
<br />
&#160;&#160;<a class="el" href="group__ipa__hbac.html#ggac4bf6648ee5fb44693543581ad8956fda63c32fd2a31addc7bdbbb9f931769b6d">HBAC_ERROR_UNPARSEABLE_RULE</a>
<br />
 }</td></tr>
<tr class="memdesc:gac4bf6648ee5fb44693543581ad8956fd"><td class="mdescLeft">&#160;</td><td class="mdescRight">Error code returned by the evaluator.  <a href="group__ipa__hbac.html#gac4bf6648ee5fb44693543581ad8956fd">More...</a><br /></td></tr>
<tr class="separator:gac4bf6648ee5fb44693543581ad8956fd"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="func-members"></a>
Functions</h2></td></tr>
<tr class="memitem:ga5e2ff922594e1c95406a58e11c02e785"><td class="memItemLeft" align="right" valign="top">enum <a class="el" href="group__ipa__hbac.html#gad62bd2c7fb837272a3cf80d176410cd6">hbac_eval_result</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ipa__hbac.html#ga5e2ff922594e1c95406a58e11c02e785">hbac_evaluate</a> (struct <a class="el" href="structhbac__rule.html">hbac_rule</a> **rules, struct <a class="el" href="structhbac__eval__req.html">hbac_eval_req</a> *hbac_req, struct <a class="el" href="structhbac__info.html">hbac_info</a> **info)</td></tr>
<tr class="memdesc:ga5e2ff922594e1c95406a58e11c02e785"><td class="mdescLeft">&#160;</td><td class="mdescRight">Evaluate an authorization request against a set of HBAC rules.  <a href="#ga5e2ff922594e1c95406a58e11c02e785">More...</a><br /></td></tr>
<tr class="separator:ga5e2ff922594e1c95406a58e11c02e785"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:gabcf175aab640e89824deaae97160d0f2"><td class="memItemLeft" align="right" valign="top">const char *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ipa__hbac.html#gabcf175aab640e89824deaae97160d0f2">hbac_result_string</a> (enum <a class="el" href="group__ipa__hbac.html#gad62bd2c7fb837272a3cf80d176410cd6">hbac_eval_result</a> result)</td></tr>
<tr class="memdesc:gabcf175aab640e89824deaae97160d0f2"><td class="mdescLeft">&#160;</td><td class="mdescRight">Display result of hbac evaluation in human-readable form.  <a href="#gabcf175aab640e89824deaae97160d0f2">More...</a><br /></td></tr>
<tr class="separator:gabcf175aab640e89824deaae97160d0f2"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ga03f9ab391cf4a158a2d11bc3e408b2f5"><td class="memItemLeft" align="right" valign="top">const char *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ipa__hbac.html#ga03f9ab391cf4a158a2d11bc3e408b2f5">hbac_error_string</a> (enum <a class="el" href="group__ipa__hbac.html#gac4bf6648ee5fb44693543581ad8956fd">hbac_error_code</a> code)</td></tr>
<tr class="memdesc:ga03f9ab391cf4a158a2d11bc3e408b2f5"><td class="mdescLeft">&#160;</td><td class="mdescRight">Display error description.  <a href="#ga03f9ab391cf4a158a2d11bc3e408b2f5">More...</a><br /></td></tr>
<tr class="separator:ga03f9ab391cf4a158a2d11bc3e408b2f5"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:gae3bfb7f61dc7f11f6bbc7f89d5e9cc40"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ipa__hbac.html#gae3bfb7f61dc7f11f6bbc7f89d5e9cc40">hbac_free_info</a> (struct <a class="el" href="structhbac__info.html">hbac_info</a> *info)</td></tr>
<tr class="memdesc:gae3bfb7f61dc7f11f6bbc7f89d5e9cc40"><td class="mdescLeft">&#160;</td><td class="mdescRight">Function to safely free <a class="el" href="structhbac__info.html" title="Extended information.">hbac_info</a> returned by <a class="el" href="group__ipa__hbac.html#ga5e2ff922594e1c95406a58e11c02e785" title="Evaluate an authorization request against a set of HBAC rules.">hbac_evaluate</a>.  <a href="#gae3bfb7f61dc7f11f6bbc7f89d5e9cc40">More...</a><br /></td></tr>
<tr class="separator:gae3bfb7f61dc7f11f6bbc7f89d5e9cc40"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:gadef62fdeda3388674ab2cc50f955c406"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ipa__hbac.html#gadef62fdeda3388674ab2cc50f955c406">hbac_rule_is_complete</a> (struct <a class="el" href="structhbac__rule.html">hbac_rule</a> *rule, uint32_t *missing_attrs)</td></tr>
<tr class="memdesc:gadef62fdeda3388674ab2cc50f955c406"><td class="mdescLeft">&#160;</td><td class="mdescRight">Evaluate whether an HBAC rule contains all necessary elements.  <a href="#gadef62fdeda3388674ab2cc50f955c406">More...</a><br /></td></tr>
<tr class="separator:gadef62fdeda3388674ab2cc50f955c406"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table>
<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
<p>Libipa_hbac provides a mechanism to validate FreeIPA HBAC rules as well as evaluate whether they apply to a particular user login attempt. </p>
<p>Libipa_hbac is case-insensitive and compatible with UTF-8. </p>
<h2 class="groupheader">Typedef Documentation</h2>
<a id="gab627f9114335229990023954682ffdd6"></a>
<h2 class="memtitle"><span class="permalink"><a href="#gab627f9114335229990023954682ffdd6">&#9670;&nbsp;</a></span>hbac_enable_debug</h2>

<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">typedef void(*) voi hbac_enable_debug) (<a class="el" href="group__ipa__hbac.html#gab8400b6ed76fb89701240b1114f464f8">hbac_debug_fn_t</a> external_debug_fn)</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>HBAC uses external_debug_fn for logging messages. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramdir">[in]</td><td class="paramname">external_debug_fn</td><td>Pointer to external logging function. </td></tr>
  </table>
  </dd>
</dl>

</div>
</div>
<h2 class="groupheader">Enumeration Type Documentation</h2>
<a id="gad8db2e23cb9fe197ba3d2cd7cc9981eb"></a>
<h2 class="memtitle"><span class="permalink"><a href="#gad8db2e23cb9fe197ba3d2cd7cc9981eb">&#9670;&nbsp;</a></span>hbac_debug_level</h2>

<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">enum <a class="el" href="group__ipa__hbac.html#gad8db2e23cb9fe197ba3d2cd7cc9981eb">hbac_debug_level</a></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Debug levels for HBAC. </p>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="ggad8db2e23cb9fe197ba3d2cd7cc9981ebaa1c55f23449dd5bdd2fadbba54006850"></a>HBAC_DBG_ERROR&#160;</td><td class="fielddoc"><p>Fatal failure (not used). </p>
</td></tr>
<tr><td class="fieldname"><a id="ggad8db2e23cb9fe197ba3d2cd7cc9981ebadd95bf7aed56c4571b46ed22be33e3df"></a>HBAC_DBG_WARNING&#160;</td><td class="fielddoc"><p>Serious failure (out of memory, for example). </p>
</td></tr>
<tr><td class="fieldname"><a id="ggad8db2e23cb9fe197ba3d2cd7cc9981eba69c15053ae680c9e51d7d2d93bbbf99f"></a>HBAC_DBG_INFO&#160;</td><td class="fielddoc"><p>Warnings (not used). </p>
</td></tr>
<tr><td class="fieldname"><a id="ggad8db2e23cb9fe197ba3d2cd7cc9981ebaa925d6f8deabf2417096b347cfcc56e4"></a>HBAC_DBG_TRACE&#160;</td><td class="fielddoc"><p>HBAC allow/disallow info. </p>
<p>Verbose description of rules. </p>
</td></tr>
</table>

</div>
</div>
<a id="gac4bf6648ee5fb44693543581ad8956fd"></a>
<h2 class="memtitle"><span class="permalink"><a href="#gac4bf6648ee5fb44693543581ad8956fd">&#9670;&nbsp;</a></span>hbac_error_code</h2>

<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">enum <a class="el" href="group__ipa__hbac.html#gac4bf6648ee5fb44693543581ad8956fd">hbac_error_code</a></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Error code returned by the evaluator. </p>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="ggac4bf6648ee5fb44693543581ad8956fdab458a5182a5fa817b9170f733e6e2a68"></a>HBAC_ERROR_UNKNOWN&#160;</td><td class="fielddoc"><p>Unexpected error. </p>
</td></tr>
<tr><td class="fieldname"><a id="ggac4bf6648ee5fb44693543581ad8956fdad2a456bafa5157c4948c4731f98bd934"></a>HBAC_SUCCESS&#160;</td><td class="fielddoc"><p>Successful evaluation. </p>
</td></tr>
<tr><td class="fieldname"><a id="ggac4bf6648ee5fb44693543581ad8956fda714c7f58d25e404aa489f7f552a328aa"></a>HBAC_ERROR_NOT_IMPLEMENTED&#160;</td><td class="fielddoc"><p>Function is not yet implemented. </p>
</td></tr>
<tr><td class="fieldname"><a id="ggac4bf6648ee5fb44693543581ad8956fda7ab6bd70d35aca7230973453f3996f94"></a>HBAC_ERROR_OUT_OF_MEMORY&#160;</td><td class="fielddoc"><p>Ran out of memory during processing. </p>
</td></tr>
<tr><td class="fieldname"><a id="ggac4bf6648ee5fb44693543581ad8956fda63c32fd2a31addc7bdbbb9f931769b6d"></a>HBAC_ERROR_UNPARSEABLE_RULE&#160;</td><td class="fielddoc"><p>Parse error while evaluating rule. </p>
</td></tr>
</table>

</div>
</div>
<a id="gad62bd2c7fb837272a3cf80d176410cd6"></a>
<h2 class="memtitle"><span class="permalink"><a href="#gad62bd2c7fb837272a3cf80d176410cd6">&#9670;&nbsp;</a></span>hbac_eval_result</h2>

<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">enum <a class="el" href="group__ipa__hbac.html#gad62bd2c7fb837272a3cf80d176410cd6">hbac_eval_result</a></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Result of HBAC evaluation. </p>
<table class="fieldtable">
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="ggad62bd2c7fb837272a3cf80d176410cd6ae037f769a8a5b21d518733cdef7bb1c1"></a>HBAC_EVAL_ERROR&#160;</td><td class="fielddoc"><p>An error occurred See the <a class="el" href="structhbac__info.html" title="Extended information.">hbac_info</a> for more details. </p>
</td></tr>
<tr><td class="fieldname"><a id="ggad62bd2c7fb837272a3cf80d176410cd6a7990610222cac06bb359bbef96ec5710"></a>HBAC_EVAL_ALLOW&#160;</td><td class="fielddoc"><p>Evaluation grants access. </p>
</td></tr>
<tr><td class="fieldname"><a id="ggad62bd2c7fb837272a3cf80d176410cd6ad2fde36248cdaa69d07c69ced9ecfd59"></a>HBAC_EVAL_DENY&#160;</td><td class="fielddoc"><p>Evaluation denies access. </p>
</td></tr>
<tr><td class="fieldname"><a id="ggad62bd2c7fb837272a3cf80d176410cd6a771aaa647d402b3796c8bd9e9bc6e915"></a>HBAC_EVAL_OOM&#160;</td><td class="fielddoc"><p>Evaluation failed due to lack of memory <a class="el" href="structhbac__info.html" title="Extended information.">hbac_info</a> is not available. </p>
</td></tr>
</table>

</div>
</div>
<h2 class="groupheader">Function Documentation</h2>
<a id="ga03f9ab391cf4a158a2d11bc3e408b2f5"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ga03f9ab391cf4a158a2d11bc3e408b2f5">&#9670;&nbsp;</a></span>hbac_error_string()</h2>

<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">const char* hbac_error_string </td>
          <td>(</td>
          <td class="paramtype">enum <a class="el" href="group__ipa__hbac.html#gac4bf6648ee5fb44693543581ad8956fd">hbac_error_code</a>&#160;</td>
          <td class="paramname"><em>code</em></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Display error description. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">code</td><td>Error code returned in <a class="el" href="structhbac__info.html" title="Extended information.">hbac_info</a> </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>English string describing the error </dd></dl>

</div>
</div>
<a id="ga5e2ff922594e1c95406a58e11c02e785"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ga5e2ff922594e1c95406a58e11c02e785">&#9670;&nbsp;</a></span>hbac_evaluate()</h2>

<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">enum <a class="el" href="group__ipa__hbac.html#gad62bd2c7fb837272a3cf80d176410cd6">hbac_eval_result</a> hbac_evaluate </td>
          <td>(</td>
          <td class="paramtype">struct <a class="el" href="structhbac__rule.html">hbac_rule</a> **&#160;</td>
          <td class="paramname"><em>rules</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">struct <a class="el" href="structhbac__eval__req.html">hbac_eval_req</a> *&#160;</td>
          <td class="paramname"><em>hbac_req</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">struct <a class="el" href="structhbac__info.html">hbac_info</a> **&#160;</td>
          <td class="paramname"><em>info</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Evaluate an authorization request against a set of HBAC rules. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramdir">[in]</td><td class="paramname">rules</td><td>A NULL-terminated list of rules to evaluate against </td></tr>
    <tr><td class="paramdir">[in]</td><td class="paramname">hbac_req</td><td>A user authorization request </td></tr>
    <tr><td class="paramdir">[out]</td><td class="paramname">info</td><td>Extended information (including the name of the rule that allowed access (or caused a parse error) </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd><ul>
<li><a class="el" href="group__ipa__hbac.html#ggad62bd2c7fb837272a3cf80d176410cd6ae037f769a8a5b21d518733cdef7bb1c1" title="An error occurred See the hbac_info for more details.">HBAC_EVAL_ERROR</a>: An error occurred</li>
<li><a class="el" href="group__ipa__hbac.html#ggad62bd2c7fb837272a3cf80d176410cd6a7990610222cac06bb359bbef96ec5710" title="Evaluation grants access.">HBAC_EVAL_ALLOW</a>: Access is granted</li>
<li><a class="el" href="group__ipa__hbac.html#ggad62bd2c7fb837272a3cf80d176410cd6ad2fde36248cdaa69d07c69ced9ecfd59" title="Evaluation denies access.">HBAC_EVAL_DENY</a>: Access is denied</li>
<li><a class="el" href="group__ipa__hbac.html#ggad62bd2c7fb837272a3cf80d176410cd6a771aaa647d402b3796c8bd9e9bc6e915" title="Evaluation failed due to lack of memory hbac_info is not available.">HBAC_EVAL_OOM</a>: Insufficient memory to complete the evaluation </li>
</ul>
</dd></dl>

</div>
</div>
<a id="gae3bfb7f61dc7f11f6bbc7f89d5e9cc40"></a>
<h2 class="memtitle"><span class="permalink"><a href="#gae3bfb7f61dc7f11f6bbc7f89d5e9cc40">&#9670;&nbsp;</a></span>hbac_free_info()</h2>

<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">void hbac_free_info </td>
          <td>(</td>
          <td class="paramtype">struct <a class="el" href="structhbac__info.html">hbac_info</a> *&#160;</td>
          <td class="paramname"><em>info</em></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Function to safely free <a class="el" href="structhbac__info.html" title="Extended information.">hbac_info</a> returned by <a class="el" href="group__ipa__hbac.html#ga5e2ff922594e1c95406a58e11c02e785" title="Evaluate an authorization request against a set of HBAC rules.">hbac_evaluate</a>. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">info</td><td><a class="el" href="structhbac__info.html" title="Extended information.">hbac_info</a> returned by <a class="el" href="group__ipa__hbac.html#ga5e2ff922594e1c95406a58e11c02e785" title="Evaluate an authorization request against a set of HBAC rules.">hbac_evaluate</a> </td></tr>
  </table>
  </dd>
</dl>

</div>
</div>
<a id="gabcf175aab640e89824deaae97160d0f2"></a>
<h2 class="memtitle"><span class="permalink"><a href="#gabcf175aab640e89824deaae97160d0f2">&#9670;&nbsp;</a></span>hbac_result_string()</h2>

<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">const char* hbac_result_string </td>
          <td>(</td>
          <td class="paramtype">enum <a class="el" href="group__ipa__hbac.html#gad62bd2c7fb837272a3cf80d176410cd6">hbac_eval_result</a>&#160;</td>
          <td class="paramname"><em>result</em></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Display result of hbac evaluation in human-readable form. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramdir">[in]</td><td class="paramname">result</td><td>Return value of <a class="el" href="group__ipa__hbac.html#ga5e2ff922594e1c95406a58e11c02e785" title="Evaluate an authorization request against a set of HBAC rules.">hbac_evaluate</a> </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>English string describing the evaluation result </dd></dl>

</div>
</div>
<a id="gadef62fdeda3388674ab2cc50f955c406"></a>
<h2 class="memtitle"><span class="permalink"><a href="#gadef62fdeda3388674ab2cc50f955c406">&#9670;&nbsp;</a></span>hbac_rule_is_complete()</h2>

<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">bool hbac_rule_is_complete </td>
          <td>(</td>
          <td class="paramtype">struct <a class="el" href="structhbac__rule.html">hbac_rule</a> *&#160;</td>
          <td class="paramname"><em>rule</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">uint32_t *&#160;</td>
          <td class="paramname"><em>missing_attrs</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Evaluate whether an HBAC rule contains all necessary elements. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramdir">[in]</td><td class="paramname">rule</td><td>An HBAC rule to evaluate </td></tr>
    <tr><td class="paramdir">[out]</td><td class="paramname">missing_attrs</td><td>A list of attributes missing from the rule This is a bitmask that may contain one or more of <a class="el" href="group__ipa__hbac.html#gae31ab9dce5991045fb4d945f9f04e68d" title="User element.">HBAC_RULE_ELEMENT_USERS</a>, <a class="el" href="group__ipa__hbac.html#ga8fda15d21054d3c3754fe1d1948b37ff" title="Service element.">HBAC_RULE_ELEMENT_SERVICES</a>, <a class="el" href="group__ipa__hbac.html#ga57195713344d39e9ca73a2775ba371a5" title="Target host element.">HBAC_RULE_ELEMENT_TARGETHOSTS</a> and <a class="el" href="group__ipa__hbac.html#gad39fb6b6afefa7ccbceab5d80eb35684" title="Source host element.">HBAC_RULE_ELEMENT_SOURCEHOSTS</a></td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>True if the rule contains all mandatory attributes</dd></dl>
<dl class="section note"><dt>Note</dt><dd>This function does not care if the rule is enabled or disabled </dd></dl>

</div>
</div>
</div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated by &#160;<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/>
</a> 1.8.15
</small></address>
</body>
</html>