351 lines
50 KiB
HTML
Executable File
351 lines
50 KiB
HTML
Executable File
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<title>Code Coverage for /var/www/socioview/manager/sessionManager.php</title>
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
<link href="css/bootstrap.min.css" rel="stylesheet">
|
|
<link href="css/style.css" rel="stylesheet">
|
|
<!--[if lt IE 9]>
|
|
<script src="js/html5shiv.min.js"></script>
|
|
<script src="js/respond.min.js"></script>
|
|
<![endif]-->
|
|
</head>
|
|
<body>
|
|
<header>
|
|
<div class="container">
|
|
<div class="row">
|
|
<div class="col-md-12">
|
|
<ol class="breadcrumb">
|
|
<li><a href="index.html">/var/www/socioview/manager</a></li>
|
|
<li class="active">sessionManager.php</li>
|
|
|
|
</ol>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</header>
|
|
<div class="container">
|
|
<table class="table table-bordered">
|
|
<thead>
|
|
<tr>
|
|
<td> </td>
|
|
<td colspan="10"><div align="center"><strong>Code Coverage</strong></div></td>
|
|
</tr>
|
|
<tr>
|
|
<td> </td>
|
|
<td colspan="3"><div align="center"><strong>Classes and Traits</strong></div></td>
|
|
<td colspan="4"><div align="center"><strong>Functions and Methods</strong></div></td>
|
|
<td colspan="3"><div align="center"><strong>Lines</strong></div></td>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
<tr>
|
|
<td class="danger">Total</td>
|
|
<td class="danger big"> <div class="progress">
|
|
<div class="progress-bar progress-bar-danger" role="progressbar" aria-valuenow="0.00" aria-valuemin="0" aria-valuemax="100" style="width: 0.00%">
|
|
<span class="sr-only">0.00% covered (danger)</span>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="danger small"><div align="right">0.00%</div></td>
|
|
<td class="danger small"><div align="right">0 / 1</div></td>
|
|
<td class="danger big"> <div class="progress">
|
|
<div class="progress-bar progress-bar-danger" role="progressbar" aria-valuenow="25.00" aria-valuemin="0" aria-valuemax="100" style="width: 25.00%">
|
|
<span class="sr-only">25.00% covered (danger)</span>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="danger small"><div align="right">25.00%</div></td>
|
|
<td class="danger small"><div align="right">1 / 4</div></td>
|
|
<td class="danger small"><abbr title="Change Risk Anti-Patterns (CRAP) Index">CRAP</abbr></td>
|
|
<td class="danger big"> <div class="progress">
|
|
<div class="progress-bar progress-bar-danger" role="progressbar" aria-valuenow="6.25" aria-valuemin="0" aria-valuemax="100" style="width: 6.25%">
|
|
<span class="sr-only">6.25% covered (danger)</span>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="danger small"><div align="right">6.25%</div></td>
|
|
<td class="danger small"><div align="right">1 / 16</div></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td class="danger">sessionManager</td>
|
|
<td class="danger big"> <div class="progress">
|
|
<div class="progress-bar progress-bar-danger" role="progressbar" aria-valuenow="0.00" aria-valuemin="0" aria-valuemax="100" style="width: 0.00%">
|
|
<span class="sr-only">0.00% covered (danger)</span>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="danger small"><div align="right">0.00%</div></td>
|
|
<td class="danger small"><div align="right">0 / 1</div></td>
|
|
<td class="danger big"> <div class="progress">
|
|
<div class="progress-bar progress-bar-danger" role="progressbar" aria-valuenow="25.00" aria-valuemin="0" aria-valuemax="100" style="width: 25.00%">
|
|
<span class="sr-only">25.00% covered (danger)</span>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="danger small"><div align="right">25.00%</div></td>
|
|
<td class="danger small"><div align="right">1 / 4</div></td>
|
|
<td class="danger small">110.70</td>
|
|
<td class="danger big"> <div class="progress">
|
|
<div class="progress-bar progress-bar-danger" role="progressbar" aria-valuenow="6.25" aria-valuemin="0" aria-valuemax="100" style="width: 6.25%">
|
|
<span class="sr-only">6.25% covered (danger)</span>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="danger small"><div align="right">6.25%</div></td>
|
|
<td class="danger small"><div align="right">1 / 16</div></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td class="success" colspan="4"> <a href="#14"><abbr title="sha1($data)">sha1</abbr></a></td>
|
|
<td class="success big"> <div class="progress">
|
|
<div class="progress-bar progress-bar-success" role="progressbar" aria-valuenow="100.00" aria-valuemin="0" aria-valuemax="100" style="width: 100.00%">
|
|
<span class="sr-only">100.00% covered (success)</span>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="success small"><div align="right">100.00%</div></td>
|
|
<td class="success small"><div align="right">1 / 1</div></td>
|
|
<td class="success small">1</td>
|
|
<td class="success big"> <div class="progress">
|
|
<div class="progress-bar progress-bar-success" role="progressbar" aria-valuenow="100.00" aria-valuemin="0" aria-valuemax="100" style="width: 100.00%">
|
|
<span class="sr-only">100.00% covered (success)</span>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="success small"><div align="right">100.00%</div></td>
|
|
<td class="success small"><div align="right">1 / 1</div></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td class="danger" colspan="4"> <a href="#22"><abbr title="reset_session($session_id=null)">reset_session</abbr></a></td>
|
|
<td class="danger big"> <div class="progress">
|
|
<div class="progress-bar progress-bar-danger" role="progressbar" aria-valuenow="0.00" aria-valuemin="0" aria-valuemax="100" style="width: 0.00%">
|
|
<span class="sr-only">0.00% covered (danger)</span>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="danger small"><div align="right">0.00%</div></td>
|
|
<td class="danger small"><div align="right">0 / 1</div></td>
|
|
<td class="danger small">6</td>
|
|
<td class="danger big"> <div class="progress">
|
|
<div class="progress-bar progress-bar-danger" role="progressbar" aria-valuenow="0.00" aria-valuemin="0" aria-valuemax="100" style="width: 0.00%">
|
|
<span class="sr-only">0.00% covered (danger)</span>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="danger small"><div align="right">0.00%</div></td>
|
|
<td class="danger small"><div align="right">0 / 8</div></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td class="danger" colspan="4"> <a href="#46"><abbr title="update_token()">update_token</abbr></a></td>
|
|
<td class="danger big"> <div class="progress">
|
|
<div class="progress-bar progress-bar-danger" role="progressbar" aria-valuenow="0.00" aria-valuemin="0" aria-valuemax="100" style="width: 0.00%">
|
|
<span class="sr-only">0.00% covered (danger)</span>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="danger small"><div align="right">0.00%</div></td>
|
|
<td class="danger small"><div align="right">0 / 1</div></td>
|
|
<td class="danger small">2</td>
|
|
<td class="danger big"> <div class="progress">
|
|
<div class="progress-bar progress-bar-danger" role="progressbar" aria-valuenow="0.00" aria-valuemin="0" aria-valuemax="100" style="width: 0.00%">
|
|
<span class="sr-only">0.00% covered (danger)</span>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="danger small"><div align="right">0.00%</div></td>
|
|
<td class="danger small"><div align="right">0 / 5</div></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td class="danger" colspan="4"> <a href="#60"><abbr title="session_start()">session_start</abbr></a></td>
|
|
<td class="danger big"> <div class="progress">
|
|
<div class="progress-bar progress-bar-danger" role="progressbar" aria-valuenow="0.00" aria-valuemin="0" aria-valuemax="100" style="width: 0.00%">
|
|
<span class="sr-only">0.00% covered (danger)</span>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="danger small"><div align="right">0.00%</div></td>
|
|
<td class="danger small"><div align="right">0 / 1</div></td>
|
|
<td class="danger small">56</td>
|
|
<td class="danger big"> <div class="progress">
|
|
<div class="progress-bar progress-bar-danger" role="progressbar" aria-valuenow="0.00" aria-valuemin="0" aria-valuemax="100" style="width: 0.00%">
|
|
<span class="sr-only">0.00% covered (danger)</span>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="danger small"><div align="right">0.00%</div></td>
|
|
<td class="danger small"><div align="right">0 / 2</div></td>
|
|
</tr>
|
|
|
|
|
|
</tbody>
|
|
</table>
|
|
<table id="code" class="table table-borderless table-condensed">
|
|
<tbody>
|
|
<tr><td><div align="right"><a name="1"></a><a href="#1">1</a></div></td><td class="codeLine"><span class="default"><?php</span></td></tr>
|
|
<tr><td><div align="right"><a name="2"></a><a href="#2">2</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="3"></a><a href="#3">3</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">namespace</span><span class="default"> </span><span class="default">manager</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="4"></a><a href="#4">4</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="5"></a><a href="#5">5</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="6"></a><a href="#6">6</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">class</span><span class="default"> </span><span class="default">sessionManager</span><span class="keyword">{</span></td></tr>
|
|
<tr><td><div align="right"><a name="7"></a><a href="#7">7</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="8"></a><a href="#8">8</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">private</span><span class="default"> </span><span class="keyword">static</span><span class="default"> </span><span class="default">$prefix</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="9"></a><a href="#9">9</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="10"></a><a href="#10">10</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="11"></a><a href="#11">11</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/*************************/</span></td></tr>
|
|
<tr><td><div align="right"><a name="12"></a><a href="#12">12</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/* SECURE SHA1 ALGORITHM */</span></td></tr>
|
|
<tr><td><div align="right"><a name="13"></a><a href="#13">13</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/*************************/</span></td></tr>
|
|
<tr><td><div align="right"><a name="14"></a><a href="#14">14</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">public</span><span class="default"> </span><span class="keyword">static</span><span class="default"> </span><span class="keyword">function</span><span class="default"> </span><span class="default">sha1</span><span class="keyword">(</span><span class="default">$data</span><span class="keyword">)</span><span class="keyword">{</span></td></tr>
|
|
<tr class="covered-by-large-tests popin" data-title="2 tests cover line 15" data-content="<ul><li class="covered-by-large-tests">phpunit\Database_check::testPasswordSizeEqCorrect</li><li class="covered-by-large-tests">phpunit\Database_check::testPasswordSizeSupIncorrect</li></ul>" data-placement="bottom" data-html="true"><td><div align="right"><a name="15"></a><a href="#15">15</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">return</span><span class="default"> </span><span class="default">sha1</span><span class="keyword">(</span><span class="default"> </span><span class="default">'">\[..|{@#))'</span><span class="keyword">.</span><span class="default">sha1</span><span class="keyword">(</span><span class="default">$data</span><span class="keyword">.</span><span class="default">'_)Q@#((%*_$%(@#'</span><span class="keyword">)</span><span class="default"> </span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr class="warning"><td><div align="right"><a name="16"></a><a href="#16">16</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">}</span></td></tr>
|
|
<tr><td><div align="right"><a name="17"></a><a href="#17">17</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="18"></a><a href="#18">18</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="19"></a><a href="#19">19</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/*****************************/</span></td></tr>
|
|
<tr><td><div align="right"><a name="20"></a><a href="#20">20</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/* INITIALISATION DE SESSION */</span></td></tr>
|
|
<tr><td><div align="right"><a name="21"></a><a href="#21">21</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/*****************************/</span></td></tr>
|
|
<tr><td><div align="right"><a name="22"></a><a href="#22">22</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">private</span><span class="default"> </span><span class="keyword">static</span><span class="default"> </span><span class="keyword">function</span><span class="default"> </span><span class="default">reset_session</span><span class="keyword">(</span><span class="default">$session_id</span><span class="keyword">=</span><span class="default">null</span><span class="keyword">)</span><span class="keyword">{</span></td></tr>
|
|
<tr><td><div align="right"><a name="23"></a><a href="#23">23</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="24"></a><a href="#24">24</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">// On ferme la session</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="25"></a><a href="#25">25</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">session_destroy</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="26"></a><a href="#26">26</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="27"></a><a href="#27">27</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">// On definit l'id session si donne en argument</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="28"></a><a href="#28">28</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">if</span><span class="keyword">(</span><span class="default"> </span><span class="default">$session_id</span><span class="default"> </span><span class="default">!=</span><span class="default"> </span><span class="default">null</span><span class="default"> </span><span class="keyword">)</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="29"></a><a href="#29">29</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">session_id</span><span class="keyword">(</span><span class="default"> </span><span class="default">$session_id</span><span class="default"> </span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="30"></a><a href="#30">30</a></div></td><td class="codeLine"><span class="default"> </span></td></tr>
|
|
<tr><td><div align="right"><a name="31"></a><a href="#31">31</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">// Precaution: on met a jour le cookie</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="32"></a><a href="#32">32</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">setcookie</span><span class="keyword">(</span><span class="default"> </span><span class="default">'PHPSESSID'</span><span class="keyword">,</span><span class="default"> </span><span class="default">session_id</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">,</span><span class="default"> </span><span class="default">time</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">+</span><span class="default">60</span><span class="keyword">*</span><span class="default">30</span><span class="keyword">,</span><span class="default"> </span><span class="default">'/'</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="33"></a><a href="#33">33</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="34"></a><a href="#34">34</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">// On redemarre la session avec le bon id session</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="35"></a><a href="#35">35</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">\</span><span class="default">session_start</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="36"></a><a href="#36">36</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="37"></a><a href="#37">37</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">// On met a jour le token</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="38"></a><a href="#38">38</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">self</span><span class="default">::</span><span class="default">update_token</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="39"></a><a href="#39">39</a></div></td><td class="codeLine"></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="40"></a><a href="#40">40</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">header</span><span class="keyword">(</span><span class="default">'Refresh: 0'</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="41"></a><a href="#41">41</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">}</span></td></tr>
|
|
<tr><td><div align="right"><a name="42"></a><a href="#42">42</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="43"></a><a href="#43">43</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/*******************/</span></td></tr>
|
|
<tr><td><div align="right"><a name="44"></a><a href="#44">44</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/* GENERE UN TOKEN */</span></td></tr>
|
|
<tr><td><div align="right"><a name="45"></a><a href="#45">45</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/*******************/</span></td></tr>
|
|
<tr><td><div align="right"><a name="46"></a><a href="#46">46</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">private</span><span class="default"> </span><span class="keyword">static</span><span class="default"> </span><span class="keyword">function</span><span class="default"> </span><span class="default">update_token</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">{</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="47"></a><a href="#47">47</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">$token</span><span class="default"> </span><span class="keyword">=</span><span class="default"> </span><span class="default">self</span><span class="default">::</span><span class="default">$prefix</span><span class="keyword">.</span><span class="default">self</span><span class="default">::</span><span class="default">sha1</span><span class="keyword">(</span><span class="default">uniqid</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="48"></a><a href="#48">48</a></div></td><td class="codeLine"><span class="default"> </span></td></tr>
|
|
<tr><td><div align="right"><a name="49"></a><a href="#49">49</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">// On definit le token en session</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="50"></a><a href="#50">50</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">$_SESSION</span><span class="keyword">[</span><span class="default">'session_token'</span><span class="keyword">]</span><span class="default"> </span><span class="keyword">=</span><span class="default"> </span><span class="default">$token</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="51"></a><a href="#51">51</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="52"></a><a href="#52">52</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">// On definit le token en cookie</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="53"></a><a href="#53">53</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">$_COOKIE</span><span class="keyword">[</span><span class="default">'session_token'</span><span class="keyword">]</span><span class="default"> </span><span class="keyword">=</span><span class="default"> </span><span class="default">$_SESSION</span><span class="keyword">[</span><span class="default">'session_token'</span><span class="keyword">]</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="54"></a><a href="#54">54</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">setcookie</span><span class="keyword">(</span><span class="default"> </span><span class="default">'session_token'</span><span class="keyword">,</span><span class="default"> </span><span class="default">$_COOKIE</span><span class="keyword">[</span><span class="default">'session_token'</span><span class="keyword">]</span><span class="keyword">,</span><span class="default"> </span><span class="default">time</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">+</span><span class="default">60</span><span class="keyword">*</span><span class="default">30</span><span class="keyword">,</span><span class="default"> </span><span class="default">'/'</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="55"></a><a href="#55">55</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">}</span></td></tr>
|
|
<tr><td><div align="right"><a name="56"></a><a href="#56">56</a></div></td><td class="codeLine"><span class="default"> </span></td></tr>
|
|
<tr><td><div align="right"><a name="57"></a><a href="#57">57</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/************/</span></td></tr>
|
|
<tr><td><div align="right"><a name="58"></a><a href="#58">58</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/* AMORCEUR */</span></td></tr>
|
|
<tr><td><div align="right"><a name="59"></a><a href="#59">59</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/************/</span></td></tr>
|
|
<tr><td><div align="right"><a name="60"></a><a href="#60">60</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">public</span><span class="default"> </span><span class="keyword">static</span><span class="default"> </span><span class="keyword">function</span><span class="default"> </span><span class="default">session_start</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">{</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="61"></a><a href="#61">61</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">\</span><span class="default">session_start</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="62"></a><a href="#62">62</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">return</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="63"></a><a href="#63">63</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="64"></a><a href="#64">64</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="65"></a><a href="#65">65</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/* [1] Génération et Gestion des donnees a utiliser</span></td></tr>
|
|
<tr><td><div align="right"><a name="66"></a><a href="#66">66</a></div></td><td class="codeLine"><span class="comment"> ==============================================================*/</span></td></tr>
|
|
<tr><td><div align="right"><a name="67"></a><a href="#67">67</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">// On genere le hash a partir des donnees personnelles</span></td></tr>
|
|
<tr class="warning"><td><div align="right"><a name="68"></a><a href="#68">68</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">self</span><span class="default">::</span><span class="default">$prefix</span><span class="default"> </span><span class="keyword">=</span><span class="default"> </span><span class="default">self</span><span class="default">::</span><span class="default">sha1</span><span class="keyword">(</span><span class="default"> </span><span class="default">$_SERVER</span><span class="keyword">[</span><span class="default">'REMOTE_ADDR'</span><span class="keyword">]</span><span class="keyword">.</span><span class="default">$_SERVER</span><span class="keyword">[</span><span class="default">'HTTP_USER_AGENT'</span><span class="keyword">]</span><span class="default"> </span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="69"></a><a href="#69">69</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="70"></a><a href="#70">70</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">// On cree un id session associe aux donnees personnelles</span></td></tr>
|
|
<tr class="warning"><td><div align="right"><a name="71"></a><a href="#71">71</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">$sessid</span><span class="default"> </span><span class="keyword">=</span><span class="default"> </span><span class="default">substr</span><span class="keyword">(</span><span class="default">self</span><span class="default">::</span><span class="default">$prefix</span><span class="keyword">,</span><span class="default">0</span><span class="keyword">,</span><span class="default">5</span><span class="keyword">)</span><span class="default"> </span><span class="keyword">.</span><span class="default"> </span><span class="default">substr</span><span class="keyword">(</span><span class="default">self</span><span class="default">::</span><span class="default">sha1</span><span class="keyword">(</span><span class="default">uniqid</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">)</span><span class="keyword">,</span><span class="default">0</span><span class="keyword">,</span><span class="default">24</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="72"></a><a href="#72">72</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="73"></a><a href="#73">73</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">// On genere un token pour l'execution suivante</span></td></tr>
|
|
<tr class="warning"><td><div align="right"><a name="74"></a><a href="#74">74</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">$token</span><span class="default"> </span><span class="keyword">=</span><span class="default"> </span><span class="default">self</span><span class="default">::</span><span class="default">$prefix</span><span class="keyword">.</span><span class="default">self</span><span class="default">::</span><span class="default">sha1</span><span class="keyword">(</span><span class="default">uniqid</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="75"></a><a href="#75">75</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="76"></a><a href="#76">76</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">// On definit/recupere le token</span></td></tr>
|
|
<tr class="warning"><td><div align="right"><a name="77"></a><a href="#77">77</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">$session_token</span><span class="default"> </span><span class="keyword">=</span><span class="default"> </span><span class="keyword">(</span><span class="keyword">isset</span><span class="keyword">(</span><span class="default">$_COOKIE</span><span class="keyword">[</span><span class="default">'session_token'</span><span class="keyword">]</span><span class="keyword">)</span><span class="keyword">)</span><span class="default"> </span><span class="keyword">?</span><span class="default"> </span><span class="default">$_COOKIE</span><span class="keyword">[</span><span class="default">'session_token'</span><span class="keyword">]</span><span class="default"> </span><span class="keyword">:</span><span class="default"> </span><span class="default">null</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="78"></a><a href="#78">78</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="79"></a><a href="#79">79</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="80"></a><a href="#80">80</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="81"></a><a href="#81">81</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/* [2] Verification de l'id session</span></td></tr>
|
|
<tr><td><div align="right"><a name="82"></a><a href="#82">82</a></div></td><td class="codeLine"><span class="comment"> ==============================================================*/</span></td></tr>
|
|
<tr class="warning"><td><div align="right"><a name="83"></a><a href="#83">83</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">\</span><span class="default">session_start</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="84"></a><a href="#84">84</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="85"></a><a href="#85">85</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">// On verifie l'id session (5 premiers chars du hash des donnees perso)</span></td></tr>
|
|
<tr class="warning"><td><div align="right"><a name="86"></a><a href="#86">86</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">$valid_sessid</span><span class="default"> </span><span class="keyword">=</span><span class="default"> </span><span class="default">strpos</span><span class="keyword">(</span><span class="default"> </span><span class="default">session_id</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">,</span><span class="default"> </span><span class="default">substr</span><span class="keyword">(</span><span class="default">self</span><span class="default">::</span><span class="default">$prefix</span><span class="keyword">,</span><span class="default">0</span><span class="keyword">,</span><span class="default">5</span><span class="keyword">)</span><span class="default"> </span><span class="keyword">)</span><span class="default"> </span><span class="default">===</span><span class="default"> </span><span class="default">0</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="87"></a><a href="#87">87</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="88"></a><a href="#88">88</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">// Si id session incorrect ou pas de token </span></td></tr>
|
|
<tr class="warning"><td><div align="right"><a name="89"></a><a href="#89">89</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">if</span><span class="keyword">(</span><span class="default"> </span><span class="keyword">!</span><span class="default">$valid_sessid</span><span class="default"> </span><span class="keyword">)</span></td></tr>
|
|
<tr class="warning"><td><div align="right"><a name="90"></a><a href="#90">90</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">self</span><span class="default">::</span><span class="default">reset_session</span><span class="keyword">(</span><span class="default"> </span><span class="default">$sessid</span><span class="default"> </span><span class="keyword">)</span><span class="keyword">;</span><span class="default"> </span><span class="comment">// On initialise la session (bon id session)</span></td></tr>
|
|
<tr><td><div align="right"><a name="91"></a><a href="#91">91</a></div></td><td class="codeLine"><span class="default"> </span></td></tr>
|
|
<tr><td><div align="right"><a name="92"></a><a href="#92">92</a></div></td><td class="codeLine"><span class="default"> </span></td></tr>
|
|
<tr><td><div align="right"><a name="93"></a><a href="#93">93</a></div></td><td class="codeLine"><span class="default"> </span></td></tr>
|
|
<tr><td><div align="right"><a name="94"></a><a href="#94">94</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/* [3] Verification du token</span></td></tr>
|
|
<tr><td><div align="right"><a name="95"></a><a href="#95">95</a></div></td><td class="codeLine"><span class="comment"> ==============================================================*/</span></td></tr>
|
|
<tr><td><div align="right"><a name="96"></a><a href="#96">96</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">// On verifie que le token est valide</span></td></tr>
|
|
<tr class="warning"><td><div align="right"><a name="97"></a><a href="#97">97</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">$valid_token</span><span class="default"> </span><span class="keyword">=</span><span class="default"> </span><span class="default">$session_token</span><span class="default"> </span><span class="default">!=</span><span class="default"> </span><span class="default">null</span><span class="keyword">;</span><span class="default"> </span><span class="comment">// verification de l'existence du cookie</span></td></tr>
|
|
<tr class="warning"><td><div align="right"><a name="98"></a><a href="#98">98</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">$valid_token</span><span class="default"> </span><span class="keyword">=</span><span class="default"> </span><span class="default">$valid_token</span><span class="default"> </span><span class="default">&&</span><span class="default"> </span><span class="default">strpos</span><span class="keyword">(</span><span class="default">$session_token</span><span class="keyword">,</span><span class="default"> </span><span class="default">self</span><span class="default">::</span><span class="default">$prefix</span><span class="keyword">)</span><span class="default"> </span><span class="default">===</span><span class="default"> </span><span class="default">0</span><span class="keyword">;</span><span class="default"> </span><span class="comment">// verification des donnes personnelles</span></td></tr>
|
|
<tr class="warning"><td><div align="right"><a name="99"></a><a href="#99">99</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">$valid_token</span><span class="default"> </span><span class="keyword">=</span><span class="default"> </span><span class="default">$valid_token</span><span class="default"> </span><span class="default">&&</span><span class="default"> </span><span class="keyword">isset</span><span class="keyword">(</span><span class="default">$_SESSION</span><span class="keyword">[</span><span class="default">'session_token'</span><span class="keyword">]</span><span class="keyword">)</span><span class="keyword">;</span><span class="default"> </span><span class="comment">// verification que la variable session associee existe</span></td></tr>
|
|
<tr class="warning"><td><div align="right"><a name="100"></a><a href="#100">100</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">$valid_token</span><span class="default"> </span><span class="keyword">=</span><span class="default"> </span><span class="default">$valid_token</span><span class="default"> </span><span class="default">&&</span><span class="default"> </span><span class="default">$_SESSION</span><span class="keyword">[</span><span class="default">'session_token'</span><span class="keyword">]</span><span class="default"> </span><span class="default">==</span><span class="default"> </span><span class="default">$_COOKIE</span><span class="keyword">[</span><span class="default">'session_token'</span><span class="keyword">]</span><span class="keyword">;</span><span class="default"> </span><span class="comment">// verification que la session est coherente</span></td></tr>
|
|
<tr><td><div align="right"><a name="101"></a><a href="#101">101</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="102"></a><a href="#102">102</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/* [4] Si token inexistant</span></td></tr>
|
|
<tr><td><div align="right"><a name="103"></a><a href="#103">103</a></div></td><td class="codeLine"><span class="comment"> ==============================================================*/</span></td></tr>
|
|
<tr class="warning"><td><div align="right"><a name="104"></a><a href="#104">104</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">if</span><span class="keyword">(</span><span class="default"> </span><span class="keyword">!</span><span class="default">$valid_token</span><span class="default"> </span><span class="keyword">)</span></td></tr>
|
|
<tr class="warning"><td><div align="right"><a name="105"></a><a href="#105">105</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">self</span><span class="default">::</span><span class="default">reset_session</span><span class="keyword">(</span><span class="default">$sessid</span><span class="keyword">)</span><span class="keyword">;</span><span class="default"> </span><span class="comment">// On initialise la session</span></td></tr>
|
|
<tr><td><div align="right"><a name="106"></a><a href="#106">106</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">else</span></td></tr>
|
|
<tr class="warning"><td><div align="right"><a name="107"></a><a href="#107">107</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">self</span><span class="default">::</span><span class="default">update_token</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">;</span><span class="default"> </span><span class="comment">// Dans tous les cas, on cree un nouveau token</span></td></tr>
|
|
<tr><td><div align="right"><a name="108"></a><a href="#108">108</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="109"></a><a href="#109">109</a></div></td><td class="codeLine"></td></tr>
|
|
<tr class="warning"><td><div align="right"><a name="110"></a><a href="#110">110</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">}</span></td></tr>
|
|
<tr><td><div align="right"><a name="111"></a><a href="#111">111</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="112"></a><a href="#112">112</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="113"></a><a href="#113">113</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">}</span></td></tr>
|
|
<tr><td><div align="right"><a name="114"></a><a href="#114">114</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="115"></a><a href="#115">115</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="116"></a><a href="#116">116</a></div></td><td class="codeLine"><span class="default">?></span></td></tr>
|
|
|
|
</tbody>
|
|
</table>
|
|
<footer>
|
|
<hr/>
|
|
<h4>Legend</h4>
|
|
<p>
|
|
<span class="success"><strong>Executed</strong></span>
|
|
<span class="danger"><strong>Not Executed</strong></span>
|
|
<span class="warning"><strong>Dead Code</strong></span>
|
|
</p>
|
|
<p>
|
|
<small>Generated by <a href="http://github.com/sebastianbergmann/php-code-coverage" target="_top">PHP_CodeCoverage 2.1.7</a> using <a href="http://php.net/" target="_top">PHP 5.6.11-1ubuntu3.1</a> and <a href="http://phpunit.de/">PHPUnit 4.7.6</a> at Sun Apr 17 14:38:12 UTC 2016.</small>
|
|
</p>
|
|
<a title="Back to the top" id="toplink" href="#"><span class="glyphicon glyphicon-arrow-up"></span></a>
|
|
</footer>
|
|
</div>
|
|
<script src="js/jquery.min.js" type="text/javascript"></script>
|
|
<script src="js/bootstrap.min.js" type="text/javascript"></script>
|
|
<script src="js/holder.min.js" type="text/javascript"></script>
|
|
<script type="text/javascript">
|
|
$(function() {
|
|
var $window = $(window)
|
|
, $top_link = $('#toplink')
|
|
, $body = $('body, html')
|
|
, offset = $('#code').offset().top;
|
|
|
|
$top_link.hide().click(function(event) {
|
|
event.preventDefault();
|
|
$body.animate({scrollTop:0}, 800);
|
|
});
|
|
|
|
$window.scroll(function() {
|
|
if($window.scrollTop() > offset) {
|
|
$top_link.fadeIn();
|
|
} else {
|
|
$top_link.fadeOut();
|
|
}
|
|
}).scroll();
|
|
|
|
$('.popin').popover({trigger: 'hover'});
|
|
});
|
|
</script>
|
|
</body>
|
|
</html>
|