272 lines
15 KiB
HTML
272 lines
15 KiB
HTML
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
|
<!-------------------------------------------------------------->
|
|
<!-- qDecoder Project -->
|
|
<!-- -->
|
|
<!-- Copyright (c) The qDecoder Project -->
|
|
<!-- http://www.qdecoder.org -->
|
|
<!-------------------------------------------------------------->
|
|
<html xmlns="http://www.w3.org/1999/xhtml">
|
|
<head>
|
|
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
<title>qcgisess.c File Reference</title>
|
|
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
<link href="doxygen.css" rel="stylesheet" type="text/css"/>
|
|
</head>
|
|
<body>
|
|
<center><h1>qDecoder API Reference</h1></center>
|
|
<!-- Generated by Doxygen 1.8.2 -->
|
|
<div id="navrow1" class="tabs">
|
|
<ul class="tablist">
|
|
<li><a href="index.html"><span>Main Page</span></a></li>
|
|
<li><a href="annotated.html"><span>Data Structures</span></a></li>
|
|
<li class="current"><a href="files.html"><span>Files</span></a></li>
|
|
</ul>
|
|
</div>
|
|
<div id="navrow2" class="tabs2">
|
|
<ul class="tablist">
|
|
<li><a href="files.html"><span>File List</span></a></li>
|
|
<li><a href="globals.html"><span>Globals</span></a></li>
|
|
</ul>
|
|
</div>
|
|
</div><!-- top -->
|
|
<div class="header">
|
|
<div class="summary">
|
|
<a href="#define-members">Macros</a> |
|
|
<a href="#func-members">Functions</a> </div>
|
|
<div class="headertitle">
|
|
<div class="title">qcgisess.c File Reference</div> </div>
|
|
</div><!--header-->
|
|
<div class="contents">
|
|
<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
|
|
<div class="textblock"><p>CGI Session API. </p>
|
|
</div><table class="memberdecls">
|
|
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="define-members"></a>
|
|
Macros</h2></td></tr>
|
|
<tr class="memitem:a95b8cbd404972ba461c01e8e2f735a44"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a95b8cbd404972ba461c01e8e2f735a44"></a>
|
|
#define </td><td class="memItemRight" valign="bottom"><b>SESSION_DEFAULT_REPOSITORY</b>   "/tmp"</td></tr>
|
|
<tr class="separator:a95b8cbd404972ba461c01e8e2f735a44"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:af811b0781576e7860ae734f3390349e9"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="af811b0781576e7860ae734f3390349e9"></a>
|
|
#define </td><td class="memItemRight" valign="bottom"><b>SESSION_ID</b>   "QSESSIONID"</td></tr>
|
|
<tr class="separator:af811b0781576e7860ae734f3390349e9"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:af6210c4dbe68ee4794a4e76ccd2a1635"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="af6210c4dbe68ee4794a4e76ccd2a1635"></a>
|
|
#define </td><td class="memItemRight" valign="bottom"><b>SESSION_PREFIX</b>   "qsession-"</td></tr>
|
|
<tr class="separator:af6210c4dbe68ee4794a4e76ccd2a1635"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a17fc17c29e7c0ef72727c8c0bab227ec"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a17fc17c29e7c0ef72727c8c0bab227ec"></a>
|
|
#define </td><td class="memItemRight" valign="bottom"><b>SESSION_STORAGE_EXTENSION</b>   ".properties"</td></tr>
|
|
<tr class="separator:a17fc17c29e7c0ef72727c8c0bab227ec"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:ac527e392dd59aaaf5165fdf7be5a907a"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ac527e392dd59aaaf5165fdf7be5a907a"></a>
|
|
#define </td><td class="memItemRight" valign="bottom"><b>SESSION_TIMEOUT_EXTENSION</b>   ".expire"</td></tr>
|
|
<tr class="separator:ac527e392dd59aaaf5165fdf7be5a907a"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a7c21fa33923a81852336806eac46a7b6"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a7c21fa33923a81852336806eac46a7b6"></a>
|
|
#define </td><td class="memItemRight" valign="bottom"><b>SESSION_TIMETOCLEAR_FILENAME</b>   "qsession-timetoclear"</td></tr>
|
|
<tr class="separator:a7c21fa33923a81852336806eac46a7b6"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:af20a6cf8e504d84352075a1780415e2d"><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="af20a6cf8e504d84352075a1780415e2d"></a>
|
|
#define </td><td class="memItemRight" valign="bottom"><b>SESSION_DEFAULT_TIMEOUT_INTERVAL</b>   (30 * 60)</td></tr>
|
|
<tr class="separator:af20a6cf8e504d84352075a1780415e2d"><td class="memSeparator" colspan="2"> </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:a4337dd74e2b07f333f10ffc1189097fd"><td class="memItemLeft" align="right" valign="top"><a class="el" href="structqentry__s.html">qentry_t</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="qcgisess_8c.html#a4337dd74e2b07f333f10ffc1189097fd">qcgisess_init</a> (<a class="el" href="structqentry__s.html">qentry_t</a> *request, const char *dirpath)</td></tr>
|
|
<tr class="memdesc:a4337dd74e2b07f333f10ffc1189097fd"><td class="mdescLeft"> </td><td class="mdescRight">Initialize session. <a href="#a4337dd74e2b07f333f10ffc1189097fd"></a><br/></td></tr>
|
|
<tr class="separator:a4337dd74e2b07f333f10ffc1189097fd"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a8a6384050e074ccffb2e5706d1a5f4af"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="qcgisess_8c.html#a8a6384050e074ccffb2e5706d1a5f4af">qcgisess_settimeout</a> (<a class="el" href="structqentry__s.html">qentry_t</a> *session, time_t seconds)</td></tr>
|
|
<tr class="memdesc:a8a6384050e074ccffb2e5706d1a5f4af"><td class="mdescLeft"> </td><td class="mdescRight">Set the auto-expiration seconds about user session. <a href="#a8a6384050e074ccffb2e5706d1a5f4af"></a><br/></td></tr>
|
|
<tr class="separator:a8a6384050e074ccffb2e5706d1a5f4af"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a098613dd87e9cb88ea5740294dd7064f"><td class="memItemLeft" align="right" valign="top">const char * </td><td class="memItemRight" valign="bottom"><a class="el" href="qcgisess_8c.html#a098613dd87e9cb88ea5740294dd7064f">qcgisess_getid</a> (<a class="el" href="structqentry__s.html">qentry_t</a> *session)</td></tr>
|
|
<tr class="memdesc:a098613dd87e9cb88ea5740294dd7064f"><td class="mdescLeft"> </td><td class="mdescRight">Get user session id. <a href="#a098613dd87e9cb88ea5740294dd7064f"></a><br/></td></tr>
|
|
<tr class="separator:a098613dd87e9cb88ea5740294dd7064f"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a21b3fb59842a4a48d74665428a46eca6"><td class="memItemLeft" align="right" valign="top">time_t </td><td class="memItemRight" valign="bottom"><a class="el" href="qcgisess_8c.html#a21b3fb59842a4a48d74665428a46eca6">qcgisess_getcreated</a> (<a class="el" href="structqentry__s.html">qentry_t</a> *session)</td></tr>
|
|
<tr class="memdesc:a21b3fb59842a4a48d74665428a46eca6"><td class="mdescLeft"> </td><td class="mdescRight">Get user session created time. <a href="#a21b3fb59842a4a48d74665428a46eca6"></a><br/></td></tr>
|
|
<tr class="separator:a21b3fb59842a4a48d74665428a46eca6"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a2d796ad7b6b322e24f7c1858c8bbab4e"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="qcgisess_8c.html#a2d796ad7b6b322e24f7c1858c8bbab4e">qcgisess_save</a> (<a class="el" href="structqentry__s.html">qentry_t</a> *session)</td></tr>
|
|
<tr class="memdesc:a2d796ad7b6b322e24f7c1858c8bbab4e"><td class="mdescLeft"> </td><td class="mdescRight">Update session data. <a href="#a2d796ad7b6b322e24f7c1858c8bbab4e"></a><br/></td></tr>
|
|
<tr class="separator:a2d796ad7b6b322e24f7c1858c8bbab4e"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a23439df038540b796d4f8adb6b420bc9"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="qcgisess_8c.html#a23439df038540b796d4f8adb6b420bc9">qcgisess_destroy</a> (<a class="el" href="structqentry__s.html">qentry_t</a> *session)</td></tr>
|
|
<tr class="memdesc:a23439df038540b796d4f8adb6b420bc9"><td class="mdescLeft"> </td><td class="mdescRight">Destroy user session. <a href="#a23439df038540b796d4f8adb6b420bc9"></a><br/></td></tr>
|
|
<tr class="separator:a23439df038540b796d4f8adb6b420bc9"><td class="memSeparator" colspan="2"> </td></tr>
|
|
</table>
|
|
<h2 class="groupheader">Function Documentation</h2>
|
|
<a class="anchor" id="a4337dd74e2b07f333f10ffc1189097fd"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="el" href="structqentry__s.html">qentry_t</a>* qcgisess_init </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="el" href="structqentry__s.html">qentry_t</a> * </td>
|
|
<td class="paramname"><em>request</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const char * </td>
|
|
<td class="paramname"><em>dirpath</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Initialize session. </p>
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">request</td><td>a pointer of request structure returned by <a class="el" href="qcgireq_8c.html#aa6f632664932495df12271c427e83b3d" title="Parse one or more request(COOKIE/POST/GET) queries.">qcgireq_parse()</a> </td></tr>
|
|
<tr><td class="paramname">dirpath</td><td>directory path where session data will be kept</td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>a pointer of malloced session data list (qentry_t type)</dd></dl>
|
|
<dl class="section note"><dt>Note</dt><dd>The returned qentry_t list must be de-allocated by calling qentry_t->free(). And if you want to append or remove some user session data, use qentry_t->*() functions then finally call <a class="el" href="qcgisess_8c.html#a2d796ad7b6b322e24f7c1858c8bbab4e" title="Update session data.">qcgisess_save()</a> to store updated session data. </dd></dl>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a8a6384050e074ccffb2e5706d1a5f4af"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">bool qcgisess_settimeout </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="el" href="structqentry__s.html">qentry_t</a> * </td>
|
|
<td class="paramname"><em>session</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">time_t </td>
|
|
<td class="paramname"><em>seconds</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Set the auto-expiration seconds about user session. </p>
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">session</td><td>a pointer of session structure </td></tr>
|
|
<tr><td class="paramname">seconds</td><td>expiration seconds</td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>true if successful, otherwise returns false</dd></dl>
|
|
<dl class="section note"><dt>Note</dt><dd>Default timeout is defined as SESSION_DEFAULT_TIMEOUT_INTERVAL. 1800 seconds </dd></dl>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a098613dd87e9cb88ea5740294dd7064f"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">const char* qcgisess_getid </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="el" href="structqentry__s.html">qentry_t</a> * </td>
|
|
<td class="paramname"><em>session</em></td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Get user session id. </p>
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">session</td><td>a pointer of session structure</td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>a pointer of session identifier</dd></dl>
|
|
<dl class="section note"><dt>Note</dt><dd>Do not free manually </dd></dl>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a21b3fb59842a4a48d74665428a46eca6"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">time_t qcgisess_getcreated </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="el" href="structqentry__s.html">qentry_t</a> * </td>
|
|
<td class="paramname"><em>session</em></td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Get user session created time. </p>
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">session</td><td>a pointer of session structure</td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>user session created time in UTC time seconds </dd></dl>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a2d796ad7b6b322e24f7c1858c8bbab4e"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">bool qcgisess_save </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="el" href="structqentry__s.html">qentry_t</a> * </td>
|
|
<td class="paramname"><em>session</em></td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Update session data. </p>
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">session</td><td>a pointer of session structure</td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>true if successful, otherwise returns false </dd></dl>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a23439df038540b796d4f8adb6b420bc9"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">bool qcgisess_destroy </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="el" href="structqentry__s.html">qentry_t</a> * </td>
|
|
<td class="paramname"><em>session</em></td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Destroy user session. </p>
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">session</td><td>a pointer of session structure</td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>true if successful, otherwise returns false</dd></dl>
|
|
<dl class="section note"><dt>Note</dt><dd>If you only want to de-allocate session structure, just call qentry_t->free(). This will remove all user session data permanantely and also free the session structure. </dd></dl>
|
|
|
|
</div>
|
|
</div>
|
|
</div><!-- contents -->
|
|
<hr class="footer"/><address class="footer"><small>
|
|
<a href="http://www.qdecoder.org/">The qDecoder Project</a>.
|
|
Sat Mar 22 2014 07:44:36
|
|
</small></address>
|
|
</body>
|
|
</html>
|