-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathcertification_authority.h
61 lines (54 loc) · 1.45 KB
/
certification_authority.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
#ifndef CERTIFICATIONAUTHORITY_H
#define CERTIFICATIONAUTHORITY_H
class CertificationAuthority{
private:
unsigned char privateKey[128];
unsigned char publicKey128;
certList validCerts;
cert certificate;
public:
/**
* Creates certificate of user, signs it with CA's private key.
*
* @param userInfo user's personal information
* @param userPublicKey user's public key
*
* @return returns zero when succesful, nonzero value otherwise
*/
cert sign(persInfo userInfo);
/**
* Sends certificate to specified adress.
*
* @param userCert user's certificate encrypted with CA's public key
* @param userAdress user's adress
*
* @return returns zero when succesful, nonzero value otherwise
*/
int sendCert(cert userCert , adress userAdress);
/**
* Adds user's certificate to list of valid certificates.
*
* @param userCert user's certificate
*
* @return returns zero when succesful, nonzero value otherwise
*/
int addToList(cert userCert);
/**
* Removes user's certificate from list of valid certificates
*
* @param userCert user's certificate
*
* @return returns zero when succesful, nonzero value otherwise
*/
int removeFromList(cert userCert);
/**
* Accepts user's request, takes action based on request type.
*
* @param requestType type of request
* @return returns zero when succesful, nonzero value otherwise
*/
int requestAccept(requestType rT);
unsigned char* getPubKey();
bool verifyCert(cert);
};
#endif //CERTIFICATION_AUTHORITY