-
Notifications
You must be signed in to change notification settings - Fork 2
/
Authenticable.h
68 lines (57 loc) · 2.78 KB
/
Authenticable.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
62
63
64
65
66
67
68
#ifndef Authenticable_H
#define Authenticable_H
#include <git2.h>
#include "libgit2wrapper_global.h"
#include <functional>
namespace Git
{
/**
* @brief A Authenticable osztály minden olyan osztály őse, amely autentikációs műveleteket végezhet.
* Önmagában nem példányosítható.
*/
class LIBGIT2WRAPPERSHARED_EXPORT Authenticable
{
public:
/**
* @brief A Authenticable::Credentials osztály egy (jellemzően callback által visszaadott) DTO objektum, amely
* a hálózati autentikációhoz szükséges adatokat tartalmazza.
*
* Amennyiben az objektum üres (`isEmpty`, avagy default konstruktorral inicializált) az jelzés arra, hogy a
* felhasználó megszakította az autentikációs műveletet.
*/
class Credentials
{
private:
std::string username;
std::string password;
bool empty;
public:
Credentials() : username(""), password(""), empty(true) {}
Credentials(const std::string& _username, const std::string& _password) : username(_username)
, password(_password)
, empty(false)
{}
bool isEmpty() const { return empty; }
const std::string& getUsername() const { return username; }
const std::string& getPassword() const { return password; }
};
using AuthenticationCallback = std::function<Git::Authenticable::Credentials()>;
protected:
Authenticable() = default;
/**
* @brief getCredentialsCallbackWrapper Visszaad egy LibGit2 autentikációs művelet során használható callbacket.
* @param getUserCredentialsCallback Felhasználó által szolgáltatott callback, melyet az autentikáció során
* a könyvtár meghív a jelszó és a felhasználónév bekérésére.
* @return Amennyiben paraméterként egy callbacket adunk meg, akkor ezt csomagolja be, egyébként egy olyat ad
* vissza, amely autentikációs lépést nem végez, de jól formált.
*
* @note Az autentikáció megszakítható, amennyiben a paraméterként megadott callback üres Credential objektumot
* ad vissza.
* @note A callback csak akkor fog lefutni, ha az autentikáció ténylegesen szükséges.
*/
git_cred_acquire_cb getCredentialsCallbackWrapper(AuthenticationCallback getUserCredentialsCallback
= nullptr
) const;
};
}
#endif // Authenticable_H