dabc7821
Geoffrey PREUD'HOMME
Oups
|
1
2
3
4
5
6
7
8
9
10
|
package etunicorn;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.ManyToOne;
import java.math.BigInteger;
import java.security.SecureRandom;
import java.util.Date;
/**
|
8f35fffd
Geoffrey PREUD'HOMME
Ajout de la sécurité
|
11
12
13
|
* etunicorn-server
* Copyright © 2017 Le Club Info Polytech Lille
* Tous droits réservés
|
dabc7821
Geoffrey PREUD'HOMME
Oups
|
14
15
16
17
18
19
20
|
*/
@Entity
public class Session {
// Durée par défaut d'une session en secondes
private static final int SESSION_DURATION = 10 * 60;
private static SecureRandom random = new SecureRandom();
|
8f35fffd
Geoffrey PREUD'HOMME
Ajout de la sécurité
|
21
|
// TODO Vérifier si c'est bien initialisé qu'une seule fois par éxecution car c'est lourd à initialiser
|
dabc7821
Geoffrey PREUD'HOMME
Oups
|
22
23
24
25
|
@ManyToOne
private Personne personne;
@Id
private String token;
|
dabc7821
Geoffrey PREUD'HOMME
Oups
|
26
27
28
29
30
31
32
33
34
35
36
37
38
|
private Date validity;
public Session() {
}
public Session(Personne personne) {
this.personne = personne;
// From http://stackoverflow.com/a/41156
this.token = new BigInteger(130, random).toString(32);
this.validity = new Date(new Date().getTime() + SESSION_DURATION * 1000);
}
|
8f35fffd
Geoffrey PREUD'HOMME
Ajout de la sécurité
|
39
40
41
42
43
44
|
public Session(Personne personne, String token, Date validity) {
this.personne = personne;
this.token = token;
this.validity = validity;
}
|
dabc7821
Geoffrey PREUD'HOMME
Oups
|
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
public Personne getPersonne() {
return personne;
}
public void setPersonne(Personne personne) {
this.personne = personne;
}
public String getToken() {
return token;
}
public void setToken(String token) {
this.token = token;
}
public Date getValidity() {
return validity;
}
public void setValidity(Date validity) {
this.validity = validity;
}
|
8f35fffd
Geoffrey PREUD'HOMME
Ajout de la sécurité
|
68
69
70
71
|
public boolean hasPermission(Permission permission) {
return personne.hasPermission(permission);
}
|
dabc7821
Geoffrey PREUD'HOMME
Oups
|
72
|
}
|