385 lines
43 KiB
HTML
385 lines
43 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<title>Code Coverage for /home/seekdasky/git/projetphp/src/Authentification.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">/home/seekdasky/git/projetphp/src</a></li>
|
|
<li class="active">Authentification.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="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 / 7</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="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 / 37</div></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td class="danger">Authentification</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="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 / 7</div></td>
|
|
<td class="danger small">306</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 / 37</div></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td class="danger" colspan="4"> <a href="#7"><abbr title="__construct()">__construct</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 / 2</div></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td class="danger" colspan="4"> <a href="#17"><abbr title="authentification($user,$mdp)">authentification</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">20</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="#31"><abbr title="deconnection()">deconnection</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 / 3</div></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td class="danger" colspan="4"> <a href="#42"><abbr title="createSecureSession($user,$role)">createSecureSession</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 / 7</div></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td class="danger" colspan="4"> <a href="#57"><abbr title="destroySecureSession()">destroySecureSession</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 / 3</div></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td class="danger" colspan="4"> <a href="#69"><abbr title="checkUser($role, $strict=false)">checkUser</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">72</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 / 12</div></td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td class="danger" colspan="4"> <a href="#83"><abbr title="getCurrentUser()">getCurrentUser</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 / 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="keyword">class</span><span class="default"> </span><span class="default">Authentification</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"><span class="default"> </span><span class="keyword">private</span><span class="default"> </span><span class="default">$users</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="6"></a><a href="#6">6</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="7"></a><a href="#7">7</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">public</span><span class="default"> </span><span class="keyword">function</span><span class="default"> </span><span class="default">__construct</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">{</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="8"></a><a href="#8">8</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">$this</span><span class="default">-></span><span class="default">users</span><span class="default"> </span><span class="keyword">=</span><span class="default"> </span><span class="default">json_decode</span><span class="keyword">(</span><span class="default">file_get_contents</span><span class="keyword">(</span><span class="default">$GLOBALS</span><span class="keyword">[</span><span class="default">'managers_dir'</span><span class="keyword">]</span><span class="keyword">.</span><span class="default">DIRECTORY_SEPARATOR</span><span class="keyword">.</span><span class="default">'config'</span><span class="keyword">.</span><span class="default">DIRECTORY_SEPARATOR</span><span class="keyword">.</span><span class="default">'users.json'</span><span class="keyword">)</span><span class="keyword">,</span><span class="default">true</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="9"></a><a href="#9">9</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">}</span></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="comment"> * méthode d'authentification, utilise param['identifiant'] et param['mdp'] et les comparent à</span></td></tr>
|
|
<tr><td><div align="right"><a name="13"></a><a href="#13">13</a></div></td><td class="codeLine"><span class="comment"> * nos utilisateurs enregistrés puis créer une session securisée par token</span></td></tr>
|
|
<tr><td><div align="right"><a name="14"></a><a href="#14">14</a></div></td><td class="codeLine"><span class="comment"> * @param array $param contiens les infomations de connection</span></td></tr>
|
|
<tr><td><div align="right"><a name="15"></a><a href="#15">15</a></div></td><td class="codeLine"><span class="comment"> * @return json json contenant le résultat de l'authentification (true si authentification correcte, sinon non)</span></td></tr>
|
|
<tr><td><div align="right"><a name="16"></a><a href="#16">16</a></div></td><td class="codeLine"><span class="comment"> */</span></td></tr>
|
|
<tr><td><div align="right"><a name="17"></a><a href="#17">17</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">public</span><span class="default"> </span><span class="keyword">function</span><span class="default"> </span><span class="default">authentification</span><span class="keyword">(</span><span class="default">$user</span><span class="keyword">,</span><span class="default">$mdp</span><span class="keyword">)</span><span class="keyword">{</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="18"></a><a href="#18">18</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">foreach</span><span class="keyword">(</span><span class="default">$this</span><span class="default">-></span><span class="default">users</span><span class="default"> </span><span class="keyword">as</span><span class="default"> </span><span class="default">$utilisateur</span><span class="default">=></span><span class="default">$infos</span><span class="keyword">)</span><span class="keyword">{</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="19"></a><a href="#19">19</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">if</span><span class="keyword">(</span><span class="default">$utilisateur</span><span class="default"> </span><span class="default">==</span><span class="default"> </span><span class="default">$user</span><span class="default"> </span><span class="keyword">and</span><span class="default"> </span><span class="default">$infos</span><span class="keyword">[</span><span class="default">'password'</span><span class="keyword">]</span><span class="default"> </span><span class="default">==</span><span class="default"> </span><span class="default">$mdp</span><span class="keyword">)</span><span class="keyword">{</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="20"></a><a href="#20">20</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">$this</span><span class="default">-></span><span class="default">createSecureSession</span><span class="keyword">(</span><span class="default">$user</span><span class="keyword">,</span><span class="default">$infos</span><span class="keyword">[</span><span class="default">'role'</span><span class="keyword">]</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="21"></a><a href="#21">21</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">return</span><span class="default"> </span><span class="default">true</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><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">}</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="23"></a><a href="#23">23</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">}</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="24"></a><a href="#24">24</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">return</span><span class="default"> </span><span class="default">false</span><span class="keyword">;</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="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">/**</span></td></tr>
|
|
<tr><td><div align="right"><a name="28"></a><a href="#28">28</a></div></td><td class="codeLine"><span class="comment"> * déconnecte l'utilisateur en détruisant la session et le cookie</span></td></tr>
|
|
<tr><td><div align="right"><a name="29"></a><a href="#29">29</a></div></td><td class="codeLine"><span class="comment"> * @return json renvoie true, il n'y aucune raison que ça foire</span></td></tr>
|
|
<tr><td><div align="right"><a name="30"></a><a href="#30">30</a></div></td><td class="codeLine"><span class="comment"> */</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="keyword">public</span><span class="default"> </span><span class="keyword">function</span><span class="default"> </span><span class="default">deconnection</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">{</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">$this</span><span class="default">-></span><span class="default">destroySecureSession</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="33"></a><a href="#33">33</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">Response</span><span class="default">::</span><span class="default">quickResponse</span><span class="keyword">(</span><span class="default">200</span><span class="keyword">,</span><span class="default">json_encode</span><span class="keyword">(</span><span class="keyword">[</span><span class="default">'result'</span><span class="default"> </span><span class="default">=></span><span class="default"> </span><span class="default">true</span><span class="keyword">]</span><span class="keyword">)</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="34"></a><a href="#34">34</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">}</span></td></tr>
|
|
<tr><td><div align="right"><a name="35"></a><a href="#35">35</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="36"></a><a href="#36">36</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/**</span></td></tr>
|
|
<tr><td><div align="right"><a name="37"></a><a href="#37">37</a></div></td><td class="codeLine"><span class="comment"> * créer une session sécurisé , protégé du vol de session par identification de l'utilisateur par navigateur/ip/cookie</span></td></tr>
|
|
<tr><td><div align="right"><a name="38"></a><a href="#38">38</a></div></td><td class="codeLine"><span class="comment"> * @param String $user nom d'utilisateur</span></td></tr>
|
|
<tr><td><div align="right"><a name="39"></a><a href="#39">39</a></div></td><td class="codeLine"><span class="comment"> * @param String $role role de l'utilisateur (0=administrateur, 1= prof, 2=scolarité,3=élève)</span></td></tr>
|
|
<tr><td><div align="right"><a name="40"></a><a href="#40">40</a></div></td><td class="codeLine"><span class="comment"> * @return void</span></td></tr>
|
|
<tr><td><div align="right"><a name="41"></a><a href="#41">41</a></div></td><td class="codeLine"><span class="comment"> */</span></td></tr>
|
|
<tr><td><div align="right"><a name="42"></a><a href="#42">42</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">private</span><span class="default"> </span><span class="keyword">function</span><span class="default"> </span><span class="default">createSecureSession</span><span class="keyword">(</span><span class="default">$user</span><span class="keyword">,</span><span class="default">$role</span><span class="keyword">)</span><span class="keyword">{</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="43"></a><a href="#43">43</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">$id</span><span class="default"> </span><span class="keyword">=</span><span class="default"> </span><span class="default">uniqid</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="44"></a><a href="#44">44</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">$_SESSION</span><span class="keyword">[</span><span class="default">'id'</span><span class="keyword">]</span><span class="default"> </span><span class="keyword">=</span><span class="default"> </span><span class="default">$id</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="45"></a><a href="#45">45</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">$_SESSION</span><span class="keyword">[</span><span class="default">'token'</span><span class="keyword">]</span><span class="default"> </span><span class="keyword">=</span><span class="default"> </span><span class="default">sha1</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="keyword">.</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">$id</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="46"></a><a href="#46">46</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">session_regenerate_id</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="47"></a><a href="#47">47</a></div></td><td class="codeLine"></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="48"></a><a href="#48">48</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">$_SESSION</span><span class="keyword">[</span><span class="default">'user'</span><span class="keyword">]</span><span class="default"> </span><span class="keyword">=</span><span class="default"> </span><span class="default">$user</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="49"></a><a href="#49">49</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">$_SESSION</span><span class="keyword">[</span><span class="default">'role'</span><span class="keyword">]</span><span class="default"> </span><span class="keyword">=</span><span class="default"> </span><span class="default">$role</span><span class="keyword">;</span></td></tr>
|
|
<tr><td><div align="right"><a name="50"></a><a href="#50">50</a></div></td><td class="codeLine"></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="51"></a><a href="#51">51</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">}</span></td></tr>
|
|
<tr><td><div align="right"><a name="52"></a><a href="#52">52</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="53"></a><a href="#53">53</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/**</span></td></tr>
|
|
<tr><td><div align="right"><a name="54"></a><a href="#54">54</a></div></td><td class="codeLine"><span class="comment"> * Détruit une session</span></td></tr>
|
|
<tr><td><div align="right"><a name="55"></a><a href="#55">55</a></div></td><td class="codeLine"><span class="comment"> * @return void</span></td></tr>
|
|
<tr><td><div align="right"><a name="56"></a><a href="#56">56</a></div></td><td class="codeLine"><span class="comment"> */</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="keyword">private</span><span class="default"> </span><span class="keyword">function</span><span class="default"> </span><span class="default">destroySecureSession</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">{</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="58"></a><a href="#58">58</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 class="danger"><td><div align="right"><a name="59"></a><a href="#59">59</a></div></td><td class="codeLine"><span class="default"> </span><span class="default">setcookie</span><span class="keyword">(</span><span class="default">'token'</span><span class="keyword">,</span><span class="default">time</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">-</span><span class="default">1</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><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">}</span></td></tr>
|
|
<tr><td><div align="right"><a name="61"></a><a href="#61">61</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="62"></a><a href="#62">62</a></div></td><td class="codeLine"><span class="default"> </span><span class="comment">/**</span></td></tr>
|
|
<tr><td><div align="right"><a name="63"></a><a href="#63">63</a></div></td><td class="codeLine"><span class="comment"> * Vérifie qu'un utilisateur donné a les droits demandés (passés en paramètres)</span></td></tr>
|
|
<tr><td><div align="right"><a name="64"></a><a href="#64">64</a></div></td><td class="codeLine"><span class="comment"> * @param int $role role minimum</span></td></tr>
|
|
<tr><td><div align="right"><a name="65"></a><a href="#65">65</a></div></td><td class="codeLine"><span class="comment"> * @param boolean $strict si strict vaut true, seul les utilisateurs avec le role précis seront acceptés, sinon tout les utilisateurs</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"> * avec un role superieur le seront</span></td></tr>
|
|
<tr><td><div align="right"><a name="67"></a><a href="#67">67</a></div></td><td class="codeLine"><span class="comment"> * @return boolean</span></td></tr>
|
|
<tr><td><div align="right"><a name="68"></a><a href="#68">68</a></div></td><td class="codeLine"><span class="comment"> */</span></td></tr>
|
|
<tr><td><div align="right"><a name="69"></a><a href="#69">69</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">checkUser</span><span class="keyword">(</span><span class="default">$role</span><span class="keyword">,</span><span class="default"> </span><span class="default">$strict</span><span class="keyword">=</span><span class="default">false</span><span class="keyword">)</span><span class="keyword">{</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="70"></a><a href="#70">70</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">if</span><span class="keyword">(</span><span class="keyword">isset</span><span class="keyword">(</span><span class="default">$_SESSION</span><span class="keyword">[</span><span class="default">'token'</span><span class="keyword">]</span><span class="keyword">)</span><span class="keyword">)</span><span class="keyword">{</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="71"></a><a href="#71">71</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">foreach</span><span class="keyword">(</span><span class="default">$_SESSION</span><span class="keyword">[</span><span class="default">'role'</span><span class="keyword">]</span><span class="default"> </span><span class="keyword">as</span><span class="default"> </span><span class="default">$roleUser</span><span class="keyword">)</span><span class="keyword">{</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="72"></a><a href="#72">72</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">if</span><span class="keyword">(</span><span class="keyword">(</span><span class="default">$strict</span><span class="default"> </span><span class="keyword">and</span><span class="default"> </span><span class="default">$roleUser</span><span class="default"> </span><span class="default">==</span><span class="default"> </span><span class="default">$role</span><span class="keyword">)</span><span class="default"> </span><span class="keyword">or</span><span class="default"> </span><span class="keyword">(</span><span class="keyword">!</span><span class="default">$strict</span><span class="default"> </span><span class="keyword">and</span><span class="default"> </span><span class="default">$roleUser</span><span class="default"><=</span><span class="default"> </span><span class="default">$role</span><span class="keyword">)</span><span class="keyword">)</span><span class="keyword">{</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="73"></a><a href="#73">73</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">if</span><span class="keyword">(</span><span class="default">$_SESSION</span><span class="keyword">[</span><span class="default">'token'</span><span class="keyword">]</span><span class="default"> </span><span class="default">==</span><span class="default"> </span><span class="default">sha1</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="keyword">.</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">$_SESSION</span><span class="keyword">[</span><span class="default">'id'</span><span class="keyword">]</span><span class="keyword">)</span><span class="keyword">)</span><span class="keyword">{</span></td></tr>
|
|
<tr class="danger"><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">session_regenerate_id</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="75"></a><a href="#75">75</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">return</span><span class="default"> </span><span class="default">true</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="76"></a><a href="#76">76</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">}</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="77"></a><a href="#77">77</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">}</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="78"></a><a href="#78">78</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">}</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="79"></a><a href="#79">79</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">}</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="80"></a><a href="#80">80</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">return</span><span class="default"> </span><span class="default">false</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="81"></a><a href="#81">81</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">}</span></td></tr>
|
|
<tr><td><div align="right"><a name="82"></a><a href="#82">82</a></div></td><td class="codeLine"></td></tr>
|
|
<tr><td><div align="right"><a name="83"></a><a href="#83">83</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">getCurrentUser</span><span class="keyword">(</span><span class="keyword">)</span><span class="keyword">{</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="84"></a><a href="#84">84</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">return</span><span class="default"> </span><span class="default">$_SESSION</span><span class="keyword">[</span><span class="default">'user'</span><span class="keyword">]</span><span class="keyword">;</span></td></tr>
|
|
<tr class="danger"><td><div align="right"><a name="85"></a><a href="#85">85</a></div></td><td class="codeLine"><span class="default"> </span><span class="keyword">}</span></td></tr>
|
|
<tr><td><div align="right"><a name="86"></a><a href="#86">86</a></div></td><td class="codeLine"><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"><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 3.0.2</a> using <a href="http://php.net/" target="_top">PHP 7.0.0RC7</a> and <a href="https://phpunit.de/">PHPUnit 5.0.10</a> at Thu Dec 3 12:04:42 UTC 2015.</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>
|