forked from pipacs/o2
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy patho1.h
124 lines (95 loc) · 4.65 KB
/
o1.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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
#ifndef O1_H
#define O1_H
#include <QNetworkAccessManager>
#include <QUrl>
#include <QNetworkReply>
#include "o0baseauth.h"
class O2ReplyServer;
/// Simple OAuth 1.0 authenticator.
class O1: public O0BaseAuth {
Q_OBJECT
public:
/// Signature method
Q_PROPERTY(QString signatureMethod READ signatureMethod WRITE setSignatureMethod NOTIFY signatureMethodChanged)
QString signatureMethod();
void setSignatureMethod(const QString &value);
/// Token request URL.
Q_PROPERTY(QUrl requestTokenUrl READ requestTokenUrl WRITE setRequestTokenUrl NOTIFY requestTokenUrlChanged)
QUrl requestTokenUrl();
void setRequestTokenUrl(const QUrl &value);
/// Parameters to pass with request URL.
Q_PROPERTY(QList<O0RequestParameter> requestParameters READ requestParameters WRITE setRequestParameters);
QList<O0RequestParameter> requestParameters();
void setRequestParameters(const QList<O0RequestParameter> &value);
/// Callback URL.
/// It should contain a `%1` place marker, to be replaced by `O0BaseAuth::localPort()`.
/// Defaults to `O2_CALLBACK_URL`.
Q_PROPERTY(QString callbackUrl READ callbackUrl WRITE setCallbackUrl)
QString callbackUrl();
void setCallbackUrl(const QString &value);
/// Authorization URL.
Q_PROPERTY(QUrl authorizeUrl READ authorizeUrl WRITE setAuthorizeUrl NOTIFY authorizeUrlChanged)
QUrl authorizeUrl();
void setAuthorizeUrl(const QUrl &value);
/// Access token URL.
Q_PROPERTY(QUrl accessTokenUrl READ accessTokenUrl WRITE setAccessTokenUrl NOTIFY accessTokenUrlChanged)
QUrl accessTokenUrl();
void setAccessTokenUrl(const QUrl &value);
/// Constructor.
explicit O1(QObject *parent = 0);
/// Parse a URL-encoded response string.
static QMap<QString, QString> parseResponse(const QByteArray &response);
/// Build the value of the "Authorization:" header.
static QByteArray buildAuthorizationHeader(const QList<O0RequestParameter> &oauthParams);
/// Create unique bytes to prevent replay attacks.
static QByteArray nonce();
/// Generate signature string depending on signature method type
QByteArray generateSignature(const QList<O0RequestParameter> headers, const QNetworkRequest &req, const QList<O0RequestParameter> &signingParameters, QNetworkAccessManager::Operation operation);
/// Calculate the HMAC-SHA1 signature of a request.
/// @param oauthParams OAuth parameters.
/// @param otherParams Other parameters participating in signing.
/// @param URL Request URL. May contain query parameters, but they will not be used for signing.
/// @param op HTTP operation.
/// @param consumerSecret Consumer (application) secret.
/// @param tokenSecret Authorization token secret (empty if not yet available).
/// @return Signature that can be used as the value of the "oauth_signature" parameter.
static QByteArray sign(const QList<O0RequestParameter> &oauthParams, const QList<O0RequestParameter> &otherParams, const QUrl &url, QNetworkAccessManager::Operation op, const QString &consumerSecret, const QString &tokenSecret);
/// Build a base string for signing.
static QByteArray getRequestBase(const QList<O0RequestParameter> &oauthParams, const QList<O0RequestParameter> &otherParams, const QUrl &url, QNetworkAccessManager::Operation op);
/// Build a concatenated/percent-encoded string from a list of headers.
static QByteArray encodeHeaders(const QList<O0RequestParameter> &headers);
public Q_SLOTS:
/// Authenticate.
Q_INVOKABLE virtual void link();
/// De-authenticate.
Q_INVOKABLE virtual void unlink();
Q_SIGNALS:
void requestTokenUrlChanged();
void authorizeUrlChanged();
void accessTokenUrlChanged();
void signatureMethodChanged();
protected Q_SLOTS:
/// Handle verification received from the reply server.
virtual void onVerificationReceived(QMap<QString,QString> params);
/// Handle token request error.
virtual void onTokenRequestError(QNetworkReply::NetworkError error);
/// Handle token request finished.
virtual void onTokenRequestFinished();
/// Handle token exchange error.
void onTokenExchangeError(QNetworkReply::NetworkError error);
/// Handle token exchange finished.
void onTokenExchangeFinished();
protected:
/// Exchange temporary token to authentication token
void exchangeToken();
QUrl requestUrl_;
QList<O0RequestParameter> requestParameters_;
QString callbackUrl_;
QUrl tokenUrl_;
QUrl refreshTokenUrl_;
QString verifier_;
QString signatureMethod_;
QNetworkAccessManager *manager_;
O2ReplyServer *replyServer_;
};
#endif // O1_H