File indexing completed on 2025-10-19 04:00:07

0001 #ifndef O1_H
0002 #define O1_H
0003 
0004 #include <QNetworkAccessManager>
0005 #include <QUrl>
0006 #include <QNetworkReply>
0007 
0008 #include "o0export.h"
0009 #include "o0baseauth.h"
0010 
0011 /// Simple OAuth 1.0 authenticator.
0012 class O0_EXPORT O1: public O0BaseAuth {
0013     Q_OBJECT
0014 
0015 public:
0016     /// HTTP User-Agent header
0017     /// Set user agent to a value unique for your application (https://tools.ietf.org/html/rfc7231#section-5.5.3)
0018     /// if you see the following error in the application log:
0019     /// O1::onTokenRequestError: 201 "Error transferring requestTokenUrl() - server replied: Forbidden" "Bad bot"
0020     Q_PROPERTY(QByteArray userAgent READ userAgent WRITE setUserAgent)
0021     QByteArray userAgent() const;
0022     void setUserAgent(const QByteArray &value);
0023 
0024     /// Signature method
0025     Q_PROPERTY(QString signatureMethod READ signatureMethod WRITE setSignatureMethod NOTIFY signatureMethodChanged)
0026     QString signatureMethod();
0027     void setSignatureMethod(const QString &value);
0028 
0029     /// Token request URL.
0030     Q_PROPERTY(QUrl requestTokenUrl READ requestTokenUrl WRITE setRequestTokenUrl NOTIFY requestTokenUrlChanged)
0031     QUrl requestTokenUrl();
0032     void setRequestTokenUrl(const QUrl &value);
0033 
0034     /// Parameters to pass with request URL.
0035     Q_PROPERTY(QList<O0RequestParameter> requestParameters READ requestParameters WRITE setRequestParameters)
0036     QList<O0RequestParameter> requestParameters();
0037     void setRequestParameters(const QList<O0RequestParameter> &value);
0038 
0039     /// Callback URL.
0040     /// It should contain a `%1` place marker, to be replaced by `O0BaseAuth::localPort()`.
0041     /// Defaults to `O2_CALLBACK_URL`.
0042     Q_PROPERTY(QString callbackUrl READ callbackUrl WRITE setCallbackUrl)
0043     QString callbackUrl();
0044     void setCallbackUrl(const QString &value);
0045 
0046     /// Authorization URL.
0047     Q_PROPERTY(QUrl authorizeUrl READ authorizeUrl WRITE setAuthorizeUrl NOTIFY authorizeUrlChanged)
0048     QUrl authorizeUrl();
0049     void setAuthorizeUrl(const QUrl &value);
0050 
0051     /// Access token URL.
0052     Q_PROPERTY(QUrl accessTokenUrl READ accessTokenUrl WRITE setAccessTokenUrl NOTIFY accessTokenUrlChanged)
0053     QUrl accessTokenUrl();
0054     void setAccessTokenUrl(const QUrl &value);
0055 
0056     /// Constructor.
0057     explicit O1(QObject *parent = 0, QNetworkAccessManager *manager = 0, O0AbstractStore *store = 0);
0058 
0059     /// Parse a URL-encoded response string.
0060     static QMap<QString, QString> parseResponse(const QByteArray &response);
0061 
0062     /// Build the value of the "Authorization:" header.
0063     static QByteArray buildAuthorizationHeader(const QList<O0RequestParameter> &oauthParams);
0064 
0065     /// Add common configuration (headers) to @p req.
0066     void decorateRequest(QNetworkRequest &req, const QList<O0RequestParameter> &oauthParams);
0067 
0068     /// Create unique bytes to prevent replay attacks.
0069     static QByteArray nonce();
0070 
0071     /// Generate signature string depending on signature method type
0072     QByteArray generateSignature(const QList<O0RequestParameter> headers, const QNetworkRequest &req, const QList<O0RequestParameter> &signingParameters, QNetworkAccessManager::Operation operation);
0073 
0074     /// Calculate the HMAC-SHA1 signature of a request.
0075     /// @param  oauthParams     OAuth parameters.
0076     /// @param  otherParams     Other parameters participating in signing.
0077     /// @param  URL             Request URL. May contain query parameters, but they will not be used for signing.
0078     /// @param  op              HTTP operation.
0079     /// @param  consumerSecret  Consumer (application) secret.
0080     /// @param  tokenSecret     Authorization token secret (empty if not yet available).
0081     /// @return Signature that can be used as the value of the "oauth_signature" parameter.
0082     static QByteArray sign(const QList<O0RequestParameter> &oauthParams, const QList<O0RequestParameter> &otherParams, const QUrl &url, QNetworkAccessManager::Operation op, const QString &consumerSecret, const QString &tokenSecret);
0083 
0084     /// Build a base string for signing.
0085     static QByteArray getRequestBase(const QList<O0RequestParameter> &oauthParams, const QList<O0RequestParameter> &otherParams, const QUrl &url, QNetworkAccessManager::Operation op);
0086 
0087     /// Build a concatenated/percent-encoded string from a list of headers.
0088     static QByteArray encodeHeaders(const QList<O0RequestParameter> &headers);
0089 
0090 public Q_SLOTS:
0091     /// Authenticate.
0092     Q_INVOKABLE virtual void link();
0093 
0094     /// De-authenticate.
0095     Q_INVOKABLE virtual void unlink();
0096 
0097 Q_SIGNALS:
0098     void requestTokenUrlChanged();
0099     void authorizeUrlChanged();
0100     void accessTokenUrlChanged();
0101     void signatureMethodChanged();
0102 
0103 public Q_SLOTS:
0104     /// Handle verification received from the reply server.
0105     virtual void onVerificationReceived(QMap<QString,QString> params);
0106 
0107 protected Q_SLOTS:
0108     /// Handle token request error.
0109     virtual void onTokenRequestError(QNetworkReply::NetworkError error);
0110 
0111     /// Handle token request finished.
0112     virtual void onTokenRequestFinished();
0113 
0114     /// Handle token exchange error.
0115     void onTokenExchangeError(QNetworkReply::NetworkError error);
0116 
0117     /// Handle token exchange finished.
0118     void onTokenExchangeFinished();
0119 
0120 protected:
0121     /// Exchange temporary token to authentication token
0122     void exchangeToken();
0123 
0124     QByteArray userAgent_;
0125     QUrl requestUrl_;
0126     QList<O0RequestParameter> requestParameters_;
0127     QString callbackUrl_;
0128     QUrl tokenUrl_;
0129     QUrl refreshTokenUrl_;
0130     QString verifier_;
0131     QString signatureMethod_;
0132     QNetworkAccessManager *manager_;
0133 };
0134 
0135 #endif // O1_H